/* ops.karto.me — operator console
   Simple, light, brand-aligned. Cobalt + ink + paper.
*/
:root {
  --cobalt:#1C2BE0; --cobalt-deep:#0A12A8; --cobalt-bright:#2F3FFF;
  --ink:#0A0E27; --ink-2:#1A1F3A; --ink-3:#2A3050;
  --cream:#F5F0E6; --paper:#FBF8F1; --panel:#FFFFFF;
  --orange:#FF6B35; --lime:#C8F35A;
  --ok:#00C389; --warn:#E8A300; --danger:#D93025;
  --muted:#6B7280; --muted-2:#9CA3AF;
  --line:rgba(10,14,39,0.07); --line-strong:rgba(10,14,39,0.12); --line-xstrong:rgba(10,14,39,0.2);
  --bg:#F6F3EC;
}
*,*::before,*::after{box-sizing:border-box;-webkit-font-smoothing:antialiased}
html,body,#root{height:100%}
body{margin:0;font-family:'Geist',system-ui,sans-serif;background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5;overflow:hidden}
button{font-family:inherit;cursor:pointer;border:0;background:none;padding:0;color:inherit}
input,select,textarea{font-family:inherit;color:inherit}
a{color:inherit;text-decoration:none}
.mono{font-family:'Geist Mono',ui-monospace,monospace}
.ital{font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;color:var(--cobalt)}

/* ============ Login ============ */
.login-screen{position:fixed;inset:0;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;overflow:auto}
.login-screen::before{content:'';position:absolute;top:-220px;right:-200px;width:520px;height:520px;border-radius:50%;background:var(--cobalt);opacity:0.04;filter:blur(40px);pointer-events:none}
.login-screen::after{content:'';position:absolute;bottom:-200px;left:-180px;width:480px;height:480px;border-radius:50%;background:var(--orange);opacity:0.04;filter:blur(40px);pointer-events:none}
.login-card{position:relative;background:var(--panel);border:1px solid var(--line-strong);border-radius:20px;padding:48px 44px;width:100%;max-width:480px;box-shadow:0 30px 80px -30px rgba(10,14,39,0.18)}
.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:36px}
.login-brand-center{justify-content:center !important;margin-bottom:32px;width:100%}
.login-brand-center img{width:56px !important;height:56px !important}
.login-brand img{width:40px;height:40px;object-fit:contain}
.login-brand-name{font-size:20px;font-weight:600;letter-spacing:-0.02em;line-height:1}
.login-brand-sub{font-family:'Geist Mono',monospace;font-size:10px;color:var(--muted);letter-spacing:0.14em;text-transform:uppercase;margin-top:4px}
.login-h1{font-size:22px;font-weight:600;letter-spacing:-0.015em;line-height:1.2;margin:0 0 22px;text-align:center;color:var(--ink)}
.login-lede{font-size:14px;color:var(--muted);margin:0 0 28px;line-height:1.5}
.login-staff{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:24px}
.staff-card{background:var(--bg);border:1.5px solid var(--line-strong);border-radius:12px;padding:16px 12px;text-align:center;cursor:pointer;transition:all .15s ease}
.staff-card:hover{border-color:var(--ink);background:var(--panel)}
.staff-card.active{border-color:var(--cobalt);background:rgba(28,43,224,0.04);box-shadow:0 0 0 3px rgba(28,43,224,0.08)}
.staff-av{width:44px;height:44px;border-radius:50%;margin:0 auto 10px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:15px;letter-spacing:-0.01em}
.staff-name{font-size:13px;font-weight:600;letter-spacing:-0.01em}
.staff-role{font-family:'Geist Mono',monospace;font-size:9.5px;color:var(--muted);letter-spacing:0.1em;text-transform:uppercase;margin-top:3px}
.login-field{margin-bottom:16px}
.login-label{font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);margin-bottom:6px;display:block}
.login-input{width:100%;padding:12px 14px;background:var(--bg);border:1.5px solid var(--line-strong);border-radius:10px;font-size:14px;outline:0;transition:border-color .12s}
.login-input:focus{border-color:var(--cobalt);background:var(--panel)}
.login-btn{width:100%;padding:13px;background:var(--ink);color:var(--cream);border-radius:10px;font-size:14px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .15s}
.login-btn:hover{background:var(--cobalt)}
.login-btn:disabled{opacity:.4;cursor:not-allowed}
.login-foot{margin-top:24px;display:flex;justify-content:space-between;font-family:'Geist Mono',monospace;font-size:10px;color:var(--muted);letter-spacing:0.08em;text-transform:uppercase}
.login-foot .pulse{display:inline-flex;align-items:center;gap:6px}
.login-foot .pulse .d{width:6px;height:6px;border-radius:50%;background:var(--ok);animation:pulse 1.8s infinite}
.login-error{background:rgba(217,48,37,0.08);border:1px solid rgba(217,48,37,0.22);color:var(--danger);padding:10px 14px;border-radius:8px;font-size:12.5px;margin-bottom:14px}
.login-hint{font-family:'Geist Mono',monospace;font-size:10.5px;color:var(--muted);background:var(--bg);padding:8px 12px;border-radius:6px;margin-top:14px;letter-spacing:0.04em;text-align:center}

