:root{
  --jade:#1E5C4A; --jade-deep:#143F33; --jade-tint:#E4EFEA;
  --rice:#FBF8F1; --ink:#2B2118; --muted:#7A6E61;
  --chili:#E0532F; --turmeric:#E8A33D; --sky:#3E7CB1; --ai:#6C5CE7;
  --line:#E7DFD2;
}
*{margin:0;padding:0;box-sizing:border-box}
body{background:var(--rice);color:var(--ink);font-family:'Inter',ui-sans-serif,system-ui,sans-serif;line-height:1.5;-webkit-font-smoothing:antialiased}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit;font-size:15px;border:1.5px solid var(--line);border-radius:12px;padding:11px 13px;width:100%;background:#fff;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--jade)}
a{color:var(--jade)}

.topbar{background:var(--jade-deep);color:#fff;padding:12px 18px;display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:10}
.topbar .brand{font-weight:700;font-size:15px}
.topbar .brand small{display:block;font-size:10px;color:#9FC4B6;font-weight:500;letter-spacing:.08em;text-transform:uppercase}
.topbar .who{margin-left:auto;font-size:12px;color:#CFE4DC;text-align:right}
.topbar .who b{display:block;color:#fff}
.topbar button{color:#9FC4B6;font-size:12px;text-decoration:underline;margin-left:10px}

.page{max-width:760px;margin:0 auto;padding:18px 16px 80px}
.kicker{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--jade);margin-bottom:10px}
.card{background:#fff;border:1px solid var(--line);border-radius:16px;padding:18px;margin-bottom:14px}
.btn{display:inline-block;background:var(--jade);color:#fff;border-radius:14px;padding:13px 22px;font-weight:700;font-size:15px;text-align:center}
.btn.block{display:block;width:100%}
.btn.ghost{background:#fff;color:var(--jade);border:1.5px solid var(--jade)}
.btn.warn{background:var(--chili)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.muted{color:var(--muted);font-size:13px}
.err{background:#FBE3DB;border:1px solid #F2C3B3;color:#A33415;border-radius:10px;padding:9px 12px;font-size:13px;margin:10px 0}
.field{margin-bottom:13px}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:5px}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
h2.title{font-size:21px;margin-bottom:4px}

/* login */
.login{max-width:380px;margin:9vh auto;padding:0 18px}
.login .logo{font-size:42px;text-align:center}
.login h1{font-size:22px;text-align:center;margin:6px 0 2px}
.login .sub{text-align:center;color:var(--muted);font-size:13px;margin-bottom:22px}

/* directory */
.search{display:flex;gap:8px;margin-bottom:10px}
.fpills{display:flex;gap:7px;margin-bottom:8px;flex-wrap:wrap}
.fp{font-size:12px;font-weight:600;border:1.5px solid var(--line);border-radius:99px;padding:6px 13px;color:var(--muted);background:#fff}
.fp.on{background:var(--jade);border-color:var(--jade);color:#fff}
.brow{display:flex;align-items:center;gap:11px;padding:13px 6px;border-bottom:1px solid var(--line);width:100%;text-align:left}
.brow:hover{background:#FDFCF8}
.brow .dot{width:11px;height:11px;border-radius:99px;flex-shrink:0;background:#CFC6B6}
.brow .nm{font-weight:600;font-size:15px}
.brow .mt{font-size:12px;color:var(--muted)}
.pill{margin-left:auto;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;border-radius:99px;padding:4px 9px;flex-shrink:0}
.p-current{background:#E0EFE7;color:#1E5C4A}.p-due{background:#FCF3E4;color:#9A6B0F}
.p-never{background:#EFEFEF;color:#6B6B6B}.p-flag{background:#FBE3DB;color:#A33415}
.fab{position:fixed;bottom:24px;right:24px;width:58px;height:58px;border-radius:99px;background:var(--jade);color:#fff;font-size:28px;box-shadow:0 10px 22px -8px rgba(30,92,74,.6);z-index:5}

/* record */
.rec{border:1px solid var(--line);border-radius:16px;overflow:hidden;margin-bottom:14px;background:#fff}
.rec .band{height:7px;background:var(--chili)}
.rec .in{padding:15px 17px}
.rec h4{font-size:18px}
.kv{display:flex;gap:8px;font-size:13.5px;margin-top:6px}
.kv b{min-width:92px;color:var(--muted);font-weight:500}
.flag{margin-top:10px;background:#FCF3E4;border:1px solid #EFD9AE;color:#7A5A14;border-radius:10px;padding:8px 11px;font-size:12.5px}
.tle{display:flex;gap:10px;padding:8px 0;font-size:13px;border-bottom:1px dashed var(--line)}
.tle:last-child{border-bottom:none}
.tle .nd{width:9px;height:9px;border-radius:99px;background:var(--jade);margin-top:5px;flex-shrink:0}
.tle .nd.old{background:#CFC6B6}
.dup{margin-top:8px;background:#FCF3E4;border:1px solid #EFD9AE;color:#7A5A14;border-radius:10px;padding:8px 11px;font-size:12.5px}
.consent{display:flex;gap:10px;align-items:flex-start;background:var(--jade-tint);border-radius:12px;padding:11px 13px;font-size:13px;color:var(--jade-deep)}
.consent input{width:20px;height:20px;margin-top:1px;accent-color:var(--jade)}

/* ======== beneficiary questionnaire (full screen) ======== */
.qwrap{min-height:100vh;display:flex;flex-direction:column;padding:20px 18px 22px;max-width:520px;margin:0 auto;font-family:'Nunito','Inter',sans-serif}
.grains{display:flex;gap:5px;margin-bottom:16px}
.grains i{flex:1;height:8px;border-radius:99px;background:#EDE6D8}
.grains i.full{background:var(--jade)}
.qtag{font-size:12px;font-weight:800;color:var(--jade);letter-spacing:.12em;text-transform:uppercase}
.qtext{font-size:25px;font-weight:800;line-height:1.25;margin:8px 0 4px}
.qsub{font-size:15px;color:var(--muted);font-weight:700}
.audio{display:inline-flex;align-items:center;gap:7px;background:var(--jade-tint);color:var(--jade-deep);border-radius:99px;padding:8px 15px;font-size:14px;font-weight:800;margin:10px 0 16px;width:max-content}
.opts{display:flex;flex-direction:column;gap:11px}
.opt{display:flex;align-items:center;gap:14px;border:2.5px solid var(--line);border-radius:18px;padding:14px 16px;background:#fff;text-align:left;min-height:62px;width:100%}
.opt .pic{width:48px;height:48px;border-radius:14px;background:var(--rice);display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0}
.opt .t{font-weight:800;font-size:18px;line-height:1.2}
.opt .s{font-size:13px;color:var(--muted);font-weight:600}
.opt.on{border-color:var(--jade);background:var(--jade-tint)}
.opt.on .check{margin-left:auto;color:var(--jade);font-weight:800;font-size:22px}
.opt.choice.on{border-color:var(--chili);background:#FFF6F2}
.opt.choice.on .check{color:var(--chili)}
.chips{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.chip{border:2.5px solid var(--line);border-radius:16px;padding:14px 8px;text-align:center;background:#fff;min-height:84px}
.chip .pic{font-size:30px;display:block;margin-bottom:4px}
.chip .t{font-weight:800;font-size:15px}
.chip.on{border-color:var(--jade);background:var(--jade-tint)}
.qfree{font-size:17px;font-weight:600;min-height:110px;border-width:2.5px;border-radius:18px}
.navrow{display:flex;gap:11px;margin-top:auto;padding-top:18px}
.navrow .back{flex:1;border:2.5px solid var(--line);border-radius:16px;padding:15px;text-align:center;font-weight:800;color:var(--muted);font-size:16px;background:#fff}
.navrow .next{flex:2;background:var(--jade);color:#fff;border-radius:16px;padding:15px;text-align:center;font-weight:800;font-size:18px}
.navrow .next:disabled{background:#B9CDC5}
.langs{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:20px 0}
.lang{border:2.5px solid var(--line);border-radius:16px;padding:16px 8px;text-align:center;font-weight:800;font-size:18px;background:#fff}
.lang.on{border-color:var(--jade);background:var(--jade-tint);color:var(--jade-deep)}
.lang:disabled{opacity:.45}
.thanks{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:14px}
.thanks .big{font-size:64px}
.thanks h3{font-size:26px;font-weight:800}
.thanks p{font-size:16px;color:var(--muted);font-weight:600;max-width:320px}

/* ======== review console ======== */
.aiwrap{border:1.5px solid #D9D3F6;border-radius:16px;overflow:hidden;background:#fff;margin-bottom:14px}
.ai-head{background:#F3F1FD;padding:10px 15px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:6px}
.ai-head .t{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ai)}
.ai-head .badge{font-size:10px;background:#E2DDFB;color:#4D3FC4;border-radius:99px;padding:3px 9px;font-weight:700}
.ai-in{padding:15px 17px;font-size:14px}
.prio{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;border-radius:6px;padding:3px 9px;margin-bottom:8px}
.prio.high{background:#FBE3DB;color:#A33415}.prio.medium{background:#FCF3E4;color:#9A6B0F}.prio.low{background:#EFEFEF;color:#6B6B6B}
.ai-q{border-left:3px solid #D9D3F6;padding:2px 0 2px 12px;margin:11px 0}
.ai-q .f{font-weight:600;font-size:13.5px}
.ai-q .e{color:var(--muted);font-size:13px}
.ai-q .ask{font-style:italic;color:var(--ai);font-size:13px;margin-top:3px}
.risk{border-radius:10px;padding:9px 12px;font-size:13px;margin:8px 0;border:1px solid}
.risk.high{background:#FBE3DB;border-color:#F2C3B3;color:#7a2a10}
.risk.medium{background:#FCF3E4;border-color:#EFD9AE;color:#7A5A14}
.risk.low{background:#F4F2ED;border-color:var(--line);color:#5d564c}
.ansgrid{display:grid;grid-template-columns:64px 1fr;gap:4px 10px;font-size:13px}
.ansgrid b{color:var(--muted);font-weight:600;font-family:ui-monospace,monospace;font-size:11px;padding-top:2px}

/* ======== dashboard ======== */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:14px}
@media(min-width:560px){.stats{grid-template-columns:repeat(4,1fr)}}
.st{background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 16px}
.st .n{font-size:28px;font-weight:700;line-height:1}
.st .l{font-size:11.5px;color:var(--muted);margin-top:5px}
.st.warn .n{color:#9A6B0F}.st.flag .n{color:var(--chili)}
.bar{display:flex;align-items:center;gap:10px;margin-top:10px;font-size:13px}
.bar .lb{width:130px;color:var(--muted);flex-shrink:0}
.bar .tr{flex:1;height:13px;background:#F1ECE1;border-radius:99px;overflow:hidden}
.bar .fl2{height:100%;border-radius:99px}
.bar .v{width:36px;text-align:right;font-weight:600}
.spin{display:inline-block;animation:sp 1s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}
.center{text-align:center}
