/* ============================================================
   Family Protection Review — FinDoc Visual System
   Navy #0D1B3E · Gold #E8A422 · Plus Jakarta Sans · radius 16px
   Reference: findoc_form_active_state_fixed.html + blueprint §8
   ============================================================ */

:root{
  --navy:#0D1B3E; --navy-soft:#1a2d5a;
  --gold:#E8A422; --gold2:#F5C45E;
  --bg:#F7F8FC; --white:#fff; --border:#E2E6EE;
  --text:#1A2540; --muted:#7A8499;
  --card-bg:#fff; --input-bg:#fff; --input-border:#E2E6EE;
  --footer-bg:#0D1B3E; --footer-text:rgba(255,255,255,0.28);
  --sidebar-bg:#fff;
  /* protection accents */
  --c-life:#D93025;  --c-life-bg:#FFF0F0;
  --c-edu:#2A6FDB;   --c-edu-bg:#EDF3FD;
  --c-ci:#E87A22;    --c-ci-bg:#FFF4E8;
  --c-health:#1B8A50;--c-health-bg:#EDFAF2;
  --green:#1B8A50; --yellow:#E8A422; --red:#D93025;
  --radius:16px; --radius-sm:10px; --radius-input:9px;
  --tr:0.22s ease;
  --shadow-soft:0 3px 18px rgba(13,27,62,.08);
  --shadow-card:0 1px 3px rgba(13,27,62,.05);
}
[data-theme="dark"]{
  --bg:#0F1623; --white:#1c2438; --border:#2a3550;
  --text:#E8EBF4; --muted:#8b97b3;
  --card-bg:#1c2438; --input-bg:#111b30; --input-border:#2a3550;
  --footer-bg:#080e1c; --footer-text:rgba(255,255,255,0.22);
  --sidebar-bg:#161d2e;
  --c-life-bg:#2d0f0f; --c-edu-bg:#1a2d4a; --c-ci-bg:#2d1f0a; --c-health-bg:#0e2318;
  --shadow-soft:0 3px 18px rgba(0,0,0,.34);
  --shadow-card:0 1px 3px rgba(0,0,0,.3);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:'Plus Jakarta Sans',system-ui,-apple-system,'Segoe UI',sans-serif;
  background:var(--bg); color:var(--text);
  min-height:100vh; line-height:1.5;
  -webkit-font-smoothing:antialiased;
  transition:background var(--tr),color var(--tr);
}
a{color:inherit;}
button,input,select,textarea{font-family:inherit;}
::selection{background:rgba(232,164,34,.25);}

/* ---------- App shell ---------- */
.app{display:flex; min-height:100vh;}
.sidebar{
  width:248px; flex-shrink:0; background:var(--sidebar-bg);
  border-right:1px solid var(--border); display:flex; flex-direction:column;
  position:sticky; top:0; height:100vh; transition:background var(--tr),transform .28s ease;
  z-index:50;
}
.sidebar-brand{
  display:flex; align-items:center; gap:11px; padding:18px 18px 16px;
  border-bottom:2.5px solid var(--gold);
}
.brand-logo{
  width:40px; height:40px; border-radius:12px; flex-shrink:0;
  background:linear-gradient(135deg,var(--navy),#21407e);
  display:grid; place-items:center; box-shadow:0 6px 16px rgba(13,27,62,.28);
}
.brand-logo svg{width:24px;height:24px;}
.brand-text .brand-title{font-size:15px;font-weight:800;letter-spacing:-.3px;color:var(--text);line-height:1.1;}
.brand-text .brand-sub{font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);margin-top:2px;}
.sidebar-nav{flex:1;overflow-y:auto;padding:14px 12px;display:flex;flex-direction:column;gap:3px;}
.nav-section{font-size:9px;font-weight:800;letter-spacing:1.4px;text-transform:uppercase;color:var(--muted);padding:14px 12px 6px;}
.nav-item{
  display:flex; align-items:center; gap:11px; padding:10px 12px; border-radius:11px;
  font-size:13.5px; font-weight:700; color:var(--muted); text-decoration:none;
  border-left:3px solid transparent; transition:all .16s;
}
.nav-item svg{width:19px;height:19px;flex-shrink:0;}
.nav-item:hover{background:rgba(232,164,34,.07);color:var(--text);}
.nav-item.active{
  background:rgba(232,164,34,.12); color:var(--text);
  border-left-color:var(--gold);
}
.nav-item.active svg{color:var(--gold);}
.sidebar-foot{padding:12px;border-top:1px solid var(--border);}

