/* ============================================================
   Gavrun Console — Admin Portal (Damson)
   Mirrors the real Gavrun Admin Portal, recolored into the
   Damson language. Pairs with damson.css (tokens, fonts, chips).
   ============================================================ */
:root{
  --side-w:264px;
  --app-bg:var(--paper);
}
body{background:var(--app-bg);}

.app{display:flex;min-height:100vh;}

/* ---------- sidebar (dark plum) ---------- */
.side{width:var(--side-w);flex:none;background:var(--dark);border-right:1px solid var(--dark-line);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;}
.side-brand{padding:24px 22px 20px;border-bottom:1px solid var(--dark-line);}
.side-brand .logo{display:inline-flex;align-items:center;gap:10px;background:rgba(252,247,241,.08);border:1px solid var(--dark-line);border-radius:100px;padding:7px 16px 7px 8px;margin-bottom:18px;}
.side-brand .logo .mk{width:28px;height:28px;border-radius:9px;background:linear-gradient(150deg,#C977A0,var(--plum));color:#fff;font-family:var(--disp);font-size:19px;display:grid;place-items:center;}
.side-brand .logo .wm{font-family:var(--sans);font-weight:700;font-size:14px;letter-spacing:.14em;color:#fff;}
.side-brand .ttl{font-family:var(--disp);font-size:27px;color:#fff;line-height:1;}
.side-brand .sub{font-size:12.5px;color:var(--dark-ink-3);margin-top:7px;}
.side-nav{padding:14px 14px;display:flex;flex-direction:column;gap:2px;overflow-y:auto;}
.nav-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:11px;font-size:14.5px;font-weight:500;color:var(--dark-ink-2);cursor:pointer;transition:background .15s,color .15s;border:none;text-align:left;background:none;font-family:var(--sans);width:100%;}
.nav-item svg{width:17px;height:17px;flex:none;opacity:.75;}
.nav-item:hover{background:rgba(252,247,241,.06);color:#fff;}
.nav-item.on{background:rgba(201,119,160,.22);color:#fff;}
.nav-item.on svg{opacity:1;color:#E8A9C6;}

/* ---------- main ---------- */
.main{flex:1;min-width:0;display:flex;flex-direction:column;}
.content{padding:26px 30px 56px;max-width:1640px;width:100%;}

/* persistent portal header card */
.portal-head{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);padding:24px 30px;margin-bottom:16px;}
.portal-top{display:flex;align-items:center;gap:14px;margin-bottom:14px;}
.portal-top .brandline{display:inline-flex;align-items:center;gap:9px;}
.portal-top .brandline .mk{width:26px;height:26px;border-radius:8px;background:var(--plum);color:#fff;font-family:var(--disp);font-size:17px;display:grid;place-items:center;}
.portal-top .brandline .wm{font-family:var(--sans);font-weight:700;font-size:13px;letter-spacing:.12em;color:var(--ink);}
.portal-top .brandline .for{font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--plum);font-weight:500;}
.portal-top .right{margin-left:auto;display:flex;align-items:center;gap:16px;}
.portal-top .who{font-size:13.5px;color:var(--ink-2);}
.portal-top .who b{color:var(--ink);font-weight:600;}
.portal-head h1{font-size:clamp(34px,3.8vw,48px);line-height:1.02;}
.portal-head .lead{font-size:15px;color:var(--ink-2);margin:8px 0 0;}

/* per-page info banner */
.info-banner{background:linear-gradient(100deg,var(--surface-2),var(--allow-bg));border:1px solid var(--line);border-radius:var(--r);padding:15px 22px;margin-bottom:22px;font-size:14.5px;color:var(--ink-2);}

.page{display:none;}
.page.on{display:block;}
@media (prefers-reduced-motion:no-preference){.page.anim{animation:pageIn .4s cubic-bezier(.2,.7,.3,1);}}
@keyframes pageIn{from{transform:translateY(10px);}to{transform:none;}}

/* ---------- overview hero row ---------- */
.ov-row{display:grid;grid-template-columns:1.75fr 1fr;gap:16px;margin-bottom:18px;}
.ov-hero{position:relative;overflow:hidden;border-radius:var(--r-lg);padding:30px 32px;color:#fff;background:linear-gradient(125deg,var(--plum) 0%,var(--plum-deep) 58%,#3C1730 100%);box-shadow:var(--shadow-lg);}
.ov-hero::after{content:"";position:absolute;right:-80px;top:-80px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(222,147,86,.4),transparent 65%);}
.ov-hero .ey{position:relative;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:#F1C9DC;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);padding:5px 12px;border-radius:100px;display:inline-block;}
.ov-hero h2{position:relative;font-family:var(--disp);font-size:clamp(24px,2.3vw,33px);line-height:1.1;color:#fff;margin:16px 0 0;max-width:none;}
.ov-hero p{position:relative;font-size:14.5px;color:#F0DCE6;margin:16px 0 0;max-width:52ch;line-height:1.55;}
.ov-chips{position:relative;display:flex;flex-wrap:wrap;gap:9px;margin-top:22px;}
.ov-chips .c{font-family:var(--mono);font-size:12px;font-weight:500;padding:7px 14px;border-radius:100px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);color:#fff;}
.ov-chips .c.warn{background:var(--hold-bg);border-color:var(--hold-line);color:var(--hold);}
.ov-side{display:flex;flex-direction:column;gap:16px;}
.side-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:22px 24px;box-shadow:var(--shadow-sm);flex:1;}
.side-card .lbl{font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);}
.side-card .big{font-family:var(--disp);font-size:30px;color:var(--ink);line-height:1;margin:10px 0 8px;display:flex;align-items:center;gap:10px;}
.side-card .big .gd{width:10px;height:10px;border-radius:50%;background:var(--allow);box-shadow:0 0 0 4px var(--allow-bg);}
.side-card p{font-size:13px;color:var(--ink-2);margin:8px 0 0;line-height:1.5;}

/* ---------- metric grid ---------- */
.mgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:13px;margin-bottom:24px;}
.mcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:17px 18px 19px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:transform .16s,box-shadow .2s;}
.mcard:hover{transform:translateY(-2px);box-shadow:var(--shadow);}
.mcard .lbl{font-family:var(--mono);font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);min-height:26px;}
.mcard .val{font-family:var(--disp);font-size:38px;line-height:1;color:var(--ink);margin:10px 0 9px;}
.mcard.accent .val{color:var(--plum);}
.mcard .desc{font-size:12px;color:var(--ink-2);line-height:1.4;}

/* ---------- control surface insights ---------- */
.cs-head{margin:6px 0 16px;}
.cs-head .eyebrow{margin-bottom:10px;}
.cs-head h2{font-family:var(--disp);font-size:clamp(26px,2.6vw,34px);color:var(--ink);line-height:1.05;}
.cs-head p{font-size:14.5px;color:var(--ink-2);margin:8px 0 0;}
.insights{background:linear-gradient(140deg,var(--surface),var(--allow-bg));border:1px solid var(--line);border-radius:var(--r-lg);padding:10px 26px;box-shadow:var(--shadow-sm);}
.insights li{list-style:none;padding:15px 0 15px 26px;border-bottom:1px solid var(--line-2);position:relative;font-size:14.5px;color:var(--ink-2);line-height:1.55;}
.insights li:last-child{border-bottom:none;}
.insights li::before{content:"";position:absolute;left:4px;top:22px;width:7px;height:7px;border-radius:50%;background:var(--plum);}
.insights a{color:var(--plum-deep);font-weight:600;text-decoration:underline;text-underline-offset:2px;text-decoration-color:var(--plum-line);}
.insights a:hover{text-decoration-color:var(--plum);}

/* ---------- panels ---------- */
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);margin-bottom:18px;overflow:hidden;}
.panel-head{display:flex;align-items:center;gap:14px;padding:18px 22px;border-bottom:1px solid var(--line-2);}
.panel-head h3{font-family:var(--sans);font-weight:700;font-size:16px;color:var(--ink);}
.panel-head .meta{margin-left:auto;font-family:var(--mono);font-size:12px;color:var(--ink-3);}
.panel-body{padding:22px;}

/* ---------- tables ---------- */
.tbl-wrap{overflow-x:auto;}
table.tbl{width:100%;border-collapse:collapse;min-width:760px;}
.tbl thead th{text-align:left;font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);font-weight:500;padding:13px 20px;border-bottom:1px solid var(--line-2);background:var(--surface-2);white-space:nowrap;}
.tbl tbody td{padding:15px 20px;border-bottom:1px solid var(--line-2);font-size:13.5px;color:var(--ink-2);vertical-align:middle;}
.tbl tbody tr:last-child td{border-bottom:none;}
.tbl tbody tr:hover{background:var(--surface-2);}
.tbl .mono{font-family:var(--mono);font-size:12.5px;color:var(--ink-2);}
.tbl .pname{color:var(--ink);font-weight:600;font-size:14px;}
.tbl .prio{font-family:var(--mono);font-size:14px;color:var(--ink);font-weight:600;}
.cat{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;color:var(--ink-2);}
.cat i{width:8px;height:8px;border-radius:2px;flex:none;}
.cat.op i{background:var(--plum);} .cat.dlp i{background:var(--apricot);} .cat.ip i{background:var(--allow);}
.status{font-family:var(--mono);font-size:12.5px;}
.status.active{color:var(--allow);} .status.disabled{color:var(--ink-3);}

