:root{
  --bg:#f5f2ec; --surface:#ffffff; --surface2:#faf8f3;
  --ink:#1b2433; --mut:#5f6b80; --line:#e6e1d6;
  --navy:#103257; --navy-d:#0b2440; --gold:#b08d57; --gold-d:#9a7945;
  --good:#1c7c3a; --good-bg:#e8f5ec; --bad:#c0392b; --bad-bg:#fbeceb; --na:#8a93a3;
  --r:16px; --sh:0 8px 28px rgba(16,50,87,.10); --sh-sm:0 2px 8px rgba(16,50,87,.07);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;background:var(--bg);color:var(--ink);
  font:16px/1.55 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif}
body{padding-bottom:env(safe-area-inset-bottom)}
h1,h2,h3{line-height:1.2;color:var(--navy)}
.muted{color:var(--mut);font-size:13.5px}
.hidden{display:none!important}

/* header */
.bar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;
  padding:11px 16px;background:#fff;border-bottom:3px solid var(--gold);box-shadow:var(--sh-sm)}
.brand{cursor:pointer;display:flex;flex-direction:column;line-height:1.15}
.brand .firm{font-weight:700;font-size:15px;color:var(--navy);letter-spacing:.2px}
.brand .tool{font-size:11px;color:var(--gold-d);text-transform:uppercase;letter-spacing:1.4px;font-weight:600}
.bar .crest{font-size:22px}

