/* ClickTrap app styles — shell, components, forms. Colours/fonts come from tokens.css. */
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:var(--f-body);color:var(--text);background:var(--bg);font-size:14px;line-height:1.5}
a{color:var(--teal)}
h1,h2,h3{font-family:var(--f-head)}

/* ---------- top bar ---------- */
.topbar{position:fixed;top:0;left:0;right:0;height:var(--bar-h);z-index:30;
  display:flex;align-items:center;gap:18px;padding:0 18px;
  background:linear-gradient(180deg,var(--bar-2),var(--bar));color:var(--bar-text);
  font-family:var(--f-chrome);box-shadow:0 1px 0 rgba(0,0,0,.22),0 2px 8px rgba(0,0,0,.12)}
.topbar .brand{display:flex;align-items:center;gap:10px;font-weight:600;letter-spacing:.03em;font-size:15px}
.topbar .brand .mark{width:18px;height:18px;border-radius:5px;background:var(--accent);
  box-shadow:inset 0 0 0 2px rgba(255,255,255,.18)}
.topbar .spacer{flex:1}
.topbar .ctx{color:var(--bar-muted);font-size:12.5px}
.topbar .ctx b{color:var(--bar-text);font-weight:600}
.topbar .user{display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--bar-text);font-family:var(--f-chrome);
  cursor:pointer;padding:6px 9px;border-radius:8px;background:transparent;border:0}
.topbar .user:hover{background:rgba(255,255,255,.09)}
.topbar .avatar{width:26px;height:26px;border-radius:50%;background:var(--accent);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600}
.topbar .caret{color:var(--bar-muted);font-size:inherit;display:inline-block;transition:transform .15s}

/* ---------- user dropdown menu ---------- */
.usermenu{position:relative}
.usermenu>summary{list-style:none;cursor:pointer}
.usermenu>summary::-webkit-details-marker{display:none}
.usermenu>summary::marker{content:""}
.usermenu[open] .caret{transform:rotate(180deg)}
.usermenu .menu{position:absolute;top:calc(100% + 6px);right:0;min-width:194px;background:var(--card);
  border:1px solid var(--line);border-radius:10px;box-shadow:0 12px 32px rgba(0,0,0,.20);padding:6px;z-index:40;font-family:var(--f-label)}
.usermenu .menu form{margin:0}
.usermenu .menu .who{padding:7px 10px 9px;border-bottom:1px solid var(--line);margin-bottom:5px}
.usermenu .menu .who .nm{font-size:12.5px;color:var(--text);font-weight:600}
.usermenu .menu .who .em{font-size:11px;color:var(--faint)}
.usermenu .menu-item{display:flex;align-items:center;gap:8px;width:100%;text-align:left;background:transparent;border:0;
  border-radius:7px;padding:8px 10px;font:inherit;font-size:12.5px;color:var(--text);cursor:pointer;text-decoration:none}
.usermenu .menu-item:hover{background:var(--hover)}
.usermenu .menu-item.disabled{opacity:.5;pointer-events:none}
.usermenu .menu-item .soon{margin-left:auto;font-size:8px;letter-spacing:.12em;color:var(--faint);border:1px solid var(--line);border-radius:4px;padding:1px 5px}

/* ---------- shell + sidebar ---------- */
.shell{display:flex;padding-top:var(--bar-h);min-height:100vh}
.side{width:var(--sidebar-w);flex:0 0 auto;background:var(--side-bg);
  border-right:1px solid var(--side-bd);box-shadow:3px 0 10px -8px rgba(0,0,0,.22);
  display:flex;flex-direction:column;position:sticky;top:var(--bar-h);height:calc(100vh - var(--bar-h));z-index:5}
.side nav{padding:12px 10px;display:flex;flex-direction:column;gap:1px}
.side .grp{font-family:var(--f-label);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);padding:16px 10px 6px}
.side a{font-family:var(--f-label);font-size:12px;letter-spacing:.02em;color:var(--text-2);text-decoration:none;
  padding:8px 10px;border-radius:7px;display:flex;align-items:center;gap:10px}
