:root {
  --bg-base:#020812;
  --bg-0:#0b0e16;--bg-1:#0f1117;--bg-2:#1a1d27;--bg-3:#222536;--bg-4:#2a2d3e;
  --teal:#00c9b1;--teal-dim:rgba(0,201,177,.13);--teal-dim-soft:rgba(0,201,177,.06);--teal-dim-strong:rgba(0,201,177,.18);
  --gold:#f5a623;--gold-dim:rgba(245,166,35,.13);--gold-dim-strong:rgba(245,166,35,.18);
  --green:#22c55e;--green-dim:rgba(34,197,94,.13);--green-dim-soft:rgba(34,197,94,.06);--green-dim-strong:rgba(34,197,94,.18);
  --red:#ef4444;--red-dim:rgba(239,68,68,.13);--red-dim-soft:rgba(239,68,68,.07);--red-dim-strong:rgba(239,68,68,.2);
  --blue:#3b82f6;--blue-dim:rgba(59,130,246,.13);--blue-dim-strong:rgba(59,130,246,.18);
  --yellow:#eab308;--yellow-dim:rgba(234,179,8,.13);
  --purple:#c084fc;--purple-dim:rgba(192,132,252,.13);
  --text-0:#fff;--text-1:#c8cdd8;--text-2:#8b92a5;--text-3:#4a5068;
  --border:rgba(255,255,255,.07);--border-s:rgba(255,255,255,.12);
  --sw:220px;--hh:56px;--r:10px;--rl:14px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:14px;background:var(--bg-base);transition:background .3s}
body{font-family:'Satoshi',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:transparent;color:var(--text-0);height:100vh;overflow:hidden;display:flex;transition:color .2s}


@keyframes fadeSlideIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}

/* Global focus-visible ring — replaces outline:none anti-pattern */
:focus-visible{outline:2px solid var(--teal);outline-offset:2px;border-radius:4px}

/* Skip to content link — hidden until focused */
.skip-link{position:fixed;top:-100px;left:16px;z-index:9999;background:var(--teal);color:#000;padding:8px 16px;border-radius:8px;font-weight:700;font-size:.875rem;text-decoration:none;transition:top .2s}
.skip-link:focus{top:16px}

/* SIDEBAR */
#sidebar{width:var(--sw);min-width:var(--sw);height:100vh;background:rgba(4,7,20,0.72);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-right:1px solid rgba(0,201,177,.15);display:flex;flex-direction:column;transition:width .25s,min-width .25s;overflow:hidden;flex-shrink:0;z-index:100;position:relative}
#sidebar.collapsed{width:56px;min-width:56px}
.s-logo{padding:14px 14px 12px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border);min-height:var(--hh)}
.logo-text{font-size:.9375rem;font-weight:700;color:var(--text-0);letter-spacing:-.02em;white-space:nowrap;overflow:hidden}
.logo-text span{color:var(--teal)}
.s-nav{padding:10px 0;flex:1;overflow-y:auto;overflow-x:hidden}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;border-radius:8px;margin:2px 8px;color:var(--text-2);transition:all .15s;white-space:nowrap;overflow:hidden;font-weight:500;font-size:.8125rem;border:none;background:none;font-family:inherit;text-align:left;width:calc(100% - 16px);min-height:44px}
.nav-item:hover{background:var(--bg-3);color:var(--text-1)}
.nav-item.active{background:var(--teal-dim);color:var(--teal)}
.nav-icon{flex-shrink:0;width:16px;height:16px}
.nav-label{overflow:hidden;white-space:nowrap}
/* Nav More button + section */
.nav-more-btn{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;border-radius:8px;margin:4px 8px;color:var(--text-3);font-size:.75rem;font-weight:600;border:1px dashed var(--border);background:none;font-family:inherit;text-align:left;width:calc(100% - 16px);transition:all .15s;letter-spacing:.02em}
.nav-more-btn:hover{background:var(--bg-3);color:var(--text-2);border-color:var(--text-3)}
.nav-more-section{border-left:2px solid var(--border);margin:2px 8px 4px 16px;padding-left:4px}
.nav-more-item{margin:1px 0;font-size:.75rem;min-height:36px;padding:7px 10px}
#sidebar.collapsed .nav-more-btn{justify-content:center;padding:8px;width:calc(100% - 16px)}
#sidebar.collapsed .nav-more-section{margin-left:8px;padding-left:0}
.s-foot{padding:10px 8px;border-top:1px solid var(--border)}
.collapse-btn{display:flex;align-items:center;gap:10px;padding:10px 10px;border-radius:8px;cursor:pointer;color:var(--text-2);transition:all .15s;font-size:.8125rem;white-space:nowrap;overflow:hidden;border:none;background:none;font-family:inherit;width:100%;min-height:44px}
.collapse-btn:hover{background:var(--bg-3);color:var(--text-1)}

/* APP SHELL */
#app{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;position:relative;z-index:1}
#header{height:var(--hh);background:rgba(4,7,20,0.65);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(0,201,177,.12);display:flex;align-items:center;padding:0 18px;gap:10px;flex-shrink:0;position:relative;z-index:200}
.h-left{flex:1;display:flex;align-items:center;gap:10px}
.search-bar{display:flex;align-items:center;gap:7px;background:var(--bg-3);border:1px solid var(--border);border-radius:8px;padding:0 10px;height:32px;width:220px;transition:border-color .15s}
.search-bar:focus-within{border-color:var(--teal)}
.search-bar input{background:none;border:none;outline:none;color:var(--text-0);font-family:inherit;font-size:.8125rem;width:100%}
.search-bar input::placeholder{color:var(--text-3)}
.h-actions{display:flex;align-items:center;gap:6px}
.icon-btn{width:44px;height:44px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;border-radius:8px;cursor:pointer;color:var(--text-2);background:none;border:none;transition:all .15s;position:relative}
.icon-btn:hover{background:var(--bg-3);color:var(--text-1)}
.notif-dot{position:absolute;top:5px;right:5px;width:6px;height:6px;background:var(--teal);border-radius:50%}
.avatar{width:30px;height:30px;border-radius:8px;background:var(--teal-dim);border:1px solid var(--teal);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.6875rem;color:var(--teal);cursor:pointer;flex-shrink:0}
.ham-btn{display:none}

/* MAIN */
#main{flex:1;position:relative;overflow:hidden;background:rgba(2,4,14,0.18)}
.section{position:absolute;inset:0;overflow-y:auto;padding:22px;display:none;flex-direction:column;gap:18px}
.section.active{display:flex}

/* TYPOGRAPHY */
.page-title{font-size:1.125rem;font-weight:700;letter-spacing:-.02em}
.page-sub{font-size:.8125rem;color:var(--text-2);margin-top:2px}
.card-title{font-size:.875rem;font-weight:600}

/* CARDS */
.card{background:rgba(8,12,30,0.72);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08);border-radius:var(--rl);padding:18px}
.card-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}

/* KPI */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.kpi-card{background:rgba(8,12,30,0.68);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);border-radius:var(--r);padding:14px}
.kpi-label{font-size:.6875rem;color:var(--text-2);text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.kpi-val{font-size:1.375rem;font-weight:700;font-variant-numeric:tabular-nums lining-nums;margin-top:3px;font-family:'Inter',sans-serif}
.kpi-delta{font-size:.6875rem;margin-top:3px;font-variant-numeric:tabular-nums;font-weight:600}
.up{color:var(--green)}.down{color:var(--red)}

/* BADGES */
.badge{display:inline-flex;align-items:center;padding:2px 7px;border-radius:4px;font-size:.625rem;font-weight:700;letter-spacing:.02em}
.b-teal{background:var(--teal-dim);color:var(--teal)}
.b-gold{background:var(--gold-dim);color:var(--gold)}
.b-green{background:var(--green-dim);color:var(--green)}
.b-red{background:var(--red-dim);color:var(--red)}
.b-blue{background:var(--blue-dim);color:var(--blue)}
.b-yellow{background:var(--yellow-dim);color:var(--yellow)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:5px;padding:10px 16px;border-radius:8px;font-size:0.875rem;font-weight:600;cursor:pointer;border:none;transition:all .15s;font-family:inherit;min-height:44px}
.btn-primary{background:var(--teal);color:#000}
.btn-primary:hover{opacity:.88}
.btn-ghost{background:transparent;color:var(--text-2);border:1px solid var(--border)}
.btn-ghost:hover{background:var(--bg-3);color:var(--text-1);border-color:var(--border-s)}
.btn-sm{padding:6px 12px;font-size:0.8125rem;min-height:36px}

/* GRIDS */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}

/* FILTER */
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.fsel{background:var(--bg-2);border:1px solid var(--border);border-radius:8px;padding:5px 9px;color:var(--text-1);font-family:inherit;font-size:.75rem;cursor:pointer;outline:none;transition:border-color .15s}
.fsel:focus{border-color:var(--teal)}

/* TABLE */
.dtable{width:100%;border-collapse:collapse;font-size:.75rem}
.dtable th{text-align:left;padding:7px 10px;color:var(--text-2);font-size:.625rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);font-weight:600}
.dtable td{padding:9px 10px;border-bottom:1px solid var(--border);font-variant-numeric:tabular-nums lining-nums}
.dtable tr:last-child td{border-bottom:none}
.dtable tr{transition:background .12s}
.dtable tbody tr:hover td{background:var(--bg-3)}
.dtable tr.flash-g td{animation:rowG .5s ease}
.dtable tr.flash-r td{animation:rowR .5s ease}
.dtable tr.watched td{background:var(--teal-dim)!important}

/* PROGRESS */
.prog-bar{height:5px;background:var(--bg-4);border-radius:3px;overflow:hidden}
.prog-fill{height:100%;background:var(--teal);border-radius:3px;transition:width .6s ease}

/* PIPELINE */
.pipeline{display:flex;align-items:flex-start;margin:10px 0}
.pip-step{flex:1;text-align:center;position:relative}
.pip-step::before{content:'';position:absolute;top:11px;left:-50%;right:50%;height:2px;background:var(--bg-4);z-index:0}
.pip-step:first-child::before{display:none}
.pip-dot{width:22px;height:22px;border-radius:50%;background:var(--bg-4);border:2px solid var(--bg-4);margin:0 auto 5px;position:relative;z-index:1;display:flex;align-items:center;justify-content:center}
.pip-step.done .pip-dot{background:var(--green);border-color:var(--green)}
.pip-step.active .pip-dot{background:var(--teal);border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-dim)}
.pip-step.done::before,.pip-step.active::before{background:var(--teal)}
.pip-label{font-size:.5625rem;color:var(--text-3);font-weight:500;line-height:1.3}
.pip-step.done .pip-label,.pip-step.active .pip-label{color:var(--text-2)}

/* TABS */
.tabs{display:flex;gap:3px;padding:3px;background:var(--bg-3);border-radius:10px;width:fit-content}
.tab{padding:6px 16px;border-radius:7px;font-size:.75rem;font-weight:600;cursor:pointer;color:var(--text-2);transition:all .15s;border:none;background:none;font-family:inherit}
.tab.active{background:var(--bg-2);color:var(--text-0)}

/* FORMS */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fg{display:flex;flex-direction:column;gap:3px}
.flabel{font-size:.625rem;font-weight:700;color:var(--text-2);text-transform:uppercase;letter-spacing:.04em}
.finput,.fselect{background:var(--bg-3);border:1px solid var(--border);border-radius:8px;padding:8px 10px;color:var(--text-0);font-family:inherit;font-size:.8125rem;outline:none;transition:border-color .15s;width:100%}
.finput:focus,.fselect:focus{border-color:var(--teal)}

/* CHECKLIST */
.cl-item{display:flex;align-items:flex-start;gap:11px;padding:12px 14px;border-bottom:1px solid var(--border);transition:background .12s}
.cl-item:last-child{border-bottom:none}
.cl-item:hover{background:var(--bg-3)}
.cb{width:17px;height:17px;border:2px solid var(--border-s);border-radius:4px;flex-shrink:0;margin-top:1px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}
.cb.checked{background:var(--teal);border-color:var(--teal)}

/* CHAT */
.chat-msgs{display:flex;flex-direction:column;gap:10px;max-height:280px;overflow-y:auto;padding:2px}
.chat-msg{display:flex;gap:7px;align-items:flex-start}
.chat-msg.user{flex-direction:row-reverse}
.bubble{max-width:82%;padding:9px 13px;border-radius:12px;font-size:.8125rem;line-height:1.5}
.chat-msg.guru .bubble{background:var(--bg-3);color:var(--text-1);border-radius:4px 12px 12px 12px}
.chat-msg.user .bubble{background:var(--teal-dim);color:var(--teal);border:1px solid var(--teal);border-radius:12px 4px 12px 12px}
.cav{width:26px;height:26px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:.6875rem;font-weight:700;flex-shrink:0}
.cav.guru{background:var(--teal-dim);color:var(--teal)}
.cav.user{background:var(--gold-dim);color:var(--gold)}
.chat-input-row{display:flex;gap:7px;margin-top:10px;border-top:1px solid var(--border);padding-top:10px}

