/* Vantage — CEO command dashboard. Theme lifted from The Kettle Black admin kit:
   white · black · cream · plum lines. */
:root{
  --ink:#1A1A1A; --ink-soft:#3f3a34; --paper:#ffffff;
  --cream:#F6F7F2; --cream-2:#EEEDE6; --cream-3:#E2DDD4;
  --stone:#808080; --stone-soft:#6b655e; --line:#E2DDD4;
  --plum:#6B2D5C; --plum-deep:#4A1E40; --plum-tint:#F0E4EC;
  --good:#2f7d52; --good-bg:#E3F0E8; --warn:#9c6a16; --warn-bg:#F6ECD6; --bad:#b23a3a; --bad-bg:#F6E0E0;
  --disp:'Cormorant Garamond',Georgia,serif; --body:'Open Sans',system-ui,sans-serif;
  --shadow:0 18px 44px rgba(26,26,26,.10); --shadow-sm:0 6px 18px rgba(26,26,26,.06);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:var(--body);background:var(--cream);color:var(--ink);line-height:1.55;-webkit-font-smoothing:antialiased}
.serif{font-family:var(--disp)}
a{color:var(--plum);text-decoration:none}
h1,h2,h3{font-family:var(--disp);font-weight:600;line-height:1.06}
.muted{color:var(--stone-soft)}
.small{font-size:12.5px}
.hidden{display:none!important}
button,input,select,textarea{font-family:inherit}
input,select,textarea{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:10px;font-size:14px;background:#fff;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--plum)}
label{display:block;font-size:12px;font-weight:600;color:var(--ink-soft);margin:0 0 5px;letter-spacing:.01em}
.field{margin-bottom:14px}
.row{display:grid;gap:12px}
.row.c2{grid-template-columns:1fr 1fr}.row.c3{grid-template-columns:1fr 1fr 1fr}
@media(max-width:640px){.row.c2,.row.c3{grid-template-columns:1fr}}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:11px 18px;border:1px solid var(--plum);border-radius:24px;background:var(--plum);color:#fff;font-weight:600;font-size:14px;cursor:pointer;transition:.15s}
.btn:hover{background:var(--plum-deep);border-color:var(--plum-deep)}
.btn.ghost{background:#fff;color:var(--plum)}.btn.ghost:hover{background:var(--plum-tint)}
.btn.sm{padding:7px 13px;font-size:12.5px}
.btn.dark{background:var(--ink);border-color:var(--ink)}.btn.dark:hover{background:#000}
.btn.block{width:100%}
.chip{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:11.5px;font-weight:600;background:var(--cream-2);color:var(--ink-soft)}
.chip.good{background:var(--good-bg);color:var(--good)}.chip.warn{background:var(--warn-bg);color:var(--warn)}.chip.bad{background:var(--bad-bg);color:var(--bad)}
.chip.plum{background:var(--plum-tint);color:var(--plum)}
.card{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:var(--shadow-sm)}
table{width:100%;border-collapse:collapse;font-size:13.5px}
th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--stone-soft);font-weight:700;padding:9px 10px;border-bottom:2px solid var(--cream-3)}
td{padding:10px;border-bottom:1px solid var(--cream-2);vertical-align:top}
tr:hover td{background:var(--cream)}
.num{text-align:right;font-variant-numeric:tabular-nums}
.kpi{background:#fff;border:1px solid var(--line);border-radius:12px;padding:13px 15px}
.kpi .v{font-size:22px;font-weight:700;line-height:1.1;letter-spacing:-.015em;font-variant-numeric:tabular-nums;color:var(--ink)}
.kpi .l{font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--stone-soft);margin-top:5px;font-weight:600}
.empty{text-align:center;color:var(--stone-soft);padding:40px 20px;font-size:14px}

/* ---------- the AI spark (TKB signature — marks every AI-powered affordance) ---------- */
@keyframes vd-spark{0%,100%{opacity:.35;transform:scale(.8)}50%{opacity:1;transform:scale(1.18)}}
.ai-spark{position:relative}
.ai-spark::after{content:"";position:absolute;top:-5px;right:-5px;width:9px;height:9px;border-radius:50%;background:radial-gradient(circle,var(--plum) 0%,rgba(107,45,92,.3) 70%,transparent 75%);box-shadow:0 0 8px 1px rgba(107,45,92,.55);animation:vd-spark 1.8s ease-in-out infinite;pointer-events:none}

/* capability chip (AI Pipeline & Skills) — colour set inline per capability */
.capchip{display:inline-flex;align-items:center;gap:5px;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:600}
.stepchip{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:14px;font-size:10.5px;font-weight:600}
.steparrow{color:var(--stone);font-size:11px}

/* ---------- the diamond mark (echoes the portrait's corner star) ---------- */
.mark{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:1.5px solid var(--plum);transform:rotate(45deg);border-radius:6px;flex:none}
.mark i{transform:rotate(-45deg);color:var(--plum);font-style:normal;font-family:var(--disp);font-weight:700;font-size:15px}
.wordmark{display:flex;align-items:center;gap:11px}
.wordmark .name{font-family:var(--disp);font-weight:600;font-size:24px;letter-spacing:.01em;line-height:1}
.wordmark .name b{color:var(--plum);font-weight:600}

/* ---------- LOGIN ---------- */
.login{min-height:100%;display:grid;grid-template-columns:1.05fr .95fr}
@media(max-width:860px){.login{grid-template-columns:1fr}.login .hero{display:none}}
.login .hero{background:linear-gradient(155deg,#2b2230,#4A1E40 60%,#6B2D5C);position:relative;overflow:hidden;display:flex;align-items:flex-end;padding:48px}
.login .hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.86;mix-blend-mode:luminosity}
.login .hero .veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(43,34,48,.25),rgba(74,30,64,.78))}
.login .hero .quote{position:relative;color:#fff;max-width:420px}
.login .hero .quote h2{font-size:34px;color:#fff;margin-bottom:10px}
.login .hero .quote p{opacity:.85;font-size:14px}
.login .panel{display:flex;align-items:center;justify-content:center;padding:40px}
.login .panel .box{width:100%;max-width:380px}
.login .panel .box>.wordmark{margin-bottom:30px}
.login h1{font-size:30px;margin-bottom:6px}
.gbtn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px;border:1px solid var(--line);border-radius:12px;background:#fff;font-weight:600;font-size:14px;cursor:pointer;transition:.15s}
.gbtn:hover{border-color:var(--plum);background:var(--cream)}
.gbtn svg{width:18px;height:18px}
.sep{display:flex;align-items:center;gap:12px;color:var(--stone-soft);font-size:12px;margin:18px 0}
.sep::before,.sep::after{content:"";flex:1;height:1px;background:var(--line)}

/* ---------- APP SHELL (collapsible left nav, TKB-style) ---------- */
.shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh;transition:grid-template-columns .18s}
.shell.nav-collapsed{grid-template-columns:72px 1fr}
.side{background:#fff;border-right:1px solid var(--line);padding:18px 14px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}
.side .brand{display:flex;align-items:center;gap:11px;padding:4px 6px 16px;cursor:pointer}
.side .brand img{width:34px;height:34px;object-fit:contain;flex:none}
.side .brand .name{font-family:var(--disp);font-weight:600;font-size:22px;line-height:1;white-space:nowrap}
.nav-collapsed .side .brand .name,.nav-collapsed .nav .lbl,.nav-collapsed .nav .grp{display:none}
.nav{display:flex;flex-direction:column;flex:1}
.nav a{display:flex;align-items:center;gap:12px;padding:10px 11px;border-radius:10px;color:var(--ink-soft);font-size:13.5px;font-weight:600;margin-bottom:2px;cursor:pointer;white-space:nowrap}
.nav a:hover{background:var(--cream)}
.nav a.on{background:var(--plum-tint);color:var(--plum-deep)}
.nav a .i{width:22px;height:22px;flex:none;display:flex;align-items:center;justify-content:center}
.nav a .i svg{width:19px;height:19px}
.nav .grp{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--stone);font-weight:700;margin:18px 11px 7px}
.nav-collapsed .side{padding:18px 10px;align-items:center}
.nav-collapsed .nav a{justify-content:center;padding:11px 0}
.side .foot{margin-top:auto;padding-top:12px;border-top:1px solid var(--line)}
.side .foot .who{display:flex;align-items:center;gap:10px;cursor:pointer;padding:6px;border-radius:10px}
.side .foot .who:hover{background:var(--cream)}
.side .foot .who img{width:38px;height:38px;border-radius:50%;object-fit:cover;border:1.5px solid var(--plum);flex:none}
.side .foot .who .nm{font-size:13px;font-weight:600;line-height:1.15}
.side .foot .who .rl{font-size:11px;color:var(--stone-soft)}
.nav-collapsed .side .foot .who{justify-content:center;padding:6px 0}
.nav-collapsed .side .foot .who .lbl{display:none}

.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:14px;padding:13px 26px;background:rgba(255,255,255,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
/* desktop collapses via the sidebar pot logo — this topbar pot only appears on mobile to open the drawer */
#navToggle{display:none;align-items:center;cursor:pointer;background:none;border:0;padding:3px;border-radius:8px}
#navToggle img{width:26px;height:26px;object-fit:contain}
#navToggle:hover{background:var(--cream)}
.topbar .spacer{flex:1}
.topbar .who{display:flex;align-items:center;gap:10px;cursor:pointer}
.topbar .who img{width:34px;height:34px;border-radius:50%;object-fit:cover;border:1.5px solid var(--plum)}
.topbar .who .nm{font-size:13px;font-weight:600;line-height:1.1}
.topbar .who .rl{font-size:11px;color:var(--stone-soft)}
.crumbs{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--stone-soft)}
.crumbs a{cursor:pointer}
.main{max-width:1180px;width:100%;margin:0 auto;padding:30px 26px 60px}

/* mobile: nav becomes a drawer */
.nav-backdrop{position:fixed;inset:0;background:rgba(26,16,28,.42);z-index:94;display:none}
@media(max-width:820px){
  #navToggle{display:flex}
  .shell,.shell.nav-collapsed{grid-template-columns:1fr}
  .side{position:fixed;left:0;top:0;width:248px;z-index:95;transform:translateX(-100%);transition:transform .22s;align-items:stretch;padding:18px 14px}
  .shell.nav-open .side{transform:translateX(0)}
  .shell.nav-open .nav-backdrop{display:block}
  .nav-collapsed .side .brand .name,.nav-collapsed .nav .lbl,.nav-collapsed .nav .grp{display:block}
  .nav-collapsed .nav a{justify-content:flex-start;padding:10px 11px}
}

/* ---------- Pot bot (floating assistant, TKB Katy-style) ---------- */
.bot-fab{position:fixed;bottom:24px;right:24px;width:56px;height:56px;border-radius:50%;background:var(--plum);box-shadow:0 6px 22px rgba(107,45,92,.45);display:grid;place-items:center;cursor:pointer;z-index:150;transition:.18s}
.bot-fab:hover{transform:scale(1.06)}
.bot-fab img{width:30px;height:30px;object-fit:contain;filter:brightness(0) invert(1)}
.bot-badge{position:absolute;top:-2px;right:-2px;min-width:20px;height:20px;padding:0 5px;border-radius:11px;background:var(--bad);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid #fff}
/* super-admin "viewing as" banner */
.viewbar{display:flex;align-items:center;gap:10px;background:var(--warn-bg);color:var(--warn);border:1px solid var(--warn);border-radius:10px;padding:8px 12px;margin-bottom:16px;font-size:13px;font-weight:600}
.viewbar button{margin-left:auto}
.bot-panel{position:fixed;bottom:90px;right:24px;width:min(92vw,372px);height:min(72vh,540px);background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:0 18px 50px rgba(26,16,28,.3);display:none;flex-direction:column;overflow:hidden;z-index:150}
.bot-panel.on{display:flex}
.bot-hd{display:flex;align-items:center;gap:9px;padding:13px 15px;border-bottom:1px solid var(--line);background:var(--cream)}
.bot-hd img{width:24px;height:24px}
.bot-hd b{font-size:14px}.bot-hd .x{margin-left:auto;cursor:pointer;color:var(--stone);font-size:18px}
.bot-body{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:9px}
.bot-msg{max-width:84%;padding:9px 12px;border-radius:14px;font-size:13px;line-height:1.5;white-space:pre-wrap}
.bot-msg.u{align-self:flex-end;background:var(--plum);color:#fff;border-bottom-right-radius:4px}
.bot-msg.b{align-self:flex-start;background:var(--cream);border:1px solid var(--line);border-bottom-left-radius:4px}
.bot-foot{display:flex;gap:8px;padding:11px;border-top:1px solid var(--line);align-items:center}
.bot-foot input{flex:1;min-width:0}
.bot-mic{flex:0 0 auto;width:40px;height:40px;border-radius:50%;border:1px solid var(--line);background:#fff;color:var(--plum);cursor:pointer;display:flex;align-items:center;justify-content:center;touch-action:none;-webkit-user-select:none;user-select:none}
.bot-mic svg{width:19px;height:19px}
.bot-mic:active{background:var(--plum-tint)}
.bot-mic.live{background:var(--plum);color:#fff;border-color:var(--plum);animation:mic-pulse 1.1s ease-in-out infinite}
@keyframes mic-pulse{0%,100%{box-shadow:0 0 0 0 rgba(107,45,92,.5)}50%{box-shadow:0 0 0 8px rgba(107,45,92,0)}}

/* welcome / home */
.welcome{display:flex;align-items:center;gap:18px;margin-bottom:8px}
.welcome img{width:60px;height:60px;border-radius:50%;object-fit:cover;border:2px solid var(--plum)}
.welcome h1{font-size:32px}
.welcome p{color:var(--stone-soft);font-size:14px}

/* the AI-apps grid */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:24px}
@media(max-width:860px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.grid{grid-template-columns:1fr}}
.tile{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:22px;cursor:pointer;transition:.18s;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px;min-height:150px}
.tile:hover{transform:translateY(-3px);border-color:var(--plum);box-shadow:var(--shadow)}
.tile .ic{width:44px;height:44px;border-radius:12px;background:var(--plum-tint);display:flex;align-items:center;justify-content:center;color:var(--plum)}
.tile .ic svg{width:23px;height:23px}
.tile h3{font-size:21px}
.tile p{font-size:12.5px;color:var(--stone-soft);line-height:1.45}
.tile .stat{margin-top:auto;font-size:11.5px;font-weight:600;color:var(--plum);display:flex;align-items:center;gap:6px}
.tile.settings .ic{background:var(--cream-2);color:var(--ink-soft)}
.tile.settings .stat{color:var(--ink-soft)}

/* view header */
.vhead{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}
.vhead h1{font-size:28px}
.vhead p{color:var(--stone-soft);font-size:13.5px;max-width:560px}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}
@media(max-width:760px){.kpis{grid-template-columns:repeat(2,1fr)}}

/* settings tabs */
.tabs{display:flex;gap:6px;flex-wrap:wrap;border-bottom:1px solid var(--line);margin-bottom:20px}
.tabs button{background:none;border:none;padding:10px 14px;font-size:13.5px;font-weight:600;color:var(--stone-soft);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}
.tabs button.on{color:var(--plum);border-bottom-color:var(--plum)}

/* lists */
.lst{display:flex;flex-direction:column;gap:10px}
.li{display:flex;align-items:center;gap:12px;padding:13px 15px;border:1px solid var(--line);border-radius:12px;background:#fff}
.li .gr{flex:1;min-width:0}
.li .gr .t{font-weight:600;font-size:14px}
.li .gr .s{font-size:12px;color:var(--stone-soft)}
.li.commit{border-left:3px solid var(--plum)}
.li.pipe{flex-wrap:wrap}
.li.pipe select{flex:1;min-width:150px;width:auto}
.dot{width:9px;height:9px;border-radius:50%;flex:none}
.dot.good{background:var(--good)}.dot.warn{background:var(--warn)}.dot.bad{background:var(--bad)}.dot.idle{background:var(--stone)}

/* modal */
.modal-back{position:fixed;inset:0;background:rgba(26,16,28,.45);z-index:160;display:none;align-items:flex-start;justify-content:center;padding:40px 16px;overflow-y:auto}
.modal-back.on{display:flex}
.modal-box{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);width:min(96vw,560px);padding:24px;position:relative}
.modal-box h2{font-size:23px;margin-bottom:4px}
.modal-box .x{position:absolute;top:16px;right:18px;cursor:pointer;font-size:22px;color:var(--stone);line-height:1}
.modal-box textarea{min-height:120px;resize:vertical}
.modal-box ol{margin-left:16px}

/* global "AI is processing" indicator — spinning pot, shown whenever an AI/processing call is in flight */
.pot-busy{position:fixed;top:72px;left:50%;transform:translateX(-50%) translateY(-8px);z-index:200;display:none;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow);border-radius:24px;padding:8px 16px 8px 11px;font-size:13px;font-weight:600;color:var(--plum-deep);opacity:0;transition:opacity .2s,transform .2s;pointer-events:none}
.pot-busy.on{display:flex;opacity:1;transform:translateX(-50%) translateY(0)}
.pot-busy img{width:24px;height:24px;object-fit:contain;animation:pot-spin 1s linear infinite}
@keyframes pot-spin{to{transform:rotate(360deg)}}

.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;padding:11px 18px;border-radius:24px;font-size:13px;font-weight:600;box-shadow:var(--shadow);z-index:180;opacity:0;transition:.2s;pointer-events:none}
.toast.show{opacity:1}
.grouptitle{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--stone-soft);font-weight:700;margin:22px 0 10px}
/* Two-panel pages (LinkedIn, Email Commits): on mobile the settings panel becomes a clean FULL-SCREEN overlay */
.hb-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:18px;align-items:start}
.hb-cfg{display:none}
.hb-ovhd{display:none}
@media(max-width:820px){
  .hb-grid{grid-template-columns:1fr}
  .hb-cfg{display:inline-flex}
  .hb-sidewrap{position:fixed;inset:0;z-index:200;background:var(--cream);display:flex;flex-direction:column;overflow:hidden;transform:translateX(100%);transition:transform .26s cubic-bezier(.4,0,.2,1)}
  .hb-sidewrap.open{transform:translateX(0)}
  .hb-ovhd{display:flex;align-items:center;gap:10px;padding:14px 16px;background:var(--plum-deep);color:#fff;flex:none}
  .hb-ovhd b{font-size:16px;flex:1;font-family:var(--disp)}
  .hb-ovx{background:rgba(255,255,255,.18);color:#fff;border:none;border-radius:20px;padding:8px 18px;font-weight:600;font-size:14px;cursor:pointer}
  .hb-sidebody{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:14px 14px 40px;min-height:0}
  .hb-sidebody>div{position:static!important}
  .cm-cols{grid-template-columns:1fr!important}
}