.side a:hover{background:var(--hover)}
.side a.active{background:var(--bar);color:var(--bar-text)}
.side a.disabled{opacity:.5;pointer-events:none}
.side a .ic{width:14px;text-align:center;opacity:.65;font-size:12px}
.side a .soon{margin-left:auto;font-size:8px;letter-spacing:.12em;color:var(--faint);border:1px solid var(--side-bd);border-radius:4px;padding:1px 5px}
.side .foot{margin-top:auto;padding:12px;border-top:1px solid var(--side-bd);font-family:var(--f-label);font-size:10px;color:var(--faint);line-height:1.5}

/* ---------- main content ---------- */
.main{flex:1;min-width:0;padding:22px 26px 44px;max-width:1180px}
.page-h{border-bottom:1px solid var(--text);padding-bottom:9px}
.page-h h1{font-size:24px;font-weight:600;letter-spacing:.01em;margin:0}
.page-h .sub{font-family:var(--f-label);font-size:11.5px;color:var(--muted);margin-top:7px}

.note{background:var(--card);border:1px dashed var(--chip-bd);border-radius:7px;padding:9px 12px;
  font-family:var(--f-label);font-size:11px;color:var(--muted);margin:14px 0 2px;line-height:1.5}

/* ---------- section header ---------- */
.sec{font-family:var(--f-label);font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);
  margin:26px 0 11px;border-bottom:1px solid var(--line);padding-bottom:5px}
.sec .n{text-transform:none;letter-spacing:0;font-weight:normal;color:var(--faint)}

/* ---------- per-view "settings bar" ---------- */
.filters{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:16px 0 2px}
.fbtn{font-family:var(--f-label);font-size:11.5px;color:var(--text-2);background:var(--card);border:1px solid var(--line);
  border-radius:7px;padding:6px 11px;cursor:pointer;display:flex;gap:7px;align-items:center}
.fbtn:hover{border-color:var(--faint)}
.fbtn .v{color:var(--text);font-weight:bold}
.fbtn .cx{color:var(--faint);font-size:9px}
.filters .rt{margin-left:auto;font-family:var(--f-label);font-size:11px;color:var(--faint);cursor:pointer}

/* ---------- scope tabs ---------- */
.tabs{display:flex;flex-wrap:wrap;margin:18px 0 0;border-bottom:1px solid var(--text)}
.tab{padding:7px 16px;font-family:var(--f-label);font-size:12px;cursor:pointer;border:1px solid var(--text);
  border-bottom:none;background:var(--chip);margin-right:3px;color:var(--muted)}
.tab.active{background:var(--bg);color:var(--text);font-weight:bold;position:relative;top:1px}

