:root{
  --bg:#ffffff; --soft:#f7f8fc; --soft2:#f1f2f9;
  --ink:#0e1020; --ink2:#3a3f56; --mut:#71778f; --line:#ebecf3;
  --primary:#6c47ff; --primary-d:#5836e6; --primary-soft:#f1ecff;
  --green:#12b66a; --gold:#7c5cff;
  --card:#ffffff; --radius:16px;
  --shadow-sm:0 1px 2px rgba(16,18,40,.05),0 1px 1px rgba(16,18,40,.04);
  --shadow:0 4px 14px -6px rgba(16,18,40,.12),0 12px 40px -20px rgba(16,18,40,.18);
  --shadow-lg:0 20px 60px -24px rgba(60,40,160,.30);
  --wrap:1140px;
}
*{box-sizing:border-box}
/* The [hidden] attribute must always win over component display rules
   (.modal/.gate/.chat-panel set display, which would otherwise override it). */
[hidden]{display:none!important}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  line-height:1.55;-webkit-font-smoothing:antialiased;letter-spacing:-.01em;
}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
.narrow{max-width:780px}
h1,h2,h3{line-height:1.12;margin:0 0 .4em;letter-spacing:-.03em}
h2{font-size:clamp(28px,3.6vw,42px);font-weight:800}
.muted{color:var(--mut)}
.grad{background:linear-gradient(95deg,var(--primary),#9b7bff);-webkit-background-clip:text;background-clip:text;color:transparent}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  background:var(--primary);color:#fff;border:0;border-radius:11px;padding:12px 20px;
  font-weight:600;font-size:15px;cursor:pointer;font-family:inherit;
  box-shadow:0 1px 2px rgba(108,71,255,.25),0 8px 22px -10px rgba(108,71,255,.5);
  transition:transform .12s ease,box-shadow .15s ease,background .15s ease}
.btn:hover{background:var(--primary-d);transform:translateY(-1px);box-shadow:0 2px 4px rgba(108,71,255,.25),0 14px 32px -12px rgba(108,71,255,.6)}
.btn:active{transform:translateY(0)}
.btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none}
.btn-lg{padding:15px 28px;font-size:16px;border-radius:12px}
.btn-sm{padding:9px 15px;font-size:14px}
.btn-block{width:100%}
.btn-ghost{background:#fff;color:var(--ink);border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.btn-ghost:hover{background:var(--soft);color:var(--ink);box-shadow:var(--shadow-sm)}
.btn-gold{background:var(--ink);color:#fff;box-shadow:0 8px 22px -12px rgba(14,16,32,.6)}
.btn-gold:hover{background:#23263b}

/* nav */
.nav{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.8);backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{font-weight:800;font-size:20px;letter-spacing:-.03em;display:inline-flex;align-items:center;gap:10px;flex:none}
.logo-mark{width:30px;height:30px;display:block;flex:none;filter:drop-shadow(0 4px 10px rgba(108,71,255,.35))}
.brand-logo{height:38px;width:auto;display:block}
.brand-logo-footer{height:34px;margin-bottom:10px}
.app-nav .brand-logo{height:34px}
@media(max-width:560px){.brand-logo{height:32px}}
.nav-links{display:flex;align-items:center;gap:30px;font-size:14.5px;color:var(--ink2);font-weight:500;white-space:nowrap}
.nav-links a:hover{color:var(--primary)}
.nav-account{color:var(--ink);font-weight:600}
#navAuth{display:inline-flex;align-items:center;gap:16px;margin-left:6px}
@media(max-width:820px){.nav-links a:not(.btn):not(.nav-account){display:none}}

/* hero */
.hero{position:relative;padding:84px 0 64px;overflow:hidden;text-align:center;
  background:radial-gradient(900px 420px at 50% -120px,var(--primary-soft),transparent 70%)}
.badge{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--ink2);
  border:1px solid var(--line);background:#fff;padding:7px 14px;border-radius:999px;margin-bottom:22px;box-shadow:var(--shadow-sm)}
.badge:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 3px rgba(18,182,106,.18)}
.hero h1{font-size:clamp(38px,6vw,68px);font-weight:800;letter-spacing:-.04em;margin:0 auto .25em;max-width:14ch}
.lede{font-size:clamp(17px,2vw,20px);color:var(--mut);max-width:620px;margin:0 auto}
.lede strong{color:var(--ink)}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin:30px 0 40px}
.trust{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}
.trust div{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:14px 22px;min-width:120px;box-shadow:var(--shadow-sm)}
.trust strong{font-size:22px;font-weight:800}
.trust span{color:var(--mut);font-size:13px;font-weight:500}

/* compliance strip */
.compliance-strip{max-width:var(--wrap);margin:0 auto 40px;background:var(--primary-soft);border:1px solid #ddd2ff;
  border-radius:14px;padding:14px 18px;font-size:13.5px;color:#4a3da6}
.compliance-strip strong{color:var(--primary-d)}

/* sections */
.section{padding:72px 0}
.section.alt{background:var(--soft)}
.section h2{text-align:center}
.sub{color:var(--mut);text-align:center;margin:-6px auto 30px;max-width:620px}

/* steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:8px}
.step{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm);transition:.15s}
.step:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.step .num{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:11px;
  background:var(--primary-soft);color:var(--primary);font-weight:800;margin-bottom:14px;font-size:17px}
.step h3{font-size:18px}
.step p{color:var(--mut);margin:0;font-size:15px}
@media(max-width:760px){.steps{grid-template-columns:1fr}}

/* tiers */
.tiers{display:grid;grid-template-columns:1fr 1fr;gap:22px;max-width:880px;margin:0 auto}
.tier-card{position:relative;background:var(--card);border:1px solid var(--line);border-radius:20px;padding:30px;box-shadow:var(--shadow-sm)}
.tier-card.featured{border-color:#d9ccff;box-shadow:var(--shadow-lg)}
.tier-card .tag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--primary);
  color:#fff;font-size:12px;font-weight:700;padding:5px 14px;border-radius:999px;white-space:nowrap;box-shadow:0 8px 20px -8px rgba(108,71,255,.7)}
.tier-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:18px}
.tier-head h3{font-size:22px;margin:0}
.price{font-size:34px;font-weight:800;letter-spacing:-.04em}
.price span{font-size:15px;color:var(--mut);font-weight:600;letter-spacing:0}
.tier-card ul{list-style:none;padding:0;margin:0 0 22px}
.tier-card li{padding:9px 0 9px 28px;position:relative;font-size:14.5px;color:var(--ink2)}
.tier-card li:before{content:"";position:absolute;left:0;top:13px;width:16px;height:16px;border-radius:50%;
  background:var(--green);-webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2l-3.5-3.5L4 14.2 9 19.2 20 8.2l-1.5-1.5z'/></svg>") center/13px no-repeat;
  mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='black' d='M9 16.2l-3.5-3.5L4 14.2 9 19.2 20 8.2l-1.5-1.5z'/></svg>") center/13px no-repeat}
.tier-card li.muted{color:var(--mut)}
.tier-card li.muted:before{background:var(--mut);-webkit-mask:none;mask:none;width:14px;height:14px;top:14px;border-radius:50%}
.fineprint{color:var(--mut);font-size:13px;margin:22px auto 0;max-width:760px;text-align:center}
@media(max-width:680px){.tiers{grid-template-columns:1fr}}

/* builder */
.builder{display:grid;grid-template-columns:1.55fr 1fr;gap:24px;align-items:start;margin-top:8px}
.builder-form,.builder-summary{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm)}
.builder-summary{position:sticky;top:88px}
.fld{display:block;margin-bottom:20px}
.fld>span{display:block;font-size:13px;color:var(--ink2);margin-bottom:8px;font-weight:600}
.fld>span small{font-weight:400;color:var(--mut)}
.fld input[type=number],.fld input[type=email],.fld input[type=password],.fld input[type=text]{
  width:100%;background:#fff;border:1px solid var(--line);color:var(--ink);
  border-radius:11px;padding:12px 14px;font-size:15px;font-family:inherit;transition:.15s}
.fld input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-soft)}
.fld-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.seg{display:inline-flex;background:var(--soft2);border-radius:12px;padding:5px;gap:4px}
.seg button{background:transparent;border:0;color:var(--ink2);padding:10px 16px;border-radius:9px;
  font-weight:600;cursor:pointer;font-family:inherit;font-size:14px;transition:.15s}