/* policy action pills */
.acts{display:flex;gap:7px;flex-wrap:wrap;}
.apill{font-family:var(--sans);font-size:12px;font-weight:600;padding:6px 13px;border-radius:100px;border:1px solid;background:var(--surface);cursor:pointer;white-space:nowrap;transition:.15s;}
.apill.enable{color:var(--allow);border-color:var(--allow-line);background:var(--allow-bg);}
.apill.disable{color:var(--hold);border-color:var(--hold-line);background:var(--hold-bg);}
.apill.sim{color:var(--plum);border-color:var(--plum-line);}
.apill.ver{color:var(--ink-2);border-color:var(--line);}
.apill.newv{color:var(--plum-deep);border-color:var(--plum-line);background:var(--plum-soft);}
.apill.del{color:var(--block);border-color:var(--block-line);background:var(--block-bg);}
.apill:hover{filter:brightness(.97);transform:translateY(-1px);}

/* policy simulation footer */
.sim-foot{display:flex;align-items:flex-end;gap:20px;flex-wrap:wrap;padding:8px 2px 0;}
.sim-foot .cs-head{margin:0;flex:1;min-width:280px;}
.sim-win{display:flex;flex-direction:column;gap:7px;}
.sim-win label{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);text-align:right;}

/* ---------- forms ---------- */
.form-field{display:flex;flex-direction:column;gap:7px;}
.form-field label{font-family:var(--sans);font-size:12.5px;font-weight:600;color:var(--ink-2);}
.form-field .hint{font-family:var(--mono);font-size:11.5px;color:var(--ink-3);margin-top:2px;line-height:1.45;}
.inp,.sel,.ta{font-family:var(--mono);font-size:13.5px;color:var(--ink);background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:11px 13px;width:100%;transition:border-color .15s,box-shadow .15s;}
.inp::placeholder,.ta::placeholder{color:var(--ink-3);}
.inp:focus,.sel:focus,.ta:focus{outline:none;border-color:var(--plum);box-shadow:0 0 0 3px var(--plum-soft);}
.sel{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%235E4E54' stroke-width='2.4'><path d='M6 9l6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;cursor:pointer;min-width:170px;}
.ta{resize:vertical;min-height:46px;line-height:1.5;}

