
/*!
 * Braintree POE Builder — scoped CSS
 * Everything is prefixed under #btpoe-app so theme styles don't leak in.
 */

/* CONTAINER RESET — neutralise theme inheritance at the boundary */
#btpoe-app {
    font-family: 'Inter', system-ui, -apple-system, sans-serif;
    color: #14202E;
    font-size: 14px;
    line-height: 1.5;
    letter-spacing: -0.005em;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}
#btpoe-app *, #btpoe-app *::before, #btpoe-app *::after { box-sizing: border-box; }
#btpoe-app button { font-family: inherit; border: none; background: none; cursor: pointer; }
#btpoe-app input, #btpoe-app select, #btpoe-app textarea { font-family: inherit; color: inherit; }
#btpoe-app a { text-decoration: none; }
#btpoe-app h1, #btpoe-app h2, #btpoe-app h3, #btpoe-app h4, #btpoe-app h5 {
    margin: 0; font-weight: 700; color: inherit; line-height: 1.2;
}
#btpoe-app p { margin: 0; }
#btpoe-app ul, #btpoe-app ol { margin: 0; padding: 0; }
#btpoe-app img { max-width: 100%; height: auto; display: block; }

/* LOGIN GATE */
.btpoe-gate { min-height: 60vh; display: grid; place-items: center; padding: 60px 20px; }
.btpoe-gate-card {
    background: #fff; border: 1px solid var(--line, #E6E4DB); border-radius: 18px;
    padding: 40px 44px; max-width: 480px; width: 100%;
    box-shadow: 0 20px 48px -12px rgba(11,30,63,0.12);
    text-align: center;
}
.btpoe-gate-mark {
    width: 56px; height: 56px; border-radius: 16px;
    background: linear-gradient(135deg, #0B1E3F 0%, #142A52 100%);
    color: #fff; display: grid; place-items: center; font-size: 22px;
    margin: 0 auto 20px;
}
.btpoe-gate-danger { background: #FCF4F2; color: #C03030; border: 1px solid #EECFC9; }
.btpoe-gate-eyebrow {
    font-size: 11px; font-weight: 700; letter-spacing: 0.14em;
    text-transform: uppercase; color: #14A67A; margin-bottom: 10px;
}
.btpoe-gate-card h2 {
    font-size: 24px; font-weight: 800; letter-spacing: -0.02em;
    color: #0B1E3F; margin-bottom: 10px;
}
.btpoe-gate-card p {
    color: #4A5568; font-size: 14px; line-height: 1.55; margin-bottom: 22px;
}
.btpoe-btn {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 11px 20px; border-radius: 10px; font-size: 14px; font-weight: 600;
    border: none; cursor: pointer; text-decoration: none;
}
.btpoe-btn-primary { background: #0B1E3F; color: #FAFAF7; }
.btpoe-btn-primary:hover { background: #142A52; }
.btpoe-btn-ghost { background: transparent; color: #4A5568; border: 1px solid #D6D3C6; }
.btpoe-btn-ghost:hover { background: #F3F2EC; color: #0B1E3F; }

/* User chip in topbar */
#btpoe-app .user-chip {
    display: flex; align-items: center; gap: 8px;
    padding: 6px 10px 6px 6px; border-radius: 999px;
    background: var(--paper-2); border: 1px solid var(--line);
    font-size: 12.5px; color: var(--text-2); font-weight: 500;
    margin-right: 8px;
}
#btpoe-app .user-chip .avatar {
    width: 24px; height: 24px; border-radius: 50%;
    background: var(--bt-ink); color: #fff;
    display: grid; place-items: center;
    font-size: 11px; font-weight: 700;
}

/* Autosave indicator */
#btpoe-app .autosave {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 11.5px; color: rgba(255,255,255,0.7); font-weight: 500;
    margin-left: 10px;
}
#btpoe-app .autosave .dot {
    width: 7px; height: 7px; border-radius: 50%;
    background: #14A67A; animation: asPulse 2s ease-in-out infinite;
}
#btpoe-app .autosave.saving .dot { background: #D97706; animation-duration: 0.8s; }
@keyframes asPulse { 0%,100% { opacity: 1 } 50% { opacity: 0.4 } }

/* Loading veil */
#btpoe-app .loader {
    display: grid; place-items: center; padding: 80px 20px; color: #8A8E8C; gap: 12px;
}
#btpoe-app .loader .sp {
    width: 32px; height: 32px; border-radius: 50%;
    border: 3px solid rgba(11,30,63,0.1); border-top-color: #14A67A;
    animation: spin 0.8s linear infinite;
}

/* =========================================================
   BRAINTREE DESIGN SYSTEM
   ========================================================= */