.main{flex:1; min-width:0; display:flex; flex-direction:column;}

/* ---------- Topbar ---------- */
.topbar{
  background:var(--white); border-bottom:1px solid var(--border);
  padding:14px 26px; display:flex; align-items:center; gap:14px;
  position:sticky; top:0; z-index:40; transition:background var(--tr);
}
.topbar h1{font-size:19px;font-weight:800;letter-spacing:-.3px;flex:1;min-width:0;}
.topbar .subtitle{font-size:12px;color:var(--muted);font-weight:600;margin-top:1px;}
.menu-toggle{display:none;background:var(--bg);border:1.5px solid var(--border);border-radius:10px;width:40px;height:40px;cursor:pointer;align-items:center;justify-content:center;color:var(--text);}
.menu-toggle svg{width:20px;height:20px;}

.theme-toggle{
  background:var(--bg); border:1.5px solid var(--border); border-radius:22px;
  padding:7px 12px; display:flex; align-items:center; gap:7px; cursor:pointer;
  font-size:12px; font-weight:700; color:var(--muted); transition:all var(--tr); flex-shrink:0;
}
.theme-toggle:hover{border-color:var(--gold);color:var(--gold);}
.avatar-pill{
  display:flex;align-items:center;gap:9px;background:var(--bg);border:1.5px solid var(--border);
  border-radius:22px;padding:5px 13px 5px 6px;flex-shrink:0;
}
.avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold2));display:grid;place-items:center;color:var(--navy);font-weight:800;font-size:13px;flex-shrink:0;}
.avatar-pill .nm{font-size:12.5px;font-weight:700;line-height:1.1;}
.avatar-pill .rl{font-size:10px;color:var(--muted);}

.content{padding:24px 26px 60px; flex:1;}
.page-max{max-width:1280px;margin:0 auto;}

/* ---------- Cards / panels ---------- */
.panel{
  background:var(--card-bg); border:1.5px solid var(--border); border-radius:var(--radius);
  box-shadow:var(--shadow-card); transition:border-color var(--tr),box-shadow var(--tr),background var(--tr);
}
.panel-pad{padding:20px 22px;}
.panel-head{padding:16px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;justify-content:space-between;flex-wrap:wrap;}
.panel-head h2{font-size:16px;font-weight:800;}
.panel-head .gold-divider{width:42px;height:3px;background:var(--gold);border-radius:99px;margin-top:6px;}

.section-title{margin:6px 0 14px;}
.section-title h2{font-size:18px;font-weight:800;letter-spacing:-.3px;}
.section-title h2 span{color:var(--gold);}
.section-title .divider{width:46px;height:3px;background:var(--gold);border-radius:99px;margin-top:7px;}