/* ROADMAP */
.rm-step{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}
.rm-step:last-child{border-bottom:none}
.step-num{width:26px;height:26px;border-radius:50%;background:var(--bg-4);border:2px solid var(--border-s);display:flex;align-items:center;justify-content:center;font-size:.6875rem;font-weight:700;color:var(--text-2);flex-shrink:0;transition:all .25s;cursor:pointer}
.rm-step.done .step-num{background:var(--green);border-color:var(--green);color:#fff}
.rm-step.in-progress .step-num{background:var(--teal);border-color:var(--teal);color:#000}
.step-ttl{font-weight:600;font-size:.875rem;margin-bottom:3px;display:flex;align-items:center;gap:7px}
.step-desc{font-size:.75rem;color:var(--text-2);line-height:1.55}
.step-meta{display:flex;gap:7px;margin-top:7px;flex-wrap:wrap;align-items:center}
.step-time{font-size:.6875rem;color:var(--text-3)}
.mistake{font-size:.6875rem;color:var(--gold);margin-top:4px;display:flex;gap:5px}

/* LESSON */
.lesson-card{background:rgba(8,12,30,0.72);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);border-radius:var(--rl);overflow:hidden;transition:border-color .2s;cursor:pointer}
.lesson-card:hover{border-color:var(--teal)}
.lesson-hd{padding:14px;display:flex;align-items:flex-start;gap:10px}
.lesson-icon{width:38px;height:38px;border-radius:9px;background:var(--teal-dim);display:flex;align-items:center;justify-content:center;color:var(--teal);flex-shrink:0}
.lesson-ttl{font-weight:600;font-size:.875rem}
.lesson-meta{font-size:.6875rem;color:var(--text-2);margin-top:2px}
.lesson-body{padding:0 14px 14px}
.lesson-tks{list-style:none;display:flex;flex-direction:column;gap:5px}
.lesson-tks li{font-size:.75rem;color:var(--text-2);padding-left:13px;position:relative;line-height:1.5}
.lesson-tks li::before{content:'→';position:absolute;left:0;color:var(--teal);font-size:.6875rem}

/* QUIZ */
.quiz-q{font-size:.875rem;font-weight:600;margin-bottom:8px}
.quiz-opts{display:flex;flex-direction:column;gap:5px}
.quiz-opt{padding:8px 12px;border-radius:8px;border:1px solid var(--border);cursor:pointer;font-size:.75rem;color:var(--text-1);transition:all .15s;background:none;font-family:inherit;text-align:left;width:100%}
.quiz-opt:hover{background:var(--bg-3);border-color:var(--border-s)}
.quiz-opt.correct{background:var(--green-dim);border-color:var(--green);color:var(--green)}
.quiz-opt.wrong{background:var(--red-dim);border-color:var(--red);color:var(--red);animation:shake .4s ease}

/* OPP CARDS */
.opp-card{background:rgba(8,12,30,0.72);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);border-radius:var(--rl);padding:14px;transition:border-color .2s,box-shadow .2s}
.opp-card:hover{border-color:var(--teal);box-shadow:0 0 0 1px var(--teal-dim)}
.opp-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:8px}
.opp-comm{font-weight:700;font-size:.875rem}
.opp-route{font-size:.6875rem;color:var(--text-2);margin-top:2px}
.opp-thesis{font-size:.75rem;color:var(--text-2);line-height:1.55;margin-bottom:10px}
/* Financial snapshot row */
.opp-fin-snap{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;margin-bottom:10px;padding:8px;background:var(--teal-dim-soft);border:1px solid var(--teal-dim);border-radius:6px}
.ofin-item{}
.ofin-l{font-size:.5rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);font-weight:600;margin-bottom:2px}
.ofin-v{font-size:.6875rem;font-weight:700;color:var(--text-1);font-variant-numeric:tabular-nums}
/* Risk preview */
.opp-risks{margin-bottom:2px}
.opp-risk-row{display:flex;align-items:flex-start;gap:6px;margin-bottom:4px}
.risk-factor{font-size:.6875rem;color:var(--text-2);line-height:1.4}
.risk-sev{display:inline-block;font-size:.5625rem;font-weight:700;letter-spacing:.04em;padding:1px 5px;border-radius:3px;flex-shrink:0;margin-top:1px}
.sev-critical{background:var(--red-dim-strong);color:#f87171;border:1px solid var(--red-dim-strong)}
.sev-high{background:var(--gold-dim-strong);color:#fbbf24;border:1px solid var(--gold-dim-strong)}
.sev-med{background:var(--blue-dim-strong);color:#60a5fa;border:1px solid var(--blue-dim-strong)}
.sev-low{background:rgba(34,197,94,.12);color:#4ade80;border:1px solid rgba(34,197,94,.22)}
/* Full report sections */
.opp-why{border-top:1px solid var(--border);padding-top:10px;display:none}
.opp-why.open{display:block}
.why-btn{font-size:.6875rem;color:var(--teal);cursor:pointer;display:flex;align-items:center;gap:3px;background:none;border:none;font-family:inherit;padding:10px 0;margin-bottom:4px;width:100%;border-top:1px solid var(--border);min-height:44px}
.intel-section{margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.05)}
.intel-section:last-child{border-bottom:none;margin-bottom:0}
.intel-hd{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--teal);margin-bottom:6px}
.intel-note{font-size:.6875rem;color:var(--text-2);line-height:1.55;margin-bottom:4px}
.intel-caveat{color:var(--text-3);font-style:italic}
.intel-list{font-size:.6875rem;color:var(--text-2);line-height:1.6;padding-left:14px;margin:4px 0 6px}
.intel-list li{margin-bottom:2px}
/* Margin scenarios grid */
.intel-scenarios{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;margin-top:8px}
.scenario{padding:6px 8px;border-radius:6px;border:1px solid}
.scenario.pessimistic{background:var(--red-dim-soft);border-color:var(--red-dim-strong)}
.scenario.base{background:var(--teal-dim-soft);border-color:var(--teal-dim-strong)}
.scenario.optimistic{background:var(--green-dim-soft);border-color:var(--green-dim-strong)}
.sc-label{font-size:.5rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);font-weight:600;margin-bottom:2px}
.sc-val{font-size:.9375rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text-1);margin-bottom:2px}
.sc-note{font-size:.5625rem;color:var(--text-3);line-height:1.4}
/* Full risk rows inside report */
.risk-full-row{display:flex;align-items:flex-start;gap:8px;margin-bottom:8px}
.risk-full-body{flex:1;min-width:0}
.risk-full-body strong{font-size:.6875rem;color:var(--text-1)}
/* Market disclaimer banner */
.market-disclaimer{display:flex;align-items:flex-start;gap:8px;padding:8px 12px;background:rgba(59,130,246,.08);border:1px solid rgba(59,130,246,.2);border-radius:6px;font-size:.6875rem;color:var(--text-2);line-height:1.55;margin-bottom:14px}

/* EMPTY STATE */
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 20px;text-align:center;gap:10px;color:var(--text-2)}
.empty h3{font-size:.9375rem;font-weight:600;color:var(--text-1)}
.empty p{font-size:.8125rem;max-width:280px}

/* MODAL — z-index 1100 sits above notif-panel (999) but below cmd-palette (4000) */
.mbg{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:1100;display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.mbg.open{display:flex}
.modal{background:rgba(8,14,32,0.92);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.12);border-radius:var(--rl);padding:22px;width:480px;max-width:95vw;max-height:90vh;overflow-y:auto;box-shadow:0 8px 40px rgba(0,0,0,.6)}
.modal-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.modal-ttl{font-size:.9375rem;font-weight:700}

/* CALC */
.calc-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--border);font-size:.8125rem}
.calc-row:last-child{border-bottom:none}
.calc-row .lbl{color:var(--text-2)}
.calc-row .val{font-weight:600;font-variant-numeric:tabular-nums}
.margin-ind{padding:10px 14px;border-radius:9px;font-size:.875rem;font-weight:700;text-align:center;margin-top:6px}
.mg{background:var(--green-dim);color:var(--green);border:1px solid var(--green)}
.my{background:var(--yellow-dim);color:var(--yellow);border:1px solid var(--yellow)}
.mr{background:var(--red-dim);color:var(--red);border:1px solid var(--red)}
.saved-calc{background:var(--bg-3);border:1px solid var(--border);border-radius:8px;padding:10px 12px;display:flex;justify-content:space-between;align-items:center}

/* SECTION HEADER */
.sec-hd{display:flex;align-items:flex-end;justify-content:space-between}
.live-dot{display:inline-flex;align-items:center;gap:5px;font-size:.625rem;font-weight:700;color:var(--green);text-transform:uppercase;letter-spacing:.05em}
.live-dot::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse 1.5s infinite}

/* ANIMATIONS */
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
@keyframes rowG{0%,100%{background:transparent}50%{background:var(--green-dim)}}
@keyframes rowR{0%,100%{background:transparent}50%{background:var(--red-dim)}}
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-5px)}40%{transform:translateX(5px)}60%{transform:translateX(-3px)}80%{transform:translateX(3px)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.fade-up{animation:fadeUp .35s ease both}

/* SCROLLBAR */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bg-4);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--text-3)}

/* UTILS */
.flex{display:flex}.items-c{align-items:center}.jc-sb{justify-content:space-between}.gap-6{gap:6px}.gap-8{gap:8px}.gap-10{gap:10px}.gap-12{gap:12px}
.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}
.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}
.text-teal{color:var(--teal)}.text-gold{color:var(--gold)}.text-green{color:var(--green)}.text-red{color:var(--red)}.text-muted{color:var(--text-2)}
.text-sm{font-size:.8125rem}.text-xs{font-size:.75rem}.fw-6{font-weight:600}.fw-7{font-weight:700}
.w-full{width:100%}.hidden{display:none!important}
.font-num{font-variant-numeric:tabular-nums lining-nums;font-family:'Inter',sans-serif}

/* ============================================================ */
/* SHIPMENTS TABLE                                              */
/* ============================================================ */

/* Outer card is zero padding; inner scroll wrapper handles it */
.ship-table-wrap { overflow: hidden }

.ship-table-scroll {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.ship-table { min-width: 720px }

/* Route column: origin→dest in one cell */
.ship-route { color: var(--text-1); white-space: nowrap }
.route-arrow { color: var(--teal); margin: 0 4px }

/* Status badges — color-coded per status */
.ship-status {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 9px;
  border-radius: 20px;
  font-size: .625rem;
  font-weight: 700;
  letter-spacing: .03em;
  white-space: nowrap;
}

.status-in-transit {
  background: var(--blue-dim);
  color: var(--blue);
  border: 1px solid rgba(59,130,246,.25);
}

.status-customs {
  background: var(--gold-dim);
  color: var(--gold);
  border: 1px solid rgba(245,166,35,.25);
}

.status-delivered {
  background: var(--green-dim);
  color: var(--green);
  border: 1px solid rgba(34,197,94,.25);
}

.status-delayed {
  background: var(--red-dim);
  color: var(--red);
  border: 1px solid rgba(239,68,68,.25);
}

.status-order-placed {
  background: var(--yellow-dim);
  color: var(--yellow);
  border: 1px solid rgba(234,179,8,.25);
}

/* ============================================================ */
/* LANDED COST CALCULATOR                                       */
/* ============================================================ */

/* Input grid: single column for clean vertical flow */
.calc-inputs {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* Small tip line below inputs */
.calc-tip {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: .6875rem;
  color: var(--text-2);
  line-height: 1.5;
}

/* Results: 2×2 grid of result cards + 1 full-width breakdown */
.lc-results-grid {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* Cost summary strip */
.lc-summary-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.lc-summary-item{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r);padding:10px 12px}
.lc-summary-label{font-size:.6875rem;color:var(--text-3);font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-bottom:3px}
.lc-summary-val{font-size:.9375rem;font-weight:800;color:var(--text-0)}
.lc-summary-sub{font-size:.6rem;color:var(--text-3);margin-top:2px}

/* Total strip */
.lc-total-strip{background:linear-gradient(90deg,rgba(239,68,68,.12),rgba(239,68,68,.04));border:1.5px solid rgba(239,68,68,.3);border-radius:var(--r);padding:14px 16px;display:flex;flex-direction:column;gap:3px}
.lc-total-label{font-size:.6875rem;font-weight:800;color:var(--red);text-transform:uppercase;letter-spacing:.06em}
.lc-total-val{font-size:1.5rem;font-weight:800;color:var(--text-0)}
.lc-total-sub{font-size:.75rem;color:var(--text-2)}

/* Profit scenarios */
.lc-profit-section{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r);padding:14px 16px}
.lc-profit-title{font-size:.75rem;font-weight:700;color:var(--text-2);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}
.profit-row{display:grid;grid-template-columns:auto 1fr 1fr auto;align-items:center;gap:10px;padding:6px 0;border-bottom:1px solid var(--border-s)}
.profit-row:last-child{border-bottom:none}
.profit-label{font-size:.8125rem;color:var(--text-1);font-weight:500}
.profit-sell{font-size:.8125rem;color:var(--text-2);text-align:right}
.profit-val{font-size:.875rem;font-weight:700;text-align:right}
.profit-pct{font-size:.75rem;font-weight:400}
.profit-note{font-size:.6875rem;color:var(--text-3);white-space:nowrap}
@media(max-width:700px){.lc-summary-strip{grid-template-columns:1fr 1fr}.profit-row{grid-template-columns:1fr 1fr;row-gap:2px}.profit-label{font-weight:700}.profit-note{display:none}}

.lc-result-card {
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: var(--rl);
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  transition: border-color .15s, box-shadow .15s;
}

.lc-result-card:hover {
  border-color: var(--border-s);
  box-shadow: 0 2px 12px rgba(0,0,0,.15);
}

.lc-result-icon { line-height: 1 }

.lc-result-label {
  font-size: .625rem;
  font-weight: 700;
  color: var(--text-2);
  text-transform: uppercase;
  letter-spacing: .05em;
}

.lc-result-value {
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1;
}

.lc-result-sub {
  font-size: .6875rem;
  color: var(--text-2);
}

/* Full-width breakdown bar card spans both columns */
.lc-breakdown-card {
  grid-column: 1 / -1;
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: var(--rl);
  padding: 16px;
}

.lc-breakdown-title {
  font-size: .75rem;
  font-weight: 600;
  margin-bottom: 10px;
  color: var(--text-1);
}

.lc-breakdown-bar {
  display: flex;
  height: 10px;
  border-radius: 6px;
  overflow: hidden;
  gap: 2px;
  margin-bottom: 10px;
}

.lc-bar-seg {
  height: 100%;
  border-radius: 3px;
  transition: width .4s ease;
  min-width: 2px;
}

.lc-breakdown-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.lc-legend-item {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: .6875rem;
  color: var(--text-2);
}

.lc-legend-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

/* ============================================================ */
/* RESPONSIVE                                                   */
/* ============================================================ */
@media(max-width:1024px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.g4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){
  #sidebar{position:fixed;left:-220px;top:0;bottom:0;z-index:150;transition:left .25s}
  #sidebar.mob-open{left:0}
  .ham-btn{display:none}
  .g2,.g3{grid-template-columns:1fr}
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .search-bar{width:150px}
  .form-grid{grid-template-columns:1fr}
  /* Mobile: stack result cards to single column */
  .lc-results-grid { grid-template-columns: 1fr }
  .lc-breakdown-card { grid-column: 1 }
  /* Bottom tab bar */
  #mob-tab-bar{display:flex}
  #main{padding-bottom:62px}
}

/* ── Mobile bottom tab bar ─────────────────────────────────────── */
#mob-tab-bar{
  display:none;
  position:fixed;bottom:0;left:0;right:0;
  z-index:200;
  background:var(--bg-1);
  border-top:1px solid var(--border);
  height:58px;
  align-items:stretch;
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
}
.mob-tab-btn{
  flex:1;display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:3px;background:none;border:none;
  color:var(--text-3);cursor:pointer;
  font-family:inherit;font-size:.5625rem;font-weight:600;
  min-height:44px;padding:4px 2px;
  transition:color .15s;
  -webkit-tap-highlight-color:transparent;
  letter-spacing:.02em;text-transform:uppercase;
}
.mob-tab-btn i{width:20px;height:20px;flex-shrink:0}
.mob-tab-btn.active{color:var(--teal)}
.mob-tab-btn:active{opacity:.7}