/* ---------- RAG verdict pills ---------- */
.verdict{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin:16px 0 2px}
.pill{font-family:var(--f-label);font-size:12px;padding:7px 12px;border-radius:6px;border:1px solid;display:flex;gap:8px;align-items:center}
.pill b{font-size:11px;text-transform:uppercase;letter-spacing:.05em}
.pill .ctx{color:var(--faint)}
.dot{width:10px;height:10px;border-radius:50%;display:inline-block}
.green{background:var(--g-bg);border-color:var(--g-bd);color:var(--g-tx)} .green .dot{background:#2e9b3a}
.amber{background:var(--a-bg);border-color:var(--a-bd);color:var(--a-tx)} .amber .dot{background:#e0a213}
.red{background:var(--r-bg);border-color:var(--r-bd);color:var(--r-tx)} .red .dot{background:#d8521f}

/* ---------- KPI tiles ---------- */
.tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:6px 0}
.tile{border:1px solid var(--line);background:var(--card);padding:12px 14px;border-radius:7px}
.tile .lab{font-family:var(--f-label);font-size:10.5px;color:var(--faint);text-transform:uppercase;letter-spacing:.04em}
.tile .val{font-family:var(--f-head);font-size:26px;margin:4px 0 2px;color:var(--text)}
.tile .d{font-family:var(--f-label);font-size:11px;color:var(--muted)}
.up{color:var(--rust)} .down{color:var(--green)}

/* ---------- card + chart placeholder ---------- */
.card{border:1px solid var(--line);background:var(--card);border-radius:7px;padding:12px 14px;margin-top:4px}
.cviews{display:flex;flex-wrap:wrap;gap:5px;margin:0 0 10px;border-bottom:1px solid var(--line-soft);padding-bottom:9px}
.cv{font-family:var(--f-label);font-size:11px;padding:5px 11px;border:1px solid var(--chip-bd);background:var(--chip);color:var(--muted);border-radius:5px;cursor:pointer}
.cv.active{background:var(--fill);color:var(--fill-text);border-color:var(--fill)}
.chart-ph{height:300px;border:1px dashed var(--chip-bd);border-radius:7px;display:flex;align-items:center;justify-content:center;
  text-align:center;color:var(--faint);font-family:var(--f-label);font-size:12px;background:var(--bg)}

/* ---------- tables ---------- */
table{width:100%;border-collapse:collapse;font-size:12.5px;margin-top:6px}
th,td{border:1px solid var(--line);padding:7px 9px;text-align:left;vertical-align:middle}
th{background:var(--chip);font-family:var(--f-label);font-size:10.5px;text-transform:uppercase;letter-spacing:.03em;color:var(--muted)}
td .mono{font-family:var(--f-label)}
.subhead td, td.subhead{background:var(--chip);font-family:var(--f-label);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--faint)}
td form{margin:0}
.col-fit{width:1%;white-space:nowrap}
.col-fit .btn-row{flex-wrap:nowrap}   /* keep Approve/Deny on one line; the column widens to fit */
.inline-role{margin:0}
.inline-role select{width:auto;padding:4px 26px 4px 9px;font-size:12px;border-radius:6px}
.tag{font-family:var(--f-label);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);
  border:1px solid var(--line);border-radius:4px;padding:1px 5px;margin-left:5px;vertical-align:middle}

.foot{margin-top:30px;border-top:1px solid var(--line);padding-top:11px;font-family:var(--f-label);font-size:10.5px;color:var(--faint)}

/* ---------- forms + buttons ---------- */
.field{margin:0 0 13px}
.field>label{display:block;font-family:var(--f-label);font-size:11px;letter-spacing:.04em;color:var(--muted);text-transform:uppercase;margin-bottom:5px}
input[type=text],input[type=email],input[type=password],input[type=date],select{width:100%;font-family:var(--f-body);font-size:14px;color:var(--text);
  background:var(--card);border:1px solid var(--line);border-radius:8px;padding:9px 11px}
input:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb, var(--accent) 22%, transparent)}
input:disabled{opacity:.6;cursor:not-allowed}
.form-narrow{max-width:420px}
.field .err{color:var(--r-tx);font-family:var(--f-label);font-size:11px;margin-top:4px}
.field.chk{display:flex;align-items:center;gap:8px}
.field.chk input{width:auto;margin:0}
.field.chk label{font-family:var(--f-label);font-size:12.5px;color:var(--text-2);text-transform:none;letter-spacing:0;margin:0}

.btn{font-family:var(--f-label);font-size:13px;background:var(--fill);color:var(--fill-text);border:1px solid var(--fill);
  border-radius:8px;padding:9px 16px;cursor:pointer;display:inline-flex;align-items:center;gap:7px}
.btn:hover{opacity:.92}
.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--line)}
.btn-ghost:hover{background:var(--hover);border-color:var(--faint);opacity:1}
.btn-sm{padding:5px 11px;font-size:11.5px;border-radius:6px}
.btn-block{display:flex;width:100%;justify-content:center}
.btn-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