/* ---------- KPI cards ---------- */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;}
.kpi{
  background:var(--card-bg);border:1.5px solid var(--border);border-radius:var(--radius);
  padding:18px 18px; position:relative; overflow:hidden; transition:all var(--tr);
}
.kpi:hover{border-color:#C8D2E8;box-shadow:var(--shadow-soft);transform:translateY(-2px);}
[data-theme="dark"] .kpi:hover{border-color:#3a4straight;}
.kpi .kpi-ic{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;margin-bottom:13px;}
.kpi .kpi-ic svg{width:22px;height:22px;}
.kpi .kpi-label{font-size:11px;font-weight:700;letter-spacing:.3px;color:var(--muted);text-transform:uppercase;}
.kpi .kpi-value{font-size:26px;font-weight:800;letter-spacing:-.5px;margin-top:4px;line-height:1.1;}
.kpi .kpi-sub{font-size:11.5px;color:var(--muted);margin-top:4px;font-weight:600;}
.ic-navy{background:rgba(13,27,62,.08);color:var(--navy);}
[data-theme="dark"] .ic-navy{background:#0e1a33;color:var(--gold2);}
.ic-gold{background:rgba(232,164,34,.14);color:var(--gold);}
.ic-blue{background:var(--c-edu-bg);color:var(--c-edu);}
.ic-green{background:var(--c-health-bg);color:var(--c-health);}
.ic-red{background:var(--c-life-bg);color:var(--c-life);}
.ic-orange{background:var(--c-ci-bg);color:var(--c-ci);}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border-radius:var(--radius-sm); padding:10px 18px; font-size:13.5px; font-weight:700;
  cursor:pointer; border:1.5px solid transparent; text-decoration:none; white-space:nowrap;
  transition:background .18s,transform .12s,box-shadow .18s,border-color .18s,color .18s;
}
.btn svg{width:17px;height:17px;}
.btn:active{transform:scale(.97);}
.btn-primary{background:var(--navy);color:#fff;box-shadow:0 3px 14px rgba(13,27,62,.18);}
.btn-primary:hover{background:var(--navy-soft);transform:translateY(-1px);box-shadow:0 5px 20px rgba(13,27,62,.25);}
.btn-gold{background:var(--gold);color:var(--navy);box-shadow:0 3px 14px rgba(232,164,34,.28);}
.btn-gold:hover{filter:brightness(1.05);transform:translateY(-1px);}
.btn-ghost{background:var(--card-bg);color:var(--text);border-color:var(--border);}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold);}
.btn-danger{background:var(--card-bg);color:var(--red);border-color:rgba(217,48,37,.3);}
.btn-danger:hover{background:var(--c-life-bg);border-color:var(--red);}
.btn-sm{padding:7px 13px;font-size:12.5px;border-radius:9px;}
.btn-block{width:100%;}
.btn:disabled{opacity:.55;cursor:not-allowed;}

/* icon-only action button (library) */
.icon-btn{
  width:34px;height:34px;border-radius:9px;border:1.5px solid var(--border);background:var(--card-bg);
  color:var(--muted);cursor:pointer;display:inline-grid;place-items:center;transition:all .16s;
}
.icon-btn svg{width:16px;height:16px;}
.icon-btn:hover{border-color:var(--gold);color:var(--gold);background:rgba(232,164,34,.08);}

/* ---------- Badges / status ---------- */
.badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:800;padding:4px 10px;border-radius:99px;letter-spacing:.2px;}
.badge-green{background:var(--c-health-bg);color:var(--c-health);}
.badge-yellow{background:rgba(232,164,34,.14);color:#a9760f;}
[data-theme="dark"] .badge-yellow{color:var(--gold2);}
.badge-red{background:var(--c-life-bg);color:var(--c-life);}
.badge-navy{background:rgba(13,27,62,.08);color:var(--navy);}
[data-theme="dark"] .badge-navy{background:#0e1a33;color:var(--gold2);}
.badge-muted{background:var(--bg);color:var(--muted);}
.dot{width:9px;height:9px;border-radius:50%;display:inline-block;flex-shrink:0;}
.dot-green{background:var(--green);}.dot-yellow{background:var(--yellow);}.dot-red{background:var(--red);}

/* ---------- Tables ---------- */
.tbl-wrap{overflow-x:auto;border-radius:var(--radius);}
table.tbl{width:100%;border-collapse:collapse;font-size:13px;min-width:640px;}
table.tbl thead th{
  font-size:10.5px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);
  text-align:left;padding:11px 14px;border-bottom:1.5px solid var(--border);white-space:nowrap;background:var(--bg);
}
[data-theme="dark"] table.tbl thead th{background:#141b2b;}
table.tbl tbody td{padding:12px 14px;border-bottom:1px solid var(--border);vertical-align:middle;}
table.tbl tbody tr:last-child td{border-bottom:none;}
table.tbl tbody tr:hover{background:rgba(232,164,34,.04);}
.num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap;}
.text-red{color:var(--red);font-weight:700;}
.text-muted{color:var(--muted);}
.fw8{font-weight:800;}

/* ---------- Forms / inputs ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 18px;}
.form-grid.cols-1{grid-template-columns:1fr;}
.field{display:flex;flex-direction:column;gap:5px;}
.field label{font-size:10.5px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--muted);}
.field .hint{font-size:11px;color:var(--muted);font-weight:500;}
.input,.select,textarea.input{
  width:100%;border:1.5px solid var(--input-border);border-radius:var(--radius-input);
  padding:10px 12px;font-size:13.5px;color:var(--text);background:var(--input-bg);outline:none;
  transition:border-color .2s,box-shadow .2s,background var(--tr),color var(--tr);
}
.input:focus,.select:focus,textarea.input:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(232,164,34,.13);}
.input[readonly]{background:var(--bg);color:var(--muted);}
textarea.input{resize:vertical;min-height:74px;}
.input-rp{display:flex;align-items:center;gap:0;border:1.5px solid var(--input-border);border-radius:var(--radius-input);background:var(--input-bg);overflow:hidden;transition:border-color .2s,box-shadow .2s;}
.input-rp:focus-within{border-color:var(--gold);box-shadow:0 0 0 3px rgba(232,164,34,.13);}
.input-rp .pfx{padding:10px 4px 10px 12px;font-weight:700;color:var(--muted);font-size:13px;}
.input-rp input{flex:1;border:none;background:transparent;padding:10px 12px 10px 4px;font-size:13.5px;color:var(--text);outline:none;font-weight:600;}
.input-suffix{position:relative;}
.input-suffix .sfx{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:12px;color:var(--muted);font-weight:700;}

/* ---------- Stepper ---------- */
.stepper{display:flex;align-items:center;gap:0;margin-bottom:24px;flex-wrap:wrap;}
.step{display:flex;align-items:center;gap:10px;flex:1;min-width:0;}
.step .dot-num{
  width:30px;height:30px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;
  background:var(--card-bg);border:2px solid var(--border);color:var(--muted);font-weight:800;font-size:13px;transition:all .2s;
}
.step .step-label{font-size:12.5px;font-weight:700;color:var(--muted);white-space:nowrap;}
.step .step-line{flex:1;height:2px;background:var(--border);margin:0 10px;border-radius:2px;min-width:14px;}
.step.active .dot-num{background:var(--gold);border-color:var(--gold);color:var(--navy);box-shadow:0 3px 10px rgba(232,164,34,.3);}
.step.active .step-label{color:var(--text);}
.step.done .dot-num{background:var(--navy);border-color:var(--navy);color:#fff;}
.step.done .step-label{color:var(--text);}
.step:last-child .step-line{display:none;}

.step-panel{display:none;animation:fadeUp .35s both;}
.step-panel.active{display:block;}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:translateY(0);}}

