
:root{
  --bg:#f4f7fb;
  --bg-2:#eef3f9;
  --surface:#ffffff;
  --surface-2:#f8fbff;
  --surface-3:#edf4ff;
  --text:#0f1b33;
  --text-2:#2a3c5b;
  --muted:#64748b;
  --line:#dbe5f1;
  --line-strong:#c7d6ea;
  --brand:#2b63ff;
  --brand-strong:#1649d8;
  --brand-soft:#e9f0ff;
  --ok:#0f8a5f;
  --warn:#a86700;
  --danger:#c53b3b;
  --navy:#0b1530;
  --navy-2:#0f1f46;
  --shadow-sm:0 10px 30px rgba(16,34,70,.06);
  --shadow:0 18px 48px rgba(16,34,70,.10);
  --shadow-lg:0 28px 80px rgba(10,28,61,.16);
  --radius:22px;
  --radius-sm:14px;
  --max:1200px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;width:100%;max-width:100%;overflow-x:hidden}
body{
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background:linear-gradient(180deg,#f8fbff 0%, #eef4fb 100%);
  line-height:1.55;
}
a{color:inherit;text-decoration:none}
img,video{display:block;max-width:100%}
button,input,select,textarea{font:inherit}
button{cursor:pointer}

.container, .hero-grid > *, .section-head > *, .review-layout > *, .mission-split > *, .auth-panel > *, .portal-grid > *, .grid-2 > *, .grid-3 > *, .grid-4 > *, .domain-grid > *, .flow-grid > *, .metric-grid > *{min-width:0}
.site-header,.site-footer,main,.portal-shell,.portal-main,.sidebar,.auth-shell,.auth-panel{max-width:100%}

.container{max-width:var(--max);margin:0 auto;padding:0 28px}
.hidden{display:none!important}
.small{font-size:12px}
.muted{color:var(--muted)}
.full{grid-column:1 / -1}
hr.sep{border:none;height:1px;background:var(--line);margin:20px 0}

/* header */
.site-header{position:sticky;top:0;z-index:80;background:rgba(248,251,255,.86);backdrop-filter:blur(16px);border-bottom:1px solid rgba(199,214,234,.65)}
.site-header .bar{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:24px;padding:16px 0}
.brand{display:inline-flex;align-items:center;gap:14px;min-width:0}
.brand-mark{width:40px;height:40px;border-radius:14px;background:linear-gradient(135deg,#0d1b40,#2050e2 58%,#6cb7ff);box-shadow:0 16px 40px rgba(32,80,226,.26);position:relative;flex:none}
.brand-mark::before{content:'';position:absolute;inset:9px;border:2px solid rgba(255,255,255,.92);border-top-left-radius:8px;border-top-right-radius:8px;border-bottom-left-radius:12px;border-bottom-right-radius:12px;clip-path:polygon(50% 0%,100% 28%,83% 100%,17% 100%,0% 28%)}
.brand-name{font-size:18px;font-weight:800;letter-spacing:-.02em}
.brand-sub{font-size:12px;color:#70809c}
.nav{display:flex;flex-wrap:wrap;align-items:center;gap:22px;justify-content:center}
.nav a{font-size:14px;font-weight:600;color:#415067;position:relative;padding:8px 0}
.nav a::after{content:'';position:absolute;left:0;right:0;bottom:-15px;height:2px;border-radius:2px;background:transparent;transition:.2s}
.nav a.active,.nav a:hover{color:var(--text)}
.nav a.active::after,.nav a:hover::after{background:var(--brand)}
.header-actions{display:flex;align-items:center;gap:12px}
.mobile-toggle{display:none;background:#fff;border:1px solid var(--line);color:var(--text);padding:11px 14px;border-radius:14px;font-weight:700}
.mobile-menu{display:none;padding:0 0 18px;gap:10px;grid-template-columns:1fr}
.mobile-menu a{background:#fff;border:1px solid var(--line);padding:12px 14px;border-radius:14px;font-weight:600;color:var(--text-2)}
.mobile-menu.open{display:grid}

/* buttons */
.btn,.btn-secondary,.btn-ghost,.btn-success,.btn-warning,.btn-danger{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  min-height:46px;padding:0 18px;border-radius:14px;border:1px solid transparent;font-weight:700;transition:transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
}
.btn{background:linear-gradient(135deg,var(--brand),#4f7dff);color:#fff;box-shadow:0 16px 34px rgba(43,99,255,.22)}
.btn:hover,.btn-secondary:hover,.btn-ghost:hover,.btn-success:hover,.btn-warning:hover,.btn-danger:hover{transform:translateY(-1px)}
.btn-secondary{background:#fff;color:var(--text);border-color:var(--line);box-shadow:var(--shadow-sm)}
.btn-ghost{background:transparent;color:#dbe7ff;border-color:rgba(255,255,255,.18)}
.btn-success{background:#eaf8f1;color:#096d49;border-color:#ccefdc}
.btn-warning{background:#fff4e6;color:#9a5f02;border-color:#ffd89f}
.btn-danger{background:#fff0f0;color:#b03434;border-color:#ffd2d2}
.desktop-only{display:inline-flex}

/* general content */
main{display:block}
.section,.section-alt,.section-dark{padding:72px 0}
.section-alt{background:linear-gradient(180deg,rgba(255,255,255,.32),rgba(255,255,255,0))}
.section-dark{background:linear-gradient(180deg,#0c1532,#091125);color:#fff}
.section-head{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,520px);gap:28px;align-items:end;margin-bottom:30px}
.eyebrow{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:var(--brand-soft);color:#2248aa;font-weight:800;font-size:12px;text-transform:uppercase;letter-spacing:.08em}
h1,h2,h3{margin:0;line-height:1.05;letter-spacing:-.04em}
h1{font-size:clamp(2.6rem,5vw,4.8rem)}
h2{font-size:clamp(2rem,3.5vw,3rem)}
h3{font-size:1.28rem;letter-spacing:-.03em}
p{margin:0}
.lead{font-size:1.07rem;line-height:1.72;color:var(--text-2)}
.actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.hero{padding:88px 0 58px}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);gap:40px;align-items:center}
.hero-copy .actions{margin:24px 0 18px}
.hero-callouts{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:18px}
.stat{background:rgba(255,255,255,.88);border:1px solid var(--line);border-radius:18px;padding:14px 16px;box-shadow:var(--shadow-sm)}
.stat strong{display:block;font-size:1.5rem;letter-spacing:-.03em}
.stat span{font-size:13px;color:var(--muted)}
.hero-stage{position:relative;background:linear-gradient(145deg,#0d1838,#0f275a 62%,#183677);border-radius:30px;padding:26px;min-height:440px;box-shadow:var(--shadow-lg);overflow:hidden}
.hero-stage::before{content:'';position:absolute;inset:auto -12% -28% auto;width:340px;height:340px;background:radial-gradient(circle,rgba(103,169,255,.44),rgba(103,169,255,0) 68%)}
.hero-stage::after{content:'';position:absolute;inset:-25% auto auto -10%;width:260px;height:260px;background:radial-gradient(circle,rgba(96,154,255,.20),rgba(96,154,255,0) 70%)}
.hero-lab{position:absolute;left:26px;bottom:26px;width:54%;height:56%;background:linear-gradient(180deg,rgba(255,255,255,.16),rgba(255,255,255,.08));border:1px solid rgba(255,255,255,.16);border-radius:24px;overflow:hidden}
.hero-lab::before{content:'';position:absolute;left:8%;right:8%;bottom:20%;height:18%;background:linear-gradient(180deg,#9eb7d9,#8aa5c9);border-radius:18px;opacity:.7}
.hero-lab::after{content:'';position:absolute;right:10%;bottom:28%;width:36%;height:18%;border-radius:20px;background:linear-gradient(180deg,#dce6f7,#bfcde6)}
.hero-objects{position:absolute;left:8%;bottom:32%;display:flex;gap:10px}
.hero-objects span{width:56px;height:38px;border-radius:10px;background:linear-gradient(180deg,#c7d6ed,#9ab0d3)}
.hero-hand{position:absolute;right:18%;top:19%;width:120px;height:90px;border-radius:24px 24px 32px 32px;background:linear-gradient(180deg,#1f2641,#0d1226);transform:rotate(-15deg);box-shadow:0 18px 40px rgba(0,0,0,.22)}
.hero-trace{position:absolute;left:35%;top:30%;width:45%;height:42%;border-top:3px solid rgba(255,255,255,.45);border-right:3px solid rgba(255,255,255,.45);border-radius:0 160px 0 0;transform:rotate(18deg)}
.hero-interface{position:absolute;right:22px;top:22px;bottom:22px;width:40%;display:grid;gap:14px;align-content:start}
.ui-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.ui-pane{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.14);border-radius:18px;padding:14px;display:grid;gap:10px}
.ui-pane.dark{background:rgba(6,15,36,.44)}
.ui-block{height:12px;border-radius:999px;background:rgba(255,255,255,.18)}
.ui-block.lg{height:16px;width:82%}.ui-block.md{width:62%}.ui-block.sm{width:40%}.ui-block.blue{background:linear-gradient(90deg,#74a7ff,#d8ebff)}
.timeline{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding-top:6px}
.timeline span{height:8px;border-radius:999px;background:rgba(255,255,255,.18)}
.timeline span.active{background:#74a7ff}

.domain-grid,.grid-3,.grid-4,.grid-2{display:grid;gap:22px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.domain-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
.domain-card,.card,.metric,.callout{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px}
.domain-card{position:relative;overflow:hidden;background:linear-gradient(180deg,#ffffff,#fbfdff)}
.domain-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent,#79a7ff)}
.domain-card h3{margin-top:12px}
.domain-card .muted{margin-top:10px}
.flow-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}
.flow-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:22px;box-shadow:var(--shadow-sm)}
.step{width:38px;height:38px;border-radius:999px;background:var(--brand-soft);color:#1d43a2;display:grid;place-items:center;font-weight:800;margin-bottom:16px}
.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}
.metric{padding:20px}
.metric strong,.metric .value{display:block;font-size:1.5rem;letter-spacing:-.03em;font-weight:800;margin-bottom:8px}
.metric span,.metric .label{display:block;color:var(--muted);font-size:14px}
.badge,.status-pill{display:inline-flex;align-items:center;justify-content:center;padding:7px 10px;border-radius:999px;font-size:12px;font-weight:800;letter-spacing:.03em}
.badge{background:#eef4ff;color:#30509a}
.badge-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.status-pill{border:1px solid transparent;text-transform:uppercase}
.status-open,.status-submitted,.status-tier1{background:#eef4ff;color:#2755c7;border-color:#dbe6ff}
.status-under_review,.status-review,.status-pending{background:#fff4e8;color:#9d5d00;border-color:#ffe0b3}
.status-needs_correction,.status-tier2{background:#fff8e6;color:#9d6a00;border-color:#ffe9b8}
.status-approved,.status-tier3{background:#eefbf4;color:#0b7b51;border-color:#caeedb}
.status-rejected,.status-cancelled{background:#fff0f0;color:#b53a3a;border-color:#ffd4d4}
.status-paused,.status-closed,.status-archived,.status-full,.status-tier4{background:#edf2f8;color:#566781;border-color:#dce5f0}

.table-wrap{background:#fff;border:1px solid var(--line);border-radius:22px;overflow:hidden;box-shadow:var(--shadow-sm)}
.table-wrap table{width:100%;border-collapse:collapse}
.table-wrap th,.table-wrap td{padding:14px 16px;border-bottom:1px solid #ebf0f6;text-align:left;vertical-align:top}
.table-wrap th{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:#6a7991;background:#f8fbff;font-weight:800}
.table-wrap tr:last-child td{border-bottom:none}

.site-footer{margin-top:72px;background:linear-gradient(180deg,#0b132b,#09101f);color:#d8e4ff;padding:54px 0 36px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:28px}
.footer-head{font-size:13px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;margin-bottom:14px;color:#aecdff}
.footer-list{display:grid;gap:10px}
.footer-list a,.site-footer p,.site-footer .small{color:#c4d4f6}
.footer-note{margin-top:28px;padding-top:18px;border-top:1px solid rgba(255,255,255,.08);color:#9fb2d7;font-size:13px}

/* forms */
.form-card{padding:24px}
.field-grid,.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.field,.field-grid>div{display:grid;gap:8px}
.field label,.field-grid label{font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#39506f}
.field input,.field select,.field textarea,.field-grid input,.field-grid select,.field-grid textarea{
  width:100%;border:1px solid var(--line-strong);background:#fff;border-radius:14px;padding:14px 15px;color:var(--text);outline:none;min-height:48px;
}
.field textarea,.field-grid textarea{min-height:130px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus,.field-grid input:focus,.field-grid select:focus,.field-grid textarea:focus{border-color:#83a8ff;box-shadow:0 0 0 4px rgba(43,99,255,.10)}
.helper{font-size:13px;color:var(--muted)}
.info-banner,.success-banner,.error-banner,.notice,.empty-state{padding:14px 16px;border-radius:16px;border:1px solid}
.info-banner,.notice{background:#f3f7ff;border-color:#d7e5ff;color:#234ea4}
.success-banner,.notice.ok{background:#effbf4;border-color:#caeedb;color:#0d7b51}
.error-banner,.notice.danger{background:#fff1f1;border-color:#ffd5d5;color:#b23838}
.notice.warn{background:#fff7ea;border-color:#ffe0af;color:#9d5b00}
.empty-state{background:#fbfdff;border-style:dashed;border-color:#d5e0ee;color:#66778f;text-align:center}
.video-drop{display:grid;gap:12px;padding:18px;border-radius:18px;border:1px dashed #b7c7e2;background:#f9fbff}
.video-preview{margin-top:12px;border:1px solid var(--line);background:#0b1020;border-radius:18px;overflow:hidden;min-height:220px;display:none}
.video-preview video{width:100%;height:auto;max-height:360px;background:#0b1020}
.upload-steps{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:12px;margin:0 0 20px}
.upload-step{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 14px;font-weight:700;color:#4a5b78;text-align:center}
.upload-step.active{background:#eef4ff;border-color:#d5e3ff;color:#224cb5}

/* portal/admin */
.portal-shell{display:grid;grid-template-columns:280px minmax(0,1fr);min-height:100vh;background:linear-gradient(180deg,#eef4fb 0%,#f6f9fd 100%)}
.sidebar{position:sticky;top:0;height:100vh;background:linear-gradient(180deg,#0c1430,#0b1c43);color:#e3edff;padding:24px 18px 22px;display:flex;flex-direction:column;gap:22px;border-right:1px solid rgba(255,255,255,.08)}
.side-nav{display:grid;gap:6px}
.side-nav a{padding:12px 14px;border-radius:14px;color:#d8e6ff;font-weight:600}
.side-nav a.active,.side-nav a:hover{background:rgba(255,255,255,.10);color:#fff}
.side-footer{margin-top:auto;display:grid;gap:12px}
.portal-main{min-width:0;padding:26px 30px 38px}
.portal-top,.page-title{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:22px}
.portal-top h1,.page-title h1{font-size:clamp(2rem,3vw,3.1rem);margin:0 0 8px}
.portal-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:20px}
.span-5{grid-column:span 5}
.span-7{grid-column:span 7}
.grid-1{display:grid;gap:20px}
.mission-card h3{margin:12px 0 10px}
.mission-meta{display:flex;flex-wrap:wrap;gap:10px;margin:14px 0;color:var(--muted);font-size:13px}
.review-layout,.mission-split{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr);gap:24px;align-items:start}
.list{display:grid;gap:14px}
.list-item{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;padding:16px 18px;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-sm)}
.list-item strong{display:block;margin-bottom:6px}
.admin-toolbar{display:flex;gap:8px;flex-wrap:wrap}
.checklist{display:grid;gap:12px}
.check{display:flex;gap:10px;align-items:flex-start;padding:12px 14px;border-radius:14px;background:#f8fbff;border:1px solid var(--line)}
.check input{margin-top:2px}
.site-breadcrumb{display:flex;align-items:center;gap:8px;color:#6e7d95;font-size:14px;margin-bottom:18px}
.portal-main .card, .portal-main .metric, .portal-main .table-wrap{box-shadow:0 12px 32px rgba(12,27,55,.06)}

/* auth */
.auth-shell{padding:70px 0}
.auth-panel{display:grid;grid-template-columns:minmax(320px,.95fr) minmax(320px,.85fr);gap:26px}
.auth-side{background:linear-gradient(145deg,#0d1838,#12306a);color:#fff;border-radius:28px;padding:30px;box-shadow:var(--shadow-lg)}
.auth-side .lead,.auth-side .small{color:#dbe6ff}
.auth-card{padding:28px}

/* utilities */
.topline{display:none}
.brandrow{display:none}
.filters{display:flex;flex-wrap:wrap;gap:12px}
.filters select,.filters input{min-height:44px;border-radius:12px;border:1px solid var(--line-strong);padding:10px 12px;background:#fff;color:var(--text)}
.legal-card{display:grid;gap:16px}
.legal-card h2{font-size:2rem}
.callout{display:grid;gap:14px}
.toolbar{display:flex;justify-content:space-between;gap:16px;align-items:center;flex-wrap:wrap}

/* responsive */
@media (max-width: 1180px){
  .site-header .bar{grid-template-columns:auto 1fr auto}
  .nav{gap:16px}
  .hero-grid,.section-head,.review-layout,.mission-split,.auth-panel{grid-template-columns:1fr}
  .hero-interface{position:relative;right:auto;top:auto;bottom:auto;width:auto;margin-top:20px}
  .hero-lab{position:relative;left:auto;bottom:auto;width:100%;height:220px;margin-top:130px}
  .hero-stage{min-height:520px}
  .flow-grid,.domain-grid,.grid-3,.grid-4,.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 960px){
  .nav,.desktop-only{display:none}
  .mobile-toggle{display:inline-flex}
  .mobile-menu{display:none}
  .portal-shell{grid-template-columns:1fr}
  .sidebar{position:relative;height:auto;padding-bottom:18px}
  .portal-main{padding:22px}
  .portal-grid{grid-template-columns:1fr}
  .span-5,.span-7{grid-column:auto}
  .footer-grid,.auth-panel,.grid-2{grid-template-columns:1fr}
}
@media (max-width: 720px){
  .container{padding:0 18px}
  .hero{padding:60px 0 36px}
  h1{font-size:2.7rem}
  .hero-callouts,.flow-grid,.domain-grid,.grid-3,.grid-4,.metric-grid,.field-grid,.form-grid,.upload-steps{grid-template-columns:1fr}
  .header-actions{gap:10px}
  .btn,.btn-secondary,.btn-ghost,.btn-success,.btn-warning,.btn-danger{width:100%}
  .actions{flex-direction:column;align-items:stretch}
}


/* ===== V8 enterprise polish overrides ===== */

:root{
  --bg:#eef3f9;
  --bg-2:#f6f9fd;
  --surface:#ffffff;
  --surface-2:#f8fbff;
  --text:#0e1830;
  --text-2:#30435f;
  --muted:#6f8099;
  --line:#d8e2ef;
  --line-strong:#c5d4e8;
  --brand:#2d64ff;
  --brand-strong:#1848d4;
  --navy:#081327;
  --navy-2:#0f2557;
  --shadow-sm:0 12px 26px rgba(12,31,67,.05);
  --shadow:0 18px 48px rgba(12,31,67,.09);
  --shadow-lg:0 28px 80px rgba(9,23,51,.18);
  --radius:24px;
  --radius-sm:16px;
  --max:1280px;
}
body{background:radial-gradient(circle at top right, rgba(108,176,255,.12), transparent 26%), linear-gradient(180deg,#f8fbff 0%, #eef3f9 100%); color:var(--text)}
.top-meta{background:linear-gradient(180deg,#0c1531,#0b1430); border-bottom:1px solid rgba(255,255,255,.08)}
.top-meta-row{display:flex; justify-content:space-between; align-items:center; gap:16px; min-height:42px}
.meta-pills{display:flex; flex-wrap:wrap; gap:8px}
.meta-pill{display:inline-flex; align-items:center; min-height:28px; padding:0 12px; border-radius:999px; background:rgba(255,255,255,.08); color:#dbe8ff; font-size:12px; font-weight:700; letter-spacing:.01em}
.meta-contact{color:#a9bedf; font-size:12px; font-weight:600}
.site-header{background:rgba(248,251,255,.88); box-shadow:0 10px 28px rgba(16,34,70,.04)}
.site-header .bar{padding:18px 0}
.brand-name{font-size:19px}
.brand-sub{font-size:12px; letter-spacing:.01em}
.nav{gap:24px}
.nav a{font-size:14px; font-weight:700; color:#53637b}
.nav a::after{bottom:-19px}
.header-actions{gap:10px}
.mobile-toggle{background:#fff; box-shadow:var(--shadow-sm)}
.mobile-menu{padding:14px 0 22px; background:transparent}
.mobile-menu a{box-shadow:var(--shadow-sm)}
.hero{padding:92px 0 64px}
.hero-grid{gap:52px; align-items:center}
.hero-copy .lead{max-width:760px}
.hero-stage{min-height:470px; border:1px solid rgba(255,255,255,.08)}
.hero-callouts .stat{background:rgba(255,255,255,.94)}
.section,.section-alt,.section-dark{padding:84px 0}
.section-head{margin-bottom:36px}
.section-head .lead{max-width:680px}
.eyebrow{box-shadow:inset 0 0 0 1px rgba(34,72,170,.08)}
.card,.domain-card,.metric,.callout,.flow-card,.table-wrap,.list-item{border-radius:24px}
.card,.domain-card,.metric,.callout,.flow-card,.table-wrap{box-shadow:var(--shadow)}
.domain-card,.flow-card,.metric,.card{background:rgba(255,255,255,.96)}
.list-item{padding:18px 20px}
.table-wrap{overflow:hidden}
table thead th{font-size:12px; text-transform:uppercase; letter-spacing:.08em; color:#61728f; background:#f9fbfe}
table td,table th{padding:14px 16px}
.badge{background:#eef4ff; color:#3055a8; border:1px solid #d5e3ff; border-radius:999px; padding:7px 12px; font-weight:700}
.badge.dark{background:rgba(255,255,255,.08); color:#e5efff; border-color:rgba(255,255,255,.12)}
.status-pill{border-radius:999px; padding:7px 11px; font-size:12px; font-weight:800; letter-spacing:.01em}
.field input,.field select,.field textarea,.field-grid input,.field-grid select,.field-grid textarea,.filters select,.filters input, input, select, textarea{
  border-radius:14px; border:1px solid var(--line-strong); min-height:48px; padding:12px 14px; background:#fff; color:var(--text); box-shadow:0 1px 0 rgba(255,255,255,.7) inset;
}
textarea{min-height:132px; resize:vertical}
input:focus,select:focus,textarea:focus{outline:none; border-color:#84a9ff; box-shadow:0 0 0 4px rgba(45,100,255,.12)}
.filters{align-items:center}
.site-footer{background:linear-gradient(180deg,#0a1430,#081226); color:#f4f7ff; margin-top:72px; padding:50px 0 24px}
.footer-wrap{display:grid; gap:28px}
.footer-grid{display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:28px}
.footer-head{font-size:13px; text-transform:uppercase; letter-spacing:.1em; color:#9db3d6; font-weight:800; margin-bottom:14px}
.footer-list{display:grid; gap:10px}
.footer-list a{color:#eef4ff; opacity:.9}
.footer-list a:hover{opacity:1}
.footer-copy,.footer-sub{color:#a7bcdd}
.footer-note{padding-top:18px; border-top:1px solid rgba(255,255,255,.08); color:#97add0; font-size:13px}
.footer-badges{margin-top:16px}

/* portal/admin shell */
.portal-shell{display:grid; grid-template-columns:320px minmax(0,1fr); min-height:100vh; background:linear-gradient(180deg,#edf3fa 0%, #f7faff 100%)}
.sidebar{padding:20px; background:transparent; border-right:none; position:sticky; top:0; height:100vh}
.sidebar-inner{height:calc(100vh - 40px); display:flex; flex-direction:column; gap:20px; border-radius:28px; padding:22px; background:linear-gradient(180deg,#08142d 0%, #0b1b43 55%, #10285f 100%); box-shadow:var(--shadow-lg); border:1px solid rgba(255,255,255,.08)}
.sidebar-brand{margin-bottom:2px}
.sidebar-note{color:#bcd0ef; font-size:13px; line-height:1.6; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.08); border-radius:18px; padding:14px 14px 13px}
.side-nav{display:grid; gap:8px}
.side-nav a{display:flex; align-items:center; min-height:46px; padding:0 14px; border-radius:14px; color:#dbe8ff; font-weight:700; border:1px solid transparent; transition:.18s ease}
.side-nav a.active,.side-nav a:hover{background:rgba(255,255,255,.10); border-color:rgba(255,255,255,.12); color:#fff; transform:translateX(1px)}
.sidebar-stats{display:grid; gap:12px; margin-top:6px}
.sidebar-stat{background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.08); border-radius:18px; padding:14px}
.sidebar-stat strong{display:block; margin-top:6px; color:#fff; font-size:14px; overflow-wrap:anywhere}
.side-footer{margin-top:auto; display:grid; gap:10px}
.side-footer .btn-secondary,.side-footer .btn-danger{width:100%}
.portal-main{padding:24px 26px 40px; min-width:0}
.portal-header{display:flex; justify-content:space-between; align-items:flex-start; gap:20px; padding:20px 22px; background:rgba(255,255,255,.88); border:1px solid var(--line); border-radius:24px; box-shadow:var(--shadow-sm); margin-bottom:22px; backdrop-filter:blur(12px)}
.portal-header h2{margin:8px 0 6px; font-size:1.9rem; letter-spacing:-.03em}
.portal-eyebrow{background:#eef4ff}
.portal-header-actions{display:flex; gap:10px; flex-wrap:wrap; align-items:center}
.portal-content{display:grid; gap:20px}
.portal-top,.page-title{margin-bottom:20px; align-items:flex-end}
.portal-top h1,.page-title h1{font-size:clamp(2rem,3vw,3rem)}
.portal-main .card,.portal-main .metric,.portal-main .table-wrap,.portal-main .list-item{box-shadow:0 14px 38px rgba(12,27,55,.07)}
.portal-grid{gap:22px}
.metric-grid{gap:18px}
.metric strong,.metric .value{font-size:1.65rem}
.mission-card .actions{margin-top:16px}
.mission-card .info-banner{margin-top:12px}
.admin-toolbar .btn-secondary,.admin-toolbar .btn-warning,.admin-toolbar .btn-success{min-height:40px; padding:0 14px; border-radius:12px}
.empty-state{padding:24px; border-radius:18px; background:#f8fbff; border:1px dashed var(--line-strong); color:var(--muted)}
.error-banner,.success-banner,.info-banner{border-radius:16px; padding:14px 16px; font-weight:600}
.info-banner{background:#f2f7ff; border:1px solid #d4e2ff; color:#36518a}
.success-banner{background:#ebfaf1; border:1px solid #cfeedd; color:#116848}
.error-banner{background:#fff0f0; border:1px solid #ffd0d0; color:#af3434}
.auth-shell{padding:82px 0}
.auth-panel{grid-template-columns:minmax(360px,1fr) minmax(360px,.95fr); gap:30px}
.auth-card{background:rgba(255,255,255,.97); box-shadow:var(--shadow); border:1px solid var(--line)}
.legal-card{background:rgba(255,255,255,.96); border:1px solid var(--line); box-shadow:var(--shadow)}
.grid-1{display:grid; gap:20px}

@media (max-width: 1180px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .portal-shell{grid-template-columns:1fr}
  .sidebar{position:relative; height:auto; padding:20px 20px 0}
  .sidebar-inner{height:auto}
}
@media (max-width: 960px){
  .top-meta-row{flex-direction:column; align-items:flex-start; padding:10px 0}
  .footer-grid{grid-template-columns:1fr}
  .portal-main{padding:20px}
  .portal-header{flex-direction:column; align-items:flex-start}
  .sidebar{padding:16px 16px 0}
}
@media (max-width: 720px){
  .meta-pills{gap:6px}
  .meta-pill{font-size:11px; min-height:26px}
  .hero-stage{min-height:430px}
  .portal-header-actions,.header-actions{width:100%}
  .portal-header-actions .btn,.portal-header-actions .btn-secondary{width:100%}
}

/* v8.1 functional polish overrides */
.portal-shell{align-items:start}
.sidebar{padding:20px 18px 20px; overflow:visible}
.sidebar-inner{min-height:calc(100vh - 40px); height:auto; max-height:calc(100vh - 40px); overflow-y:auto; overflow-x:hidden; padding-bottom:18px}
.side-nav{display:grid; gap:8px}
.side-nav a{display:block}
.sidebar-stats{margin-top:auto}
.side-footer{position:sticky; bottom:0; background:linear-gradient(180deg, rgba(8,20,45,0), rgba(8,20,45,.82) 18%, rgba(8,20,45,.98) 100%); padding-top:12px}
.side-footer .btn-secondary,.side-footer .btn-danger{display:inline-flex; align-items:center; justify-content:center; min-height:44px; border-radius:14px}
.portal-main{padding-bottom:48px}
.metric-grid{display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:16px}
@media (max-width: 1100px){.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media (max-width: 720px){.metric-grid{grid-template-columns:1fr;} .portal-header{flex-direction:column; align-items:flex-start;} .portal-header-actions{width:100%; justify-content:flex-start; flex-wrap:wrap}}


/* mobile stability pass */
@media (max-width: 960px){
  .site-header .bar{grid-template-columns:minmax(0,1fr) auto auto;gap:10px}
  .brand{min-width:0}
  .brand-name{font-size:16px}
  .brand-sub{font-size:11px}
  .header-actions{gap:8px}
  .mobile-menu{padding-top:10px}
  .mobile-menu a{width:100%}
  .portal-shell{grid-template-columns:1fr!important}
  .sidebar{position:relative!important;top:auto!important;height:auto!important;min-height:0!important;overflow:visible!important;padding:16px 14px 18px!important;border-right:none;border-bottom:1px solid rgba(255,255,255,.08);border-radius:0 0 24px 24px;box-shadow:none}
  .portal-main{padding:20px 16px 28px!important}
  .portal-top,.page-title,.toolbar{flex-direction:column;align-items:flex-start}
  .filters{display:grid;grid-template-columns:1fr;gap:10px;width:100%}
  .filters input,.filters select{width:100%}
  .review-layout,.mission-split,.section-head,.hero-grid,.auth-panel,.grid-2,.grid-3,.grid-4,.domain-grid,.flow-grid,.metric-grid,.field-grid,.form-grid,.upload-steps{grid-template-columns:1fr!important}
  .span-5,.span-7{grid-column:auto!important}
  .table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .table-wrap table{min-width:720px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:20px}
}
@media (max-width: 720px){
  body{overflow-x:hidden}
  .container{padding:0 16px}
  .site-header .bar{padding:14px 0}
  .mobile-toggle{padding:10px 12px;min-height:44px}
  .hero{padding:48px 0 30px}
  h1{font-size:2.35rem;line-height:1.02}
  h2{font-size:1.85rem}
  .lead{font-size:1rem;line-height:1.65}
  .actions{flex-direction:column;align-items:stretch}
  .actions .btn,.actions .btn-secondary,.actions .btn-ghost,.actions .btn-success,.actions .btn-warning,.actions .btn-danger,.form-card .btn,.sidebar .btn,.sidebar .btn-secondary,.side-footer .btn,.side-footer .btn-secondary,.side-footer .btn-danger{width:100%}
  .hero-stage{padding:18px;border-radius:24px;min-height:0}
  .hero-interface{position:relative;right:auto;top:auto;bottom:auto;width:auto;margin-top:14px}
  .hero-lab{position:relative;left:auto;bottom:auto;width:100%;height:180px;margin-top:28px}
  .hero-callouts,.flow-grid,.domain-grid,.grid-3,.grid-4,.metric-grid,.field-grid,.form-grid,.upload-steps{grid-template-columns:1fr!important}
  .auth-shell{padding:30px 0}
  .auth-side,.auth-card,.card,.domain-card,.metric,.callout,.flow-card,.form-card{padding:20px;border-radius:20px}
  .auth-panel{gap:18px}
  .portal-shell{display:block}
  .sidebar{padding:14px 12px 16px!important;gap:12px;border-radius:0 0 22px 22px}
  .side-nav{display:grid;gap:6px}
  .side-nav a{padding:11px 12px;font-size:15px}
  .side-footer{display:grid;gap:10px;margin-top:6px}
  .side-footer > *{min-width:0}
  .portal-main{padding:18px 14px 24px!important}
  .portal-top h1,.page-title h1{font-size:2.2rem}
  .mission-card,.list-item{padding:18px}
  .mission-meta{gap:8px;row-gap:6px}
  .badge-row{row-gap:8px}
  .table-wrap{border-radius:18px}
  .table-wrap table{min-width:640px}
  .site-footer{padding:42px 0 28px}
  .footer-grid{grid-template-columns:1fr;gap:18px}
  .footer-note{margin-top:18px;padding-top:14px}
}
@media (max-width: 520px){
  .container{padding:0 14px}
  .site-header .bar{grid-template-columns:minmax(0,1fr) auto auto;gap:8px}
  .brand{gap:10px}
  .brand-mark{width:34px;height:34px;border-radius:12px}
  .brand-name{font-size:15px}
  .brand-sub{font-size:10px;line-height:1.3}
  .btn,.btn-secondary,.btn-ghost,.btn-success,.btn-warning,.btn-danger{min-height:44px;padding:0 14px;border-radius:12px}
  .hero-stage,.auth-side,.auth-card,.card,.domain-card,.metric,.callout,.flow-card,.form-card,.table-wrap{border-radius:18px}
  .field input,.field select,.field textarea,.field-grid input,.field-grid select,.field-grid textarea,.filters input,.filters select{min-height:46px;padding:13px 14px}
  .sidebar{padding:12px 10px 14px!important}
  .side-nav a{padding:10px 12px}
  .side-footer .btn,.side-footer .btn-secondary,.side-footer .btn-danger{min-height:44px}
  .portal-top h1,.page-title h1{font-size:2rem}
  .table-wrap table{min-width:600px}
}


/* v8.4 single-image + legal modal + mobile refinement */
.hero-stage-single{min-height:420px;padding:0;display:grid;place-items:stretch;background:linear-gradient(145deg,#0d1838,#12306a);overflow:hidden}
.hero-stage-image{width:100%;height:100%;object-fit:cover;display:block}
.hero-image-placeholder{display:grid;place-items:center;height:100%;padding:28px}
.hero-image-placeholder-inner{max-width:420px;text-align:center;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:24px;padding:28px;color:#fff;box-shadow:inset 0 0 0 1px rgba(255,255,255,.04)}
.hero-image-placeholder-inner h3{margin:16px 0 10px;color:#fff}
.hero-image-placeholder-inner .muted{color:#d7e5ff}
.legal-links-card a{color:var(--brand-strong);text-decoration:underline}
.legal-links-card label{display:block;line-height:1.7}
.legal-checklist-panel .muted{margin:6px 0 10px}
.legal-list-item{align-items:center}
.legal-list-actions{justify-content:flex-end}
.legal-modal{position:fixed;inset:0;z-index:120;display:grid;place-items:center;padding:20px}
.legal-modal.hidden{display:none!important}
.legal-modal-backdrop{position:absolute;inset:0;background:rgba(8,20,45,.58);backdrop-filter:blur(4px)}
.legal-modal-dialog{position:relative;z-index:1;width:min(860px,100%);max-height:min(88vh,860px);display:grid;grid-template-rows:auto minmax(0,1fr) auto;gap:16px;padding:22px 22px 18px}
.legal-modal-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}
.legal-close{flex:none}
.legal-modal-body{overflow:auto;border:1px solid var(--line);border-radius:18px;padding:18px;background:#fbfdff;min-height:260px;max-height:52vh;-webkit-overflow-scrolling:touch}
.legal-modal-copy{display:grid;gap:14px;color:var(--text-2);line-height:1.75}
.legal-modal-copy p{margin:0}
.legal-modal-actions{display:flex;justify-content:space-between;gap:16px;align-items:center;flex-wrap:wrap}
body.modal-open{overflow:hidden}
@media (max-width: 960px){
  .sidebar-inner{max-height:none!important;overflow:visible!important}
  .side-footer{position:static!important;background:none!important;padding-top:0!important}
  .portal-shell,.contributor-shell,.admin-shell{overflow-x:hidden}
  .portal-main,.sidebar{overflow:visible!important}
  .auth-panel{grid-template-columns:1fr!important}
  .auth-side,.auth-card{width:100%;min-width:0}
}
@media (max-width: 720px){
  .hero-stage-single{min-height:320px}
  .hero-image-placeholder{padding:18px}
  .hero-image-placeholder-inner{padding:22px;border-radius:20px}
  .legal-modal{padding:12px}
  .legal-modal-dialog{padding:18px 16px 16px;border-radius:20px;max-height:92vh}
  .legal-modal-head{flex-direction:column;align-items:flex-start}
  .legal-modal-actions{flex-direction:column;align-items:stretch}
  .legal-modal-actions .btn{width:100%}
  .legal-modal-body{max-height:54vh}
  .sidebar{border-radius:0 0 22px 22px}
}

/* V9 improvements */
.section-dark .lead,.section-dark .metric span,.section-dark .metric strong{color:#e9f1ff;}
.section-dark .metric{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12);}
.field.error input,.field.error select,.field.error textarea,.field-grid .field.error input,.field-grid .field.error select{border-color:#ff8f8f;box-shadow:0 0 0 4px rgba(197,59,59,.08);}
.helper.error{color:var(--danger);font-weight:600;}
.legal-modal-copy h4{margin:16px 0 6px;font-size:1rem;color:var(--text);}
.legal-modal-copy ul{margin:0 0 12px 18px;color:var(--text-2);}
.portal-note{font-size:13px;color:var(--muted);}
.status-draft{background:#edf2f8;color:#566781;border-color:#dce5f0;}
.confirm-dialog{max-width:480px;}
.table-scroll{overflow:auto;-webkit-overflow-scrolling:touch;}
@media (max-width:720px){ .hero-stage{min-height:320px;} .hero-stage-single{min-height:260px;} .site-header .bar{grid-template-columns:1fr auto;} .brand{min-width:0} .header-actions .btn-secondary.desktop-only{display:none} .mobile-menu a{font-size:16px;} .auth-panel{grid-template-columns:1fr;} .auth-card,.auth-side{padding:22px;} .portal-main{padding:16px;} .field-grid,.form-grid{grid-template-columns:1fr;} }


/* V10 functionality + mobile-first portal refinements */
.toast-root{position:fixed;right:18px;bottom:18px;z-index:220;display:grid;gap:10px;max-width:min(92vw,360px)}
.toast{background:#0f1830;color:#fff;border-radius:16px;padding:14px 16px;box-shadow:0 22px 60px rgba(9,23,51,.24);opacity:0;transform:translateY(8px);transition:opacity .18s ease, transform .18s ease;border:1px solid rgba(255,255,255,.08)}
.toast.show{opacity:1;transform:translateY(0)}
.toast-success{background:linear-gradient(180deg,#0b6d49,#0a5a3d)}
.toast-error{background:linear-gradient(180deg,#a23030,#7f1e1e)}
.toast-info{background:linear-gradient(180deg,#173779,#122d63)}
.toast-title{font-weight:800;margin-bottom:4px}
.toast-copy{font-size:14px;line-height:1.45}
.mobile-portal-nav{display:none}
.history-list{display:grid;gap:16px}
.history-card-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start}
.history-meta{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:14px;color:var(--muted);font-size:13px}
.submission-detail-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:18px}
.timeline-steps{display:grid;gap:12px;margin-top:10px}
.timeline-step{padding:12px 14px;border-radius:16px;border:1px solid var(--line);background:#f8fbff;color:var(--muted)}
.timeline-step.done{background:#eef4ff;border-color:#d4e1ff;color:#234ea4}
.timeline-step strong{display:block;color:var(--text);margin-bottom:4px}
.field.error input,.field.error select,.field.error textarea,.field-grid>div.error input,.field-grid>div.error select,.field-grid>div.error textarea,.video-drop.error{border-color:#ff8f8f!important;box-shadow:0 0 0 4px rgba(197,59,59,.08)!important}
.video-drop.error{background:#fff7f7}
@media (max-width: 960px){
  .portal-shell{display:block;overflow-x:hidden}
  .sidebar{display:none!important}
  .portal-main{padding-top:14px!important;overflow-x:hidden}
  .mobile-portal-nav{display:block;position:sticky;top:0;z-index:30;margin:0 0 14px;background:rgba(248,251,255,.97);backdrop-filter:blur(10px);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow-sm)}
  .mobile-portal-nav-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:8px;padding:10px}
  .mobile-portal-nav a{display:flex;align-items:center;justify-content:center;min-height:44px;padding:0 14px;border-radius:12px;background:#fff;border:1px solid var(--line);font-size:14px;font-weight:700;color:var(--text-2);text-align:center}
  .mobile-portal-nav a.active{background:#eef4ff;border-color:#d4e1ff;color:#234ea4}
  .mobile-portal-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:0 10px 10px}
  .mobile-portal-actions .btn-secondary,.mobile-portal-actions .btn-danger{width:100%;justify-content:center}
  .portal-header{margin-top:0}
  .history-meta{grid-template-columns:1fr}
  .submission-detail-grid{grid-template-columns:1fr}
  .toast-root{left:14px;right:14px;bottom:14px;max-width:none}
  .review-card-list{display:grid;gap:14px}
  .review-card-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
  .review-card-meta{display:grid;gap:10px;margin-top:12px}
}
@media (max-width: 720px){
  .toast{border-radius:14px;padding:13px 14px}
  .mobile-portal-nav-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .mobile-portal-actions{grid-template-columns:1fr}
}

.btn-danger[disabled],.btn-secondary[disabled],button[disabled]{opacity:.55;cursor:not-allowed;pointer-events:none}

/* V12 stability + mobile fixes */
html,body{max-width:100%;overflow-x:hidden}
.portal-shell,.portal-main,.mobile-portal-nav,.mobile-portal-nav-grid,.table-wrap,.review-card-list{max-width:100%;overflow-x:hidden}
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
@media (max-width:960px){
  .mobile-portal-nav{display:block;position:sticky;top:0;z-index:40}
  .mobile-portal-nav-grid{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:8px;padding:10px}
  .mobile-portal-nav a{min-width:0;white-space:normal;line-height:1.2;padding:10px 12px;min-height:48px}
  .portal-header,.portal-top,.page-title{margin-top:0}
}
@media (max-width:640px){
  .mobile-portal-nav-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  .mobile-portal-actions{display:grid!important;grid-template-columns:1fr 1fr;gap:8px;padding:0 10px 10px}
  .review-card-head,.history-card-head{display:grid;grid-template-columns:1fr;gap:10px}
  .review-card .actions,.history-actions,.actions{flex-wrap:wrap}
  .review-card .btn-secondary,.review-card .btn,.history-actions .btn-secondary,.history-actions .btn-warning,.history-actions .btn-danger{width:100%}
}


/* v14 upload consent and admin detail improvements */
.consent-panel{padding:20px 22px;background:linear-gradient(180deg,#fbfcff 0%,#f4f7fd 100%);border:1px solid #d9e3f5}
.consent-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}
.consent-header h3{margin:0 0 4px}
.consent-list{display:grid;gap:14px}
.consent-item{background:#fff;border:1px solid var(--line);border-radius:18px;padding:14px 16px;box-shadow:0 10px 28px rgba(16,24,40,.04)}
.consent-check{display:flex;gap:14px;align-items:flex-start;cursor:pointer}
.consent-check input{margin-top:4px;width:18px;height:18px;accent-color:#1f4ed8}
.consent-check-copy{display:grid;gap:4px;line-height:1.55}
.consent-check-copy strong{font-size:1rem}
.consent-details{margin-top:10px;border-top:1px dashed #d8e0ef;padding-top:10px}
.consent-details summary{cursor:pointer;font-weight:700;color:#143b8f;list-style:none}
.consent-details summary::-webkit-details-marker{display:none}
.consent-details summary::after{content:'+';float:right;font-size:1.1rem;color:#4767b7}
.consent-details[open] summary::after{content:'−'}
.consent-details-body{padding-top:10px;display:grid;gap:10px}
.compact-actions{gap:10px;flex-wrap:wrap}
.compact-actions .btn-secondary{padding:.6rem .9rem}
.review-insight-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:16px}
.review-insight-card{border:1px solid var(--line);border-radius:16px;padding:14px;background:#fbfcff}
.review-insight-card h4{margin:0 0 10px;font-size:1rem}
.key-value-list{display:grid;gap:10px}
.key-value-item{display:grid;grid-template-columns:180px 1fr;gap:12px;padding:10px 0;border-bottom:1px solid #edf1f7}
.key-value-item:last-child{border-bottom:none;padding-bottom:0}
.key-value-item strong{color:#475467;font-weight:700}
.admin-flag-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.admin-flag{display:inline-flex;align-items:center;border-radius:999px;padding:6px 10px;font-size:.84rem;font-weight:700;background:#eef4ff;color:#1849a9;border:1px solid #d3e2ff}
.admin-flag.warn{background:#fff4e5;color:#b54708;border-color:#fedf89}
.admin-flag.danger{background:#fef3f2;color:#b42318;border-color:#fecdca}
.admin-video-card .video-preview{min-height:260px}
.upload-analysis{margin-top:12px;padding:12px 14px;border-radius:14px;background:#f8fbff;border:1px solid #d7e7ff;display:grid;gap:8px}
.upload-analysis .meta-row{display:flex;flex-wrap:wrap;gap:10px}
.upload-analysis .badge{background:#fff}
@media (max-width: 900px){.review-insight-grid{grid-template-columns:1fr}.key-value-item{grid-template-columns:1fr}.consent-header{flex-direction:column;align-items:flex-start}}


/* v17 auth + legal popup improvements */
.consent-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px;padding-top:10px;border-top:1px dashed #d8e0ef}
.consent-actions .btn-secondary{min-height:40px}
.legal-readmore-dialog{width:min(920px,100%);max-height:min(90vh,900px)}
.legal-readmore-dialog .legal-modal-body{background:#fff;line-height:1.75}
.legal-readmore-dialog h4{margin:10px 0 6px}
.legal-readmore-dialog ul{margin:0;padding-left:20px}
.legal-readmore-dialog li{margin:6px 0}


/* v18 processing pipeline */
.status-processing{background:#eef4ff;color:#2457c5;border-color:#cddcff}
.status-ready_for_review{background:#eefbf3;color:#1f7a48;border-color:#c8ead6}
.status-duplicate_flagged{background:#fff5ea;color:#b35b00;border-color:#ffd7ad}


/* v19 layout polish */
:root{--max:1440px}
.portal-shell.top-shell{display:block;min-height:100vh;background:linear-gradient(180deg,#eef4fb 0%,#f6f9fd 100%)}
.portal-shell.top-shell .sidebar,
.portal-shell.top-shell .mobile-portal-nav{display:none!important}
.portal-main.portal-main-wide{padding:24px 28px 40px;max-width:1440px;margin:0 auto}
.top-shell-bar{padding:20px 24px;border-radius:28px;margin-bottom:18px;background:rgba(255,255,255,.92);border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.top-shell-brand-row{display:flex;justify-content:space-between;gap:18px;align-items:flex-start}
.top-shell-brand .brand-name{color:var(--text)}
.top-shell-brand .brand-sub{color:var(--muted)}
.top-shell-account{display:grid;gap:8px;justify-items:end;text-align:right}
.top-shell-account-line{display:grid;gap:4px}
.top-shell-nav-row{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.top-shell-nav{display:flex;flex-wrap:wrap;gap:10px}
.shell-tab{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:999px;border:1px solid var(--line);background:#f8fbff;color:var(--text-2);font-weight:700;font-size:14px}
.shell-tab.active{background:var(--brand);border-color:var(--brand);color:#fff;box-shadow:0 10px 24px rgba(43,99,255,.18)}
.top-shell-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}
.portal-header.portal-header-wide{margin-bottom:20px}
.review-pro-shell{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(360px,.92fr);gap:22px;align-items:start}
.review-main-column,.review-side-column{min-width:0}
.review-hero-card{padding:24px;border-radius:24px}
.review-hero-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-start}
.review-hero-head h1{font-size:2.25rem;line-height:1.05;margin:12px 0 8px}
.review-hero-meta{min-width:220px;display:grid;gap:12px;padding:14px 16px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,#fbfdff 0%,#f3f7ff 100%)}
.review-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin:18px 0 16px}
.review-summary-card{padding:14px 16px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,#fbfdff 0%,#f3f7ff 100%);display:grid;gap:4px}
.review-summary-card strong{font-size:1rem}
.review-video-shell{padding-top:4px}
.review-video-frame{border-radius:22px;overflow:hidden;background:#07142f;box-shadow:var(--shadow-sm);min-height:460px}
.review-video-frame video{width:100%;height:min(62vh,720px);object-fit:contain;background:#07142f}
.review-section-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-top:18px}
.review-data-card{padding:20px;border-radius:22px}
.section-headline{display:grid;gap:6px;margin-bottom:14px}
.section-headline h3{margin:0;font-size:1.1rem}
.review-kv-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0;border:1px solid var(--line);border-radius:18px;overflow:hidden;background:#fff}
.review-kv-grid .key-value-item{display:grid;gap:6px;padding:14px 16px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);background:linear-gradient(180deg,#fff 0%,#fcfdff 100%)}
.review-kv-grid .key-value-item:nth-child(2n){border-right:none}
.review-kv-grid .key-value-item strong{font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:#6a7b96}
.review-kv-wide{grid-column:1 / -1}
.hash-cell{word-break:break-all}
.review-side-column{display:grid;gap:18px;position:sticky;top:20px}
.review-decision-card,.review-checklist-card{padding:22px;border-radius:24px}
.review-decision-card .field-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.review-decision-card textarea{min-height:120px}
.review-action-row .btn,.review-action-row .btn-secondary{min-width:180px}
.review-processing-card{padding:28px;border-radius:24px}

@media (max-width: 1180px){
  .top-shell-brand-row,.top-shell-nav-row,.review-hero-head,.review-pro-shell{grid-template-columns:1fr;display:grid}
  .top-shell-account{justify-items:start;text-align:left}
  .top-shell-actions{justify-content:flex-start}
  .review-side-column{position:static}
  .review-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 860px){
  .portal-main.portal-main-wide{padding:16px}
  .top-shell-bar{padding:16px}
  .review-summary-grid,.review-section-grid,.review-kv-grid,.review-decision-card .field-grid{grid-template-columns:1fr}
  .review-kv-grid .key-value-item{border-right:none}
  .review-video-frame{min-height:300px}
  .review-video-frame video{height:320px}
}


/* v20 enterprise review redesign */
.top-shell-bar{padding:18px 22px}
.top-shell-row-main{display:grid;grid-template-columns:minmax(0,1.25fr) auto;gap:18px;align-items:center}
.top-shell-brand-wrap{display:grid;gap:14px;min-width:0}
.top-shell-meta-wrap{display:grid;gap:12px;justify-items:end}
.top-shell-nav{display:flex;flex-wrap:wrap;gap:8px}
.shell-tab{padding:9px 13px;font-size:13px}
.shell-badges{justify-content:flex-end}
.review-v20{display:grid;grid-template-columns:minmax(0,1.5fr) 420px;gap:22px;align-items:start}
.review-v20-main,.review-v20-side{min-width:0}
.review-v20-hero{padding:24px;border-radius:26px}
.review-v20-hero-head{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:18px;align-items:start}
.review-v20-hero h1{margin:10px 0 8px;font-size:2.2rem;line-height:1.04}
.review-v20-statstrip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.review-stat{padding:14px 16px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,#fbfdff 0%,#f4f7fe 100%);display:grid;gap:5px}
.review-v20-video-wrap{margin-top:18px}
.review-v20-video{border-radius:22px;overflow:hidden;background:#07142f;box-shadow:var(--shadow-sm)}
.review-v20-video video{width:100%;height:520px;object-fit:contain;background:#07142f}
.review-v20-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-top:18px}
.review-v20-panel{padding:20px;border-radius:22px}
.review-v20-panel-wide{grid-column:1 / -1}
.review-data-list{display:grid;gap:0;border:1px solid var(--line);border-radius:18px;overflow:hidden;background:#fff}
.review-data-list.compact .review-row{grid-template-columns:140px 1fr}
.review-row{display:grid;grid-template-columns:180px 1fr;border-bottom:1px solid var(--line);min-height:54px}
.review-row:last-child{border-bottom:none}
.review-row-key{padding:14px 16px;background:#f8fbff;font-size:12px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:#6a7b96;border-right:1px solid var(--line)}
.review-row-val{padding:14px 16px;color:var(--text);display:flex;align-items:center;flex-wrap:wrap;gap:8px}
.review-dup-top{margin-bottom:14px}
.review-v20-side{display:grid;gap:18px;position:sticky;top:20px}
.review-v20-decision,.review-v20-checklist{padding:22px;border-radius:24px}
.review-v20-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
.checklist-v20 .check{padding:14px 16px;border-radius:16px}
.enterprise-empty{padding:28px;border-radius:24px}
.page-skeleton{display:grid;gap:18px}
.skeleton-hero,.skeleton-panel{padding:22px;border-radius:24px}
.skeleton-grid{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(340px,.9fr);gap:18px}
.skeleton-line{height:12px;border-radius:999px;background:linear-gradient(90deg,#edf2fa 20%,#f8fbff 50%,#edf2fa 80%);background-size:200% 100%;animation:skeletonPulse 1.2s linear infinite}
.skeleton-line.lg{height:18px;width:38%}
.skeleton-line.md{height:12px;width:55%;margin-top:12px}
.skeleton-line.sm{height:12px;width:100%;margin-top:14px}
.skeleton-media{height:340px;margin-top:18px;border-radius:18px;background:linear-gradient(90deg,#edf2fa 20%,#f8fbff 50%,#edf2fa 80%);background-size:200% 100%;animation:skeletonPulse 1.2s linear infinite}
@keyframes skeletonPulse{0%{background-position:200% 0}100%{background-position:-200% 0}}

@media (max-width: 1280px){
  .top-shell-row-main,.review-v20,.review-v20-hero-head,.skeleton-grid{grid-template-columns:1fr}
  .top-shell-meta-wrap{justify-items:start}
  .shell-badges,.top-shell-actions{justify-content:flex-start}
  .review-v20-side{position:static}
}
@media (max-width: 900px){
  .review-v20-grid,.review-v20-statstrip,.review-v20-form-grid,.review-row{grid-template-columns:1fr}
  .review-row-key{border-right:none;border-bottom:1px solid var(--line)}
  .review-v20-video video{height:320px}
}