/* ============ Shell ============ */
.app{display:grid;grid-template-columns:1fr;height:100vh;width:100vw;background:var(--bg);position:relative}
.sidebar{background:var(--paper);border-right:1px solid var(--line-strong);display:flex;flex-direction:column;position:fixed;left:0;top:0;width:232px;height:100vh;z-index:50;transform:translateX(-100%);transition:transform .42s cubic-bezier(.22,1,.36,1) .12s, box-shadow .35s ease;box-shadow:0 24px 60px -30px rgba(10,14,39,0)}
.sb-trigger{position:fixed;left:0;top:0;width:14px;height:100vh;z-index:49}
.sb-trigger:hover ~ .sidebar,
.sidebar:hover,
.sidebar.open{transform:translateX(0);transition-delay:0s;box-shadow:0 24px 60px -20px rgba(10,14,39,0.22)}
.sb-brand{padding:20px 18px 18px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--line)}
.sb-brand img{width:32px;height:32px;object-fit:contain}
.sb-brand-title{font-size:15px;font-weight:600;letter-spacing:-0.02em;line-height:1}
.sb-brand-sub{font-family:'Geist Mono',monospace;font-size:9.5px;color:var(--muted);letter-spacing:0.12em;text-transform:uppercase;margin-top:3px}
.sb-nav{padding:12px 10px;display:flex;flex-direction:column;gap:1px;flex:1;overflow-y:auto}
.sb-item{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:8px;font-size:13.5px;color:var(--ink-2);cursor:pointer;text-align:left;width:100%;position:relative;transition:background .12s ease;font-weight:500}
.sb-item:hover{background:var(--bg)}
.sb-item.active{background:var(--ink);color:var(--cream)}
.sb-item .ic{width:16px;height:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:.85}
.sb-item.active .ic{opacity:1}
.sb-item .badge{margin-left:auto;font-family:'Geist Mono',monospace;font-size:10px;padding:1px 7px;border-radius:999px;background:var(--bg);color:var(--ink-2);letter-spacing:0.04em;font-weight:500}
.sb-item.active .badge{background:rgba(255,255,255,0.16);color:var(--cream)}
.sb-item .badge.alert{background:var(--orange);color:#fff}
.sb-foot{border-top:1px solid var(--line);padding:12px 10px}
.sb-user{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;width:100%}
.sb-user:hover{background:var(--bg)}
.sb-user-av{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11.5px;font-weight:600;color:#fff;flex-shrink:0;font-family:'Geist Mono',monospace}
.sb-user-meta{flex:1;text-align:left;min-width:0}
.sb-user-name{font-size:12.5px;font-weight:600;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-user-role{font-family:'Geist Mono',monospace;font-size:9px;color:var(--muted);letter-spacing:0.1em;text-transform:uppercase;margin-top:2px}
.sb-logout{color:var(--muted);transition:color .12s}
.sb-logout:hover{color:var(--danger)}

/* ============ Main ============ */
.main{display:flex;flex-direction:column;overflow:hidden}
.topbar{display:flex;align-items:center;padding:0 28px;height:54px;border-bottom:1px solid var(--line-strong);background:var(--bg);gap:14px;flex-shrink:0}
.crumbs{display:flex;align-items:center;gap:6px;font-family:'Geist Mono',monospace;font-size:11px;letter-spacing:0.06em;color:var(--muted);white-space:nowrap;flex-shrink:0}
.crumbs .sep{opacity:.4}
.crumbs .cur{color:var(--ink);text-transform:uppercase;letter-spacing:0.12em;font-weight:500}
.topbar-search{margin-left:20px;display:flex;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--line-strong);border-radius:8px;padding:6px 12px;min-width:300px;color:var(--muted);transition:border-color .12s}
.topbar-search:focus-within{border-color:var(--cobalt)}
.topbar-search input{border:0;outline:0;background:transparent;font-size:13px;flex:1;color:var(--ink)}
.topbar-search input::placeholder{color:var(--muted)}
.topbar-search kbd{font-family:'Geist Mono',monospace;font-size:10px;color:var(--muted);background:var(--bg);border:1px solid var(--line);border-radius:4px;padding:1px 5px}
.topbar-actions{margin-left:auto;display:flex;align-items:center;gap:8px}
.env-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:6px;font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;background:var(--ink);color:var(--cream)}
.env-pill .d{width:6px;height:6px;border-radius:50%;background:var(--ok);animation:pulse 1.8s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.4)}}
.icon-btn{width:32px;height:32px;border-radius:7px;display:inline-flex;align-items:center;justify-content:center;color:var(--ink-2);transition:background .12s}
.icon-btn:hover{background:var(--panel)}
.content{flex:1;overflow-y:auto;padding:28px 32px 48px}

/* ============ Page header ============ */
.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;padding-bottom:22px;border-bottom:1px solid var(--line-strong);margin-bottom:28px}
.page-head > div:first-child{flex:1;min-width:0}
.eyebrow{font-family:'Geist Mono',monospace;font-size:10.5px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);font-weight:500}
.page-head h1{margin:8px 0 8px;font-size:34px;letter-spacing:-0.03em;font-weight:600;line-height:1.1}
.page-head h1 .ital{font-size:1.05em}
.page-head-sub{font-size:13.5px;color:var(--muted);max-width:640px}
.page-head-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}