.form-actions{display:flex;justify-content:space-between;gap:12px;margin-top:22px;padding-top:18px;border-top:1px solid var(--border);}

/* ---------- Repeater rows (family / policy) ---------- */
.repeater-item{
  border:1.5px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:14px;
  background:var(--bg);position:relative;
}
[data-theme="dark"] .repeater-item{background:#141b2b;}
.repeater-item .rm-btn{position:absolute;top:12px;right:12px;}
.repeater-head{font-size:12px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;}

/* ---------- Toggle ---------- */
.toggle{display:inline-flex;align-items:center;gap:9px;cursor:pointer;font-size:13px;font-weight:600;}
.toggle input{display:none;}
.toggle .track{width:40px;height:22px;border-radius:99px;background:var(--border);position:relative;transition:background .2s;flex-shrink:0;}
.toggle .track::after{content:'';position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.25);}
.toggle input:checked + .track{background:var(--gold);}
.toggle input:checked + .track::after{transform:translateX(18px);}

/* ---------- Library list ---------- */
.lib-toolbar{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-bottom:18px;}
.search-box{flex:1;min-width:220px;position:relative;}
.search-box svg{position:absolute;left:13px;top:50%;transform:translateY(-50%);width:17px;height:17px;color:var(--muted);}
.search-box input{padding-left:38px;}
.status-cell{display:flex;align-items:center;gap:8px;}