/* ── Arrived status badge ─────────────────────────────────── */
.status-arrived {
  background: var(--purple-dim);
  color: var(--purple);
  border: 1px solid var(--purple-dim);
}

/* ── Mobile sidebar overlay ───────────────────────────────── */
#mob-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:140;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}
#mob-overlay.open{display:block}

/* ── Command palette ──────────────────────────────────────── */
#cmdPalette{display:none;position:fixed;inset:0;z-index:4000;background:rgba(0,0,0,.7);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);align-items:flex-start;justify-content:center;padding-top:18vh}
#cmdPalette.open{display:flex}

/* ── Notification panel ───────────────────────────────────── */
.notif-panel {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: 280px;
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: 14px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.4);
  z-index: 999;
  overflow: hidden;
}
.notif-hd {
  padding: 12px 16px 8px;
  font-size: 12px;
  font-weight: 700;
  color: var(--text-0);
  border-bottom: 1px solid var(--border);
}
.notif-item {
  padding: 10px 16px;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: background 0.15s;
}
.notif-item:hover { background: var(--bg-3); }
.notif-item:last-child { border-bottom: none; }
.notif-title { font-size: 12px; font-weight: 600; color: var(--text-0); }
.notif-sub { font-size: 11px; color: var(--text-2); margin-top: 2px; }
.notif-empty { padding: 16px; font-size: 12px; color: var(--text-2); text-align: center; }

/* ── Onboarding overlay ───────────────────────────────────── */
.onboard-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  z-index: 3000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.onboard-card {
  background: var(--bg-2);
  border: 1px solid var(--border, #1e2d3d);
  border-radius: 24px;
  padding: 40px 36px;
  max-width: 520px;
  width: 100%;
  text-align: center;
}
.onboard-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 24px;
}
.onboard-brand {
  font-size: 20px;
  font-weight: 800;
  color: var(--text-0);
  letter-spacing: -0.03em;
}
.onboard-title {
  font-size: 26px;
  font-weight: 800;
  color: var(--text-0);
  letter-spacing: -0.03em;
  margin: 0 0 12px;
}
.onboard-sub {
  font-size: 14px;
  color: var(--text-2, #8899a6);
  line-height: 1.65;
  margin: 0 0 28px;
}
.onboard-q {
  font-size: 13px;
  font-weight: 700;
  color: var(--text-1, #c8cdd8);
  margin-bottom: 14px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.onboard-choices {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 20px;
}
.onboard-choice {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 18px;
  border-radius: 16px;
  border: 2px solid var(--border, #1e2d3d);
  background: var(--bg-3, #141c24);
  cursor: pointer;
  text-align: left;
  font-family: inherit;
  transition: all 0.18s ease;
}
.onboard-choice:hover {
  border-color: var(--teal, #00c9b1);
  background: rgba(0, 201, 177, 0.06);
}
.onboard-choice-icon { font-size: 24px; flex-shrink: 0; }
.onboard-choice-title {
  display: block;
  font-size: 14px;
  font-weight: 700;
  color: var(--text-0);
}
.onboard-choice-sub {
  display: block;
  font-size: 12px;
  color: var(--text-2, #8899a6);
  margin-top: 2px;
  line-height: 1.4;
}
.onboard-skip { font-size: 12px; color: var(--text-2, #8899a6); }

/* ── Simulated badge variant ──────────────────────────────── */
.live-dot.simulated {
  background: var(--purple-dim);
  color: var(--purple);
  border-color: var(--purple-dim);
}
/* Override the green pulsing dot to purple, no animation */
.live-dot.simulated::before {
  background: var(--purple);
  animation: none;
}

/* ═══════════════════════════════════════════════════════════════════
   MOTION LAYER
   ═══════════════════════════════════════════════════════════════════ */

/* Section slide-in on every navigation */
@keyframes sectionIn {
  from { opacity: 0; transform: translateX(18px); }
  to   { opacity: 1; transform: translateX(0); }
}
.section.active {
  animation: sectionIn .32s cubic-bezier(0.22, 1, 0.36, 1) both;
}

/* KPI card lift */
.kpi-card {
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  will-change: transform;
}
.kpi-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0,0,0,.3);
  border-color: var(--border-s);
}

/* Opportunity card richer hover (override existing transition to add transform) */
.opp-card {
  transition: transform .18s ease, border-color .2s, box-shadow .2s;
  will-change: transform;
}
.opp-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 10px 32px rgba(0,0,0,.32), 0 0 0 1px var(--teal-dim);
}

/* Lesson card lift (override existing transition) */
.lesson-card {
  transition: transform .18s ease, border-color .2s;
  will-change: transform;
}
.lesson-card:hover { transform: translateY(-3px); }

/* Generic card hover depth */
.card {
  transition: box-shadow .18s ease;
  will-change: box-shadow;
}
.card:hover { box-shadow: 0 6px 20px rgba(0,0,0,.2); }

/* Button tactile press */
.btn { transform-origin: center; }
.btn:active { transform: scale(0.96); }

/* Status badge glow pulses — keeps shipments feeling alive */
@keyframes glow-blue {
  0%,100% { box-shadow: 0 0 0 0 rgba(59,130,246,0); }
  50%      { box-shadow: 0 0 7px 2px rgba(59,130,246,.28); }
}
@keyframes glow-gold {
  0%,100% { box-shadow: 0 0 0 0 rgba(245,166,35,0); }
  50%      { box-shadow: 0 0 7px 2px rgba(245,166,35,.28); }
}
.status-in-transit { animation: glow-blue 2.8s ease infinite; }
.status-customs     { animation: glow-gold 2.8s ease infinite; }

/* Search bar focus expand */
.search-bar { transition: border-color .15s, width .28s cubic-bezier(0.22,1,0.36,1); }
.search-bar:focus-within { width: 280px; }

/* Nav item spring transition */
.nav-item { transition: all .2s cubic-bezier(0.22,1,0.36,1); }

/* ── Command Palette ──────────────────────────────────────────────── */
@keyframes cmdIn {
  from { opacity: 0; transform: scale(.96) translateY(-8px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}
.cmd-box {
  width: 560px;
  max-width: calc(100vw - 32px);
  background: var(--bg-2);
  border: 1px solid var(--border-s);
  border-radius: 16px;
  box-shadow: 0 24px 64px rgba(0,0,0,.55);
  overflow: hidden;
  animation: cmdIn .18s cubic-bezier(0.22,1,0.36,1) both;
}
.cmd-search-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
}
.cmd-input {
  flex: 1;
  background: none;
  border: none;
  font-family: inherit;
  font-size: .9375rem;
  color: var(--text-0);
}
.cmd-input::placeholder { color: var(--text-3); }
.cmd-esc {
  font-size: .625rem;
  padding: 2px 6px;
  border-radius: 4px;
  background: var(--bg-4);
  border: 1px solid var(--border-s);
  color: var(--text-3);
  font-family: inherit;
}
.cmd-results {
  max-height: 360px;
  overflow-y: auto;
  padding: 6px;
}
.cmd-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  border-radius: 8px;
  cursor: pointer;
  font-size: .8125rem;
  transition: background .1s;
}
.cmd-item:hover, .cmd-item.selected, .cmd-item.active {
  background: var(--teal-dim);
  color: var(--teal);
}
.cmd-item-icon {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  background: var(--bg-3);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--text-2);
}
.cmd-item.selected .cmd-item-icon, .cmd-item.active .cmd-item-icon { background: var(--teal-dim); color: var(--teal); }
.cmd-item-label { flex: 1; font-weight: 500; }
.cmd-item-sub { font-size: .6875rem; color: var(--text-3); }
.cmd-section-header {
  font-size: .625rem;
  font-weight: 700;
  letter-spacing: .06em;
  color: var(--text-3);
  text-transform: uppercase;
  padding: 8px 12px 4px;
}
.cmd-empty {
  padding: 32px;
  text-align: center;
  color: var(--text-3);
  font-size: .8125rem;
}
.cmd-footer {
  display: flex;
  gap: 16px;
  padding: 8px 16px;
  border-top: 1px solid var(--border);
  font-size: .625rem;
  color: var(--text-3);
}
.cmd-footer kbd {
  display: inline-block;
  padding: 1px 5px;
  border-radius: 3px;
  background: var(--bg-4);
  border: 1px solid var(--border-s);
  font-family: inherit;
  font-size: .625rem;
  color: var(--text-2);
  margin-right: 3px;
}

/* Dashboard alert rows */
.dash-alert-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 0;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: background .12s;
  border-radius: 6px;
}
.dash-alert-row:last-child { border-bottom: none; }
.dash-alert-row:hover { background: var(--bg-3); }

/* ── Live Tracking Modal ──────────────────────────────────── */
.trk-header{padding:4px 0 16px;border-bottom:1px solid var(--border);margin-bottom:16px}
.trk-route{font-size:1rem;font-weight:700;color:var(--text-0)}
.trk-arrow{color:var(--teal);margin:0 6px}
.trk-num{font-size:.75rem;color:var(--text-2);margin-top:3px;font-family:monospace}
.trk-status-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:8px}
.trk-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;font-size:.8125rem;font-weight:600}
.trk-eta{font-size:.8125rem;color:var(--text-2)}
.trk-timeline{display:flex;flex-direction:column;gap:0;max-height:340px;overflow-y:auto;padding-right:4px}
.tl-row{display:flex;gap:12px;min-height:48px}
.tl-latest .tl-msg{color:var(--text-0);font-weight:600}
.tl-left{display:flex;flex-direction:column;align-items:center;width:20px;flex-shrink:0}
.tl-dot{width:10px;height:10px;border-radius:50%;background:var(--border-s);border:2px solid var(--border-s);flex-shrink:0;margin-top:4px}
.tl-dot-live{background:var(--teal);border-color:var(--teal);box-shadow:0 0 0 3px rgba(0,201,177,.25)}
.tl-line{width:2px;background:var(--border);flex:1;margin:4px 0}
.tl-body{padding-bottom:16px;flex:1}
.tl-msg{font-size:.8125rem;color:var(--text-1);line-height:1.4}
.tl-sub{font-size:.6875rem;color:var(--text-3);margin-top:3px;display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.trk-loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:40px 0;color:var(--text-2);font-size:.875rem}
.trk-spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--teal);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}
@keyframes spin{to{transform:rotate(360deg)}}
.trk-error,.trk-nokey{text-align:center;padding:28px 20px}
.trk-nokey h3,.trk-error h3{font-size:1rem;font-weight:700;margin-bottom:8px;color:var(--text-0)}
.trk-nokey p,.trk-error p{font-size:.8125rem;color:var(--text-2);line-height:1.6;max-width:380px;margin:0 auto}
.trk-key-row{display:flex;gap:8px;margin-top:16px;max-width:420px;margin-left:auto;margin-right:auto}
.trk-empty{text-align:center;padding:24px;color:var(--text-3);font-size:.8125rem}
.trk-footer{display:flex;align-items:center;justify-content:space-between;margin-top:16px;padding-top:12px;border-top:1px solid var(--border)}
.trk-powered{font-size:.6875rem;color:var(--text-3)}