/* ---------- modal ---------- */
.modal-scrim{position:fixed;inset:0;background:rgba(30,18,25,.55);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center;z-index:100;padding:24px;}
.modal-scrim.on{display:flex;}
.modal{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--shadow-xl);max-width:640px;width:100%;max-height:90vh;overflow:auto;}
.modal.wide{max-width:760px;}
@media (prefers-reduced-motion:no-preference){.modal-scrim.on .modal{animation:modalIn .32s cubic-bezier(.2,.8,.3,1);}}
@keyframes modalIn{from{transform:translateY(14px) scale(.985);}to{transform:none;}}
.modal-head{display:flex;align-items:flex-start;gap:16px;padding:26px 30px 22px;border-bottom:1px solid var(--line-2);}
.modal-head .mz{width:44px;height:44px;border-radius:12px;background:var(--plum);color:#fff;font-family:var(--disp);font-size:27px;display:grid;place-items:center;flex:none;}
.modal-head h3{font-family:var(--disp);font-size:31px;color:var(--ink);line-height:1;}
.modal-head p{font-size:14px;color:var(--ink-2);margin:7px 0 0;line-height:1.45;}
.modal-head .x{margin-left:auto;width:38px;height:38px;border-radius:50%;border:1px solid var(--line);background:var(--surface-2);cursor:pointer;display:grid;place-items:center;color:var(--ink-2);flex:none;font-family:var(--mono);font-size:15px;}
.modal-head .x:hover{border-color:var(--plum);color:var(--plum);}
.modal-body{padding:24px 30px;}
.modal-body p{font-size:15.5px;color:var(--ink-2);line-height:1.66;margin:0 0 16px;}
.modal-body p:last-child{margin:0;}
.modal-body strong{color:var(--plum-deep);font-weight:600;}
.modal-body .pf-tags{display:flex;flex-wrap:wrap;gap:8px;margin:4px 0 20px;}
.modal-foot{display:flex;align-items:center;gap:14px;padding:18px 30px;border-top:1px solid var(--line-2);background:var(--surface-2);}
.modal-foot .lic{font-family:var(--mono);font-size:11.5px;color:var(--ink-3);margin-right:auto;}

/* create-policy modal specifics */
.tabs{display:inline-flex;gap:6px;background:var(--surface-2);border:1px solid var(--line);border-radius:100px;padding:4px;margin-bottom:24px;}
.tabs button{font-family:var(--sans);font-size:13.5px;font-weight:600;padding:9px 20px;border-radius:100px;border:none;background:none;color:var(--ink-2);cursor:pointer;}
.tabs button.on{background:var(--plum);color:#fff;}
.cp-field{margin-bottom:20px;}
.cp-label{display:flex;align-items:center;gap:8px;font-family:var(--sans);font-size:12.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);margin-bottom:9px;}
.cp-label .i{width:18px;height:18px;border-radius:50%;background:var(--plum-soft);border:1px solid var(--plum-line);color:var(--plum);font-family:var(--mono);font-size:11px;display:grid;place-items:center;font-style:italic;}
.cp-hint{font-size:12.5px;color:var(--ink-3);margin-top:8px;line-height:1.5;}
.gen-panel{background:linear-gradient(120deg,var(--plum-soft),var(--allow-bg));border:1px solid var(--line);border-radius:var(--r);padding:18px 20px;margin:6px 0 22px;}
.gen-panel p{font-size:14px;color:var(--ink-2);margin:0 0 14px;}
.callout{border:1px solid var(--hold-line);background:var(--hold-bg);border-radius:var(--r);padding:16px 18px;margin-top:8px;}
.callout .ct{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--hold);font-weight:600;margin-bottom:6px;}
.callout p{font-size:13.5px;color:#7A5A12;margin:0;line-height:1.5;font-weight:500;}
.btn-grad{background:linear-gradient(120deg,var(--plum),var(--plum-deep));color:#fff;}
.btn-grad:hover{filter:brightness(1.06);}

/* empty state */
.empty{border:1px dashed var(--line);border-radius:var(--r);padding:40px 24px;text-align:center;color:var(--ink-3);font-size:14px;background:var(--surface-2);}
.empty .em-ic{width:42px;height:42px;border-radius:12px;background:var(--surface);border:1px solid var(--line);display:grid;place-items:center;margin:0 auto 14px;}
.empty .em-ic svg{width:20px;height:20px;color:var(--ink-3);}
.empty b{display:block;color:var(--ink-2);font-family:var(--sans);font-weight:600;font-size:15px;margin-bottom:4px;}

.agent-cell{color:var(--ink);font-weight:500;} .agent-cell small{display:block;font-family:var(--mono);font-size:11px;color:var(--ink-3);font-weight:400;margin-top:2px;}
.chip.miss{color:var(--block);background:var(--block-bg);border-color:var(--block-line);} .chip.miss .dot{background:var(--block);}

/* ---------- governance review (audit logs) ---------- */
.gov-filters{display:grid;grid-template-columns:1.4fr 1fr 1fr auto;gap:18px;align-items:end;margin-top:18px;}
.gov-filters label{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);font-weight:500;margin-bottom:7px;display:block;}
.results-card{border:1px solid var(--line);border-radius:12px;padding:12px 20px;background:var(--surface-2);min-width:190px;}
.results-card .rl{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);}
.results-card .rv{font-family:var(--disp);font-size:22px;color:var(--ink);line-height:1.1;margin-top:4px;}
.tbl tr.ok td{background:rgba(79,122,82,.05);}
.tbl tr.bad td{background:rgba(178,58,71,.07);}
.tbl tr.ok:hover td,.tbl tr.bad:hover td{filter:brightness(.99);}
.spill{font-family:var(--mono);font-size:11.5px;font-weight:500;padding:4px 12px;border-radius:100px;border:1px solid;}
.spill.ok{color:var(--allow);background:var(--allow-bg);border-color:var(--allow-line);}
.spill.bad{color:var(--block);background:var(--block-bg);border-color:var(--block-line);}
.viol .pn{color:var(--ink);font-weight:600;font-size:13px;}
.viol .tm{display:block;color:var(--block);font-family:var(--mono);font-size:11.5px;margin-top:3px;}
.viol.none{color:var(--ink-3);}
.pager{display:flex;align-items:center;justify-content:space-between;padding:16px 22px;border-top:1px solid var(--line-2);}
.pager .pg{font-family:var(--mono);font-size:12.5px;color:var(--ink-3);}
@media (max-width:880px){.gov-filters{grid-template-columns:1fr 1fr;}}

/* ---------- create policy form ---------- */
.pol-grid2{display:grid;grid-template-columns:1fr 1fr;gap:20px 26px;}
.pol-grid2 .span2{grid-column:1 / -1;}
.pol-grid2 .hint{font-family:var(--mono);font-size:11.5px;color:var(--ink-3);margin-top:2px;line-height:1.45;}

/* responsive */
@media (max-width:1100px){.ov-row{grid-template-columns:1fr;}}
@media (max-width:860px){
  .app{flex-direction:column;}
  .side{position:relative;width:100%;height:auto;flex-direction:row;align-items:center;overflow-x:auto;}
  .side-brand{border-bottom:none;border-right:1px solid var(--dark-line);white-space:nowrap;}
  .side-brand .logo{display:none;}
  .side-nav{flex-direction:row;padding:10px;gap:4px;}
  .nav-item{white-space:nowrap;}
  .content{padding:20px 18px 44px;}
  .portal-top .who{display:none;}
}
