/* GNOSIS Health — bold brand theme (CREAM / light, one language across every screen). */
/* Display: Space Grotesk · Body: Inter */
@font-face{font-family:'GH Display';src:url('/fonts/space-grotesk.woff2') format('woff2');font-weight:500 800;font-display:swap}
@font-face{font-family:'GH Sans';src:url('/fonts/inter.woff2') format('woff2');font-weight:400 600;font-display:swap}

:root{
  --bg:#f4f1e8; --rail:#ffffff; --card:#ffffff; --card2:#efe9db; --line:#e6e0d1;
  --cream:#f4f1e8; --cream-line:#e6e0d1; --ink:#141416; --ink2:#5f5f68;
  --lime:#c9f24c; --lime-ink:#5c6b12; --purple:#7c5ce8; --red:#e8402b; --teal:#1f9e88; --blue:#4257e0; --orange:#e0891a; --pink:#e0447a;
  --txt:#17171a; --muted:#6f6f78;
  --disp:'GH Display',system-ui,-apple-system,"Segoe UI",sans-serif;
  --sans:'GH Sans',system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --mono:ui-monospace,"SF Mono",Menlo,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{background:var(--bg);color:var(--txt);font-family:var(--sans);font-size:14px;-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:var(--disp);font-weight:800;letter-spacing:-.01em;line-height:1.02}
button{font-family:inherit;cursor:pointer}
input,select{font-family:inherit}
img{max-width:100%}
a{color:var(--purple)}

/* ---------- logo ---------- */
.logo{display:flex;align-items:center;gap:11px}
.logo .mark{width:38px;height:38px;flex:none}
.logo .word{font-family:var(--disp);font-weight:800;font-size:21px;line-height:.8;letter-spacing:-.01em;color:var(--ink)}
.logo .word small{display:block;font-family:var(--sans);font-weight:800;font-size:9.5px;letter-spacing:.32em;color:var(--teal);margin-top:4px}

/* ================= AUTH ================= */
.auth{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr;background:var(--cream);color:var(--ink)}
.auth .hero{padding:52px 56px;position:relative;overflow:hidden;display:flex;flex-direction:column}
.auth .hero .hh{font-family:var(--disp);font-size:52px;line-height:.98;letter-spacing:-.02em;margin:40px 0 16px}
.auth .hero .hh .g{color:var(--teal)}
.auth .hero .hs{font-size:15px;line-height:1.55;color:var(--ink2);max-width:360px}
.auth .hero .graphic{margin-top:auto;width:300px;height:300px;align-self:flex-start}
.auth .formwrap{background:var(--card);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;position:relative}
.card-auth{width:100%;max-width:380px}
.card-auth h2{font-size:30px;color:var(--txt);margin-bottom:4px}
.card-auth .sub{color:var(--muted);font-size:13px;margin-bottom:24px}
.trust{display:flex;flex-wrap:wrap;gap:8px 14px;margin-top:22px;font-size:11.5px;color:var(--muted);font-weight:600}
.trust span{display:inline-flex;align-items:center;gap:5px}
.field{margin-bottom:14px}
.field label{display:block;font-size:12px;font-weight:700;color:var(--muted);margin-bottom:6px}
.field input,.field select{width:100%;background:#faf8f2;border:1.5px solid var(--line);border-radius:13px;padding:13px 15px;color:var(--txt);font-size:15px;outline:none}
.field input:focus,.field select:focus{border-color:var(--teal)}
.field input:disabled{opacity:.55}
.field.code input{letter-spacing:.4em;font-size:20px;text-align:center;font-weight:700}
.btn{width:100%;background:var(--ink);color:#fff;border:none;border-radius:40px;padding:15px;font-size:15px;font-weight:800;display:flex;align-items:center;justify-content:center;gap:10px}
.btn .arr{width:26px;height:26px;border-radius:50%;background:var(--lime);color:var(--ink);display:flex;align-items:center;justify-content:center;font-size:15px}
.btn.lime{background:var(--lime);color:var(--lime-ink)}
.btn.red{background:var(--red);color:#fff}
.btn.ghost{background:var(--card2);color:var(--txt)}
.switch{margin-top:16px;text-align:center;color:var(--muted);font-size:13px}
.switch button{background:none;border:none;color:var(--purple);font-weight:700;font-size:13px}
.err{background:rgba(232,64,43,.1);color:#b3261e;border-radius:10px;padding:9px 12px;font-size:13px;margin-top:12px}
.ok{background:rgba(31,158,136,.14);color:#0f7a63;border-radius:10px;padding:9px 12px;font-size:13px;margin-top:8px}
.qrbox{background:var(--card2);border-radius:14px;padding:16px;text-align:center;margin-bottom:14px}
.qrbox img{width:170px;border-radius:10px;background:#fff;padding:8px}
.qrbox .sk{font-family:var(--mono);font-size:11px;color:var(--muted);margin-top:10px;word-break:break-all}

/* legal footer (shared) */
.legalfoot{display:flex;flex-wrap:wrap;gap:6px 16px;align-items:center;font-size:12px;color:var(--muted)}
.legalfoot a{color:var(--muted);text-decoration:none;font-weight:600}
.legalfoot a:hover{color:var(--txt)}
.legalfoot .sep{opacity:.5}
.auth .formwrap .legalfoot{position:absolute;bottom:22px;left:0;right:0;justify-content:center;padding:0 24px}

/* ================= APP SHELL ================= */
.app{display:grid;grid-template-columns:238px 1fr;min-height:100vh}
.rail{background:var(--rail);border-right:1px solid var(--line);display:flex;flex-direction:column;padding:22px 16px;position:sticky;top:0;height:100vh}
.rail .logo{padding:4px 6px 22px}
.rail nav{display:flex;flex-direction:column;gap:4px}
.rail nav a{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:13px;color:var(--ink2);text-decoration:none;font-weight:600;font-size:14px;position:relative}
.rail nav a .ni{width:30px;height:30px;border-radius:9px;background:var(--card2);display:flex;align-items:center;justify-content:center;font-size:15px;flex:none}
.rail nav a:hover{color:var(--txt);background:var(--card2)}
.rail nav a.on{background:var(--lime);color:var(--lime-ink)}
.rail nav a.on .ni{background:rgba(20,20,22,.1)}
.rail nav a .badge{margin-left:auto;background:var(--red);color:#fff;font-size:11px;font-weight:800;border-radius:20px;padding:1px 8px}
.rail nav a.on .badge{background:var(--ink);color:var(--lime)}
.rail .who{margin-top:auto;padding:14px 8px 4px;border-top:1px solid var(--line)}
.rail .who b{display:block;font-size:14px}
.rail .who span{display:block;font-size:12px;color:var(--muted);margin:2px 0 10px}
.rail .who button{width:100%;background:var(--card2);color:var(--txt);border:none;border-radius:11px;padding:9px;font-size:13px;font-weight:700}

.main{padding:26px 30px 30px;min-width:0;display:flex;flex-direction:column}
.top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:22px;gap:16px;flex-wrap:wrap}
.top .k{font-size:13px;color:var(--muted);font-weight:700}
.top h1{font-size:30px;margin-top:3px}
.top .simtag{display:inline-block;background:rgba(31,158,136,.12);color:var(--teal);border:1px solid rgba(31,158,136,.3);border-radius:20px;padding:4px 11px;font-size:11px;font-weight:800;margin-top:8px}
.top .actions{display:flex;gap:8px}
.top .actions button{background:var(--card);border:1px solid var(--line);color:var(--txt);border-radius:11px;padding:9px 14px;font-size:13px;font-weight:700;display:flex;align-items:center;gap:6px}
.appfoot{margin-top:28px;padding-top:16px;border-top:1px solid var(--line)}

/* cards + grids */
.card{background:var(--card);border-radius:20px;padding:18px;border:1px solid var(--line)}
.grid{display:grid;gap:14px}
.g4{grid-template-columns:repeat(4,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g2{grid-template-columns:repeat(2,1fr)}

/* stat tiles */
.tile{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:15px}
.tile .ic{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;margin-bottom:12px}
.tile .n{font-family:var(--disp);font-size:26px;letter-spacing:-.02em}
.tile .l{font-size:12px;color:var(--muted);margin-top:2px;font-weight:600}

/* big stat cards */
.stat{display:flex;align-items:center;gap:14px}
.stat .meta{flex:1;min-width:0}
.stat .meta .l{font-size:13px;color:var(--muted);font-weight:700}
.stat .meta .v{font-family:var(--disp);font-size:34px;letter-spacing:-.02em;margin-top:4px}
.stat .meta .up{font-size:12px;font-weight:800;margin-top:3px}
.up.g{color:var(--teal)}.up.o{color:var(--orange)}.up.r{color:var(--red)}
.donut{width:66px;height:66px;flex:none}
.spark{width:110px;height:46px;flex:none}

.sh{display:flex;justify-content:space-between;align-items:center;margin:26px 2px 12px}
.sh h3{font-size:17px}
.sh .va{color:var(--purple);font-size:12px;font-weight:700}
.psub{color:var(--muted);font-size:13px;margin-top:3px}

/* bars */
.rrow{display:flex;align-items:center;gap:12px;margin-bottom:13px}
.rrow .rl{width:190px;font-weight:700;font-size:13px}
.rrow .bar{flex:1;height:9px;border-radius:6px;background:var(--card2);overflow:hidden}
.rrow .bar i{display:block;height:100%;border-radius:6px}
.rrow .rn{width:24px;text-align:right;font-weight:800;color:var(--muted)}

/* trend chart */
.chart{display:flex;align-items:stretch;gap:10px;height:180px}
.chart .cb{flex:1;display:flex;flex-direction:column;gap:7px}
.chart .cb .val{text-align:center;font-size:11px;color:var(--muted);font-weight:700}
.chart .cb .barcol{flex:1;display:flex;align-items:flex-end}
.chart .cb .bar{width:100%;max-width:36px;margin:0 auto;background:var(--card2);border-radius:8px 8px 4px 4px;min-height:4px}
.chart .cb.last .bar{background:var(--lime)}
.chart .cb .xl{text-align:center;font-size:10px;color:var(--muted)}

/* flags */
.flag{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:15px 16px;border-left:4px solid var(--muted);display:flex;gap:14px;align-items:flex-start;margin-bottom:11px}
.flag.high{border-left-color:var(--red)}
.flag.medium{border-left-color:var(--orange)}
.flag.low{border-left-color:var(--teal)}
.flag .fi{width:40px;height:40px;border-radius:11px;flex:none;display:flex;align-items:center;justify-content:center;font-size:18px}
.flag.high .fi{background:rgba(232,64,43,.12)}
.flag.medium .fi{background:rgba(224,137,26,.14)}
.flag.low .fi{background:rgba(31,158,136,.14)}
.flag .fb{flex:1;min-width:0}
.flag .fb .sev{display:inline-block;font-size:10px;font-weight:800;letter-spacing:.05em;padding:2px 8px;border-radius:20px;margin-bottom:6px}
.flag.high .sev{background:rgba(232,64,43,.12);color:#b3261e}
.flag.medium .sev{background:rgba(224,137,26,.16);color:#8a5a00}
.flag.low .sev{background:rgba(31,158,136,.14);color:#0f7a63}
.flag .fb b{display:block;font-size:15px}
.flag .fb .meta{font-size:12px;color:var(--muted);margin:3px 0 6px;font-weight:600}
.flag .fb p{font-size:13px;color:#4a4a52;line-height:1.5}
.flag .fa{align-self:center;flex:none}
.flag .fa button{background:var(--lime);color:var(--lime-ink);border:none;border-radius:11px;padding:10px 14px;font-size:13px;font-weight:800;white-space:nowrap}
.flag.high .fa button{background:var(--red);color:#fff}

/* empty state */
.empty{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:40px 24px;text-align:center;max-width:560px;margin:6px auto}
.empty img{width:220px;max-width:66%;border-radius:16px;margin:0 auto 18px;display:block}
.empty b{display:block;font-family:var(--disp);font-size:22px;margin-bottom:5px}
.empty span{color:var(--muted);font-size:14px}

/* table */
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{text-align:left;color:var(--muted);font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;padding:0 12px 10px}
.tbl td{padding:13px 12px;border-top:1px solid var(--line)}
.pill{display:inline-block;border-radius:20px;padding:3px 10px;font-size:11px;font-weight:800}
.pill.ok{background:rgba(31,158,136,.14);color:#0f7a63}
.pill.warn{background:rgba(224,137,26,.16);color:#8a5a00}
.pill.bad{background:rgba(232,64,43,.12);color:#b3261e}
.lnk{background:var(--card2);color:var(--txt);border:none;border-radius:9px;padding:6px 11px;font-size:12px;font-weight:700}

/* verify + hash */
.verify{display:inline-flex;align-items:center;gap:8px;border-radius:12px;padding:10px 14px;font-weight:800;font-size:13px}
.verify.good{background:rgba(31,158,136,.14);color:#0f7a63}
.verify.bad{background:rgba(232,64,43,.12);color:#b3261e}
.hash{font-family:var(--mono);color:var(--muted)}

/* cookie consent */
.cookiebar{position:fixed;left:16px;right:16px;bottom:16px;background:var(--ink);color:#f3efe4;border-radius:16px;padding:16px 20px;display:flex;align-items:center;gap:16px;flex-wrap:wrap;z-index:100;box-shadow:0 12px 40px rgba(0,0,0,.28);max-width:760px;margin:0 auto}
.cookiebar p{font-size:13px;line-height:1.5;flex:1;min-width:220px}
.cookiebar a{color:var(--lime);font-weight:700}
.cookiebar .cbtn{display:flex;gap:8px}
.cookiebar button{border:none;border-radius:10px;padding:10px 16px;font-size:13px;font-weight:800;cursor:pointer}
.cookiebar .acc{background:var(--lime);color:var(--lime-ink)}
.cookiebar .ess{background:rgba(255,255,255,.12);color:#fff}

/* responsive */
@media (max-width:820px){
  .app{grid-template-columns:1fr}
  .rail{flex-direction:row;position:fixed;bottom:0;top:auto;left:0;right:0;height:auto;width:100%;padding:8px;border-right:none;border-top:1px solid var(--line);z-index:50;overflow-x:auto}
  .rail .logo,.rail .who{display:none}
  .rail nav{flex-direction:row;gap:2px;width:100%;justify-content:space-around}
  .rail nav a{flex-direction:column;gap:3px;font-size:10px;padding:6px}
  .rail nav a .badge{position:absolute;margin:0;transform:translate(14px,-6px)}
  .main{padding:18px 16px 90px}
  .auth{grid-template-columns:1fr}
  .auth .hero{display:none}
  .g4,.g3,.g2{grid-template-columns:1fr 1fr}
}

/* home worklist + activity */
.statusline{color:var(--muted);font-size:14.5px;margin:-6px 0 2px}
.statusline b{color:var(--txt)}
.tile.clk{cursor:pointer}
.tile.clk:hover{border-color:var(--teal)}
.sh .va{cursor:pointer}
.act{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:11px 14px;display:flex;align-items:center;gap:12px;margin-bottom:8px}
.act .ai{width:34px;height:34px;border-radius:10px;flex:none;display:flex;align-items:center;justify-content:center;font-size:15px;background:var(--card2);font-weight:800}
.act .at{flex:1;min-width:0}
.act .at b{font-size:13px;font-weight:700;display:block}
.act .at span{display:block;font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.act .tm{font-size:11px;color:var(--muted);white-space:nowrap}

/* === ELEVATE: line icons + refined chrome === */
.ic-svg{width:18px;height:18px;display:block;flex:none}
.rail nav a{color:var(--muted);font-weight:600}
.rail nav a .ni{background:transparent;width:24px;height:24px}
.rail nav a .ni .ic-svg{width:21px;height:21px;color:inherit}
.rail nav a:hover{background:var(--card2);color:var(--txt)}
.rail nav a.on{background:var(--card2);color:var(--txt);font-weight:700}
.rail nav a.on .ni{color:var(--teal)}
.rail nav a.on .badge{background:var(--red);color:#fff}
.tile{position:relative}
.tile .ti{position:absolute;top:15px;right:15px;color:var(--muted);opacity:.5}
.tile .ti .ic-svg{width:20px;height:20px}
.tile .n{font-size:30px}
.tile .l{text-transform:uppercase;letter-spacing:.055em;font-size:10.5px;color:var(--muted);margin-top:6px}
.trust{gap:9px 18px}
.trust span{gap:6px;color:var(--ink2)}
.trust .ic-svg{width:15px;height:15px;color:var(--teal)}
.act .ai{background:var(--card2);color:var(--ink2)}
.act .ai .ic-svg{width:17px;height:17px}
.flag .fi .ic-svg{width:20px;height:20px}
.flag.high .fi{color:#b3261e}.flag.medium .fi{color:#8a5a00}.flag.low .fi{color:#0f7a63}

/* === COLOUR DISTINCTION between sections/cards === */
/* tinted summary strip */
.statusline{background:rgba(224,137,26,.08);border:1px solid rgba(224,137,26,.25);border-left:4px solid var(--orange);border-radius:12px;padding:12px 15px;font-size:14px;margin:2px 0 4px}
.statusline.clear{background:rgba(31,158,136,.09);border-color:rgba(31,158,136,.26);border-left-color:var(--teal)}
/* category colour per tile */
.tile.tone{border-left:4px solid var(--c)}
.tile.tone .ti{color:var(--c);opacity:.9}
/* colour accent on each section heading */
.sh h3 .acc{display:inline-block;width:4px;height:15px;border-radius:3px;background:var(--c);margin-right:9px;vertical-align:-1px}