/* ── Partners Section ──────────────────────────────────────── */
.partners-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap}
.partners-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;margin-bottom:20px}
.partner-card{background:rgba(8,12,30,0.72);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);border-radius:var(--rl);padding:16px;cursor:pointer;transition:border-color .18s,transform .18s,box-shadow .18s;display:flex;flex-direction:column;gap:8px}
.partner-card:hover{border-color:rgba(0,201,177,.35);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.32)}
.partner-card:focus-visible{outline:2px solid var(--teal);outline-offset:2px}
.partner-card-hd{display:flex;align-items:flex-start;gap:10px}
.partner-flag{font-size:1.75rem;line-height:1;flex-shrink:0}
.partner-name{font-size:.875rem;font-weight:700;color:var(--text-0);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.partner-region{font-size:.6875rem;color:var(--text-3);margin-top:2px}
.partner-verified{color:var(--teal);flex-shrink:0;display:flex}
.partner-desc{font-size:.75rem;color:var(--text-2);line-height:1.55;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;flex:1}
.partner-specialties{display:flex;flex-wrap:wrap;gap:5px;margin-top:auto}
.partner-tag{font-size:.625rem;padding:2px 7px;border-radius:10px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:var(--text-2);white-space:nowrap}
.partner-footer{display:flex;align-items:center;gap:8px;padding-top:8px;border-top:1px solid var(--border);flex-wrap:wrap}
.partner-rating{font-size:.75rem;font-weight:600;color:var(--text-0)}
.partner-response{font-size:.6875rem;color:var(--text-3);display:flex;align-items:center;gap:3px;margin-right:auto}
/* Partner detail modal */
.partner-detail-hd{display:flex;gap:14px;align-items:flex-start;padding-bottom:16px;border-bottom:1px solid var(--border);margin-bottom:4px}
.partner-detail-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:8px}
.partner-stat{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:10px;padding:12px;text-align:center}
.partner-stat-val{font-size:1.125rem;font-weight:700;color:var(--text-0);display:flex;align-items:center;justify-content:center;gap:4px;margin-bottom:4px}
.partner-stat-lbl{font-size:.625rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em}
@media(max-width:768px){.partners-grid{grid-template-columns:1fr}.partners-toolbar{flex-direction:column;align-items:stretch}}

/* ── Guru AI Orb ────────────────────────────────────────────── */
.guru-orb-wrap{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 0 8px}
.guru-orb{width:96px;height:96px;border-radius:50%;overflow:hidden;position:relative;border:2px solid rgba(0,201,177,.4);box-shadow:0 0 20px rgba(0,201,177,.2),0 0 40px rgba(0,201,177,.08);transition:box-shadow .4s ease,border-color .4s ease}
.guru-orb-video{width:100%;height:100%;object-fit:cover;display:block}
.guru-orb.thinking{border-color:rgba(0,201,177,.9);box-shadow:0 0 28px rgba(0,201,177,.5),0 0 60px rgba(0,201,177,.2);animation:orbPulse 1s ease-in-out infinite}
@keyframes orbPulse{0%,100%{box-shadow:0 0 28px rgba(0,201,177,.5),0 0 60px rgba(0,201,177,.2)}50%{box-shadow:0 0 40px rgba(0,201,177,.8),0 0 80px rgba(0,201,177,.35)}}
.guru-orb-label{font-size:.6875rem;font-weight:600;color:var(--teal);letter-spacing:.08em;text-transform:uppercase}

/* ── Skeleton loaders ──────────────────────────────────────────── */
@keyframes shimmer {
  0%   { background-position: -400px 0; }
  100% { background-position:  400px 0; }
}
.skeleton {
  border-radius: 6px;
  background: linear-gradient(90deg, var(--bg-3) 25%, var(--bg-4) 50%, var(--bg-3) 75%);
  background-size: 800px 100%;
  animation: shimmer 1.4s infinite linear;
}
.skeleton-line { height: 12px; margin-bottom: 8px; }
.skeleton-line:last-child { width: 65%; margin-bottom: 0; }
.skeleton-chip { height: 24px; width: 80px; border-radius: 20px; display: inline-block; }
.skeleton-block { height: 48px; }

/* Staggered entrance for opp-cards */
@keyframes cardEnter {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}
.opp-card { animation: cardEnter .32s cubic-bezier(0.22,1,0.36,1) both; }
.opp-card:nth-child(1)  { animation-delay: .00s; }
.opp-card:nth-child(2)  { animation-delay: .05s; }
.opp-card:nth-child(3)  { animation-delay: .10s; }
.opp-card:nth-child(4)  { animation-delay: .15s; }
.opp-card:nth-child(5)  { animation-delay: .20s; }
.opp-card:nth-child(6)  { animation-delay: .24s; }
.opp-card:nth-child(7)  { animation-delay: .28s; }
.opp-card:nth-child(8)  { animation-delay: .32s; }
.opp-card:nth-child(n+9){ animation-delay: .36s; }

/* Pulse badge for live/loading states */
@keyframes badgePulse {
  0%,100% { opacity: 1; }
  50%      { opacity: .55; }
}
.badge-live { animation: badgePulse 2s ease infinite; }

/* Toast notifications */
#toast-container {
  position: fixed; bottom: 24px; right: 24px;
  z-index: 9000; display: flex; flex-direction: column; gap: 8px;
  pointer-events: none;
}
.toast {
  background: var(--bg-2); border: 1px solid var(--border-s);
  border-radius: 10px; padding: 10px 16px;
  font-size: .8125rem; color: var(--text-0);
  box-shadow: 0 8px 24px rgba(0,0,0,.4);
  display: flex; align-items: center; gap: 8px;
  pointer-events: auto;
  animation: toastIn .25s cubic-bezier(0.22,1,0.36,1) both;
}
.toast.out { animation: toastOut .3s ease forwards; }
.toast-icon { color: var(--teal); flex-shrink: 0; }
@keyframes toastIn  { from { opacity:0; transform: translateY(12px) scale(.96); } to { opacity:1; transform: translateY(0) scale(1); } }
@keyframes toastOut { to   { opacity:0; transform: translateY(8px) scale(.95); pointer-events:none; } }

/* FX skeleton placeholder (shown while rates load) */
.customs-ref-card{background:var(--bg-3);border:1px solid var(--border);border-radius:9px;padding:10px 12px;transition:border-color .18s}
.customs-ref-card:hover{border-color:var(--border-s)}
.fx-skeleton-row {
  display: flex; flex-wrap: wrap; gap: 6px; margin-top: 4px;
}
.fx-skeleton-row .skeleton-chip { width: 90px; }

/* ================================================================
   FEATURE 1 — ONBOARDING WIZARD
   ================================================================ */
.wiz-overlay{position:fixed;inset:0;z-index:9500;background:rgba(2,4,14,.92);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);display:flex;align-items:center;justify-content:center;padding:16px}
.wiz-card{background:var(--bg-2);border:1px solid var(--border-s);border-radius:18px;padding:36px 40px;width:100%;max-width:500px;box-shadow:0 32px 80px rgba(0,0,0,.6);position:relative;overflow:hidden}
.wiz-logo{display:flex;align-items:center;gap:10px;margin-bottom:24px}
.wiz-brand{font-size:1.125rem;font-weight:700;color:var(--text-0);letter-spacing:-.02em}
.wiz-brand span{color:var(--teal)}
.wiz-progress-track{height:3px;background:var(--border);border-radius:99px;margin-bottom:8px;overflow:hidden}
.wiz-progress-fill{height:100%;background:linear-gradient(90deg,var(--teal),#00e5d0);border-radius:99px;transition:width .4s cubic-bezier(.4,0,.2,1)}
.wiz-step-label{font-size:.6875rem;color:var(--text-3);letter-spacing:.12em;text-transform:uppercase;margin-bottom:28px}
.wiz-steps-wrap{position:relative;overflow:hidden;min-height:260px}
.wiz-step{position:absolute;inset:0;transition:transform .38s cubic-bezier(.4,0,.2,1),opacity .3s;opacity:1;pointer-events:auto}
.wiz-step[aria-hidden="true"]{opacity:0;pointer-events:none}
.wiz-step.slide-out-left{transform:translateX(-60px) !important;opacity:0 !important}
.wiz-step.slide-out-right{transform:translateX(60px) !important;opacity:0 !important}
.wiz-title{font-size:1.125rem;font-weight:700;letter-spacing:-.02em;color:var(--text-0);margin-bottom:8px}
.wiz-sub{font-size:.8125rem;color:var(--text-2);line-height:1.6;margin-bottom:20px}
.wiz-label{display:block;font-size:.75rem;color:var(--text-2);font-weight:500;margin-bottom:8px}
.wiz-field{margin-top:4px}
.wiz-select-wrap{position:relative;display:flex;align-items:center;background:var(--bg-3);border:1px solid var(--border-s);border-radius:10px;overflow:hidden}
.wiz-flag{padding:0 10px;font-size:1.1rem;flex-shrink:0;pointer-events:none}
.wiz-select{flex:1;background:transparent;border:none;outline:none;color:var(--text-0);font-family:inherit;font-size:.875rem;padding:12px 12px 12px 0;cursor:pointer;-webkit-appearance:none;appearance:none}
.wiz-select option{background:var(--bg-2);color:var(--text-0)}
.wiz-radio-group{display:flex;flex-direction:column;gap:10px}
.wiz-radio-opt{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--bg-3);border:1.5px solid var(--border);border-radius:10px;cursor:pointer;transition:border-color .18s,background .18s}
.wiz-radio-opt:hover{border-color:var(--border-s);background:var(--bg-4)}
.wiz-radio-opt input{position:absolute;opacity:0;width:0;height:0}
.wiz-radio-opt.checked{border-color:var(--teal);background:var(--teal-dim)}
.wiz-radio-icon{font-size:1.25rem;flex-shrink:0}
.wiz-radio-body{display:flex;flex-direction:column;gap:2px}
.wiz-radio-title{font-size:.875rem;font-weight:600;color:var(--text-0)}
.wiz-radio-sub{font-size:.75rem;color:var(--text-2)}
.wiz-budget-display{font-size:2rem;font-weight:700;color:var(--teal);letter-spacing:-.04em;text-align:center;padding:16px 0;font-variant-numeric:tabular-nums}
.wiz-slider{width:100%;-webkit-appearance:none;appearance:none;height:4px;border-radius:99px;background:linear-gradient(90deg,var(--teal) 0%,var(--teal) var(--prog,44%),var(--bg-4) var(--prog,44%),var(--bg-4) 100%);outline:none;cursor:pointer}
.wiz-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--teal);border:3px solid var(--bg-0);box-shadow:0 0 0 2px var(--teal);cursor:pointer;transition:box-shadow .15s}
.wiz-slider::-webkit-slider-thumb:hover{box-shadow:0 0 0 4px rgba(0,201,177,.25)}
.wiz-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--teal);border:3px solid var(--bg-0);cursor:pointer}
.wiz-slider-labels{display:flex;justify-content:space-between;margin-top:8px;font-size:.625rem;color:var(--text-3)}
.wiz-success{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding-top:16px}
.wiz-success-icon{font-size:3rem;margin-bottom:16px;animation:wiz-bounce .5s cubic-bezier(.4,0,.2,1)}
@keyframes wiz-bounce{0%{transform:scale(.6)}70%{transform:scale(1.15)}100%{transform:scale(1)}}
.wiz-nav{display:flex;justify-content:flex-end;gap:10px;margin-top:28px}
.wiz-skip-link{text-align:center;margin-top:14px}
.wiz-skip-link button{background:none;border:none;color:var(--text-3);font-size:.75rem;cursor:pointer;font-family:inherit;text-decoration:underline;transition:color .15s}
.wiz-skip-link button:hover{color:var(--text-2)}
.wiz-next{min-width:140px;justify-content:center}

/* ================================================================
   FEATURE 2 — GUIDED PROGRESS TRACKER
   ================================================================ */
.journey-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--rl);padding:18px 20px;margin-bottom:0}
.journey-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:10px}
.journey-title{font-size:.875rem;font-weight:600;color:var(--text-0)}
.journey-progress-text{font-size:.75rem;color:var(--text-2)}
.journey-bar-track{height:3px;background:var(--border);border-radius:99px;overflow:hidden;flex:1;min-width:80px}
.journey-bar-fill{height:100%;background:linear-gradient(90deg,var(--teal),#00e5d0);border-radius:99px;transition:width .6s cubic-bezier(.4,0,.2,1)}
.journey-toggle{background:none;border:none;color:var(--text-3);cursor:pointer;font-size:.75rem;white-space:nowrap;transition:color .15s;font-family:inherit}
.journey-toggle:hover{color:var(--text-1)}
.milestone-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-top:4px}
.milestone-item{padding:12px 14px;background:var(--bg-3);border:1.5px solid var(--border);border-radius:10px;display:flex;flex-direction:column;gap:6px;transition:border-color .18s;position:relative}
.milestone-item.ms-current{border-color:var(--teal);background:var(--teal-dim)}
.milestone-item.ms-done{border-color:rgba(34,197,94,.25);background:rgba(34,197,94,.05)}
.milestone-item.ms-locked{opacity:.5}
.ms-icon-wrap{width:30px;height:30px;border-radius:8px;background:var(--bg-4);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ms-current .ms-icon-wrap{background:rgba(0,201,177,.18)}
.ms-done .ms-icon-wrap{background:rgba(34,197,94,.18)}
.ms-title{font-size:.8125rem;font-weight:600;color:var(--text-0)}
.ms-desc{font-size:.6875rem;color:var(--text-2);line-height:1.45}
.ms-status-chip{display:inline-flex;align-items:center;gap:4px;font-size:.625rem;font-weight:600;padding:2px 7px;border-radius:99px;letter-spacing:.04em;text-transform:uppercase;width:fit-content}
.ms-status-chip.locked{background:var(--bg-4);color:var(--text-3)}
.ms-status-chip.inprog{background:var(--teal-dim);color:var(--teal)}
.ms-status-chip.done{background:var(--green-dim);color:var(--green)}
.ms-start-btn{margin-top:4px;font-size:.6875rem;font-weight:600;color:var(--teal);background:none;border:none;cursor:pointer;font-family:inherit;text-align:left;padding:0;transition:opacity .15s}
.ms-start-btn:hover{opacity:.7}

/* ================================================================
   FEATURE 3 — EXPERIENCE BADGES
   ================================================================ */
.badge-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.badge-item{position:relative;background:var(--bg-3);border:1px solid var(--border);border-radius:12px;padding:16px 10px;display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;transition:border-color .18s,box-shadow .18s;cursor:default}
.badge-item.unlocked{border-color:rgba(0,201,177,.3)}
.badge-item.unlocked:hover{border-color:var(--teal);box-shadow:0 0 16px rgba(0,201,177,.18)}
.badge-item.locked{filter:grayscale(1);opacity:.5}
.badge-icon-wrap{width:44px;height:44px;border-radius:50%;background:var(--bg-4);display:flex;align-items:center;justify-content:center}
.badge-item.unlocked .badge-icon-wrap{background:var(--teal-dim)}
.badge-name{font-size:.6875rem;font-weight:600;color:var(--text-1)}
.badge-lock-overlay{position:absolute;top:8px;right:8px;width:16px;height:16px;display:flex;align-items:center;justify-content:center;color:var(--text-3)}
.badge-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);background:var(--bg-1);border:1px solid var(--border-s);border-radius:8px;padding:8px 12px;font-size:.6875rem;color:var(--text-1);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .18s;z-index:50;max-width:200px;white-space:normal;text-align:center}
.badge-item:hover .badge-tooltip{opacity:1}
@keyframes badge-pop{0%{transform:scale(.7);opacity:0}70%{transform:scale(1.1)}100%{transform:scale(1);opacity:1}}
.badge-item.badge-just-unlocked{animation:badge-pop .45s cubic-bezier(.4,0,.2,1) both}
@keyframes badge-glow{0%,100%{box-shadow:0 0 0 rgba(0,201,177,0)}50%{box-shadow:0 0 20px rgba(0,201,177,.35)}}
.badge-item.unlocked{animation:badge-glow 3s ease infinite}