.seg button.active{background:#fff;color:var(--primary);box-shadow:var(--shadow-sm)}
.state-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(66px,1fr));gap:7px;
  max-height:236px;overflow:auto;padding:10px;background:var(--soft);border:1px solid var(--line);border-radius:12px}
.state-chip{font-size:12.5px;font-weight:600;text-align:center;padding:8px 4px;border-radius:9px;cursor:pointer;
  border:1px solid var(--line);background:#fff;user-select:none;transition:.12s}
.state-chip:hover{border-color:#cdbcff}
.state-chip.on{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 6px 14px -6px rgba(108,71,255,.6)}
.state-chip small{display:block;font-size:10px;color:var(--mut);font-weight:500}
.state-chip.on small{color:#e7deff}
.presets{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.presets button{background:#fff;border:1px solid var(--line);color:var(--ink2);
  border-radius:999px;padding:7px 14px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:.12s}
.presets button:hover{border-color:var(--primary);color:var(--primary)}

/* summary */
.builder-summary h3{font-size:18px;margin-bottom:14px}
.sum-row{display:flex;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid var(--line);font-size:14px}
.sum-row span{color:var(--mut)}
.sum-row b{font-weight:600}
.sum-row.total{font-size:22px;border-bottom:0;margin-top:6px;align-items:baseline}
.sum-row.total b{color:var(--primary);font-weight:800}
.live{font-variant-numeric:tabular-nums}
.sum-row b.live.bump{animation:bump .3s ease}
@keyframes bump{0%{transform:scale(1)}40%{transform:scale(1.08);color:var(--primary)}100%{transform:scale(1)}}
.sum-row.total b.live{display:inline-block}
.avail-bar{height:8px;background:var(--soft2);border-radius:999px;overflow:hidden;margin:2px 0 8px}
.avail-bar i{display:block;height:100%;width:0;border-radius:999px;
  background:linear-gradient(90deg,var(--primary),#9b7bff);transition:width .55s cubic-bezier(.2,.8,.2,1)}
.avail-bar i.over{background:linear-gradient(90deg,#e8554d,#ff8a63)}
.avail-note{font-size:12px;margin-bottom:6px;min-height:16px}
.quote-msg{min-height:18px;font-size:13px;margin:8px 0;color:#d23b3b;font-weight:500}
.quote-msg.ok{color:var(--green)}
.ack{display:flex;gap:10px;align-items:flex-start;font-size:12.5px;color:var(--ink2);margin:16px 0 18px;cursor:pointer;
  background:var(--soft);border:1px solid var(--line);border-radius:11px;padding:12px}
.ack input{margin-top:2px;accent-color:var(--primary);width:16px;height:16px}
.secure{text-align:center;color:var(--mut);font-size:12px;margin:12px 0 0}
@media(max-width:840px){.builder{grid-template-columns:1fr}.builder-summary{position:static}}

/* inventory table */
.inv-toggle{display:flex;justify-content:center;margin-bottom:18px}
.table-wrap{max-height:480px;overflow:auto;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);background:#fff;max-width:760px;margin:0 auto}
.inv-table{width:100%;border-collapse:collapse;font-size:14px}
.inv-table th,.inv-table td{text-align:left;padding:13px 18px;border-bottom:1px solid var(--line)}
.inv-table th{position:sticky;top:0;background:#fff;color:var(--mut);font-weight:600;border-bottom:1px solid var(--line)}
.inv-table td:last-child,.inv-table th:last-child{text-align:right;font-variant-numeric:tabular-nums;font-weight:600}
.inv-table tr:last-child td{border-bottom:0}
.inv-table tbody tr:hover td{background:var(--soft)}

/* faq */
details{background:var(--card);border:1px solid var(--line);border-radius:13px;padding:16px 20px;margin-bottom:12px;box-shadow:var(--shadow-sm)}
summary{cursor:pointer;font-weight:600;list-style:none;font-size:15.5px}
summary::-webkit-details-marker{display:none}
summary:after{content:"+";float:right;color:var(--primary);font-weight:700;font-size:18px}
details[open] summary:after{content:"–"}
details p{color:var(--mut);margin:12px 0 0;font-size:14.5px}

/* footer */
.footer{border-top:1px solid var(--line);padding:48px 0;background:var(--soft)}
.footer-inner{display:grid;grid-template-columns:1fr 2fr;gap:28px}
.footer .brand{margin-bottom:8px}
.disclaimer{color:var(--mut);font-size:12px;line-height:1.6}
.secure-line{color:var(--ink2);font-size:12.5px;margin:10px 0 0;font-weight:500}
@media(max-width:680px){.footer-inner{grid-template-columns:1fr}}

/* modal */
.modal{position:fixed;inset:0;z-index:60;display:grid;place-items:center;background:rgba(14,16,32,.45);padding:20px;backdrop-filter:blur(2px)}
.modal-card{position:relative;background:#fff;border-radius:20px;padding:32px;width:100%;max-width:410px;box-shadow:var(--shadow-lg)}
.modal-x{position:absolute;top:14px;right:16px;background:0;border:0;color:var(--mut);font-size:26px;cursor:pointer;line-height:1}
.modal-card h3{font-size:23px}
.switch{text-align:center;font-size:14px;color:var(--mut);margin:16px 0 0}
.switch a{color:var(--primary);font-weight:600}
.err{background:#fdecec;border:1px solid #f6c9c9;color:#c0392b;padding:11px 13px;border-radius:11px;font-size:13.5px;margin-bottom:14px}

/* chat */
.chat-fab{position:fixed;right:22px;bottom:22px;z-index:50;background:var(--primary);color:#fff;border:0;
  border-radius:999px;padding:14px 20px;font-weight:600;font-size:15px;cursor:pointer;font-family:inherit;
  box-shadow:0 12px 30px -8px rgba(108,71,255,.6)}
.chat-fab:hover{background:var(--primary-d)}
.chat-panel{position:fixed;right:22px;bottom:22px;z-index:55;width:min(384px,calc(100vw - 44px));height:540px;
  background:#fff;border:1px solid var(--line);border-radius:20px;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-lg)}
.chat-head{display:flex;justify-content:space-between;align-items:center;padding:16px 18px;
  background:linear-gradient(120deg,var(--primary),#8b6bff);color:#fff;font-weight:700}
.chat-head button{background:0;border:0;color:#fff;font-size:22px;cursor:pointer;opacity:.85}
.chat-body{flex:1;overflow:auto;padding:18px;display:flex;flex-direction:column;gap:10px;background:var(--soft)}
.msg{max-width:86%;padding:11px 14px;border-radius:14px;font-size:14px;line-height:1.45}
.msg.bot{background:#fff;border:1px solid var(--line);align-self:flex-start;border-bottom-left-radius:4px;box-shadow:var(--shadow-sm)}
.msg.user{background:var(--primary);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.chat-input{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line);background:#fff}
.chat-input input{flex:1;background:#fff;border:1px solid var(--line);color:var(--ink);border-radius:10px;padding:11px 13px;font-family:inherit;font-size:14px}
.chat-input input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-soft)}

/* account/success pages */
.page{max-width:780px;margin:0 auto;padding:56px 24px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;margin-bottom:18px;box-shadow:var(--shadow-sm)}
.order-row{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:16px 0;border-bottom:1px solid var(--line);flex-wrap:wrap}
.order-row:last-child{border-bottom:0}
.pill{font-size:12px;font-weight:600;padding:4px 11px;border-radius:999px;border:1px solid var(--line)}
.pill.ready{background:#e7f8ef;color:#0f9d58;border-color:#bfead2}
.pill.pending{background:#fff7e6;color:#b5891b;border-color:#f0dcb0}
.spinner{width:18px;height:18px;border:3px solid var(--line);border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite;display:inline-block;vertical-align:middle;margin-right:6px}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── trust bar (minimal, monochrome) ───────────────────────────────────────── */
.trustbar{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff;padding:15px 0}
.trustbar-inner{display:flex;flex-wrap:wrap;justify-content:center;align-items:baseline}
.tb{display:flex;align-items:baseline;gap:7px;padding:3px 28px}
.tb + .tb{border-left:1px solid var(--line)}
.tb b{font-size:15px;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.tb span{font-size:13px;color:var(--mut)}
@media(max-width:680px){.tb{padding:3px 14px}.tb + .tb{border-left:0}}

/* ── landing: quality grid ─────────────────────────────────────────────────── */
.qgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:10px}
.qcard{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm);transition:.15s}
.qcard:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.qico{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;
  background:var(--primary-soft);color:var(--primary);margin-bottom:14px}
.qico svg{width:23px;height:23px}
.qcard h3{font-size:17px}
.qcard p{color:var(--mut);font-size:14px;margin:0}
@media(max-width:900px){.qgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.qgrid{grid-template-columns:1fr}}

/* ── landing: verticals ────────────────────────────────────────────────────── */
.vgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:10px}
.vcard{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm);transition:.15s}
.vcard:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.vico{display:inline-grid;place-items:center;width:52px;height:52px;border-radius:15px;font-size:24px;margin-bottom:14px;
  background:color-mix(in srgb,var(--c) 14%,#fff);border:1px solid color-mix(in srgb,var(--c) 28%,#fff)}
.vcard h3{font-size:19px}
.vcard p{color:var(--mut);font-size:14.5px;margin:0}
@media(max-width:860px){.vgrid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.vgrid{grid-template-columns:1fr}}

/* ── ROI / mass texting ────────────────────────────────────────────────────── */
.roi-band{background:linear-gradient(180deg,var(--primary-soft),#fff)}
.roi-flow{display:flex;align-items:stretch;justify-content:center;gap:14px;flex-wrap:wrap;margin-top:6px}
.roi-card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:22px 20px;text-align:center;
  box-shadow:var(--shadow-sm);flex:1;min-width:170px;max-width:215px;display:flex;flex-direction:column;justify-content:center}
.roi-n{font-size:30px;font-weight:800;letter-spacing:-.02em}
.roi-l{font-weight:600;margin-top:4px;font-size:15px}
.roi-s{font-size:12.5px;color:var(--mut);margin-top:4px}
.roi-op{display:flex;align-items:center;font-size:24px;color:var(--mut);font-weight:700}
.roi-card.win .roi-n{color:var(--green)}
.roi-card.big{background:linear-gradient(150deg,var(--primary),#8b6bff);border-color:transparent;color:#fff;box-shadow:var(--shadow-lg)}
.roi-card.big .roi-l{color:#f2eeff}
.roi-card.big .roi-s{color:#e0d6ff}
.roi-kicker{text-align:center;margin:24px auto 0;font-size:16px;color:var(--ink2);max-width:640px}
.roi-kicker b{color:var(--primary-d)}
@media(max-width:820px){.roi-flow{flex-direction:column;align-items:center}.roi-card{max-width:340px;width:100%}.roi-op{transform:rotate(90deg)}}

/* ── reviews (flip to reveal real screenshot) ──────────────────────────────── */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:8px}
.review{position:relative;min-height:310px;perspective:1400px;cursor:pointer;outline:none}
.review-inner{position:relative;width:100%;height:100%;min-height:310px;
  transition:transform .6s cubic-bezier(.4,.15,.2,1);transform-style:preserve-3d}
.review.flipped .review-inner{transform:rotateY(180deg)}
.review-face{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;
  display:flex;flex-direction:column;gap:14px;background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm);overflow:hidden}
.review-face.back{transform:rotateY(180deg);align-items:center;justify-content:center;gap:12px}
.review:hover .review-face{box-shadow:var(--shadow)}
.bubbles{display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.bubble{background:var(--soft2);border-radius:16px;border-bottom-left-radius:5px;padding:12px 15px;
  font-size:14.5px;color:var(--ink);margin:0;line-height:1.5;max-width:100%}
.bubble b{font-weight:700;color:var(--primary-d)}
.rv-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:auto;width:100%}
.rv-meta{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--ink2);font-weight:600}
.rv-check{display:inline-grid;place-items:center;width:20px;height:20px;border-radius:50%;
  background:#e7f8ef;color:var(--green);font-size:12px;font-weight:800}
.flip-hint{font-size:12px;color:var(--primary);font-weight:600;white-space:nowrap}
.review-face.back .shot{max-width:100%;max-height:228px;border-radius:10px;border:1px solid var(--line);object-fit:contain}
.shot-missing{display:none;flex:1;width:100%;align-items:center;justify-content:center;text-align:center;
  flex-direction:column;gap:4px;color:var(--mut);font-size:13px;border:1px dashed var(--line);border-radius:10px;padding:24px}
@media(max-width:820px){.reviews{grid-template-columns:1fr}}

/* ── landing: why split ────────────────────────────────────────────────────── */
.splitrow{display:grid;grid-template-columns:1.4fr 1fr;gap:30px;align-items:center;margin-top:8px}
.split-list{display:flex;flex-direction:column;gap:14px}
.sl-item{background:var(--card);border:1px solid var(--line);border-radius:13px;padding:18px 20px;font-size:15px;color:var(--ink2);box-shadow:var(--shadow-sm)}
.sl-item b{color:var(--ink)}
.cta-card{background:linear-gradient(160deg,#fff,var(--primary-soft));border:1px solid #e1d8ff;border-radius:20px;padding:30px;box-shadow:var(--shadow)}
.cta-card h3{font-size:22px}
@media(max-width:820px){.splitrow{grid-template-columns:1fr}.cta-card{position:static}}

/* ── dashboard ─────────────────────────────────────────────────────────────── */
.app-body{background:var(--soft)}
.gate{min-height:100vh;display:grid;place-content:center;justify-items:center;gap:14px;color:var(--mut);font-size:15px}
.app-nav{background:#fff}
.app-nav .nav-inner{gap:18px}
.tabs{display:flex;gap:6px;background:var(--soft2);border-radius:12px;padding:5px;margin:0 auto}
.tab{background:transparent;border:0;color:var(--ink2);padding:9px 18px;border-radius:9px;font-weight:600;cursor:pointer;font-family:inherit;font-size:14.5px;transition:.15s}
.tab.active{background:#fff;color:var(--primary);box-shadow:var(--shadow-sm)}
.nav-user{display:flex;align-items:center;gap:16px;font-size:14px}
.who{color:var(--mut);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nav-logout{color:var(--ink2);font-weight:600}
.nav-logout:hover{color:var(--primary)}
.tabpane{padding:36px 0 80px}
.app-head{margin-bottom:22px}
.app-head h1{font-size:30px;margin-bottom:4px}
.inv-block{margin-top:8px;border-top:1px solid var(--line);padding-top:20px}
.inv-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;font-size:13px;color:var(--ink2);font-weight:600}
.seg.sm button{padding:7px 12px;font-size:13px}
.inv-block .table-wrap{max-height:300px;max-width:none}
.link{color:var(--primary);font-weight:600}
.report-frame{width:100%;height:1500px;border:1px solid var(--line);border-radius:var(--radius);background:#fff;box-shadow:var(--shadow-sm);display:block}
@media(max-width:760px){.tabs{margin:0}.who{display:none}.app-nav .nav-inner{flex-wrap:wrap;height:auto;padding-top:12px;padding-bottom:12px}}

/* scroll reveal */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}