/* ---------- Empty state ---------- */
.empty{text-align:center;padding:54px 24px;color:var(--muted);}
.empty .empty-ic{width:64px;height:64px;border-radius:18px;background:var(--bg);display:grid;place-items:center;margin:0 auto 16px;}
.empty .empty-ic svg{width:30px;height:30px;color:var(--muted);}
.empty h3{font-size:16px;font-weight:800;color:var(--text);margin-bottom:6px;}
.empty p{font-size:13px;margin-bottom:18px;}

/* ---------- Toast ---------- */
.toast{
  position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(80px);
  background:var(--navy);color:#fff;border-radius:12px;padding:13px 22px;
  font-size:13px;font-weight:600;display:flex;align-items:center;gap:10px;
  box-shadow:0 8px 32px rgba(0,0,0,.28);z-index:99999;opacity:0;white-space:nowrap;
  transition:transform .35s cubic-bezier(.34,1.56,.64,1),opacity .3s;
}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1;}
.toast.success{border-left:4px solid var(--green);}
.toast.error{border-left:4px solid var(--red);}
.toast svg{width:18px;height:18px;}

/* ---------- Modal ---------- */
.modal-overlay{position:fixed;inset:0;background:rgba(7,12,26,.55);backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center;z-index:9000;padding:20px;}
.modal-overlay.show{display:flex;}
.modal{background:var(--card-bg);border:1.5px solid var(--border);border-radius:var(--radius);max-width:420px;width:100%;padding:24px;box-shadow:0 20px 60px rgba(0,0,0,.3);animation:fadeUp .25s both;}
.modal h3{font-size:17px;font-weight:800;margin-bottom:8px;}
.modal p{font-size:13.5px;color:var(--muted);margin-bottom:20px;line-height:1.55;}
.modal-actions{display:flex;gap:10px;justify-content:flex-end;}