/* ================================================================
   FEATURE 4 — PROFILE SECTION
   ================================================================ */
.profile-layout{display:grid;grid-template-columns:300px 1fr;gap:18px;align-items:start}
.profile-id-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--rl);padding:24px;display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center}
.profile-avatar-lg{width:72px;height:72px;border-radius:50%;background:var(--teal-dim);border:2px solid var(--teal);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:var(--teal);letter-spacing:-.02em;flex-shrink:0}
.profile-name-display{font-size:1rem;font-weight:700;color:var(--text-0)}
.profile-sub-display{font-size:.75rem;color:var(--text-2)}
.profile-form{display:flex;flex-direction:column;gap:12px;width:100%}
.pf-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.pf-field{display:flex;flex-direction:column;gap:5px}
.pf-label{font-size:.6875rem;font-weight:500;color:var(--text-2);letter-spacing:.04em;text-transform:uppercase}
.pf-input{background:var(--bg-3);border:1px solid var(--border);border-radius:8px;padding:9px 12px;font-size:.8125rem;color:var(--text-0);font-family:inherit;outline:none;transition:border-color .15s}
.pf-input:focus{border-color:var(--teal)}
.pf-select{background:var(--bg-3);border:1px solid var(--border);border-radius:8px;padding:9px 12px;font-size:.8125rem;color:var(--text-0);font-family:inherit;outline:none;transition:border-color .15s;-webkit-appearance:none;appearance:none;cursor:pointer}
.pf-select:focus{border-color:var(--teal)}
.profile-right{display:flex;flex-direction:column;gap:18px}
.profile-section-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--rl);padding:20px 22px}
.profile-sec-title{font-size:.875rem;font-weight:600;color:var(--text-0);margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.suggestion-list{display:flex;flex-direction:column;gap:10px}
.suggestion-item{display:flex;gap:12px;padding:12px 14px;background:var(--bg-3);border:1px solid var(--border);border-left:3px solid var(--teal);border-radius:8px;transition:border-color .18s}
.suggestion-item:hover{border-color:var(--border-s)}
.suggestion-icon{flex-shrink:0;width:20px;height:20px;color:var(--teal);margin-top:1px}
.suggestion-body{flex:1;min-width:0}
.suggestion-text{font-size:.8125rem;color:var(--text-1);line-height:1.5}
.suggestion-link{font-size:.6875rem;color:var(--teal);text-decoration:none;margin-top:4px;display:inline-block;opacity:.8;transition:opacity .15s}
.suggestion-link:hover{opacity:1}
.trade-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.trade-stat-item{background:var(--bg-3);border-radius:8px;padding:12px 14px;text-align:center}
.trade-stat-val{font-size:1.25rem;font-weight:700;color:var(--teal);font-variant-numeric:tabular-nums}
.trade-stat-label{font-size:.6875rem;color:var(--text-2);margin-top:2px}

/* ================================================================
   FEATURE 5 — SMART FILTER BAR (enhanced)
   ================================================================ */
.smart-filter-bar{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--rl);padding:14px 16px;display:flex;flex-direction:column;gap:12px;margin-bottom:4px}
.sfb-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.sfb-label{font-size:.6875rem;font-weight:600;color:var(--text-3);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;min-width:90px}
.sfb-pills{display:flex;flex-wrap:wrap;gap:6px;flex:1}
.sfb-pill{padding:4px 10px;border-radius:99px;border:1.5px solid var(--border);background:transparent;color:var(--text-2);font-size:.6875rem;font-weight:500;cursor:pointer;font-family:inherit;transition:all .15s;white-space:nowrap}
.sfb-pill:hover{border-color:var(--border-s);color:var(--text-1)}
.sfb-pill.active{border-color:var(--teal);background:var(--teal-dim);color:var(--teal)}
.sfb-select{background:var(--bg-3);border:1px solid var(--border);border-radius:8px;padding:6px 10px;font-size:.75rem;color:var(--text-1);font-family:inherit;outline:none;transition:border-color .15s;cursor:pointer;-webkit-appearance:none;appearance:none}
.sfb-select:focus{border-color:var(--teal)}
.sfb-input{background:var(--bg-3);border:1px solid var(--border);border-radius:8px;padding:6px 10px;font-size:.75rem;color:var(--text-0);font-family:inherit;outline:none;transition:border-color .15s;min-width:160px}
.sfb-input:focus{border-color:var(--teal)}
.sfb-autocomplete{position:relative;flex:1;max-width:280px}
.sfb-ac-list{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg-2);border:1px solid var(--border-s);border-radius:8px;z-index:200;box-shadow:0 8px 24px rgba(0,0,0,.4);display:none;max-height:180px;overflow-y:auto}
.sfb-ac-list.open{display:block}
.sfb-ac-item{padding:8px 12px;font-size:.75rem;color:var(--text-1);cursor:pointer;transition:background .12s}
.sfb-ac-item:hover{background:var(--bg-3);color:var(--text-0)}
.sfb-range-wrap{display:flex;align-items:center;gap:10px;flex:1}
.sfb-range{flex:1;-webkit-appearance:none;appearance:none;height:3px;border-radius:99px;background:var(--bg-4);outline:none;cursor:pointer}
.sfb-range::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--teal);border:2px solid var(--bg-0);cursor:pointer}
.sfb-range-val{font-size:.75rem;color:var(--teal);font-weight:600;font-variant-numeric:tabular-nums;min-width:70px;text-align:right}
.sfb-actions{display:flex;align-items:center;gap:8px;margin-left:auto}
.sfb-clear-btn{font-size:.6875rem;color:var(--text-3);background:none;border:none;cursor:pointer;font-family:inherit;transition:color .15s;white-space:nowrap}
.sfb-clear-btn:hover{color:var(--text-1)}
.sfb-filter-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;border-radius:99px;background:var(--teal);color:#000;font-size:.625rem;font-weight:700;padding:0 5px}
.sfb-exp-toggle{display:flex;border:1px solid var(--border);border-radius:8px;overflow:hidden}
.sfb-exp-btn{padding:5px 12px;font-size:.6875rem;background:transparent;border:none;color:var(--text-2);cursor:pointer;font-family:inherit;font-weight:500;transition:all .15s;white-space:nowrap}
.sfb-exp-btn.active{background:var(--teal-dim);color:var(--teal)}
.sfb-empty{padding:48px 0;text-align:center;color:var(--text-3);font-size:.875rem}
.sfb-empty-icon{font-size:2.5rem;margin-bottom:12px}
.sfb-empty p{margin-top:6px;font-size:.75rem;color:var(--text-3)}

/* Mobile responsive overrides */
@media(max-width:767px){
  .wiz-card{padding:24px 20px}
  .milestone-list{grid-template-columns:1fr 1fr}
  .badge-grid{grid-template-columns:repeat(2,1fr)}
  .profile-layout{grid-template-columns:1fr}
  .pf-row{grid-template-columns:1fr}
  .smart-filter-bar .sfb-row{flex-direction:column;align-items:flex-start}
  .sfb-pills{gap:5px}
  .sfb-label{min-width:unset}
}

/* ================================================================
   FIX 2 — JARGON TOOLTIP SYSTEM
   ================================================================ */
.jargon-tip{position:relative;display:inline;border-bottom:1px dotted var(--text-3);cursor:help;white-space:nowrap}
.jargon-card{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translateX(-50%);width:240px;background:var(--bg-1);border:1px solid var(--border-s);border-radius:10px;padding:10px 13px;font-size:.75rem;color:var(--text-1);line-height:1.55;box-shadow:0 10px 30px rgba(0,0,0,.5);opacity:0;pointer-events:none;transition:opacity .18s;z-index:500;white-space:normal;text-align:left;font-weight:400}
.jargon-tip:hover .jargon-card,.jargon-tip:focus .jargon-card{opacity:1}
/* Prevent card clipping on edges */
.jargon-tip:first-child .jargon-card{left:0;transform:none}

/* ================================================================
   FIX 3 — BEGINNER MODE BANNER
   ================================================================ */
.beginner-banner{display:flex;align-items:center;gap:10px;padding:9px 18px;background:rgba(0,201,177,.08);border-bottom:1px solid rgba(0,201,177,.15);font-size:.75rem;color:var(--text-1);flex-shrink:0;position:relative;z-index:150}
.beginner-banner a,.beginner-banner button.bb-link{color:var(--teal);background:none;border:none;cursor:pointer;font-family:inherit;font-size:inherit;text-decoration:underline;padding:0}
.beginner-banner button.bb-link:hover{opacity:.75}
[data-interface="advanced"] .beginner-banner{display:none}
[data-interface="advanced"] .sfb-hs-row,[data-interface="advanced"] .sfb-exp-advanced{display:flex}
[data-interface="beginner"] .sfb-hs-row,[data-interface="beginner"] .sfb-exp-advanced{display:none}

/* Budget context hint */
.wiz-budget-hint,.sfb-budget-hint{font-size:.75rem;color:var(--text-2);text-align:center;margin-top:10px;line-height:1.5;font-style:italic;padding:0 8px}


/* ================================================================
   COST CALCULATOR — Interactive landed cost widget in reports
   ================================================================ */