/* ---------- flash messages ---------- */
.flashes{list-style:none;margin:0 0 14px;padding:0}
.flash{font-family:var(--f-label);font-size:12.5px;padding:9px 13px;border-radius:8px;margin:0 0 8px;border:1px solid}
.flash-info{background:var(--chip);border-color:var(--line);color:var(--text)}
.flash-error{background:var(--r-bg);border-color:var(--r-bd);color:var(--r-tx)}

/* ---------- centred auth/public layout ---------- */
.authwrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.authcard{width:100%;max-width:382px;background:var(--card);border:1px solid var(--line);border-radius:12px;
  padding:24px 26px 22px;box-shadow:0 8px 34px rgba(0,0,0,.07)}
.authbrand{display:flex;align-items:center;gap:10px;font-family:var(--f-chrome);font-weight:600;letter-spacing:.03em;color:var(--text)}
.authbrand .mark{width:18px;height:18px;border-radius:5px;background:var(--accent)}
.authcard h1{font-size:21px;margin:14px 0 4px}
.authcard .lead{font-family:var(--f-label);font-size:12px;color:var(--muted);margin:0 0 16px}
.auth-or{display:flex;align-items:center;gap:10px;color:var(--faint);font-family:var(--f-label);font-size:11px;margin:14px 0;text-transform:uppercase;letter-spacing:.1em}
.auth-or::before,.auth-or::after{content:"";flex:1;height:1px;background:var(--line)}
.auth-alt{margin-top:16px;font-family:var(--f-label);font-size:12px;color:var(--muted);text-align:center}

/* ---------- settings: section titles + theme picker ---------- */
.main h2{font-family:var(--f-head);font-size:17px;font-weight:600;margin:30px 0 8px;
  border-bottom:1px solid var(--line);padding-bottom:6px}
.main h2:first-of-type{margin-top:18px}
.scheme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:10px;margin:6px 0}
.scheme-opt{display:flex;align-items:center;gap:9px;border:1px solid var(--line);border-radius:9px;padding:9px 11px;cursor:pointer;background:var(--card)}
.scheme-opt:hover{border-color:var(--faint)}
.scheme-opt input{width:auto;margin:0}
.scheme-opt .sw{width:22px;height:22px;border-radius:5px;border:1px solid var(--line);flex:0 0 auto}
.scheme-opt .nm{font-family:var(--f-label);font-size:12.5px;color:var(--text)}
.scheme-opt .md{font-family:var(--f-label);font-size:10.5px;color:var(--faint);margin-left:auto}
.scheme-opt:has(input:checked){border-color:var(--accent);box-shadow:0 0 0 2px color-mix(in srgb, var(--accent) 30%, transparent)}

/* ---------- account settings: two-column grid + prominent toggle ---------- */
.settings-form{max-width:680px}
.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:15px 20px;margin:2px 0 4px}
.settings-grid .field{margin:0}
.settings-grid .full{grid-column:1 / -1}
.toggle-card{display:flex;gap:12px;align-items:flex-start;border:1px solid var(--line);border-radius:9px;
  padding:13px 15px;background:var(--card);margin:18px 0 6px;max-width:680px}
.toggle-card input{width:auto;margin:2px 0 0;flex:0 0 auto}
.toggle-card label{display:flex;flex-direction:column;gap:3px;cursor:pointer;margin:0}
.toggle-card .t{font-family:var(--f-label);font-size:13px;font-weight:600;color:var(--text);text-transform:none;letter-spacing:0}
.toggle-card .d{font-size:12px;color:var(--muted);line-height:1.45}
@media(max-width:640px){.settings-grid{grid-template-columns:1fr}}

@media(max-width:860px){.tiles{grid-template-columns:repeat(2,1fr)}.side{display:none}}