/* ---------- Login ---------- */
.login-wrap{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;}
.login-aside{background:linear-gradient(155deg,#0D1B3E 0%,#16265a 60%,#0a1430 100%);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:48px;color:#fff;}
.login-aside::before{content:"";position:absolute;width:320px;height:320px;border-radius:50%;background:var(--gold);opacity:.12;top:-70px;right:-60px;}
.login-aside::after{content:"";position:absolute;width:220px;height:220px;border-radius:50%;background:var(--gold);opacity:.07;bottom:30px;left:-50px;}
.login-aside .la-inner{position:relative;z-index:2;max-width:360px;}
.login-aside .la-logo{width:60px;height:60px;border-radius:17px;background:rgba(232,164,34,.16);border:1.5px solid rgba(232,164,34,.35);display:grid;place-items:center;margin-bottom:24px;}
.login-aside .la-logo svg{width:34px;height:34px;}
.login-aside h2{font-size:30px;font-weight:800;letter-spacing:-.6px;line-height:1.15;margin-bottom:14px;}
.login-aside h2 span{color:var(--gold2);}
.login-aside p{font-size:14px;color:rgba(255,255,255,.7);line-height:1.6;}
.login-aside .la-foot{position:absolute;bottom:32px;left:48px;right:48px;font-size:12px;color:rgba(255,255,255,.45);z-index:2;}
.login-main{display:flex;align-items:center;justify-content:center;padding:40px 28px;background:var(--bg);}
.login-card{width:100%;max-width:380px;}
.login-card .lc-brand{font-size:11px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:8px;}
.login-card h1{font-size:26px;font-weight:800;letter-spacing:-.4px;margin-bottom:6px;}
.login-card .lc-sub{font-size:13.5px;color:var(--muted);margin-bottom:26px;}
.login-card .field{margin-bottom:16px;}
.login-row{display:flex;align-items:center;justify-content:space-between;margin:6px 0 20px;font-size:12.5px;}
.login-err{background:var(--c-life-bg);color:var(--red);border:1.5px solid rgba(217,48,37,.3);border-radius:10px;padding:11px 14px;font-size:13px;font-weight:600;margin-bottom:18px;}
.login-hint{margin-top:22px;font-size:11.5px;color:var(--muted);text-align:center;line-height:1.6;}

/* ---------- Client Summary (preview + public + pdf-screen) ---------- */
.summary-doc{max-width:1180px;margin:0 auto;}
.cs-header{
  background:var(--card-bg);border:1.5px solid var(--border);border-radius:var(--radius);
  padding:20px 24px;display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-bottom:16px;
  border-bottom:2.5px solid var(--gold);
}
.cs-header .cs-logo{width:48px;height:48px;border-radius:13px;background:linear-gradient(135deg,var(--navy),#21407e);display:grid;place-items:center;flex-shrink:0;}
.cs-header .cs-logo svg{width:28px;height:28px;}
.cs-title h2{font-size:20px;font-weight:800;letter-spacing:-.4px;}
.cs-title .cs-client{font-size:14px;color:var(--gold);font-weight:800;margin-top:1px;}
.cs-meta{margin-left:auto;display:flex;gap:26px;flex-wrap:wrap;}
.cs-meta .m-label{font-size:9.5px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--muted);}
.cs-meta .m-val{font-size:13.5px;font-weight:700;margin-top:2px;}

.cs-section-label{display:flex;align-items:center;gap:10px;margin:22px 0 12px;}
.cs-section-label .sl-badge{width:28px;height:28px;border-radius:8px;background:var(--navy);color:#fff;display:grid;place-items:center;font-weight:800;font-size:13px;flex-shrink:0;}
[data-theme="dark"] .cs-section-label .sl-badge{background:#0a1124;color:var(--gold2);}
.cs-section-label h3{font-size:15px;font-weight:800;letter-spacing:.2px;}

/* Section A basis cards */
.basis-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.basis-card{background:var(--card-bg);border:1.5px solid var(--border);border-radius:var(--radius);padding:16px 18px;display:flex;align-items:center;gap:14px;}
.basis-card .b-ic{width:42px;height:42px;border-radius:11px;display:grid;place-items:center;flex-shrink:0;background:rgba(232,164,34,.12);color:var(--gold);}
.basis-card .b-ic svg{width:22px;height:22px;}
.basis-card .b-label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;}
.basis-card .b-val{font-size:21px;font-weight:800;letter-spacing:-.4px;margin-top:2px;}
.basis-card .b-formula{font-size:11px;color:var(--muted);margin-top:2px;}

/* Section B summary + focus */
.summary-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.sum-card{background:var(--card-bg);border:1.5px solid var(--border);border-radius:var(--radius);padding:15px 16px;position:relative;overflow:hidden;}
.sum-card .accent-bar{position:absolute;top:0;left:0;width:4px;height:100%;}
.sum-card .sc-top{display:flex;align-items:center;gap:10px;margin-bottom:9px;}
.sum-card .sc-ic{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;flex-shrink:0;}
.sum-card .sc-ic svg{width:20px;height:20px;}
.sum-card .sc-name{font-size:13px;font-weight:800;flex:1;}
.sum-card .sc-text{font-size:11.5px;color:var(--muted);line-height:1.55;}
.acc-life{background:var(--c-life);} .acc-edu{background:var(--c-edu);}
.acc-ci{background:var(--c-ci);} .acc-health{background:var(--c-health);}

.legend-bar{display:flex;gap:24px;flex-wrap:wrap;align-items:center;background:var(--card-bg);border:1.5px solid var(--border);border-radius:var(--radius);padding:14px 18px;margin-top:14px;}
.legend-bar .lg{display:flex;align-items:center;gap:8px;font-size:12.5px;font-weight:700;}
.legend-title{font-size:10.5px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--muted);}

.focus-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:14px;}
.focus-card{border-radius:var(--radius);padding:14px;border:1.5px solid var(--border);}
.focus-card.f-life{background:var(--c-life-bg);} .focus-card.f-ci{background:var(--c-ci-bg);}
.focus-card.f-health{background:var(--c-health-bg);} .focus-card.f-edu{background:var(--c-edu-bg);}
.focus-card .f-title{font-size:12px;font-weight:800;letter-spacing:.5px;margin-bottom:6px;}
.focus-card .f-desc{font-size:11px;line-height:1.5;color:var(--text);opacity:.85;}

/* Section C table */
.posisi-table{font-size:12px;}
.posisi-table thead th{font-size:9.5px;}
.area-pill{display:inline-flex;align-items:center;gap:7px;font-weight:800;font-size:12px;}
.area-pill .ap-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0;}

/* Footer (navy bar, clickable) */
.cs-footer{
  background:var(--footer-bg);border-radius:14px;padding:16px 22px;margin-top:22px;
  display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
}
.cs-footer .ff-block{display:flex;align-items:center;gap:9px;color:rgba(255,255,255,.85);font-size:13px;font-weight:700;}
.cs-footer .ff-block svg{width:17px;height:17px;color:var(--gold2);flex-shrink:0;}
.cs-footer .ff-label{color:var(--gold2);font-weight:800;}
.cs-footer a{color:#fff;text-decoration:none;font-weight:700;}
.cs-footer a:hover{text-decoration:underline;color:var(--gold2);}
.cs-footer .ff-sep{width:1px;height:20px;background:rgba(255,255,255,.18);}

/* action strip (preview/public) */
.action-strip{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px;}

/* public page wrapper */
.public-wrap{min-height:100vh;background:var(--bg);padding:26px 20px 50px;}

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .kpi-grid{grid-template-columns:repeat(2,1fr);}
  .summary-cards{grid-template-columns:repeat(2,1fr);}
  .focus-grid{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:860px){
  .sidebar{position:fixed;left:0;top:0;transform:translateX(-100%);box-shadow:0 0 40px rgba(0,0,0,.3);}
  .sidebar.open{transform:translateX(0);}
  .menu-toggle{display:inline-flex;}
  .sidebar-backdrop{display:none;position:fixed;inset:0;background:rgba(7,12,26,.5);z-index:45;}
  .sidebar-backdrop.show{display:block;}
  .login-wrap{grid-template-columns:1fr;}
  .login-aside{display:none;}
}
@media (max-width:640px){
  .content{padding:18px 14px 80px;}
  .topbar{padding:12px 14px;}
  .kpi-grid{grid-template-columns:1fr 1fr;gap:11px;}
  .form-grid{grid-template-columns:1fr;}
  .basis-grid{grid-template-columns:1fr;}
  .summary-cards{grid-template-columns:1fr;}
  .focus-grid{grid-template-columns:1fr 1fr;}
  .step .step-label{display:none;}
  .cs-meta{margin-left:0;width:100%;gap:18px;}
  .stepper{gap:0;}
  .form-actions .btn{flex:1;}
  /* tables -> horizontal scroll preserved via .tbl-wrap */
}