.screen{display:none;padding:18px 16px 96px;max-width:780px;margin:0 auto}
.screen.active{display:block;animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* hero */
.hero{background:linear-gradient(160deg,var(--navy),var(--navy-d));color:#fff;border-radius:var(--r);
  padding:26px 22px;box-shadow:var(--sh);margin-bottom:6px;position:relative;overflow:hidden}
.hero:after{content:"";position:absolute;right:-40px;top:-40px;width:160px;height:160px;border-radius:50%;
  background:radial-gradient(circle,rgba(176,141,87,.35),transparent 70%)}
.hero h1{color:#fff;font-size:25px;margin:.1em 0 .3em}
.hero p{color:#cfd9e6;margin:0 0 18px}
.hero .primary{background:var(--gold);color:#241a08}
.hero .primary:hover{background:var(--gold-d)}
.sec-h{margin:24px 0 8px;font-size:12.5px;text-transform:uppercase;letter-spacing:1px;color:var(--gold-d);font-weight:700}

button{font:inherit;cursor:pointer;border:none;border-radius:12px;padding:13px 16px;font-weight:600;transition:.15s}
button:active{transform:scale(.97)}
.primary{background:var(--navy);color:#fff;box-shadow:var(--sh-sm)}
.primary:hover{background:var(--navy-d)}
.ghost{background:#fff;color:var(--navy);border:1.5px solid var(--line)}
.ghost:hover{border-color:var(--gold)}
.danger{color:var(--bad)}
.big{width:100%;font-size:17px;padding:16px}
.row{display:flex;gap:10px;margin-top:14px}.row.wrap{flex-wrap:wrap}.row button{flex:1}
.row3{display:grid;grid-template-columns:auto auto 1fr;gap:8px;margin-top:14px}

.card,.pj,.clip,.how,.wiz{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh-sm)}
.fld{display:block;margin:13px 0;font-size:13px;color:var(--mut);font-weight:600}
.fld input{display:block;width:100%;margin-top:6px;padding:13px;border-radius:12px;border:1.5px solid var(--line);
  background:var(--surface2);color:var(--ink);font-size:16px}
.fld input:focus{outline:none;border-color:var(--navy)}
textarea{width:100%;min-height:62px;padding:12px;border-radius:12px;border:1.5px solid var(--line);background:var(--surface2);color:var(--ink);font-size:16px;margin-top:10px;resize:vertical}

/* setup wizard */
.wiz{padding:16px 18px;margin:14px 0}
.wiz h3{margin:.2em 0 .6em;font-size:16px}
.stepper{display:flex;align-items:center;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line)}
.stepper:last-child{border-bottom:none}
.stepper .lab{font-size:15px;color:var(--ink);font-weight:600}
.stepper .lab small{display:block;font-weight:400;color:var(--mut);font-size:12px}
.cnt{display:flex;align-items:center;gap:14px}
.cnt button{width:40px;height:40px;border-radius:50%;background:var(--navy);color:#fff;font-size:22px;line-height:1;padding:0;display:grid;place-items:center}
.cnt .v{min-width:24px;text-align:center;font-size:19px;font-weight:700;color:var(--navy)}
.toggle{position:relative;width:52px;height:30px;border-radius:30px;background:#cfd3da;transition:.2s;cursor:pointer;flex:0 0 auto}
.toggle.on{background:var(--good)}
.toggle:after{content:"";position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:50%;background:#fff;transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.toggle.on:after{left:25px}

details.adv{margin-top:12px}
details.adv summary{cursor:pointer;font-weight:600;color:var(--navy);padding:8px 0;list-style:none}
details.adv summary::-webkit-details-marker{display:none}
details.adv summary:before{content:"▸ ";color:var(--gold-d)}
details.adv[open] summary:before{content:"▾ "}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.chip{display:flex;align-items:center;gap:6px;padding:9px 12px;border-radius:999px;border:1.5px solid var(--line);
  background:var(--surface2);color:var(--mut);font-size:13.5px;cursor:pointer}
.chip.on{background:#eef3f8;border-color:var(--navy);color:var(--navy);font-weight:600}
.chip input{display:none}

.switch{display:flex;align-items:center;gap:10px;margin:16px 0 4px;font-size:14.5px;color:var(--ink)}
.switch input{width:20px;height:20px;accent-color:var(--navy)}
.switch.sm{margin:0;font-size:12px;color:var(--mut)}

.list{display:flex;flex-direction:column;gap:10px}
.pj{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:14px}
.pj-a,.clip-a{display:flex;gap:6px}
.mini{padding:8px 11px;font-size:13px;border-radius:10px;background:var(--surface2);border:1.5px solid var(--line);color:var(--navy)}
.mini.danger{color:var(--bad);border-color:#f0d6d3}

.how{margin-top:24px;padding:6px 18px 16px}
.how ol{padding-left:18px}.how li{margin:9px 0;color:var(--mut)}.how b{color:var(--ink)}

/* interview */
.iv-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;gap:10px}
.area-name{font-size:20px;font-weight:700;color:var(--navy)}
.progress-wrap{height:6px;background:var(--line);border-radius:6px;overflow:hidden;margin:2px 0 12px}
.progress-bar{height:100%;width:0;background:linear-gradient(90deg,var(--navy),var(--gold));transition:width .3s}
.rec{display:flex;align-items:center;gap:7px;font-variant-numeric:tabular-nums;background:#fff;
  border:1.5px solid var(--line);border-radius:999px;padding:6px 12px;font-size:14px;color:var(--ink)}
.dot{width:11px;height:11px;border-radius:50%;background:#c2c8d2}
.dot.live{background:var(--bad);animation:pulse 1s infinite}
@keyframes pulse{50%{opacity:.35}}
.cam-wrap{position:relative;border-radius:var(--r);overflow:hidden;background:#0c1622;aspect-ratio:16/10;border:1px solid var(--line);box-shadow:var(--sh-sm)}
.cam-wrap video{width:100%;height:100%;object-fit:cover;display:block}
.listen{position:absolute;left:10px;bottom:10px;background:rgba(192,57,43,.95);color:#fff;font-size:12px;padding:6px 12px;border-radius:999px;opacity:0;transition:.2s;font-weight:600}
.listen.on{opacity:1}
.coach{position:absolute;right:10px;bottom:10px;background:rgba(255,255,255,.92);color:var(--navy);font-size:11.5px;padding:5px 10px;border-radius:999px;font-weight:600}
.intro{color:var(--mut);background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--gold);border-radius:12px;padding:13px;margin:12px 0}
.rec-controls{margin:12px 0}

.card{padding:16px;margin-top:12px;box-shadow:var(--sh)}
.item-counter{font-size:12px}
.item-label{font-size:19px;font-weight:700;margin:2px 0 4px;color:var(--navy)}
.item-prompt{color:var(--mut);margin-bottom:12px}
.status-btns{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.sbtn{padding:14px 8px;border:1.5px solid var(--line);background:var(--surface2);color:var(--ink);font-size:14.5px;font-weight:600}
.sbtn.good.sel{background:var(--good-bg);border-color:var(--good);color:var(--good)}
.sbtn.defect.sel{background:var(--bad-bg);border-color:var(--bad);color:var(--bad)}
.sbtn.na.sel{background:#eef0f3;border-color:var(--na);color:var(--na)}

.xrow{display:flex;flex-wrap:wrap;align-items:center;gap:8px;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--line)}
.xrow label{font-size:14.5px;color:var(--ink);flex:1 1 60%;font-weight:600}
.xrow input[type=number]{width:84px;padding:10px;border-radius:10px;border:1.5px solid var(--line);background:var(--surface2);color:var(--ink)}
.xrow .where{flex:1 1 100%;padding:10px;border-radius:10px;border:1.5px solid var(--line);background:var(--surface2);color:var(--ink)}
.yn{display:flex;gap:6px}
.yn-b{padding:9px 15px;border-radius:10px;border:1.5px solid var(--line);background:var(--surface2);color:var(--ink);font-size:14px;font-weight:600}
.yn-b.sel{background:var(--navy);border-color:var(--navy);color:#fff}

.iv-foot{position:fixed;left:0;right:0;bottom:0;display:flex;align-items:center;gap:12px;justify-content:space-between;
  padding:10px 14px calc(10px + env(safe-area-inset-bottom));background:rgba(255,255,255,.96);backdrop-filter:blur(10px);
  border-top:1px solid var(--line);z-index:15}
.iv-foot .sm{padding:7px 10px}

.clip{padding:13px}
.clip-h{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;color:var(--navy)}
.clip video{width:100%;border-radius:12px;background:#000;max-height:300px}
.clip-a{margin-top:8px}

footer.site{max-width:780px;margin:24px auto 0;padding:18px 16px;border-top:1px solid var(--line);color:var(--mut);font-size:12.5px;text-align:center}
footer.site b{color:var(--navy)}
.badge{display:inline-block;background:var(--surface2);border:1px solid var(--line);border-radius:999px;padding:3px 10px;font-size:11px;color:var(--gold-d);font-weight:700;margin-bottom:6px}