.cost-calc{background:var(--bg-1);border:1px solid var(--border);border-radius:12px;padding:16px 18px;margin-top:12px}
.cost-calc.cost-calc-simple{padding:14px 16px}
.calc-hd{font-size:.75rem;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px;display:flex;align-items:center;gap:5px}
.calc-stale-warn{font-size:.72rem;color:var(--gold);background:rgba(255,185,50,.08);border:1px solid rgba(255,185,50,.2);border-radius:6px;padding:6px 10px;margin-bottom:10px}
.calc-controls{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.calc-ctrl-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.calc-label{font-size:.72rem;color:var(--text-2);min-width:90px;flex-shrink:0}
.calc-slider-wrap{display:flex;align-items:center;gap:8px;flex:1;min-width:0}
.calc-slider{flex:1;-webkit-appearance:none;height:4px;border-radius:2px;background:var(--border);outline:none;cursor:pointer}
.calc-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--teal);cursor:pointer;border:2px solid var(--bg-0);box-shadow:0 0 0 3px rgba(0,201,177,.2)}
.calc-slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--teal);cursor:pointer;border:2px solid var(--bg-0)}
.calc-pill{font-size:.75rem;font-weight:700;color:var(--teal);background:var(--teal-dim);padding:2px 8px;border-radius:20px;white-space:nowrap}
.calc-method-sel{font-size:.72rem;padding:3px 6px;height:auto;min-width:0;max-width:260px}
.calc-breakdown{border-top:1px solid var(--border);padding-top:10px;display:flex;flex-direction:column;gap:5px}
.calc-line{display:flex;justify-content:space-between;align-items:center;font-size:.78rem;color:var(--text-2);padding:1px 0}
.calc-line span:first-child{color:var(--text-2)}
.calc-line span:last-child,.calc-line >span:last-child{color:var(--text-1);font-variant-numeric:tabular-nums}
.calc-total-line{border-top:1px solid var(--border);margin-top:4px;padding-top:6px;font-size:.82rem}
.calc-total-line strong{color:var(--text-1)}
.calc-duty-free{color:var(--green) !important}
.calc-badge{display:inline-flex;align-items:center;font-size:.6rem;font-weight:700;background:var(--bg-0);color:var(--text-3);border:1px solid var(--border);padding:1px 5px;border-radius:10px;margin-left:4px}
.calc-margin-block{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}
.calc-margin-row{display:flex;align-items:baseline;gap:8px;margin-bottom:4px}
.calc-margin-num{font-size:1.6rem;font-weight:800;color:var(--teal);line-height:1;font-variant-numeric:tabular-nums}
.calc-margin-label{font-size:.72rem;color:var(--text-2)}
.calc-margin-note{font-size:.72rem;color:var(--text-3);margin-bottom:10px;font-style:italic}
.calc-order-total{font-size:.78rem;color:var(--text-2);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.calc-order-total strong{color:var(--text-1);font-variant-numeric:tabular-nums}
.calc-copy-btn{background:var(--bg-0);border:1px solid var(--border);border-radius:6px;color:var(--text-2);font-size:.7rem;padding:3px 8px;cursor:pointer;margin-left:auto;white-space:nowrap;transition:background .15s,color .15s}
.calc-copy-btn:hover{background:var(--teal-dim);color:var(--teal);border-color:var(--teal)}
.calc-ship-note{margin-top:8px;font-style:italic}
/* Budget hint in smart filter bar */
#sfBudgetHint{font-size:.7rem;color:var(--text-3);white-space:nowrap;align-self:center;margin-left:6px}
@media(max-width:600px){.calc-ctrl-row{flex-direction:column;align-items:flex-start}.calc-slider-wrap{width:100%}.calc-method-sel{max-width:100%}.calc-margin-num{font-size:1.3rem}}
/* Next steps panel */
.next-steps-list{padding-left:18px;margin:8px 0 0}
.next-steps-list li{margin-bottom:8px;font-size:.8125rem;color:var(--text-1);line-height:1.5}
.next-steps-list li strong{color:var(--text-0)}
.next-steps-list a{color:var(--teal);text-decoration:none}
.next-steps-list a:hover{text-decoration:underline}
/* Regulatory owner badge */
.reg-owner-link{font-size:.6rem;background:var(--bg-3);border:1px solid var(--border);border-radius:3px;padding:1px 4px;color:var(--text-2);text-decoration:none;margin-left:6px;white-space:nowrap;vertical-align:middle}
.reg-owner-link:hover{color:var(--teal);border-color:var(--teal)}
/* Sidebar group separators */
.nav-sep{font-size:.5625rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-3);padding:10px 20px 4px;margin-top:4px;white-space:nowrap;overflow:hidden;opacity:1;transition:opacity .2s}
#sidebar.collapsed .nav-sep{opacity:0;height:0;padding:0;margin:0}
/* Plain English toggle */
.pe-toggle{background:var(--bg-3);border:1px solid var(--border);border-radius:20px;color:var(--text-2);font-size:.72rem;font-weight:600;padding:4px 12px;cursor:pointer;white-space:nowrap;transition:all .15s;font-family:inherit}
.pe-toggle:hover{border-color:var(--teal);color:var(--teal)}
.pe-toggle.pe-active{background:var(--teal-dim);border-color:var(--teal);color:var(--teal)}
/* Benchmark signal row in calculator */
.calc-benchmark-row{margin:8px 0 4px;padding:6px 8px;background:var(--bg-0);border-radius:6px;border:1px solid var(--border)}
/* Timeline in report */
.timeline-list{display:flex;flex-direction:column;gap:0}
.timeline-row{display:flex;gap:0;align-items:flex-start;padding:6px 0;border-bottom:1px solid var(--border)}
.timeline-row:last-child{border-bottom:none}
.timeline-week{flex-shrink:0;width:90px;font-size:.72rem;font-weight:700;color:var(--teal);padding-top:1px}
.timeline-desc{font-size:.78rem;color:var(--text-1);line-height:1.5}
@media(max-width:480px){.pe-toggle{display:none}}

/* ── Global tooltip ────────────────────────────────────────────── */
#ztip{
  position:fixed;
  z-index:9500;
  max-width:230px;
  background:var(--bg-3);
  border:1px solid var(--border-s);
  border-radius:9px;
  padding:9px 12px;
  font-size:.72rem;
  color:var(--text-1);
  line-height:1.55;
  pointer-events:none;
  opacity:0;
  transform:translateY(5px);
  transition:opacity .14s ease,transform .14s ease;
  box-shadow:0 6px 20px rgba(0,0,0,.45);
  will-change:opacity,transform;
}
#ztip.zt-visible{
  opacity:1;
  transform:translateY(0);
}

/* ── Fix 4 — Report section progressive disclosure ─────────────── */
.report-section{border:none;border-bottom:1px solid var(--border)}
.report-section summary{display:flex;align-items:center;gap:6px;cursor:pointer;list-style:none;padding:9px 0;user-select:none}
.report-section summary::-webkit-details-marker{display:none}
.report-section summary .intel-hd{margin-bottom:0;flex:1;font-size:.6875rem}
.section-chevron{flex-shrink:0;transition:transform .2s ease;color:var(--text-3);display:inline-flex;align-items:center}
.report-section[open] .section-chevron{transform:rotate(180deg)}

/* ── Fix 5 — Learning completion graduation state ──────────────── */
.grad-state{text-align:center;padding:36px 20px;grid-column:1/-1}
.grad-state .grad-icon{font-size:2.5rem;margin-bottom:10px}
.grad-state h3{font-size:1rem;font-weight:700;margin-bottom:6px}
.grad-state p{font-size:.8125rem;color:var(--text-2);max-width:320px;margin:0 auto}

/* ── Fix 6 — Chat typing dots ──────────────────────────────────── */
.typing-bubble{display:inline-flex;align-items:center;gap:5px;padding:10px 14px;background:var(--bg-3);border-radius:12px 12px 12px 3px}
.typing-dot{width:6px;height:6px;border-radius:50%;background:var(--text-3);animation:typingPulse 1.2s ease-in-out infinite}
.typing-dot:nth-child(2){animation-delay:.2s}
.typing-dot:nth-child(3){animation-delay:.4s}
@keyframes typingPulse{0%,80%,100%{opacity:.25;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}

/* ── Fix 7 — Why-btn chevron rotation ──────────────────────────── */
.why-chevron{transition:transform .2s ease;display:inline-flex;align-items:center}
.why-btn.wh-open .why-chevron{transform:rotate(180deg)}

/* ── Fix 8 — Market grid skeleton + fade ───────────────────────── */
#oppGrid{transition:opacity .15s ease}
#oppGrid.g-fading{opacity:0;pointer-events:none}
.opp-card-sk{background:var(--bg-2);border-radius:var(--r);padding:18px;border:1px solid var(--border);animation:skPulse 1.4s ease-in-out infinite}
.sk-ln{height:11px;background:var(--bg-3);border-radius:5px;margin-bottom:9px}
.sk-ln.w80{width:80%}.sk-ln.w60{width:60%}.sk-ln.w40{width:40%}.sk-ln.w90{width:90%}
@keyframes skPulse{0%,100%{opacity:.45}50%{opacity:.9}}

/* ── Fix 9 — Paragraph margin reset for page-sub ───────────────── */
p.page-sub{margin:0}

/* ── Fix 2 — Toast undo button ──────────────────────────────────── */
.toast-undo-btn{background:none;border:none;color:var(--teal);cursor:pointer;font-size:.75rem;font-weight:700;padding:0 0 0 10px;font-family:inherit;white-space:nowrap}
.toast-undo-btn:hover{text-decoration:underline}

/* ── Fix 3 — Sticky action bar in corridor report ──────────────── */
.intel-action-bar{display:flex;gap:8px;padding:10px 0 6px;border-bottom:1px solid var(--border);margin-bottom:4px}

/* ── opp-card journey button row ────────────────────────────────── */
.opp-card-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:0}
.opp-journey-btn{font-size:.72rem;padding:5px 10px;gap:4px}

/* ── Brain-Off Mode — Journey UI ────────────────────────────────── */

/* Empty state */
.journey-empty{text-align:center;padding:60px 20px;max-width:380px;margin:0 auto}
.journey-empty-icon{font-size:3rem;margin-bottom:14px}
.journey-empty h3{font-size:1.05rem;font-weight:700;margin-bottom:8px}
.journey-empty p{font-size:.85rem;color:var(--text-2);line-height:1.6;margin:0}

/* Fraud alert banner */
.fraud-alert-banner{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;background:rgba(220,53,69,.08);border:1px solid rgba(220,53,69,.35);border-radius:var(--r);padding:12px 14px;margin-bottom:10px}
.fraud-alert-left{display:flex;align-items:flex-start;gap:10px;flex:1;min-width:0}
.fraud-alert-icon{color:var(--red);flex-shrink:0;margin-top:2px}
.fraud-alert-title{font-size:.82rem;font-weight:700;color:var(--red);margin-bottom:4px}
.fraud-alert-detail{font-size:.78rem;color:var(--text-1);line-height:1.5;margin-bottom:4px}
.fraud-alert-action{font-size:.75rem;color:var(--text-2)}
.fraud-dismiss-btn{background:none;border:none;color:var(--text-3);cursor:pointer;flex-shrink:0;padding:2px;line-height:1}
.fraud-dismiss-btn:hover{color:var(--red)}
.fraud-sev-badge.sev-critical{background:rgba(220,53,69,.15);color:var(--red)}
.fraud-sev-badge.sev-high{background:rgba(245,166,35,.15);color:var(--gold)}
.fraud-sev-badge.sev-medium{background:rgba(0,149,255,.1);color:#0095ff}

/* Next Action card */
.next-action-card{background:var(--bg-2);border:1.5px solid var(--teal);border-radius:var(--r);padding:16px 18px;margin-bottom:14px;display:flex;flex-direction:column;gap:10px}
.next-action-complete{border-color:var(--green);background:rgba(0,201,177,.06);flex-direction:row;align-items:center;flex-wrap:wrap}
.nac-complete-icon{font-size:1.8rem;flex-shrink:0}
.nac-header{display:flex;align-items:center;justify-content:space-between;gap:8px}
.nac-tag{font-size:.68rem;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.08em;display:inline-flex;align-items:center;gap:4px}
.nac-stage{font-size:.7rem;color:var(--text-3)}
.nac-body{flex:1}
.nac-label{font-size:.95rem;font-weight:700;color:var(--text-0);line-height:1.35;margin-bottom:3px}
.nac-sub{font-size:.75rem;color:var(--text-3)}
.nac-progress-wrap{display:flex;align-items:center;gap:10px}
.nac-progress-bar{flex:1;height:6px;background:var(--bg-3);border-radius:3px;overflow:hidden}
.nac-progress-fill{height:100%;background:var(--teal);border-radius:3px;transition:width .4s ease}
.nac-pct{font-size:.72rem;font-weight:700;color:var(--teal);white-space:nowrap}
.nac-btn{align-self:flex-start;gap:5px;display:inline-flex;align-items:center}

/* Region context panel */
.journey-region-panel{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r);margin-bottom:14px;overflow:hidden}
.jrp-summary{display:flex;align-items:center;gap:6px;cursor:pointer;list-style:none;padding:11px 14px;font-size:.82rem;font-weight:600;color:var(--text-1);user-select:none}
.jrp-summary::-webkit-details-marker{display:none}
.jrp-summary .section-chevron{margin-left:auto}
.journey-region-panel[open] .section-chevron{transform:rotate(180deg)}
.jrp-body{padding:2px 14px 12px;display:flex;flex-direction:column;gap:6px}
.jrp-item{display:flex;flex-direction:column;gap:2px;padding:6px 0;border-bottom:1px solid var(--border)}
.jrp-item:last-child{border-bottom:none}
.jrp-label{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3)}
.jrp-val{font-size:.8rem;color:var(--text-1);line-height:1.5}
.jrp-fraud .jrp-val{color:var(--gold)}

/* Stage list header */
.journey-stages-hd{display:flex;align-items:center;justify-content:space-between;padding:6px 0 8px;font-size:.72rem;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em}

/* Stage rows */
.journey-stages{display:flex;flex-direction:column;gap:0}
.journey-stage{border:1px solid var(--border);border-radius:var(--r);margin-bottom:8px;overflow:hidden;background:var(--bg-2)}
.journey-stage.jstage-active{border-color:var(--teal);background:var(--bg-1)}
.journey-stage.jstage-done{opacity:.75}
.journey-stage.jstage-locked{opacity:.5}
.jstage-header{display:flex;align-items:center;gap:10px;padding:12px 14px}
.jstage-dot{width:26px;height:26px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:var(--text-3);flex-shrink:0}
.jstage-dot.jsd-active{border-color:var(--teal);color:var(--teal)}
.jstage-dot.jsd-done{background:var(--green);border-color:var(--green);color:#fff}
.jstage-dot.jsd-locked{border-color:var(--border);color:var(--text-3);opacity:.5}
.jstage-meta{flex:1;min-width:0}
.jstage-title{font-size:.85rem;font-weight:700;color:var(--text-0)}
.jstage-sub{font-size:.72rem;color:var(--text-3);margin-top:1px}
.jstage-desc{font-size:.8rem;color:var(--text-2);padding:0 14px 10px;line-height:1.55;border-bottom:1px solid var(--border)}

/* Task rows */
.jstage-tasks{padding:6px 14px 4px;display:flex;flex-direction:column;gap:2px}
.jtask{display:flex;align-items:flex-start;gap:8px;padding:8px 0;border-bottom:1px solid var(--border)}
.jtask:last-child{border-bottom:none}
.jtask.jtask-done .jtask-label{color:var(--text-3);text-decoration:line-through}
.jtask.jtask-skipped .jtask-label{color:var(--text-3);font-style:italic}
.jtask-check{color:var(--text-3);flex-shrink:0;cursor:pointer;margin-top:1px;line-height:1}
.jtask-check.jtask-checked{color:var(--green)}
.jtask-check.jtask-skipped-ico{color:var(--text-3)}
.jtask-content{flex:1;min-width:0}
.jtask-label{font-size:.82rem;color:var(--text-1);line-height:1.4}
.jtask-btns{display:flex;align-items:center;gap:4px;flex-shrink:0}
.jtask-check-btn{background:var(--bg-3);border:1px solid var(--border);border-radius:6px;color:var(--teal);font-size:.7rem;font-weight:700;padding:3px 8px;cursor:pointer;display:inline-flex;align-items:center;gap:3px;white-space:nowrap;font-family:inherit}
.jtask-check-btn:hover{background:var(--teal-dim);border-color:var(--teal)}
.jtask-action-btn{background:var(--teal-dim);border:1px solid var(--teal);border-radius:6px;color:var(--teal);font-size:.7rem;font-weight:700;padding:3px 8px;cursor:pointer;display:inline-flex;align-items:center;gap:3px;white-space:nowrap;font-family:inherit}
.jtask-action-btn:hover{background:var(--teal);color:var(--bg-0)}
.jtask-skip-btn{background:none;border:none;color:var(--text-3);cursor:pointer;padding:3px;line-height:1}
.jtask-skip-btn:hover{color:var(--text-2)}

/* Journey guide modal content */
.jguide-what{font-size:.83rem;color:var(--text-2);line-height:1.6;margin-bottom:14px;padding:10px 12px;background:var(--bg-3);border-radius:8px}
.jguide-section-hd{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);margin:12px 0 5px}
.jguide-text{font-size:.82rem;color:var(--text-1);line-height:1.55;margin-bottom:6px}
.jguide-list{padding-left:16px;margin:0 0 6px;font-size:.82rem;color:var(--text-1);line-height:1.9}
.jguide-warn li{color:var(--red)}
.jguide-cost{background:var(--bg-3);border-radius:8px;padding:10px 12px;font-size:.78rem;color:var(--text-2);display:flex;align-items:flex-start;gap:6px;margin-top:6px}