/* ============ Buttons ============ */
.btn{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:8px;font-size:13px;font-weight:500;border:1px solid transparent;transition:all .12s ease;white-space:nowrap;font-family:inherit}
.btn-primary{background:var(--ink);color:var(--cream)}
.btn-primary:hover{background:var(--cobalt)}
.btn-cobalt{background:var(--cobalt);color:#fff}
.btn-cobalt:hover{background:var(--cobalt-deep)}
.btn-ghost{background:var(--panel);border-color:var(--line-strong);color:var(--ink)}
.btn-ghost:hover{background:var(--cream)}
.btn-outline{background:transparent;border-color:var(--line-strong);color:var(--ink)}
.btn-outline:hover{background:var(--panel)}
.btn-sm{padding:5px 10px;font-size:12px;border-radius:6px}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover{background:#b8261d}
.btn-ok{background:var(--ok);color:#fff}
.btn-ok:hover{background:#009e6f}

/* ============ Cards & layout ============ */
.card{background:var(--panel);border:1px solid var(--line-strong);border-radius:12px;padding:20px 22px}
.card-pad-sm{padding:14px 16px}
.card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:16px}
.card-head h3{margin:0;font-size:14.5px;font-weight:600;letter-spacing:-0.005em}
.card-head-sub{margin-top:3px;font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted)}

.row-2{display:grid;grid-template-columns:1.6fr 1fr;gap:16px;margin-bottom:16px}
.row-2-even{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.row-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:16px}
.row-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:16px}

.divider{height:1px;background:var(--line-strong);margin:24px 0}

/* ============ Metrics ============ */
.metric-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-strong);border:1px solid var(--line-strong);border-radius:12px;overflow:hidden;margin-bottom:20px}
.metric{background:var(--panel);padding:18px 20px;display:flex;flex-direction:column;gap:4px;position:relative;overflow:hidden;min-height:104px;justify-content:flex-start}
.metric:has(.metric-spark){padding-bottom:0}
.metric-label{font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.metric-value{font-size:28px;font-weight:600;letter-spacing:-0.035em;line-height:1.05;margin-top:auto}
.metric-value .u{font-family:'Geist Mono',monospace;font-size:11px;color:var(--muted);letter-spacing:0.05em;margin-left:4px;font-weight:500}
.metric-delta{font-family:'Geist Mono',monospace;font-size:10.5px;display:flex;align-items:center;gap:5px;margin-top:6px;letter-spacing:0.04em}
.metric-delta.up{color:var(--ok)}
.metric-delta.down{color:var(--danger)}
.metric-spark{display:block;width:calc(100% + 40px);margin:14px -20px 0;height:48px}

/* Brands metric segmented bar */
.brand-metrics .metric{padding:22px 24px;gap:0;min-height:auto;display:flex;flex-direction:column;justify-content:space-between}
.brand-metrics .metric .metric-label{margin-bottom:0}
.brand-metrics .metric .metric-value{margin:0;font-size:38px;line-height:1;margin-top:6px}
.metric-roster .seg-bar{display:flex;height:6px;border-radius:3px;overflow:hidden;background:rgba(10,14,39,0.06);gap:2px;margin-top:18px}
.metric-roster .seg{height:100%}
.metric-roster .seg-live{background:#3DD68C}
.metric-roster .seg-paused{background:#F5B544}
.metric-roster .seg-pending{background:rgba(10,14,39,0.25)}
.metric-roster .seg-legend{display:flex;justify-content:space-between;gap:8px;margin-top:10px;font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.metric-roster .seg-legend span{display:inline-flex;align-items:center;gap:6px}
.metric-roster .seg-legend b{color:var(--ink);font-weight:600;margin-left:4px;font-size:11px}
.metric-roster .seg-legend i.d{width:7px;height:7px;border-radius:2px;display:inline-block}
.metric-roster .seg-legend i.d.ok{background:#3DD68C}
.metric-roster .seg-legend i.d.warn{background:#F5B544}
.metric-roster .seg-legend i.d.mut{background:rgba(10,14,39,0.25)}
.brand-metrics .metric-foot{display:flex;justify-content:space-between;gap:8px;margin-top:18px;padding-top:14px;border-top:1px solid var(--line);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}

/* ============ Pills & chips ============ */
.pill{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:5px;font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:0.06em;text-transform:uppercase;font-weight:500;border:1px solid var(--line-strong);background:var(--bg);color:var(--ink-2)}
.pill.ok{background:rgba(0,195,137,0.08);border-color:rgba(0,195,137,0.3);color:var(--ok)}
.pill.warn{background:rgba(232,163,0,0.1);border-color:rgba(232,163,0,0.3);color:var(--warn)}
.pill.danger{background:rgba(217,48,37,0.08);border-color:rgba(217,48,37,0.3);color:var(--danger)}
.pill.cobalt{background:rgba(28,43,224,0.08);border-color:rgba(28,43,224,0.3);color:var(--cobalt)}
.pill.dark{background:var(--ink);color:var(--cream);border-color:var(--ink)}

.chip{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:6px;font-size:12px;color:var(--ink-2);background:var(--bg);border:1px solid var(--line-strong);cursor:pointer;font-weight:500;transition:all .12s}
.chip:hover{background:var(--panel)}
.chip.active{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.chip-sep{width:1px;height:20px;background:var(--line-strong);margin:0 4px}
.chip-label{font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:0.12em;color:var(--muted);text-transform:uppercase;margin-right:2px}
.filter-strip{display:flex;align-items:center;gap:10px;margin-bottom:18px;padding:10px 14px;background:var(--panel);border:1px solid var(--line-strong);border-radius:10px;flex-wrap:wrap}

/* ============ Page tabs ============ */
.pagetabs{display:flex;gap:2px;border-bottom:1px solid var(--line-strong);margin-bottom:22px;overflow-x:auto}
.pagetab{padding:10px 16px;font-size:13px;color:var(--muted);font-weight:500;border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap;display:flex;align-items:center;gap:8px}
.pagetab:hover{color:var(--ink)}
.pagetab.active{color:var(--ink);border-color:var(--ink)}
.pagetab .ct{font-family:'Geist Mono',monospace;font-size:10px;color:var(--muted);background:var(--bg);padding:1px 7px;border-radius:999px}
.pagetab.active .ct{background:var(--ink);color:var(--cream)}

/* ============ Table ============ */
.table{width:100%;background:var(--panel);border:1px solid var(--line-strong);border-radius:12px;overflow:hidden}
.table-hd,.table-row{display:grid;align-items:center}
.table-hd{font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);padding:11px 20px;background:var(--bg);border-bottom:1px solid var(--line-strong);font-weight:500}
.table-row{padding:13px 20px;font-size:13px;border-bottom:1px solid var(--line);transition:background .1s}
.table-row:last-child{border-bottom:0}
.table-row:hover{background:var(--bg)}
.table-row .c-strong{font-weight:500}
.av{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:3px;border:1px solid var(--line-strong)}
.av img{max-width:100%;max-height:100%;object-fit:contain}
.av-init{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11.5px;font-weight:600;color:#fff;font-family:'Geist Mono',monospace}

/* ============ Forms ============ */
.field{display:flex;flex-direction:column;gap:6px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field-row-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.field-label{font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);font-weight:500}
.field-hint{font-size:11.5px;color:var(--muted);line-height:1.5}
.input,.select,.textarea{padding:10px 12px;background:var(--bg);border:1px solid var(--line-strong);border-radius:8px;font-size:13.5px;outline:0;transition:all .12s;font-family:inherit;width:100%}
.input:focus,.select:focus,.textarea:focus{border-color:var(--cobalt);background:var(--panel)}
.textarea{resize:vertical;min-height:90px;line-height:1.5}
.select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 12px center;padding-right:34px}

/* Wizard stepper */
.wiz-steps{display:flex;gap:0;padding:0 26px 18px;border-bottom:1px solid var(--line)}
.wiz-step{flex:1;display:flex;align-items:center;gap:10px;padding:14px 0;font-size:12px;color:var(--muted);min-width:0}
.wiz-step .n{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--line-xstrong);display:flex;align-items:center;justify-content:center;font-family:'Geist Mono',monospace;font-size:11px;font-weight:600;background:var(--paper);color:var(--muted);flex-shrink:0}
.wiz-step.done .n{background:var(--ok);border-color:var(--ok);color:#fff}
.wiz-step.cur .n{background:var(--ink);border-color:var(--ink);color:var(--cream)}
.wiz-step.cur{color:var(--ink);font-weight:500}
.wiz-step > span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wiz-step::after{content:'';flex:1;height:1px;background:var(--line-strong);margin:0 12px;min-width:14px}
.wiz-step:last-child::after{display:none}
.wiz-step.done::after{background:var(--ok)}

.denom-chip{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:999px;background:var(--bg);border:1px solid var(--line-strong);font-family:'Geist Mono',monospace;font-size:12px;cursor:pointer;transition:all .12s}
.denom-chip:hover{border-color:var(--ink)}
.denom-chip.active{background:var(--ink);color:var(--cream);border-color:var(--ink)}

.switch{width:34px;height:20px;border-radius:999px;background:var(--line-xstrong);position:relative;cursor:pointer;transition:background .15s ease;flex-shrink:0}
.switch::after{content:'';position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.2);transition:transform .15s ease}
.switch.on{background:var(--ok)}
.switch.on::after{transform:translateX(14px)}

/* ============ DevOps surface (dark) ============ */
.tech-panel{background:#0B1028;color:var(--cream);border-radius:12px;padding:20px 22px;border:1px solid rgba(232,228,216,0.08);position:relative;overflow:hidden}
.tech-panel .card-head h3{color:var(--cream)}
.tech-panel .card-head-sub{color:rgba(232,228,216,0.55)}
.tech-panel .eyebrow{color:rgba(232,228,216,0.55)}
.tech-panel .field-label{color:rgba(232,228,216,0.5)}

/* Vital tile */
.vital{background:rgba(232,228,216,0.04);border:1px solid rgba(232,228,216,0.08);border-radius:10px;padding:14px 16px;position:relative}
.vital .l{font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:rgba(232,228,216,0.5);display:flex;justify-content:space-between;align-items:center}
.vital .v{font-size:26px;font-weight:600;letter-spacing:-0.03em;margin-top:6px;color:var(--cream)}
.vital .v .u{font-family:'Geist Mono',monospace;font-size:13px;color:rgba(232,228,216,0.5);font-weight:500;margin-left:2px}
.vital .sub{font-family:'Geist Mono',monospace;font-size:10px;color:rgba(232,228,216,0.45);margin-top:4px;letter-spacing:0.04em}
.vital .bar{margin-top:10px;height:3px;background:rgba(232,228,216,0.08);border-radius:2px;overflow:hidden}
.vital .bar .fill{height:100%;background:var(--ok);border-radius:2px;transition:width .3s}
.vital .bar .fill.warn{background:var(--warn)}
.vital .bar .fill.danger{background:var(--danger)}
.vital .dot{width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 3px rgba(0,195,137,0.16)}

/* Sparkline */
.spark-chart{height:110px;width:100%;position:relative}
.spark-chart svg{width:100%;height:100%;display:block}

/* Probe grid */
.probe-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.probe{display:flex;align-items:center;gap:10px;padding:10px 14px;background:rgba(232,228,216,0.04);border:1px solid rgba(232,228,216,0.08);border-radius:10px;font-family:'Geist Mono',monospace;font-size:11.5px}
.probe .dot{width:9px;height:9px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 3px rgba(0,195,137,0.16);flex-shrink:0}
.probe .dot.warn{background:var(--warn);box-shadow:0 0 0 3px rgba(232,163,0,0.16)}
.probe .dot.danger{background:var(--danger);box-shadow:0 0 0 3px rgba(217,48,37,0.16)}
.probe .nm{color:var(--cream);font-weight:500;letter-spacing:-.01em;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.probe .rt{color:rgba(232,228,216,0.5);font-size:10px;letter-spacing:0.04em;flex-shrink:0}

/* Pipeline */
.pipeline{display:flex;gap:8px;align-items:stretch}
.pipe{flex:1;background:rgba(232,228,216,0.04);border:1px solid rgba(232,228,216,0.08);border-radius:10px;padding:14px 12px 12px;display:flex;flex-direction:column;align-items:center;gap:6px;position:relative}
.pipe.live{border-color:rgba(200,243,90,0.4);background:rgba(200,243,90,0.06);box-shadow:0 0 0 3px rgba(200,243,90,0.08) inset}
.pipe-ic{width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--cream)}
.pipe-nm{font-size:13px;font-weight:600;color:var(--cream)}
.pipe-sub{font-family:'Geist Mono',monospace;font-size:9px;letter-spacing:0.1em;color:rgba(232,228,216,0.5);text-transform:uppercase}
.pipe .ar{position:absolute;right:-6px;top:50%;transform:translateY(-50%);color:rgba(232,228,216,0.25);font-size:12px;z-index:2}

/* Topology */
.topo{height:280px;position:relative;background:rgba(232,228,216,0.02);border-radius:10px;border:1px solid rgba(232,228,216,0.06);overflow:hidden}
.topo svg{width:100%;height:100%;display:block}
.topo-node{position:absolute;background:rgba(11,16,40,0.9);border:1px solid rgba(232,228,216,0.14);border-radius:8px;padding:7px 11px;font-size:11.5px;color:var(--cream);display:flex;align-items:center;gap:7px;font-weight:500}
.topo-node .b{font-family:'Geist Mono',monospace;font-size:9.5px;color:rgba(232,228,216,0.5);letter-spacing:0.06em}

/* Commits */
.commit-row{display:grid;grid-template-columns:100px 1fr 90px 110px;gap:12px;align-items:center;padding:11px 14px;border-bottom:1px solid rgba(232,228,216,0.06);font-size:13px;color:rgba(232,228,216,0.85)},216,0.88)}
.commit-row:last-child{border-bottom:0}
.commit-sha{font-family:'Geist Mono',monospace;font-size:11px;color:#A89BFF;background:rgba(106,90,205,0.18);padding:3px 8px;border-radius:4px;display:inline-block;letter-spacing:0.05em;text-align:center}
.commit-msg{font-size:12.5px;color:var(--cream);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.commit-author{font-family:'Geist Mono',monospace;font-size:10px;color:rgba(232,228,216,0.55)}
.commit-time{font-family:'Geist Mono',monospace;font-size:10px;color:rgba(232,228,216,0.5);text-align:right}
.commit-ci{font-family:'Geist Mono',monospace;font-size:9.5px;padding:2px 6px;border-radius:3px;letter-spacing:0.06em;text-transform:uppercase;display:inline-block}
.commit-ci.ok{color:var(--ok);background:rgba(0,195,137,0.12)}
.commit-ci.fail{color:var(--warn);background:rgba(232,163,0,0.14)}
.commit-row.live{background:rgba(200,243,90,0.05);border-left:2px solid var(--lime)}

/* Playbook */
.playbook{display:flex;flex-direction:column;gap:8px}
.pb-item{background:rgba(232,228,216,0.04);border:1px solid rgba(232,228,216,0.08);border-radius:10px;padding:13px 16px;cursor:pointer;display:flex;align-items:center;gap:12px;color:var(--cream);font-size:13px;transition:background .12s ease;width:100%;text-align:left}
.pb-item:hover{background:rgba(232,228,216,0.07)}
.pb-item .ic{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.pb-item .ic.warn{background:var(--warn)}
.pb-item .ic.danger{background:var(--danger)}
.pb-item .ic.cobalt{background:var(--cobalt-bright)}
.pb-item .ic.ok{background:var(--ok)}
.pb-item .ar{margin-left:auto;color:rgba(232,228,216,0.4)}
.pb-detail{background:rgba(0,0,0,0.25);border:1px solid rgba(232,228,216,0.06);border-radius:10px;padding:14px 18px;margin-left:20px;font-family:'Geist Mono',monospace;font-size:12px;color:rgba(232,228,216,0.85)}
.pb-detail .step{display:flex;gap:10px;padding:5px 0}
.pb-detail .step .n{color:var(--lime);flex-shrink:0}
.pb-detail code{background:rgba(200,243,90,0.1);color:var(--lime);padding:2px 5px;border-radius:3px}

/* Service log block */
.log-block{background:#06091B;border:1px solid rgba(232,228,216,0.08);border-radius:8px;padding:14px 16px;font-family:'Geist Mono',monospace;font-size:11.5px;color:rgba(232,228,216,0.85);max-height:240px;overflow-y:auto;line-height:1.55}
.log-block .tm{color:rgba(232,228,216,0.4)}
.log-block .lv{padding:0 5px;border-radius:3px;font-size:10px;letter-spacing:0.04em;margin-right:6px}
.log-block .lv.info{color:#7FB6FF;background:rgba(127,182,255,0.1)}
.log-block .lv.warn{color:var(--warn);background:rgba(232,163,0,0.12)}
.log-block .lv.error{color:#FF7F72;background:rgba(217,48,37,0.14)}
.log-block .lv.ok{color:var(--ok);background:rgba(0,195,137,0.12)}

/* Controlled actions */
.ctrl-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.ctrl{background:rgba(232,228,216,0.04);border:1px solid rgba(232,228,216,0.08);border-radius:10px;padding:14px}
.ctrl-t{font-size:13px;font-weight:600;color:var(--cream)}
.ctrl-s{font-family:'Geist Mono',monospace;font-size:10px;color:rgba(232,228,216,0.5);letter-spacing:0.06em;margin-top:3px}
.ctrl button{width:100%;margin-top:12px;padding:8px;background:transparent;border:1px solid rgba(217,48,37,0.45);color:#ff8f7f;border-radius:6px;font-size:11px;font-family:'Geist Mono',monospace;letter-spacing:0.08em;text-transform:uppercase;font-weight:500;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .12s}
.ctrl button:hover{background:rgba(217,48,37,0.1);border-color:var(--danger);color:#fff}
.ctrl button.arm{background:var(--danger);color:#fff;border-color:var(--danger)}
.ctrl button.cobalt{border-color:rgba(47,63,255,0.5);color:#9FA8FF}
.ctrl button.cobalt:hover{background:rgba(47,63,255,0.15);color:#fff}

/* ============ Modal ============ */
.modal-backdrop{position:fixed;inset:0;background:rgba(10,14,39,0.5);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .18s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{background:var(--panel);border-radius:14px;width:100%;max-width:760px;max-height:92vh;overflow-y:auto;box-shadow:0 30px 80px -20px rgba(10,14,39,.4)}
.modal-lg{max-width:900px}
.modal-hd{padding:22px 26px 14px;border-bottom:1px solid var(--line)}
.modal-hd h2{margin:0;font-size:22px;font-weight:600;letter-spacing:-0.02em}
.modal-hd .sub{font-size:13px;color:var(--muted);margin-top:4px}
.modal-body{padding:22px 26px;display:flex;flex-direction:column;gap:16px}
.modal-foot{padding:14px 26px 22px;display:flex;gap:10px;justify-content:space-between;align-items:center;border-top:1px solid var(--line)}

/* Toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--ink);color:var(--cream);padding:11px 18px;border-radius:10px;font-size:13px;z-index:200;box-shadow:0 20px 40px -10px rgba(10,14,39,.4);display:flex;align-items:center;gap:10px;animation:toastIn .22s ease}
.toast .ic{color:var(--lime)}
@keyframes toastIn{from{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%,0)}}

/* KV row */
.kv{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px dashed var(--line);font-size:13px;gap:12px}
.kv:last-child{border-bottom:0}
.kv .k{font-family:'Geist Mono',monospace;font-size:10px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase}
.kv .v{font-weight:500;text-align:right}

/* Liability bar */
.liab-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;padding:0;background:var(--line-strong);border:1px solid var(--line-strong);border-radius:12px;overflow:hidden;margin-bottom:18px}
.liab-cell{padding:18px 22px;background:var(--cream)}
.liab-cell .l{font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted)}
.liab-cell .v{font-size:24px;font-weight:600;letter-spacing:-0.025em;margin-top:5px}
.liab-cell .v .u{font-size:11px;font-family:'Geist Mono',monospace;color:var(--muted);margin-left:4px}
.liab-cell .m{font-family:'Geist Mono',monospace;font-size:10px;color:var(--muted);letter-spacing:0.04em;margin-top:3px}

/* ============ Iraq map ============ */
.iraq-map{aspect-ratio:7/6;width:100%;position:relative;background:var(--bg);border-radius:10px;border:1px solid var(--line)}
.iraq-map svg{width:100%;height:100%;display:block}
.gov-path{fill:#E8E2D2;stroke:var(--panel);stroke-width:1.5;cursor:pointer;transition:fill .15s}
.gov-path:hover{stroke:var(--ink);stroke-width:2}
.gov-label{font-family:'Geist Mono',monospace;font-size:10px;font-weight:500;fill:var(--ink);pointer-events:none}
.gov-tooltip{position:absolute;background:var(--ink);color:var(--cream);padding:10px 14px;border-radius:8px;font-size:12px;pointer-events:none;box-shadow:0 10px 30px -10px rgba(10,14,39,0.4);z-index:5;white-space:nowrap}
.gov-tooltip .nm{font-weight:600;font-size:13px}
.gov-tooltip .rv{font-family:'Geist Mono',monospace;color:var(--lime);margin-top:3px;font-size:11px;letter-spacing:0.04em}
.gov-tooltip .ct{font-family:'Geist Mono',monospace;color:rgba(232,228,216,0.55);margin-top:1px;font-size:10px;letter-spacing:0.04em}

/* Sales chart axes */
.timeline-chart{height:280px;position:relative}
.timeline-chart svg{width:100%;height:100%;display:block;overflow:visible}

/* User detail */
.user-detail-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:18px}
.action-log-item{display:flex;gap:12px;padding:10px 0;border-bottom:1px dashed var(--line);font-size:13px;align-items:flex-start}
.action-log-item:last-child{border-bottom:0}
.action-log-item .dot{width:6px;height:6px;border-radius:50%;margin-top:7px;flex-shrink:0}

/* Brand card */
.brand-card{background:var(--panel);border:1px solid var(--line-strong);border-radius:12px;padding:18px;cursor:pointer;transition:border-color .12s, transform .12s;display:flex;flex-direction:column;gap:14px}
.brand-card:hover{border-color:var(--ink)}
.brand-card-head{display:flex;align-items:center;gap:12px}
.brand-card-logo{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;color:#fff;flex-shrink:0;font-family:'Geist Mono',monospace;border:1px solid rgba(0,0,0,0.06);overflow:hidden}
.brand-card-logo img{max-width:100%;max-height:100%;object-fit:contain}
.brand-card-nm{font-size:14.5px;font-weight:600;letter-spacing:-0.01em}
.brand-card-cat{font-family:'Geist Mono',monospace;font-size:10px;color:var(--muted);letter-spacing:0.1em;text-transform:uppercase;margin-top:2px}
.brand-card-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding-top:12px;border-top:1px dashed var(--line)}
.brand-card-stat .l{font-family:'Geist Mono',monospace;font-size:9px;color:var(--muted);letter-spacing:0.1em;text-transform:uppercase}
.brand-card-stat .v{font-size:14px;font-weight:600;margin-top:2px;letter-spacing:-0.01em}

/* Ticket detail */
.ticket-card{background:var(--panel);border:1px solid var(--line-strong);border-radius:10px;padding:14px 16px;cursor:pointer;transition:border-color .12s}
.ticket-card:hover{border-color:var(--ink)}
.ticket-card.active{border-color:var(--cobalt);box-shadow:0 0 0 3px rgba(28,43,224,0.08)}

/* Scrollbar */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--line-xstrong);border-radius:6px;border:2px solid var(--bg)}
::-webkit-scrollbar-thumb:hover{background:var(--ink-3)}

@media(max-width:900px){
  .metric-grid,.probe-grid,.ctrl-grid,.row-2,.row-2-even,.row-3,.row-4{grid-template-columns:1fr}
  .app{grid-template-columns:1fr}
  .sidebar{display:none}
}

/* ============ DevOps dark technical theme ============
   Activated when on the DevOps screen. Overrides core tokens
   so every card, table and pill inherits the dark treatment. */
.app[data-screen-label="devops"]{
  --cream:#E8EDF5; --paper:#0E1220; --panel:#141828;
  --ink:#E8EDF5; --ink-2:#B8C0D4; --ink-3:#7A8499;
  --bg:#0A0D17;
  --line:rgba(255,255,255,0.06);
  --line-strong:rgba(255,255,255,0.10);
  --line-xstrong:rgba(255,255,255,0.18);
  --muted:#7A8499; --muted-2:#5A6478;
  --cobalt:#5468FF; --cobalt-deep:#3A4ED9; --cobalt-bright:#7C8EFF;
  --ok:#3DD68C; --warn:#F5B544; --danger:#FF5C57;
  color:var(--ink);
  background:var(--bg);
}
.app[data-screen-label="devops"] .topbar{background:var(--bg);border-bottom-color:var(--line-strong)}
.app[data-screen-label="devops"] .crumbs span{color:var(--muted)}
.app[data-screen-label="devops"] .crumbs .cur{color:var(--ink)}
.app[data-screen-label="devops"] .ital{color:var(--cobalt-bright)}
.app[data-screen-label="devops"] body,
.app[data-screen-label="devops"]{font-family:'Geist Mono','Geist',monospace}
.app[data-screen-label="devops"] h1,.app[data-screen-label="devops"] h2,.app[data-screen-label="devops"] h3{font-family:'Geist',sans-serif}
/* Subtle scanline-ish texture on the canvas */
.app[data-screen-label="devops"] .content{
  background:
    linear-gradient(transparent 0%,transparent 50%, rgba(255,255,255,0.012) 50%, rgba(255,255,255,0.012) 100%);
  background-size:100% 4px;
}
/* Cards and tables */
.app[data-screen-label="devops"] .card,
.app[data-screen-label="devops"] .tech-panel,
.app[data-screen-label="devops"] .metric{background:var(--panel);border-color:var(--line-strong)}
.app[data-screen-label="devops"] .table-hd{color:var(--muted);border-bottom-color:var(--line-strong)}
.app[data-screen-label="devops"] .table-row{border-bottom-color:var(--line)}
.app[data-screen-label="devops"] .table-row:hover{background:rgba(84,104,255,0.06)}
/* Pills get a glassy dark treatment */
.app[data-screen-label="devops"] .pill{background:rgba(255,255,255,0.04);border-color:var(--line-strong);color:var(--ink-2)}
.app[data-screen-label="devops"] .pill.ok{background:rgba(61,214,140,0.10);border-color:rgba(61,214,140,0.28);color:var(--ok)}
.app[data-screen-label="devops"] .pill.warn{background:rgba(245,181,68,0.10);border-color:rgba(245,181,68,0.28);color:var(--warn)}
.app[data-screen-label="devops"] .pill.danger{background:rgba(255,92,87,0.10);border-color:rgba(255,92,87,0.28);color:var(--danger)}
/* Sidebar */
.app[data-screen-label="devops"] .sidebar{background:#0C1020;border-right-color:var(--line-strong)}
.app[data-screen-label="devops"] .sb-brand{border-bottom-color:var(--line)}
.app[data-screen-label="devops"] .sb-item{color:var(--ink-2)}
.app[data-screen-label="devops"] .sb-item:hover{background:rgba(255,255,255,0.04)}
.app[data-screen-label="devops"] .sb-item.active{background:rgba(84,104,255,0.14);color:var(--ink)}
/* Buttons */
.app[data-screen-label="devops"] .btn{border-color:var(--line-strong);color:var(--ink)}
.app[data-screen-label="devops"] .btn-ghost{background:transparent}
.app[data-screen-label="devops"] .btn-ghost:hover{background:rgba(255,255,255,0.04);border-color:var(--line-xstrong)}
.app[data-screen-label="devops"] .btn-cobalt{background:var(--cobalt);color:#fff;border-color:var(--cobalt)}
.app[data-screen-label="devops"] .btn-cobalt:hover{background:var(--cobalt-bright)}
/* Inputs */
.app[data-screen-label="devops"] input,
.app[data-screen-label="devops"] select,
.app[data-screen-label="devops"] textarea{background:rgba(255,255,255,0.03);border-color:var(--line-strong);color:var(--ink)}
/* Page head text */
.app[data-screen-label="devops"] .page-head h1{color:var(--ink)}
.app[data-screen-label="devops"] .card-head h3{color:var(--ink)}
.app[data-screen-label="devops"] .card-head-sub{color:var(--muted)}
/* Topbar actions/icons */
.app[data-screen-label="devops"] .icon-btn{color:var(--ink-2);border-color:var(--line-strong)}
.app[data-screen-label="devops"] .env-pill{background:rgba(255,255,255,0.04);border-color:var(--line-strong);color:var(--ink-2)}

/* Architecture diagram */
.arch-diagram{position:relative;background:linear-gradient(180deg, rgba(84,104,255,0.04), rgba(255,255,255,0.01));border:1px solid rgba(255,255,255,0.08);border-radius:10px;padding:8px;overflow:hidden}
.arch-diagram svg{width:100%;height:auto;display:block;max-height:380px}
.arch-legend{display:flex;flex-wrap:wrap;gap:14px;padding:10px 12px 4px;font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:0.08em;color:rgba(232,237,245,0.6);text-transform:uppercase}
.arch-legend span{display:inline-flex;align-items:center;gap:6px}
.arch-legend i{width:8px;height:8px;border-radius:2px;display:inline-block;box-shadow:0 0 6px currentColor}

/* Top endpoints inside throughput card */
.endpoints{display:flex;flex-direction:column;gap:2px}
.ep-row{display:grid;grid-template-columns:46px 1fr 90px 70px 64px 56px;align-items:center;gap:12px;padding:7px 0;border-bottom:1px solid var(--line)}
.ep-row:last-child{border-bottom:none}
.ep-method{font-family:'Geist Mono',monospace;font-size:9.5px;letter-spacing:.08em;font-weight:600;text-align:center;padding:3px 0;border-radius:3px}
.ep-method.m-get{background:rgba(28,43,224,0.10);color:#1C2BE0}
.ep-method.m-post{background:rgba(245,181,68,0.16);color:#A87100}
.ep-path{font-size:11.5px;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ep-bar{position:relative;height:4px;background:rgba(10,14,39,0.06);border-radius:2px;overflow:hidden}
.ep-bar i{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,#1C2BE0,#5C6BFF);border-radius:2px}
.ep-rps,.ep-p99,.ep-err{font-size:11px;text-align:right}
.ep-rps em,.ep-p99 em{font-style:normal;color:var(--muted);margin-left:3px;font-size:9.5px}
.ep-err.ok{color:var(--ok)}
.ep-err.warn{color:#A87100}
.ep-err.mut{color:var(--muted)}

/* Architecture inspect modal */
.arch-modal{background:#0E1220;border:1px solid rgba(255,255,255,0.10);border-radius:14px;width:min(1100px,94vw);max-height:92vh;display:flex;flex-direction:column;box-shadow:0 40px 100px -20px rgba(0,0,0,0.7);overflow:hidden}
.arch-modal-hd{display:flex;align-items:flex-start;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid rgba(255,255,255,0.08);gap:16px}
.arch-modal-hd h2{font-size:18px;font-weight:600;letter-spacing:-0.015em;margin:0;color:#E8EDF5}
.arch-modal-hd .sub{font-size:11px;color:rgba(232,237,245,0.55);letter-spacing:0.06em;margin-top:6px}
.arch-modal-body{padding:18px 24px;overflow:auto;flex:1}
.arch-modal-body .arch-diagram svg{max-height:none;height:auto}
.arch-modal-foot{display:flex;flex-wrap:wrap;align-items:center;gap:18px;padding:14px 24px;border-top:1px solid rgba(255,255,255,0.08);font-size:10.5px;letter-spacing:0.08em;color:rgba(232,237,245,0.7)}
.arch-modal-foot span{display:inline-flex;align-items:center;gap:8px}
.arch-modal-foot .d{width:6px;height:6px;border-radius:50%;display:inline-block;background:rgba(255,255,255,0.4)}
.arch-modal-foot .d.ok{background:#3DD68C;box-shadow:0 0 8px #3DD68C}
.arch-modal-foot .d.warn{background:#F5B544;box-shadow:0 0 8px #F5B544}

/* ============ Brand detail popup ============ */
.brand-detail-overlay{position:fixed;inset:0;background:rgba(10,14,39,0.42);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:center;justify-content:center;padding:32px;animation:bdFade .14s ease-out}
@keyframes bdFade{from{opacity:0}to{opacity:1}}
.brand-detail{width:min(720px,94vw);max-height:88vh;background:var(--panel);border:1px solid var(--line-strong);border-radius:14px;display:flex;flex-direction:column;box-shadow:0 40px 100px -20px rgba(10,14,39,0.4);animation:bdPop .22s cubic-bezier(.2,.7,.2,1);overflow:hidden}
@keyframes bdPop{from{transform:translateY(12px) scale(.98);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}
.bd-header{padding:18px 22px 0;border-bottom:1px solid var(--line);position:relative}
.bd-header-popup{padding:18px 22px 0}
.bd-header-row{display:flex;align-items:center;gap:14px;position:relative;z-index:1}
.bd-logo{width:48px!important;height:48px!important;font-size:20px!important;border-radius:10px;border:1px solid var(--line-strong);box-shadow:none}
.bd-header-meta{flex:1;min-width:0}
.bd-name{font-size:18px;font-weight:600;letter-spacing:-0.02em;color:var(--ink)}
.bd-legal{font-size:10.5px;color:var(--muted);letter-spacing:.04em;margin-top:3px}
.bd-header-actions{display:flex;align-items:center;gap:8px}
.bd-meta{display:flex;flex-wrap:wrap;gap:8px;padding:10px 0 0;font-size:10px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase}
.bd-tabs{display:flex;gap:0;margin-top:14px;border-bottom:none}
.bd-tab{appearance:none;background:transparent;border:0;padding:10px 14px;font-family:inherit;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);cursor:pointer;position:relative;font-weight:500}
.bd-tab:hover{color:var(--ink)}
.bd-tab.active{color:var(--ink)}
.bd-tab.active::after{content:"";position:absolute;left:14px;right:14px;bottom:-1px;height:2px;background:var(--cobalt);border-radius:2px}
.bd-body{flex:1;overflow-y:auto;padding:22px 26px 32px}
.bd-stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-strong);border:1px solid var(--line-strong);border-radius:10px;overflow:hidden;margin-bottom:22px}
.bd-stat{background:var(--panel);padding:14px 16px;display:flex;flex-direction:column;gap:6px}
.bd-stat .l{font-family:'Geist Mono',monospace;font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.bd-stat .v{font-size:18px;font-weight:600;letter-spacing:-0.02em;color:var(--ink)}
.bd-stat .v .u{font-family:'Geist Mono',monospace;font-size:10px;color:var(--muted);margin-left:4px;font-weight:500}
.bd-section{margin-top:22px}
.bd-section-hd{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:12px}
.bd-section-hd h4{font-size:13px;font-weight:600;letter-spacing:-0.01em;margin:0;color:var(--ink)}
.bd-chart{height:120px}
.bd-chart svg{width:100%;height:100%;display:block}
.bd-contact{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:8px;overflow:hidden}
.bd-contact-cell{background:var(--panel);padding:12px 14px}
.bd-contact-cell .l{font-family:'Geist Mono',monospace;font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.bd-contact-cell .v{font-size:13px;color:var(--ink)}
.bd-card-list{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:8px;overflow:hidden}
.bd-card-row{display:grid;grid-template-columns:1.4fr 110px 90px 90px;align-items:center;gap:10px;padding:11px 14px;background:var(--panel);border-bottom:1px solid var(--line)}
.bd-card-row:last-child{border-bottom:none}
.bd-serial{font-size:11.5px;color:var(--ink)}
.bd-amount{font-size:12px;text-align:right}
.bd-amount em{font-style:normal;color:var(--muted);font-size:9.5px;margin-left:4px}
.bd-when{font-size:10.5px;color:var(--muted);text-align:right;letter-spacing:.04em}
.bd-branch-list{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:8px;overflow:hidden}
.bd-branch-row{display:grid;grid-template-columns:1fr 100px 100px;align-items:center;gap:14px;padding:13px 16px;background:var(--panel);border-bottom:1px solid var(--line)}
.bd-branch-row:last-child{border-bottom:none}
.bd-branch-nm{font-size:13.5px;font-weight:500;color:var(--ink)}
.bd-branch-city{font-size:10.5px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin-top:2px}
.bd-branch-stat .l{font-family:'Geist Mono',monospace;font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.bd-branch-stat .v{font-size:13px;color:var(--ink);margin-top:2px}
.bd-settings{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:8px;overflow:hidden}
.bd-setting{background:var(--panel);padding:12px 14px}
.bd-setting .l{font-family:'Geist Mono',monospace;font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.bd-setting .v{font-size:13px;color:var(--ink)}
.bd-actions{display:flex;gap:8px;margin-top:18px;flex-wrap:wrap}

/* Design tab — per-denomination card art */
.bd-design-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}
.bd-design-tile{display:flex;flex-direction:column;gap:8px}
.bd-design-art{position:relative;aspect-ratio:1.586/1;border-radius:10px;overflow:hidden;cursor:pointer;display:flex;align-items:center;justify-content:center;border:1px solid var(--line-strong);transition:transform .12s}
.bd-design-art:hover{transform:translateY(-1px)}
.bd-design-art img{width:100%;height:100%;object-fit:cover;display:block}
.bd-design-placeholder{display:flex;flex-direction:column;align-items:center;gap:6px;color:rgba(255,255,255,0.85)}
.bd-design-placeholder .mono{font-size:9.5px;letter-spacing:.14em;text-transform:uppercase}
.bd-design-overlay{position:absolute;inset:0;background:rgba(0,0,0,0.5);color:#fff;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;font-size:10px;letter-spacing:.16em}
.bd-design-art:hover .bd-design-overlay{opacity:1}
.bd-design-meta{display:flex;align-items:center;justify-content:space-between;gap:8px}
.bd-design-amount{font-size:14px;font-weight:600;letter-spacing:-0.01em;color:var(--ink)}
.bd-design-amount em{font-style:normal;color:var(--muted);font-size:10px;margin-left:5px;letter-spacing:.06em;font-weight:500}
.bd-design-actions{display:flex;gap:4px}
.bd-design-btn{width:22px;height:22px;border-radius:5px;background:var(--bg);border:1px solid var(--line-strong);color:var(--muted);display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0}
.bd-design-btn:hover{background:var(--panel);color:var(--ink)}
.bd-design-btn-danger:hover{background:var(--danger);border-color:var(--danger);color:#fff}
.bd-design-tile-add{border:1px dashed rgba(28,43,224,0.3);border-radius:10px;background:rgba(28,43,224,0.04);padding:14px;display:flex;align-items:center;justify-content:center}
.bd-design-add-form{display:flex;flex-direction:column;gap:8px;width:100%}
.bd-design-add-label{font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);text-align:center}
.bd-denom-input{width:100%;padding:8px 10px;border:1px solid var(--line-strong);border-radius:6px;background:var(--panel);font-size:13px;letter-spacing:.02em}
.bd-denom-input:focus{outline:none;border-color:var(--cobalt);box-shadow:0 0 0 3px rgba(28,43,224,0.08)}

.bd-custom-row{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:8px;overflow:hidden}
.bd-custom-cell{background:var(--panel);padding:12px 14px;display:flex;flex-direction:column;gap:4px}
.bd-custom-cell .l{font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.bd-custom-cell .u{font-size:9.5px;color:var(--muted);letter-spacing:.06em;align-self:flex-end}
.bd-custom-input{appearance:none;border:none;background:transparent;font-size:18px;font-weight:600;letter-spacing:-0.01em;color:var(--ink);padding:0;width:100%}
.bd-custom-input:focus{outline:none}
.bd-custom-input:disabled{color:var(--muted);opacity:.5}
@media(max-width:700px){
  .bd-stat-row{grid-template-columns:repeat(2,1fr)}
  .brand-detail{width:100vw}
}

/* User comments */
.uc-card{padding:0;overflow:hidden}
.uc-card .card-head{padding:14px 16px;border-bottom:1px solid var(--line)}
.uc-composer{padding:14px 16px;background:var(--bg);border-bottom:1px solid var(--line)}
.uc-textarea{width:100%;padding:10px 12px;border:1px solid var(--line-strong);border-radius:8px;background:var(--panel);font:inherit;font-size:13px;line-height:1.45;color:var(--ink);resize:vertical;min-height:64px}
.uc-textarea::placeholder{color:var(--muted)}
.uc-textarea:focus{outline:none;border-color:var(--cobalt);box-shadow:0 0 0 3px rgba(28,43,224,0.08)}
.uc-composer-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:10px}
.uc-hint{font-size:9.5px;letter-spacing:.1em;color:var(--muted)}
.uc-thread{display:flex;flex-direction:column}
.uc-comment{display:grid;grid-template-columns:32px 1fr;gap:12px;padding:14px 16px;border-bottom:1px solid var(--line)}
.uc-comment:last-child{border-bottom:none}
.uc-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#1C2BE0 0%,#3D4DFF 100%);color:#fff;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;letter-spacing:.04em}
.uc-body{min-width:0}
.uc-meta{display:flex;align-items:baseline;gap:8px;margin-bottom:4px;flex-wrap:wrap}
.uc-author{font-size:13px;font-weight:600;color:var(--ink);letter-spacing:-0.01em}
.uc-role{font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);background:var(--bg);padding:2px 6px;border-radius:4px;border:1px solid var(--line-strong)}
.uc-when{font-size:10.5px;color:var(--muted);letter-spacing:.04em;margin-left:auto}
.uc-text{font-size:13px;line-height:1.55;color:var(--ink-2);text-wrap:pretty}
.uc-empty{padding:24px 16px;text-align:center;font-size:10.5px;letter-spacing:.12em;color:var(--muted)}