:root {
  --bt-ink:#0B1E3F; --bt-ink-2:#142A52; --bt-ink-3:#1E3A64;
  --bt-leaf:#14A67A; --bt-leaf-2:#0D8A64; --bt-leaf-soft:#E6F7F0;
  --bt-sky:#3D6FD9; --bt-sky-soft:#EAF0FC;
  --paper:#FAFAF7; --paper-2:#F3F2EC;
  --line:#E6E4DB; --line-2:#D6D3C6;
  --text:#14202E; --text-2:#4A5568; --text-3:#8A8E8C;
  --ok:#14A67A; --ok-soft:#E6F7F0;
  --warn:#D97706; --warn-soft:#FEF3C7;
  --danger:#C03030; --danger-soft:#FCE8E6;
  --shadow-sm:0 1px 2px rgba(11,30,63,0.06), 0 1px 1px rgba(11,30,63,0.04);
  --shadow-md:0 4px 14px -4px rgba(11,30,63,0.12), 0 2px 4px rgba(11,30,63,0.05);
  --shadow-lg:0 20px 48px -12px rgba(11,30,63,0.22), 0 8px 16px -8px rgba(11,30,63,0.08);
  --r-sm:8px; --r-md:12px; --r-lg:18px; --r-xl:24px;
}
#btpoe-app {box-sizing:border-box}
#btpoe-app, #btpoe-app {margin:0;padding:0}
#btpoe-app {
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:var(--paper); color:var(--text); min-height:100vh;
  -webkit-font-smoothing:antialiased; letter-spacing:-0.005em;
  background-image:
    radial-gradient(circle at 20% 10%, rgba(20,166,122,0.03), transparent 40%),
    radial-gradient(circle at 90% 80%, rgba(11,30,63,0.03), transparent 45%);
}
#btpoe-app button {font-family:inherit}
#btpoe-app input, #btpoe-app select, #btpoe-app textarea {font-family:inherit;color:var(--text)}
#btpoe-app a {color:var(--bt-sky);text-decoration:none}
#btpoe-app /* TOP BAR */
.topbar {position:sticky;top:0;z-index:50;background:rgba(250,250,247,0.85);backdrop-filter:saturate(1.4) blur(12px);-webkit-backdrop-filter:saturate(1.4) blur(12px);border-bottom:1px solid var(--line)}
#btpoe-app .topbar-inner {max-width:1240px;margin:0 auto;display:flex;align-items:center;gap:28px;padding:14px 28px}
#btpoe-app .brand {display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--bt-ink)}
#btpoe-app .brand-mark {width:30px;height:30px;border-radius:9px;background:var(--bt-ink);display:grid;place-items:center;color:var(--paper);position:relative;overflow:hidden}
#btpoe-app .brand-mark svg {width:18px;height:18px}
#btpoe-app .brand-mark::after {content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 20%, rgba(20,166,122,0.35), transparent 60%)}
#btpoe-app .brand-text {display:flex;flex-direction:column;line-height:1}
#btpoe-app .brand-text .b1 {font-weight:800;font-size:14px;letter-spacing:-0.02em}
#btpoe-app .brand-text .b2 {font-size:10.5px;color:var(--text-3);margin-top:3px;text-transform:uppercase;letter-spacing:0.12em;font-weight:600}
#btpoe-app .nav {display:flex;gap:2px;margin-left:auto}
#btpoe-app .nav a {display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:10px;font-size:13.5px;font-weight:500;color:var(--text-2);text-decoration:none;transition:background .15s, color .15s;cursor:pointer}
#btpoe-app .nav a:hover {background:var(--paper-2);color:var(--bt-ink)}
#btpoe-app .nav a.active {background:var(--bt-ink);color:var(--paper)}
#btpoe-app .nav a i {font-size:12px;width:14px;text-align:center}
#btpoe-app .topbar-cta {display:flex;align-items:center;gap:8px;margin-left:8px}
#btpoe-app /* VIEWS */
.view {display:none;animation:fadeUp .35s ease both}
#btpoe-app .view.active {display:block}
@keyframes fadeUp {from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
#btpoe-app .page {max-width:1080px;margin:0 auto;padding:36px 28px 120px}
#btpoe-app .page-narrow {max-width:880px}
#btpoe-app .page-head {display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:32px}
#btpoe-app .eyebrow {text-transform:uppercase;letter-spacing:0.14em;font-size:11px;font-weight:700;color:var(--bt-leaf);display:inline-flex;align-items:center;gap:8px;margin-bottom:10px}
#btpoe-app .eyebrow::before {content:"";width:18px;height:2px;background:var(--bt-leaf);display:inline-block}
#btpoe-app .page-title {font-size:34px;font-weight:800;letter-spacing:-0.025em;color:var(--bt-ink);line-height:1.05;margin:0}
#btpoe-app .page-sub {color:var(--text-2);font-size:15px;margin-top:8px;max-width:640px}
#btpoe-app /* BUTTONS */
.btn {display:inline-flex;align-items:center;gap:8px;border:none;cursor:pointer;font-weight:600;font-size:13.5px;padding:10px 16px;border-radius:10px;transition:transform .12s, box-shadow .18s, background .15s, border-color .15s, color .15s;line-height:1}
#btpoe-app .btn:active {transform:translateY(0.5px)}
#btpoe-app .btn i {font-size:12px}
#btpoe-app .btn-primary {background:var(--bt-ink);color:var(--paper);box-shadow:var(--shadow-sm)}
#btpoe-app .btn-primary:hover {background:var(--bt-ink-2);box-shadow:var(--shadow-md)}
#btpoe-app .btn-leaf {background:var(--bt-leaf);color:#fff;box-shadow:0 1px 2px rgba(20,166,122,0.3)}
#btpoe-app .btn-leaf:hover {background:var(--bt-leaf-2);box-shadow:0 8px 20px -6px rgba(20,166,122,0.5)}
#btpoe-app .btn-leaf:disabled {background:#C8CCC9;color:#fff;cursor:not-allowed;box-shadow:none}
#btpoe-app .btn-ghost {background:transparent;color:var(--text-2);border:1px solid var(--line-2)}
#btpoe-app .btn-ghost:hover {background:var(--paper-2);color:var(--bt-ink);border-color:var(--line-2)}
#btpoe-app .btn-quiet {background:transparent;color:var(--text-2);padding:8px 12px}
#btpoe-app .btn-quiet:hover {background:var(--paper-2);color:var(--bt-ink)}
#btpoe-app .btn-danger {background:transparent;color:var(--danger);border:1px solid #EECFC9}
#btpoe-app .btn-danger:hover {background:var(--danger);color:#fff;border-color:var(--danger)}
#btpoe-app .btn-sm {padding:7px 12px;font-size:12.5px;border-radius:8px}
#btpoe-app .btn-icon {padding:8px;width:34px;height:34px;justify-content:center}
#btpoe-app /* STAT CARDS */
.stats {display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:32px}
#btpoe-app .stat {position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:20px 22px;overflow:hidden;transition:transform .2s, box-shadow .2s}
#btpoe-app .stat:hover {transform:translateY(-2px);box-shadow:var(--shadow-md)}
#btpoe-app .stat-label {font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;color:var(--text-3);display:flex;align-items:center;gap:6px}
#btpoe-app .stat-label .dot {width:6px;height:6px;border-radius:50%;background:var(--bt-ink)}
#btpoe-app .stat-num {font-size:44px;font-weight:800;color:var(--bt-ink);letter-spacing:-0.03em;line-height:1;margin-top:10px;font-variant-numeric:tabular-nums}
#btpoe-app .stat-sub {font-size:12px;color:var(--text-3);margin-top:8px}
#btpoe-app .stat-glyph {position:absolute;top:16px;right:16px;width:28px;height:28px;border-radius:8px;display:grid;place-items:center;font-size:12px;background:var(--paper-2);color:var(--bt-ink)}
#btpoe-app .stat.s-total .stat-glyph {background:var(--bt-sky-soft);color:var(--bt-sky)}
#btpoe-app .stat.s-draft .stat-glyph {background:var(--warn-soft);color:var(--warn)}
#btpoe-app .stat.s-draft .dot {background:var(--warn)}
#btpoe-app .stat.s-done .stat-glyph {background:var(--bt-leaf-soft);color:var(--bt-leaf)}
#btpoe-app .stat.s-done .dot {background:var(--bt-leaf)}
#btpoe-app .stat.s-month .stat-glyph {background:#EFEAF8;color:#6C4AB6}
#btpoe-app .stat.s-month .dot {background:#6C4AB6}
#btpoe-app /* PANELS */
.panel {background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm)}
#btpoe-app .panel + .panel {margin-top:16px}
#btpoe-app .panel-head {display:flex;align-items:center;gap:10px;padding:16px 22px;border-bottom:1px solid var(--line);background:linear-gradient(180deg, #fff 0%, var(--paper) 100%)}
#btpoe-app .panel-head h3 {margin:0;font-size:14px;font-weight:700;color:var(--bt-ink);letter-spacing:-0.01em;display:flex;align-items:center;gap:10px}
#btpoe-app .panel-head h3 i {color:var(--bt-leaf);font-size:13px}
#btpoe-app .panel-head .count-pill {margin-left:auto;font-size:11px;font-weight:600;color:var(--text-2);background:var(--paper-2);padding:3px 10px;border-radius:999px;border:1px solid var(--line)}
#btpoe-app .panel-body {padding:22px}
#btpoe-app .panel-body.compact {padding:10px}
#btpoe-app /* LIST ITEMS */
.item {display:flex;align-items:center;gap:16px;padding:14px 16px;border-radius:12px;transition:background .15s;border:1px solid transparent}
#btpoe-app .item + .item {margin-top:2px}
#btpoe-app .item:hover {background:var(--paper);border-color:var(--line)}
#btpoe-app .item-ring {width:46px;height:46px;flex-shrink:0;display:grid;place-items:center}
#btpoe-app .ring-svg {width:46px;height:46px;transform:rotate(-90deg)}
#btpoe-app .ring-bg {fill:none;stroke:var(--line);stroke-width:3}
#btpoe-app .ring-fg {fill:none;stroke:var(--bt-leaf);stroke-width:3;stroke-linecap:round;transition:stroke-dashoffset .6s ease}
#btpoe-app .item-ring .ring-num {position:absolute;font-size:11px;font-weight:700;color:var(--bt-ink);font-variant-numeric:tabular-nums}
#btpoe-app .item-ring-wrap {position:relative;display:grid;place-items:center}
#btpoe-app .item-main {flex:1;min-width:0}
#btpoe-app .item-title {font-weight:700;font-size:14.5px;color:var(--bt-ink);letter-spacing:-0.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#btpoe-app .item-meta {font-size:12.5px;color:var(--text-3);margin-top:3px;display:flex;gap:8px;flex-wrap:wrap;align-items:center}
#btpoe-app .item-meta .sep {color:var(--line-2)}
#btpoe-app .item-actions {display:flex;gap:6px;flex-shrink:0}
#btpoe-app .status-pill {display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;padding:3px 10px;border-radius:999px;letter-spacing:0.02em}
#btpoe-app .status-pill.draft {background:var(--warn-soft);color:var(--warn)}
#btpoe-app .status-pill.submitted {background:var(--bt-leaf-soft);color:var(--bt-leaf-2)}
#btpoe-app .status-pill .d {width:6px;height:6px;border-radius:50%;background:currentColor}
#btpoe-app .empty {text-align:center;padding:56px 20px;color:var(--text-3)}
#btpoe-app .empty i {font-size:32px;color:var(--line-2);margin-bottom:14px;display:block}
#btpoe-app .empty-title {font-size:14px;font-weight:600;color:var(--text-2);margin-bottom:4px}
#btpoe-app .empty-action {display:inline-flex;margin-top:14px}
#btpoe-app /* FORM HERO */
.form-hero {position:relative;background:radial-gradient(circle at 15% 120%, rgba(20,166,122,0.18), transparent 55%),radial-gradient(circle at 90% -20%, rgba(61,111,217,0.15), transparent 55%),linear-gradient(180deg, var(--bt-ink) 0%, var(--bt-ink-2) 100%);color:#fff;border-radius:var(--r-xl);padding:28px 32px;margin-bottom:22px;overflow:hidden}
#btpoe-app .form-hero::after {content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,0.06) 1px, transparent 1px);background-size:16px 16px;mask:linear-gradient(90deg, transparent, black 30%, black 70%, transparent);pointer-events:none}
#btpoe-app .form-hero-top {display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:14px;position:relative}
#btpoe-app .form-hero .crumb {font-size:11.5px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.6);display:flex;align-items:center;gap:8px}
#btpoe-app .form-hero .crumb i {font-size:9px}
#btpoe-app .hero-title {font-size:28px;font-weight:800;letter-spacing:-0.025em;margin:2px 0 6px;line-height:1.1;position:relative}
#btpoe-app .hero-sub {font-size:13.5px;color:rgba(255,255,255,0.7);position:relative}
#btpoe-app .hero-typetag {display:inline-flex;align-items:center;gap:6px;background:rgba(20,166,122,0.18);border:1px solid rgba(20,166,122,0.5);color:#A6E8CE;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;margin-top:6px}
#btpoe-app .progress-block {position:relative;display:flex;align-items:center;gap:14px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);padding:10px 14px;border-radius:14px;backdrop-filter:blur(6px)}
#btpoe-app .progress-ring {position:relative;width:48px;height:48px}
#btpoe-app .progress-ring svg {transform:rotate(-90deg)}
#btpoe-app .progress-ring .pr-bg {stroke:rgba(255,255,255,0.15);fill:none;stroke-width:4}
#btpoe-app .progress-ring .pr-fg {stroke:var(--bt-leaf);fill:none;stroke-width:4;stroke-linecap:round;transition:stroke-dashoffset .6s ease}
#btpoe-app .progress-ring .pr-num {position:absolute;inset:0;display:grid;place-items:center;font-size:12px;font-weight:800;color:#fff;font-variant-numeric:tabular-nums}
#btpoe-app .progress-label {display:flex;flex-direction:column;line-height:1.2}
#btpoe-app .progress-label .pl-top {font-size:11px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.55)}
#btpoe-app .progress-label .pl-main {font-size:14px;font-weight:700;color:#fff;margin-top:4px}
#btpoe-app .hero-actions {display:flex;gap:8px;position:relative;flex-wrap:wrap}
#btpoe-app .btn-hero-ghost {background:rgba(255,255,255,0.1);color:#fff;border:1px solid rgba(255,255,255,0.15)}
#btpoe-app .btn-hero-ghost:hover {background:rgba(255,255,255,0.18);border-color:rgba(255,255,255,0.25)}
#btpoe-app /* INPUTS */
.field {display:flex;flex-direction:column;gap:6px}
#btpoe-app .field-label {font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--text-2);display:flex;align-items:center;gap:6px}
#btpoe-app .field-label .req {color:var(--danger);font-size:10px}
#btpoe-app .field-label .opt {color:var(--text-3);font-size:10px;font-weight:600;text-transform:none;letter-spacing:0}
#btpoe-app .ctrl {width:100%;border:1px solid var(--line-2);border-radius:10px;padding:11px 14px;font-size:14px;background:#fff;transition:border-color .15s, box-shadow .15s, background .15s;color:var(--text)}
#btpoe-app .ctrl::placeholder {color:#B3B5B3}
#btpoe-app .ctrl:focus {outline:none;border-color:var(--bt-ink);box-shadow:0 0 0 4px rgba(11,30,63,0.08)}
#btpoe-app textarea.ctrl {resize:vertical;min-height:84px;line-height:1.5}
#btpoe-app select.ctrl {appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238A8E8C' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
#btpoe-app .grid-2 {display:grid;grid-template-columns:1fr 1fr;gap:16px}
#btpoe-app .grid-3 {display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
#btpoe-app .grid-2 .wide, #btpoe-app .grid-3 .wide {grid-column:1/-1}
#btpoe-app /* PII + BRANDING BANNERS */
.banner {display:flex;gap:12px;align-items:flex-start;padding:14px 18px;border-radius:12px;margin-bottom:22px;font-size:13px;line-height:1.5;border:1px solid;border-left-width:4px}
#btpoe-app .banner-pii {background:#FDF4F3;border-color:#EECFC9;border-left-color:var(--danger);color:#6A1F1A}
#btpoe-app .banner-pii i {color:var(--danger);font-size:16px;margin-top:1px;flex-shrink:0}
#btpoe-app .banner-pii b {color:var(--danger)}
#btpoe-app .banner-brand {background:var(--bt-sky-soft);border-color:#CFD9F4;border-left-color:var(--bt-sky);color:var(--bt-ink-2)}
#btpoe-app .banner-brand i {color:var(--bt-sky);font-size:16px;margin-top:1px;flex-shrink:0}
#btpoe-app /* SECTION CARDS */
.sections-head {display:flex;align-items:baseline;justify-content:space-between;margin:28px 0 14px;gap:12px}
#btpoe-app .sections-head h2 {font-size:13px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-3);margin:0}
#btpoe-app .sections-progress {font-size:12px;color:var(--text-3);font-variant-numeric:tabular-nums}
#btpoe-app .sections-progress b {color:var(--bt-ink);font-weight:700}
#btpoe-app .sec {background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;margin-bottom:12px;transition:border-color .2s, box-shadow .2s, transform .12s}
#btpoe-app .sec:hover {box-shadow:var(--shadow-md)}
#btpoe-app .sec.complete {border-color:#B9E5D4;background:linear-gradient(180deg, #F6FCF9 0%, #fff 40px)}
#btpoe-app .sec-head {display:flex;align-items:center;gap:14px;padding:16px 20px;cursor:pointer;user-select:none}
#btpoe-app .sec-num {width:32px;height:32px;border-radius:10px;background:var(--paper-2);color:var(--bt-ink);display:grid;place-items:center;font-weight:700;font-size:13px;font-variant-numeric:tabular-nums;flex-shrink:0;transition:background .2s, color .2s, transform .3s;border:1px solid var(--line)}
#btpoe-app .sec.complete .sec-num {background:var(--bt-leaf);color:#fff;border-color:var(--bt-leaf)}
#btpoe-app .sec.complete .sec-num i {animation:popIn .35s ease both}
@keyframes popIn {0%{transform:scale(0);opacity:0}60%{transform:scale(1.25)}100%{transform:scale(1);opacity:1}}
#btpoe-app .sec-label {flex:1;font-size:14.5px;font-weight:600;color:var(--bt-ink);letter-spacing:-0.01em}
#btpoe-app .sec-meta {display:flex;align-items:center;gap:8px;flex-shrink:0}
#btpoe-app .tag {display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:700;padding:4px 9px;border-radius:999px;letter-spacing:0.04em}
#btpoe-app .tag.req {background:var(--danger-soft);color:var(--danger)}
#btpoe-app .tag.opt {background:var(--paper-2);color:var(--text-2)}
#btpoe-app .tag.done {background:var(--bt-leaf-soft);color:var(--bt-leaf-2)}
#btpoe-app .tag.todo {background:var(--paper-2);color:var(--text-3);border:1px solid var(--line)}
#btpoe-app .tag .d {width:5px;height:5px;border-radius:50%;background:currentColor}
#btpoe-app .sec-chev {width:28px;height:28px;border-radius:8px;display:grid;place-items:center;color:var(--text-3);transition:transform .25s, background .15s;font-size:11px}
#btpoe-app .sec-head:hover .sec-chev {background:var(--paper-2)}
#btpoe-app .sec.collapsed .sec-chev {transform:rotate(-90deg)}
#btpoe-app .sec-body {padding:6px 20px 20px 20px;animation:slideOpen .25s ease}
#btpoe-app .sec.collapsed .sec-body {display:none}
@keyframes slideOpen {from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
#btpoe-app .sec-hint {display:flex;gap:10px;align-items:flex-start;background:var(--bt-sky-soft);border-left:3px solid var(--bt-sky);padding:10px 14px;border-radius:8px;font-size:13px;color:var(--bt-ink-2);margin-bottom:16px;line-height:1.5}
#btpoe-app .sec-hint i {color:var(--bt-sky);margin-top:2px;flex-shrink:0}
#btpoe-app /* UPLOAD ZONE */
.uz {position:relative;border:1.5px dashed var(--line-2);border-radius:14px;padding:28px 20px;text-align:center;cursor:pointer;background:var(--paper);transition:border-color .2s, background .2s, transform .15s}
#btpoe-app .uz:hover {border-color:var(--bt-ink);background:#fff}
#btpoe-app .uz.dragover {border-color:var(--bt-leaf);background:var(--bt-leaf-soft);border-style:solid;transform:scale(1.005)}
#btpoe-app .uz.locked {border-color:#EECFC9;background:#FCF4F2;cursor:not-allowed}
#btpoe-app .uz-icon {width:52px;height:52px;border-radius:16px;background:#fff;color:var(--bt-ink);display:inline-grid;place-items:center;font-size:18px;margin-bottom:12px;border:1px solid var(--line);transition:background .2s, color .2s, transform .2s}
#btpoe-app .uz:hover .uz-icon {background:var(--bt-ink);color:#fff;transform:translateY(-2px)}
#btpoe-app .uz.dragover .uz-icon {background:var(--bt-leaf);color:#fff;transform:scale(1.08)}
#btpoe-app .uz.locked .uz-icon {color:var(--danger);background:#fff}
#btpoe-app .uz-title {font-size:14px;font-weight:600;color:var(--bt-ink)}
#btpoe-app .uz-sub {font-size:12.5px;color:var(--text-3);margin-top:4px}
#btpoe-app .uz.locked .uz-title {color:var(--danger)}
#btpoe-app .img-count {display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--text-3);margin-top:10px}
#btpoe-app .img-count b {color:var(--bt-ink);font-variant-numeric:tabular-nums}
#btpoe-app .cap-bar {position:relative;width:120px;height:4px;background:var(--paper-2);border-radius:2px;overflow:hidden}
#btpoe-app .cap-fill {height:100%;background:var(--bt-leaf);border-radius:2px;transition:width .3s ease}
#btpoe-app .cap-fill.near {background:var(--warn)}
#btpoe-app .cap-fill.full {background:var(--danger)}
#btpoe-app .grid-files {display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;margin-top:12px}
#btpoe-app .f-item {position:relative;aspect-ratio:4/3;border-radius:12px;overflow:hidden;background:var(--paper-2);border:1px solid var(--line);transition:transform .15s, box-shadow .15s}
#btpoe-app .f-item:hover {transform:translateY(-2px);box-shadow:var(--shadow-md)}
#btpoe-app .f-item img {width:100%;height:100%;object-fit:cover;display:block}
#btpoe-app .f-rm {position:absolute;top:6px;right:6px;width:24px;height:24px;border-radius:50%;background:rgba(11,30,63,0.85);color:#fff;border:none;cursor:pointer;display:grid;place-items:center;font-size:11px;opacity:0;transition:opacity .15s, background .15s, transform .15s}
#btpoe-app .f-item:hover .f-rm {opacity:1}
#btpoe-app .f-rm:hover {background:var(--danger);transform:scale(1.08)}
#btpoe-app .f-pdf {display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:10px;background:linear-gradient(180deg, #fff 0%, var(--paper) 100%)}
#btpoe-app .f-pdf .p-ic {width:38px;height:46px;border-radius:4px;background:#fff;border:1px solid var(--line);display:grid;place-items:center;font-size:10px;font-weight:800;color:var(--danger);position:relative;box-shadow:var(--shadow-sm)}
#btpoe-app .f-pdf .p-ic::before {content:"";position:absolute;top:0;right:0;width:10px;height:10px;background:linear-gradient(225deg, var(--line) 50%, transparent 50%)}
#btpoe-app .f-pdf .p-name {font-size:10.5px;font-weight:600;color:var(--bt-ink);text-align:center;word-break:break-all;line-height:1.3;max-width:100%;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
#btpoe-app .f-pdf .p-size {font-size:10px;color:var(--text-3)}
#btpoe-app /* STICKY BAR */
.sticky {position:fixed;bottom:20px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:16px;background:rgba(11,30,63,0.95);color:#fff;padding:10px 10px 10px 22px;border-radius:999px;box-shadow:var(--shadow-lg);backdrop-filter:blur(10px);z-index:40;max-width:calc(100% - 28px);animation:slideUp .4s ease both}
@keyframes slideUp {from{opacity:0;transform:translate(-50%, 20px)}to{opacity:1;transform:translate(-50%,0)}}
#btpoe-app .sticky-text {font-size:13px;color:rgba(255,255,255,0.85);font-weight:500;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
#btpoe-app .sticky-text b {color:#fff;font-weight:700}
#btpoe-app .sticky-text.ready {color:#A6E8CE}
#btpoe-app /* TOASTS */
#toasts {position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none}
#btpoe-app .toast {display:flex;align-items:center;gap:10px;background:#fff;color:var(--bt-ink);border:1px solid var(--line);padding:12px 16px 12px 14px;border-radius:14px;box-shadow:var(--shadow-lg);font-size:13.5px;font-weight:500;min-width:260px;pointer-events:auto;animation:toastIn .3s ease;border-left:4px solid var(--bt-ink)}
@keyframes toastIn {from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
#btpoe-app .toast.success {border-left-color:var(--bt-leaf)}
#btpoe-app .toast.success .t-ic {background:var(--bt-leaf-soft);color:var(--bt-leaf)}
#btpoe-app .toast.error {border-left-color:var(--danger)}
#btpoe-app .toast.error .t-ic {background:var(--danger-soft);color:var(--danger)}
#btpoe-app .toast.warn {border-left-color:var(--warn)}
#btpoe-app .toast.warn .t-ic {background:var(--warn-soft);color:var(--warn)}
#btpoe-app .toast.info {border-left-color:var(--bt-sky)}
#btpoe-app .toast.info .t-ic {background:var(--bt-sky-soft);color:var(--bt-sky)}
#btpoe-app .t-ic {width:28px;height:28px;border-radius:8px;display:grid;place-items:center;font-size:13px;background:var(--paper-2);color:var(--bt-ink);flex-shrink:0}
#btpoe-app /* MODAL */
.modal-ovl {position:fixed;inset:0;background:rgba(11,30,63,0.6);backdrop-filter:blur(6px);display:grid;place-items:center;z-index:2000;animation:fadeIn .2s ease}
@keyframes fadeIn {from{opacity:0}to{opacity:1}}
#btpoe-app .modal-box {background:#fff;border-radius:var(--r-xl);padding:28px;max-width:480px;width:90%;box-shadow:var(--shadow-lg);animation:fadeUp .25s ease both}
#btpoe-app .modal-box h4 {margin:0 0 10px 0;font-size:18px;color:var(--bt-ink);font-weight:700;letter-spacing:-0.01em}
#btpoe-app .modal-box p {margin:0 0 22px 0;font-size:14px;color:var(--text-2);line-height:1.5}
#btpoe-app .modal-actions {display:flex;gap:10px;justify-content:flex-end}
#btpoe-app /* POE TYPE PICKER */
.type-grid {display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;margin-top:20px}
#btpoe-app .type-card {background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:16px 18px;cursor:pointer;transition:all .18s;text-align:left;display:flex;flex-direction:column;gap:6px;position:relative;overflow:hidden}
#btpoe-app .type-card:hover {border-color:var(--bt-leaf);box-shadow:var(--shadow-md);transform:translateY(-1px)}
#btpoe-app .type-card .tc-ic {width:36px;height:36px;border-radius:10px;background:var(--paper-2);color:var(--bt-ink);display:grid;place-items:center;font-size:14px;margin-bottom:4px}
#btpoe-app .type-card:hover .tc-ic {background:var(--bt-leaf-soft);color:var(--bt-leaf)}
#btpoe-app .type-card .tc-name {font-size:14px;font-weight:700;color:var(--bt-ink);letter-spacing:-0.01em}
#btpoe-app .type-card .tc-meta {font-size:12px;color:var(--text-3);margin-top:2px}
#btpoe-app .type-card .tc-count {font-size:10.5px;font-weight:700;color:var(--bt-leaf-2);background:var(--bt-leaf-soft);padding:3px 8px;border-radius:999px;align-self:flex-start;margin-top:6px;letter-spacing:0.04em;text-transform:uppercase}
#btpoe-app .type-cat-title {font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:0.14em;color:var(--text-3);margin:26px 0 4px;display:flex;align-items:center;gap:10px}
#btpoe-app .type-cat-title::after {content:"";flex:1;height:1px;background:var(--line)}
#btpoe-app /* URL link test */
.link-test {display:inline-flex;align-items:center;gap:6px;font-size:12.5px;color:var(--bt-sky);font-weight:600;margin-top:8px}
#btpoe-app .link-test i {font-size:10px}
#btpoe-app /* SEARCH / FILTERS */
.filters {display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}
#btpoe-app .input-wrap {position:relative;flex:1;max-width:360px;min-width:240px}
#btpoe-app .input-wrap i {position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-3);font-size:13px}
#btpoe-app .input-wrap .ctrl {padding-left:40px}
#btpoe-app /* SPINNER */
.spinner {width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,0.35);border-top-color:#fff;animation:spin .7s linear infinite;display:inline-block}
@keyframes spin {to{transform:rotate(360deg)}}
#btpoe-app /* SETTINGS */
.prog-row {display:flex;align-items:center;gap:10px;padding:10px;border-radius:12px;background:var(--paper);border:1px solid var(--line);margin-bottom:8px;transition:border-color .15s}
#btpoe-app .prog-row:hover {border-color:var(--line-2)}
#btpoe-app .prog-row .p-ic {width:32px;height:32px;border-radius:10px;background:#fff;color:var(--bt-leaf);display:grid;place-items:center;font-size:12px;border:1px solid var(--line);flex-shrink:0}
#btpoe-app .prog-row input {flex:1;border:1px solid transparent;background:transparent;padding:6px 10px;border-radius:8px;font-size:14px;font-weight:500;color:var(--bt-ink)}
#btpoe-app .prog-row input:hover {border-color:var(--line-2);background:#fff}
#btpoe-app .prog-row input:focus {outline:none;border-color:var(--bt-ink);background:#fff;box-shadow:0 0 0 3px rgba(11,30,63,0.08)}
#btpoe-app .danger-panel {border-color:#EECFC9;background:#FCF7F6}
#btpoe-app .danger-panel .panel-head {background:linear-gradient(180deg, #fff 0%, #FCF4F2 100%);border-bottom-color:#EECFC9}
#btpoe-app .danger-panel .panel-head h3 i {color:var(--danger)}
#btpoe-app /* REFERENCE CARDS */
.ref-grid {display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}
#btpoe-app .ref-card {background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:14px 16px}
#btpoe-app .ref-card h5 {margin:0 0 6px 0;font-size:13px;font-weight:700;color:var(--bt-ink)}
#btpoe-app .ref-card p {margin:0;font-size:12.5px;color:var(--text-2);line-height:1.5}
#btpoe-app .ref-card p + p {margin-top:6px}
#btpoe-app /* RESPONSIVE */
@media (max-width:780px) {
  .stats{grid-template-columns:repeat(2,1fr)}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .nav a span{display:none}
  .nav a{padding:8px 10px}
  .page{padding:24px 16px 140px}
  .page-title{font-size:26px}
  .hero-title{font-size:22px}
  .form-hero{padding:22px}
  .topbar-inner{padding:12px 16px}
  .sticky{left:12px;right:12px;transform:none;width:auto;max-width:none;flex-wrap:wrap;border-radius:18px;padding:12px 14px}
  .sticky-text{white-space:normal}
}