/* Auto-complete message */
.jstage-autocomplete-msg{display:flex;align-items:center;gap:6px;padding:10px 14px;font-size:.78rem;color:var(--teal);font-weight:600;border-top:1px solid var(--border)}

/* Journey resume bar — injected at top of every section */
.journey-resume-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;background:rgba(0,201,177,.07);border:1px solid rgba(0,201,177,.22);border-radius:var(--r);padding:10px 14px;margin-bottom:14px;flex-wrap:wrap}
.jrb-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0}
.jrb-progress{width:40px;height:40px;border-radius:50%;background:var(--bg-3);border:2px solid rgba(0,201,177,.3);flex-shrink:0;overflow:hidden;position:relative}
.jrb-fill{position:absolute;bottom:0;left:0;width:100%;background:var(--teal);transition:height .3s ease}
.jrb-text{flex:1;min-width:0}
.jrb-stage{font-size:.68rem;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:3px;margin-bottom:2px}
.jrb-task{font-size:.8rem;color:var(--text-1);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.jrb-btn{flex-shrink:0;gap:4px;display:inline-flex;align-items:center}

/* Dashboard journey panels */
.dash-journey-cta{display:flex;align-items:center;gap:12px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r);padding:14px 16px;margin-bottom:14px;flex-wrap:wrap}
.djc-body{flex:1}
.djc-title{font-size:.85rem;font-weight:700;color:var(--text-0);margin-bottom:2px}
.djc-sub{font-size:.75rem;color:var(--text-3)}
.dash-journey-panel{background:rgba(0,201,177,.06);border:1.5px solid rgba(0,201,177,.25);border-radius:var(--r);padding:14px 16px;margin-bottom:14px}
.dash-journey-complete{background:rgba(0,201,177,.04);border-color:var(--green)}
.djp-header{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.djp-tag{font-size:.68rem;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.07em;display:inline-flex;align-items:center;gap:4px}
.djp-progress-wrap{display:flex;align-items:center;gap:6px;margin-left:auto}
.djp-progress-bar{width:80px;height:5px;background:var(--bg-3);border-radius:3px;overflow:hidden}
.djp-progress-fill{height:100%;background:var(--teal);border-radius:3px;transition:width .4s}
.djp-pct{font-size:.68rem;font-weight:700;color:var(--teal)}
.djp-meta{font-size:.75rem;color:var(--text-3);margin-bottom:8px}
.djp-next{font-size:.8rem;color:var(--text-1);margin-bottom:10px;display:flex;gap:5px;align-items:baseline}
.djp-next-label{font-size:.68rem;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}
.djp-next-task{line-height:1.4}
.djp-btn{gap:4px;display:inline-flex;align-items:center}
.djp-left{display:flex;align-items:center;gap:10px}
.djp-emoji{font-size:1.5rem}
.djp-title{font-size:.9rem;font-weight:700;color:var(--text-0)}
.djp-sub{font-size:.75rem;color:var(--text-3)}

/* Template textarea (supplier email, PO) */
.jguide-template-area{width:100%;height:260px;font-size:.75rem;font-family:monospace;background:var(--bg-0);border:1px solid var(--border);border-radius:8px;color:var(--text-1);padding:12px;resize:vertical;line-height:1.7;box-sizing:border-box}
.jguide-template-area:focus{outline:none;border-color:var(--teal)}

@media(max-width:600px){.next-action-card{padding:13px 14px}.nac-label{font-size:.88rem}.jstage-header{padding:10px 12px}.jstage-tasks{padding:4px 12px 2px}.journey-resume-bar{flex-direction:column;align-items:flex-start}.jrb-progress{width:32px;height:32px}}

/* ── HS Code lookup UI ──────────────────────────────────────── */
.hs-match-card{background:var(--bg-3);border:1px solid var(--border);border-radius:9px;padding:12px 14px;animation:fadeUp .2s ease}
.hs-match-found{border-color:rgba(0,201,177,.35)}
.hs-match-selected{border-color:rgba(0,201,177,.55)}
.hs-match-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}
.hs-match-label{font-size:.6875rem;font-weight:700;color:var(--teal);display:flex;align-items:center;gap:4px}
.hs-match-code-badge{font-size:.6875rem;font-weight:700;color:var(--text-2);background:var(--bg-4);border:1px solid var(--border);border-radius:5px;padding:2px 7px}
.hs-match-desc{font-size:.8125rem;color:var(--text-0);margin-bottom:4px}
.hs-match-duty{font-size:.75rem;color:var(--text-2);margin-bottom:10px}
.hs-match-actions{display:flex;gap:8px;flex-wrap:wrap}
.hs-match-code{font-size:.6875rem;font-weight:700;color:var(--teal);display:flex;align-items:center;gap:4px;margin-bottom:4px}
.hs-suggestions-list{display:flex;flex-direction:column;gap:5px}
.hs-suggestion-btn{display:flex;align-items:center;gap:10px;padding:9px 12px;background:var(--bg-3);border:1px solid var(--border);border-radius:8px;cursor:pointer;text-align:left;font-family:inherit;transition:border-color .15s;width:100%}
.hs-suggestion-btn:hover{border-color:var(--teal);background:var(--bg-4)}
.hs-sug-name{flex:1;font-size:.8125rem;color:var(--text-0);font-weight:500}
.hs-sug-code{font-size:.6875rem;color:var(--text-3);font-family:monospace}
.hs-sug-duty{font-size:.75rem;font-weight:700;min-width:40px;text-align:right}
.hs-not-found{background:var(--bg-3);border:1px solid var(--border);border-radius:9px;padding:12px 14px}
.hs-guide-steps{margin:0;padding-left:18px;font-size:.75rem;color:var(--text-1);line-height:1.9}

/* ── Calculator primary nav item ──────────────────────────────── */
.nav-item-primary{background:rgba(0,201,177,.1);color:var(--teal);border:1px solid rgba(0,201,177,.22);font-weight:700;margin-bottom:4px;margin-top:4px}
.nav-item-primary:hover{background:rgba(0,201,177,.18);color:var(--teal)}
.nav-item-primary.active{background:rgba(0,201,177,.2);color:var(--teal);border-color:rgba(0,201,177,.4)}
#sidebar.collapsed .nav-item-primary .nav-label{display:none}

/* ── Post-calculation CTA card ────────────────────────────────── */
.calc-cta-card{display:flex;gap:16px;align-items:flex-start;background:linear-gradient(135deg,rgba(0,201,177,.07) 0%,rgba(245,166,35,.05) 100%);border:1.5px solid rgba(0,201,177,.3);border-radius:var(--r);padding:20px 22px;animation:fadeUp .35s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.cta-lock-icon{font-size:1.8rem;flex-shrink:0;padding-top:2px}
.cta-body{flex:1}
.cta-headline{font-size:1.05rem;font-weight:800;color:var(--text-0);margin-bottom:4px}
.cta-sub{font-size:.8125rem;color:var(--text-2);margin-bottom:10px}
.cta-risks{list-style:none;padding:0;margin:0 0 12px;display:flex;flex-direction:column;gap:5px}
.cta-risks li{font-size:.8125rem;color:var(--text-1);display:flex;gap:7px;align-items:baseline}
.cta-check{color:var(--teal);font-weight:700;flex-shrink:0}
.cta-pitch{font-size:.8125rem;color:var(--text-2);margin:0 0 14px;line-height:1.55}
.cta-actions{display:flex;flex-direction:column;gap:7px}
.cta-btn{font-size:.875rem;padding:10px 20px;font-weight:700;letter-spacing:.01em}
.cta-trial{font-size:.72rem;color:var(--text-3)}
/* CTA journey step preview */
.cta-journey-steps{display:flex;flex-direction:column;gap:4px;margin:10px 0 14px;background:rgba(0,201,177,.05);border:1px solid rgba(0,201,177,.15);border-radius:8px;padding:10px 12px}
.cta-step{font-size:.8rem;color:var(--text-2);display:flex;align-items:center;gap:6px;padding:2px 0}
.cta-step-done{color:var(--teal);font-weight:600}
@media(max-width:600px){.calc-cta-card{flex-direction:column;gap:10px;padding:16px}.cta-lock-icon{font-size:1.4rem}}

/* ── Product search card ───────────────────────────────────────── */
.lpc-search-card{padding:22px 24px}
.lpc-search-hero{display:flex;flex-direction:column;gap:8px}
.lpc-search-label{display:flex;align-items:center;gap:8px;font-size:.9375rem;font-weight:700;color:var(--text-0)}
.lpc-search-hint{font-size:.8125rem;color:var(--text-2);line-height:1.5;margin-bottom:4px}
.lpc-search-input{width:100%;background:var(--bg-3);border:1.5px solid var(--border);border-radius:10px;padding:13px 16px;font-size:1rem;color:var(--text-0);font-family:inherit;outline:none;transition:border-color .15s}
.lpc-search-input:focus{border-color:var(--teal)}
.lpc-search-input::placeholder{color:var(--text-3)}

/* ── Autocomplete dropdown ─────────────────────────────────────── */
.lc-ac-wrap{position:relative}
.lc-ac-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg-3);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 28px rgba(0,0,0,.35);z-index:200;overflow:hidden}
.lc-ac-item{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;cursor:pointer;gap:12px;transition:background .1s}
.lc-ac-item:hover{background:var(--bg-4)}
.lc-ac-item+.lc-ac-item{border-top:1px solid var(--border-s)}
.lc-ac-name{font-size:.875rem;font-weight:600;color:var(--text-0)}
.lc-ac-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.lc-ac-code{font-size:.6875rem;color:var(--text-3);font-family:monospace;letter-spacing:.03em}
.lc-ac-free{font-size:.75rem;font-weight:700;color:var(--green)}
.lc-ac-rate{font-size:.75rem;font-weight:700;color:var(--gold)}
.lc-product-confirm{display:none;align-items:center;gap:5px;font-size:.6875rem;color:var(--green);margin-top:6px;font-weight:600}

/* ── Known product result card ─────────────────────────────────── */
.lpc-result-card{border:1px solid var(--border);border-radius:12px;overflow:hidden;animation:fadeUp .25s ease}
.lpc-result-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:16px 18px;background:var(--bg-3);border-bottom:1px solid var(--border)}
.lpc-result-name{font-size:1.05rem;font-weight:800;color:var(--text-0);margin-bottom:3px}
.lpc-result-desc{font-size:.75rem;color:var(--text-2)}
.lpc-result-badges{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex-shrink:0}
.lpc-hs-badge{font-size:.75rem;font-weight:700;font-family:monospace;background:var(--bg-4);border:1px solid var(--border);border-radius:6px;padding:3px 8px;color:var(--text-1)}
.lpc-duty-free{font-size:.875rem;font-weight:800;color:var(--green)}
.lpc-duty-rate{font-size:.875rem;font-weight:800;color:var(--gold)}
.lpc-result-body{display:grid;grid-template-columns:1fr 1fr;gap:0;padding:0}
.lpc-result-col{padding:16px 18px}
.lpc-result-col+.lpc-result-col{border-left:1px solid var(--border)}
.lpc-col-title{display:flex;align-items:center;gap:6px;font-size:.75rem;font-weight:700;color:var(--text-1);margin-bottom:10px;text-transform:uppercase;letter-spacing:.04em}
.lpc-checklist{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:7px}
.lpc-checklist li{font-size:.8125rem;color:var(--text-1);display:flex;gap:8px;align-items:baseline;line-height:1.4}
.lpc-checklist li::before{content:"✓";color:var(--teal);font-weight:700;flex-shrink:0;font-size:.75rem}
.lpc-result-cta{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;background:rgba(0,201,177,.05);border-top:1px solid rgba(0,201,177,.2)}
.lpc-cta-note{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--green);font-weight:600}

/* ── Unknown product guide card ────────────────────────────────── */
.lpc-guide-card{border:1px solid var(--border);border-radius:12px;padding:20px;animation:fadeUp .25s ease}
.lpg-header{margin-bottom:18px}
.lpg-title{font-size:.9375rem;font-weight:700;color:var(--text-0);margin-bottom:4px}
.lpg-sub{font-size:.8125rem;color:var(--text-2)}
.lpg-steps{display:flex;flex-direction:column;gap:14px;margin-bottom:18px}
.lpg-step{display:flex;gap:14px;align-items:flex-start}
.lpg-num{width:26px;height:26px;border-radius:50%;background:rgba(0,201,177,.15);border:1.5px solid rgba(0,201,177,.4);color:var(--teal);font-size:.75rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.lpg-step-body{}
.lpg-step-title{font-size:.875rem;font-weight:700;color:var(--text-0);margin-bottom:3px}
.lpg-step-text{font-size:.8125rem;color:var(--text-2);line-height:1.55}
.lpg-step-text a{color:var(--teal);text-decoration:underline}

/* ── Use-case selector ─────────────────────────────────────────── */
.lpc-usecase-card{border:1px solid var(--border);border-radius:12px;padding:20px;animation:fadeUp .2s ease}
.lpc-usecase-q{font-size:1rem;font-weight:800;color:var(--text-0);margin-bottom:6px}
.lpc-usecase-sub{font-size:.8125rem;color:var(--text-2);margin-bottom:16px;line-height:1.5}
.lpc-usecase-options{display:flex;flex-direction:column;gap:8px}
.lpc-usecase-btn{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;background:var(--bg-3);border:1.5px solid var(--border);border-radius:10px;cursor:pointer;font-size:.9rem;font-weight:600;color:var(--text-0);text-align:left;transition:border-color .15s,background .15s;font-family:inherit}
.lpc-usecase-btn:hover{border-color:var(--teal);background:rgba(0,201,177,.06);color:var(--teal)}
.lpc-usecase-arrow{color:var(--text-3);flex-shrink:0}
.lpc-usecase-btn:hover .lpc-usecase-arrow{color:var(--teal)}

/* ── Product flags (long goods, anti-dumping etc) ──────────────── */
.lpc-flags{display:flex;flex-direction:column;gap:6px;padding:12px 18px;border-top:1px solid var(--border)}
.lpc-flag{display:flex;align-items:flex-start;gap:8px;font-size:.8125rem;line-height:1.5;padding:8px 12px;border-radius:8px}
.lpc-flag-info{background:rgba(99,102,241,.07);color:var(--text-1);border:1px solid rgba(99,102,241,.18)}
.lpc-flag-warn{background:rgba(245,158,11,.07);color:var(--text-1);border:1px solid rgba(245,158,11,.22)}
.lpc-flag strong{color:var(--text-0)}
.lpc-flag a{color:var(--teal);text-decoration:underline}
.lpc-source-link{color:var(--teal);text-decoration:none;margin-left:4px;font-size:.6875rem}
.lpc-source-link:hover{text-decoration:underline}

/* ── Regulatory alert block ────────────────────────────────────── */
.lpc-reg-block{margin:0;padding:16px 18px;border-top:1px solid var(--border)}
.lpc-reg-warning{background:rgba(245,158,11,.06);border-left:3px solid #f59e0b}
.lpc-reg-danger {background:rgba(239,68,68,.06); border-left:3px solid #ef4444}
.lpc-reg-caution{background:rgba(99,102,241,.06);border-left:3px solid #6366f1}
.lpc-reg-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.lpc-reg-icon{display:flex;align-items:center}
.lpc-reg-warning .lpc-reg-icon{color:#f59e0b}
.lpc-reg-danger  .lpc-reg-icon{color:#ef4444}
.lpc-reg-caution .lpc-reg-icon{color:#6366f1}
.lpc-reg-title{font-size:.8125rem;font-weight:700;color:var(--text-0)}
.lpc-reg-alert{font-size:.8125rem;color:var(--text-2);line-height:1.5;margin-bottom:14px;font-style:italic}
.lpc-reg-steps{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.lpc-reg-step{display:flex;gap:12px;align-items:flex-start}
.lpc-reg-step-num{width:22px;height:22px;border-radius:50%;background:rgba(255,255,255,.08);border:1px solid var(--border);font-size:.6875rem;font-weight:800;color:var(--text-1);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.lpc-reg-warning .lpc-reg-step-num{border-color:rgba(245,158,11,.4);color:#f59e0b}
.lpc-reg-danger  .lpc-reg-step-num{border-color:rgba(239,68,68,.4); color:#ef4444}
.lpc-reg-caution .lpc-reg-step-num{border-color:rgba(99,102,241,.4);color:#6366f1}
.lpc-reg-step-label{font-size:.8125rem;font-weight:700;color:var(--text-0);margin-bottom:2px}
.lpc-reg-step-detail{font-size:.75rem;color:var(--text-2);line-height:1.5}
.lpc-reg-link{display:inline-flex;align-items:center;gap:5px;font-size:.75rem;color:var(--teal);text-decoration:none;font-weight:600}
.lpc-reg-link:hover{text-decoration:underline}

@media(max-width:680px){.lpc-result-body{grid-template-columns:1fr}.lpc-result-col+.lpc-result-col{border-left:none;border-top:1px solid var(--border)}.lpc-result-cta{flex-direction:column;align-items:flex-start}}

/* ── Dashboard Redesign ────────────────────────────────────────── */
.db-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px}
.db-row{display:grid;gap:16px;margin-bottom:16px}
.db-row-split{grid-template-columns:1.4fr 1fr}
.db-row-3{grid-template-columns:repeat(3,1fr)}
.db-card{background:var(--bg-2);border:1px solid var(--border);border-radius:14px;padding:18px}
.db-card-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.db-card-title{font-size:.875rem;font-weight:700;color:var(--text-0)}
/* KPI 2×2 grid inside the summary card */
.db-kpi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
.db-kpi-tile{border-radius:10px;padding:14px;transition:transform .15s;cursor:default}
.db-kpi-tile:hover{transform:translateY(-2px)}
.db-kpi-orange{background:rgba(249,115,22,.1);border:1px solid rgba(249,115,22,.2)}
.db-kpi-green{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.2)}
.db-kpi-teal{background:rgba(0,201,177,.1);border:1px solid rgba(0,201,177,.22)}
.db-kpi-purple{background:rgba(139,92,246,.1);border:1px solid rgba(139,92,246,.2)}
.db-kpi-icon-wrap{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:10px}
.db-icon-orange{background:rgba(249,115,22,.25);color:#f97316}
.db-icon-green{background:rgba(16,185,129,.25);color:#10b981}
.db-icon-teal{background:rgba(0,201,177,.25);color:#00c9b1}
.db-icon-purple{background:rgba(139,92,246,.25);color:#8b5cf6}
.db-kpi-big{font-size:1.45rem;font-weight:800;color:var(--text-0);line-height:1.1;margin-bottom:4px}
.db-kpi-lbl{font-size:.6875rem;color:var(--text-2);font-weight:600;margin-bottom:2px}
.db-kpi-sub{font-size:.625rem;color:var(--text-3)}
/* Legend dots */
.db-legend-dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}
/* Alert rows */
.db-alert-row{display:flex;align-items:center;gap:8px;padding:7px 0;border-bottom:1px solid var(--border-s);cursor:pointer}
.db-alert-row:last-child{border-bottom:none}
/* Category progress bars */
.db-progress-row{margin-bottom:11px}
.db-progress-label{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-2);margin-bottom:5px;font-weight:500}
.db-progress-track{height:6px;background:var(--bg-4);border-radius:3px;overflow:hidden}
.db-progress-fill{height:100%;border-radius:3px;transition:width .7s cubic-bezier(.22,1,.36,1)}
/* Empty state */
.db-empty{text-align:center;padding:20px 0;color:var(--text-3);font-size:.8125rem}
.db-empty p{margin-top:6px}
/* Responsive breakpoints */
@media(max-width:1000px){.db-row-split{grid-template-columns:1fr}}
@media(max-width:780px){.db-row-3{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.db-row-3,.db-kpi-grid{grid-template-columns:1fr}}

/* ── Sourcing section ───────────────────────────────────────────── */
.lpc-sourcing-block{margin:14px 0;border-top:1px solid var(--border-s);padding-top:14px}
.lpc-sourcing-hd{font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-2);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.lpc-sourcing-row{display:flex;gap:12px;align-items:flex-start;padding:11px 13px;background:var(--bg-2);border-radius:8px;margin-bottom:7px;border:1px solid var(--border)}
.lpc-sourcing-row:last-child{margin-bottom:0}
.lpc-sourcing-flag{font-size:22px;line-height:1;flex-shrink:0;margin-top:1px}
.lpc-sourcing-body{flex:1;min-width:0}
.lpc-sourcing-top{display:flex;align-items:baseline;gap:6px;flex-wrap:wrap;margin-bottom:3px}
.lpc-sourcing-country{font-size:13px;font-weight:700;color:var(--text-0)}
.lpc-sourcing-cat{font-size:11px;color:var(--text-2)}
.lpc-sourcing-fit{font-size:12px;color:var(--text-1);margin-bottom:3px}
.lpc-sourcing-note{font-size:11.5px;color:var(--text-2);font-style:italic;line-height:1.4}
.lpc-sourcing-alts{margin-top:6px;font-size:11px;color:var(--text-3)}
.lpc-sourcing-alt{color:var(--teal);text-decoration:none;margin-right:6px}
.lpc-sourcing-alt:hover{text-decoration:underline}
.lpc-sourcing-meta{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex-shrink:0;min-width:90px}
.lpc-sourcing-platform{font-size:12px;font-weight:700;color:var(--teal);text-decoration:none;white-space:nowrap;display:flex;align-items:center;gap:3px}
.lpc-sourcing-platform:hover{text-decoration:underline}
.lpc-sourcing-platform-txt{font-size:12px;font-weight:700;color:var(--text-2)}
.lpc-risk-badge{font-size:9.5px;font-weight:700;padding:2px 8px;border-radius:20px;white-space:nowrap}
.src-risk-low{background:var(--green-dim);color:var(--green)}
.src-risk-med{background:var(--gold-dim);color:var(--gold)}
.src-risk-high{background:rgba(249,115,22,.15);color:#fb923c}
.src-risk-vhigh{background:var(--red-dim);color:var(--red)}
.lpc-sourcing-cert{font-size:9.5px;color:var(--text-3);white-space:nowrap}
@media(max-width:520px){.lpc-sourcing-meta{min-width:70px}.lpc-sourcing-row{flex-wrap:wrap}.lpc-sourcing-meta{flex-direction:row;align-items:center;flex-shrink:unset;width:100%;justify-content:flex-start;gap:8px}}

/* ── URL analysis input ─────────────────────────────────────────── */
.lpc-url-divider{display:flex;align-items:center;gap:10px;margin:14px 0 10px;color:var(--text-3);font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.lpc-url-divider::before,.lpc-url-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.lpc-url-row{display:flex;gap:8px;align-items:center}
.lpc-url-input{flex:1;background:var(--bg-2);border:1px solid var(--border);border-radius:8px;padding:9px 12px;font-size:12.5px;color:var(--text-1);outline:none;transition:border .2s}
.lpc-url-input::placeholder{color:var(--text-3)}
.lpc-url-input:focus{border-color:var(--teal)}
.lpc-url-btn{display:flex;align-items:center;gap:5px;padding:9px 16px;background:var(--teal-dim);color:var(--teal);border:1px solid rgba(0,201,177,.3);border-radius:8px;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .2s}
.lpc-url-btn:hover{background:var(--teal-dim-strong)}
.lpc-url-btn:disabled{opacity:.5;cursor:not-allowed}
/* AI result card extras */
.lpc-ai-badge{display:inline-flex;align-items:center;gap:5px;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--purple);background:var(--purple-dim);padding:3px 10px;border-radius:20px;margin-bottom:12px}
.lpc-origin-badge{background:var(--blue-dim);color:var(--blue);font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px}
.lpc-price-badge{background:var(--green-dim);color:var(--green);font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px}
.lpc-ai-flags{margin:14px 0;padding:12px 14px;background:var(--red-dim-soft);border:1px solid rgba(239,68,68,.2);border-radius:8px}
.lpc-ai-flags-hd{font-size:11.5px;font-weight:700;color:var(--red);margin-bottom:8px;display:flex;align-items:center;gap:6px}
.lpc-ai-flag{font-size:12px;color:var(--text-1);padding:5px 0;border-bottom:1px solid rgba(239,68,68,.1);line-height:1.5}
.lpc-ai-flag:last-child{border-bottom:none;padding-bottom:0}
.lpc-analyzing{display:flex;align-items:center;gap:10px;padding:18px;background:var(--bg-2);border-radius:10px;font-size:13px;color:var(--text-2);border:1px solid var(--border)}
.lpc-ai-error{display:flex;align-items:center;gap:8px;padding:14px;background:var(--red-dim-soft);border:1px solid rgba(239,68,68,.2);border-radius:8px;font-size:13px;color:var(--red)}

/* ── Shipping options section */
.lpc-shipping-block{margin:14px 0;border-top:1px solid var(--border-s);padding-top:14px}
.lpc-shipping-hd{font-size:12px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}
.lpc-ship-row{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:8px;background:var(--bg-2);margin-bottom:6px}
.lpc-ship-icon{font-size:16px;width:22px;text-align:center;flex-shrink:0}
.lpc-ship-body{flex:1;min-width:0}
.lpc-ship-name{font-size:13px;font-weight:600;color:var(--text-1);display:block}
.lpc-ship-time{font-size:11px;color:var(--text-3)}
.lpc-ship-right{text-align:right;flex-shrink:0}
.lpc-ship-range{font-size:13px;font-weight:700;color:var(--accent);display:block}
.lpc-ship-unit{font-size:10px;color:var(--text-3)}
.lpc-ship-tag{font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;background:var(--bg-3);color:var(--text-2);flex-shrink:0;white-space:nowrap}
.lpc-shipping-note{font-size:11px;color:var(--text-3);margin-top:8px}
.lpc-shipping-note a{color:var(--accent);text-decoration:none}
