/* ============================================================
   DomVue · App shared styles (kabinet + admin)
   Bloomberg-tier density, monospace-first, brand colors
   ============================================================ */

:root{
  --ink:#0B0E14; --ink-2:#0F141C; --ink-3:#141923; --ink-4:#1A2030;
  --border:#1C2330; --border-2:#262F3E; --border-3:#384356;
  --text:#E8ECF1; --text-2:#C7CDD8; --muted:#8B95A7; --muted-2:#5C6678; --muted-3:#3F4858;
  --primary:#5B8FC0; --primary-2:#6FA0D0; --primary-deep:#2C4A6B; --primary-pale:#A8C4DD;
  --primary-glow:rgba(91,143,192,.14);
  --st-active:#3FB950; --st-expiring:#F0B72F; --st-expired:#E8843C;
  --st-redemption:#E55656; --st-pending:#A371F7; --st-auction:#FF6B9D;
  --st-drop:#5B8FC0;
  --row-h:30px; --row-h-compact:26px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Geist Mono','JetBrains Mono','SF Mono',ui-monospace,monospace;
  font-size:12.5px;line-height:1.4;
  background:var(--ink);color:var(--text);
  -webkit-font-smoothing:antialiased;
  font-feature-settings:'zero','ss01';
}
.sans{font-family:'Inter',-apple-system,system-ui,sans-serif}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:0;padding:0;cursor:pointer}

/* ============ TOP BAR ============ */
.topbar{
  height:42px;display:flex;align-items:stretch;
  background:var(--ink-2);border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:40;
}
.topbar-l,.topbar-r{display:flex;align-items:center;gap:0}
.topbar-l{flex:1;min-width:0}
.tb-brand{
  display:flex;align-items:center;gap:9px;padding:0 16px;
  border-right:1px solid var(--border);height:100%;
}
.tb-brand-wm{font-family:'Inter',sans-serif;font-weight:600;font-size:14px;letter-spacing:-.03em;color:var(--text);
  display:inline-flex;align-items:center;gap:3px}
.tb-brand-dot{width:2.5px;height:2.5px;border-radius:50%;background:var(--primary);transform:translateY(2px)}

.tb-tabs{display:flex;height:100%}
.tb-tab{
  display:flex;align-items:center;gap:6px;padding:0 14px;height:100%;
  font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;
  border-right:1px solid var(--border);cursor:pointer;transition:color .12s,background .12s;
}
.tb-tab:hover{color:var(--text-2);background:var(--ink-3)}
.tb-tab.active{color:var(--text);background:var(--ink);border-bottom:2px solid var(--primary);height:calc(100% + 1px)}
.tb-tab .tb-count{
  font-size:10px;background:var(--ink-4);color:var(--muted);
  padding:1px 5px;border-radius:2px;border:1px solid var(--border-2);
}
.tb-tab.active .tb-count{color:var(--primary);border-color:rgba(91,143,192,.32);background:rgba(91,143,192,.08)}

.tb-search{
  display:flex;align-items:center;gap:8px;padding:0 14px;flex:1;min-width:0;
  border-right:1px solid var(--border);
}
.tb-search input{
  flex:1;background:transparent;border:0;outline:0;color:var(--text);
  font:inherit;font-size:12px;min-width:0;
}
.tb-search input::placeholder{color:var(--muted-2)}
.tb-kbd{
  font-size:10px;padding:1px 5px;border-radius:2px;
  background:var(--ink-4);border:1px solid var(--border-2);color:var(--muted);
}

.tb-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:0 12px;height:100%;border-left:1px solid var(--border);
  font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;
  cursor:pointer;transition:color .12s,background .12s;
}
.tb-btn:hover{color:var(--text);background:var(--ink-3)}
.tb-btn.primary{color:var(--primary);background:var(--primary-glow)}
.tb-btn.primary:hover{color:#fff;background:var(--primary)}
.tb-btn .dot{width:6px;height:6px;border-radius:50%;background:currentColor}

/* ============ TOOLBAR (filters under tabs) ============ */
.toolbar{
  display:flex;align-items:center;gap:0;
  background:var(--ink-2);border-bottom:1px solid var(--border);
  height:34px;position:sticky;top:42px;z-index:35;
}
.tlb-group{display:flex;align-items:center;height:100%;border-right:1px solid var(--border)}
.tlb-label{
  font-size:10px;color:var(--muted-2);padding:0 10px 0 14px;
  text-transform:uppercase;letter-spacing:.08em;
}
.tlb-chip{
  display:inline-flex;align-items:center;gap:5px;
  padding:3px 8px;margin-right:6px;border-radius:2px;
  font-size:11px;color:var(--muted);
  border:1px solid transparent;cursor:pointer;transition:all .12s;
}
.tlb-chip:hover{color:var(--text);background:var(--ink-3)}
.tlb-chip.active{color:var(--text);background:var(--ink-4);border-color:var(--border-2)}
.tlb-chip .d{width:6px;height:6px;border-radius:50%;background:currentColor;opacity:.7}
.tlb-chip .x{margin-left:4px;color:var(--muted-2);font-size:10px}
.tlb-spacer{flex:1}
.tlb-meta{
  font-size:11px;color:var(--muted-2);padding:0 14px;
}
.tlb-meta strong{color:var(--text);font-weight:500}

/* ============ ATTENTION STRIP ============ */
.attn-strip{
  background:var(--ink-2);border-bottom:1px solid var(--border);
  padding:8px 14px;display:flex;align-items:center;gap:12px;
  font-size:11px;
}
.attn-strip .label{
  color:var(--muted-2);text-transform:uppercase;letter-spacing:.08em;
  display:flex;align-items:center;gap:6px;flex-shrink:0;
}
.attn-strip .label .pulse{
  width:6px;height:6px;border-radius:50%;background:var(--st-auction);
  box-shadow:0 0 0 3px rgba(255,107,157,.18);
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.55}}
.attn-strip .items{display:flex;gap:0;overflow-x:auto;flex:1}
.attn-pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:4px 10px;margin-right:8px;border-radius:3px;
  background:var(--ink-3);border:1px solid var(--border-2);
  font-size:11px;cursor:pointer;transition:border-color .12s;flex-shrink:0;
}
.attn-pill:hover{border-color:var(--border-3)}
.attn-pill .name{color:var(--text);font-weight:500}
.attn-pill .rec{color:var(--muted)}
.attn-pill .arrow{color:var(--primary);margin-left:4px}

/* ============ TABLE ============ */
.tbl-wrap{flex:1;overflow:auto;background:var(--ink)}
table.tbl{
  width:100%;border-collapse:collapse;table-layout:fixed;
  font-size:12px;
}
.tbl thead th{
  position:sticky;top:0;z-index:10;
  background:var(--ink-2);
  text-align:left;font-weight:500;color:var(--muted);
  font-size:10px;text-transform:uppercase;letter-spacing:.08em;
  padding:7px 10px;height:28px;
  border-bottom:1px solid var(--border-2);
  border-right:1px solid var(--border);
  white-space:nowrap;cursor:pointer;user-select:none;
}
.tbl thead th:last-child{border-right:0}
.tbl thead th:hover{color:var(--text);background:var(--ink-3)}
.tbl thead th.sorted{color:var(--primary)}
.tbl thead th .sort{font-size:9px;margin-left:4px;opacity:.7}
.tbl tbody td{
  padding:0 10px;height:var(--row-h);
  border-bottom:1px solid var(--border);
  border-right:1px solid var(--border);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  vertical-align:middle;
}
.tbl tbody td:last-child{border-right:0}
.tbl tbody tr{cursor:pointer;transition:background .08s}
.tbl tbody tr:hover{background:var(--ink-2)}
.tbl tbody tr.selected{background:rgba(91,143,192,.08)}
.tbl tbody tr.attn td:first-child{box-shadow:inset 2px 0 0 var(--st-auction)}

.cell-domain{color:var(--text);font-weight:500}
.cell-domain .tld{color:var(--muted)}
.cell-muted{color:var(--muted)}
.cell-num{font-variant-numeric:tabular-nums;color:var(--text-2)}
.cell-num.warn{color:var(--st-expiring)}
.cell-num.danger{color:var(--st-redemption)}
.cell-rec{color:var(--text-2);font-size:11.5px}
.cell-rec .verb{color:var(--primary)}
.cell-tag{
  display:inline-block;padding:1px 5px;margin-right:3px;
  background:var(--ink-3);border:1px solid var(--border-2);border-radius:2px;
  font-size:10px;color:var(--muted);
}
.cell-icon{color:var(--muted);font-size:11px}

/* ============ BADGES ============ */
.bdg{
  display:inline-flex;align-items:center;gap:5px;
  font-size:10.5px;font-weight:500;
  padding:1px 6px;border-radius:2px;
  border:1px solid;line-height:1.4;
}
.bdg .d{width:5px;height:5px;border-radius:50%}
.bdg-active{color:var(--st-active);border-color:rgba(63,185,80,.3);background:rgba(63,185,80,.08)}
.bdg-active .d{background:var(--st-active)}
.bdg-expiring{color:var(--st-expiring);border-color:rgba(240,183,47,.3);background:rgba(240,183,47,.08)}
.bdg-expiring .d{background:var(--st-expiring)}
.bdg-expired{color:var(--st-expired);border-color:rgba(232,132,60,.3);background:rgba(232,132,60,.08)}
.bdg-expired .d{background:var(--st-expired)}
.bdg-redemption{color:var(--st-redemption);border-color:rgba(229,86,86,.3);background:rgba(229,86,86,.08)}
.bdg-redemption .d{background:var(--st-redemption)}
.bdg-pending{color:var(--st-pending);border-color:rgba(163,113,247,.3);background:rgba(163,113,247,.08)}
.bdg-pending .d{background:var(--st-pending)}
.bdg-auction{color:var(--st-auction);border-color:rgba(255,107,157,.3);background:rgba(255,107,157,.08)}
.bdg-auction .d{background:var(--st-auction)}
.bdg-drop{color:var(--st-drop);border-color:rgba(91,143,192,.32);background:rgba(91,143,192,.08)}
.bdg-drop .d{background:var(--st-drop)}
.bdg-mute{color:var(--muted);border-color:var(--border-2);background:var(--ink-3)}
.bdg-mute .d{background:var(--muted)}

/* ============ STATUS BAR (bottom) ============ */
.statusbar{
  height:24px;background:var(--ink-2);border-top:1px solid var(--border);
  display:flex;align-items:center;font-size:10.5px;color:var(--muted);
  position:sticky;bottom:0;z-index:30;
}
.sb-item{padding:0 12px;border-right:1px solid var(--border);height:100%;
  display:flex;align-items:center;gap:6px}
.sb-item:last-child{border-right:0}
.sb-item .dot{width:5px;height:5px;border-radius:50%;background:var(--st-active)}
.sb-spacer{flex:1}
.sb-item strong{color:var(--text);font-weight:500}

/* ============ APP SHELL ============ */
.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}
.app-main{display:flex;flex-direction:column;flex:1;overflow:hidden}

/* ============ DRAWER (add domain) ============ */
.drawer-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.5);
  z-index:60;display:none;
}
.drawer-overlay.open{display:block}
.drawer{
  position:fixed;top:0;right:0;bottom:0;width:520px;max-width:90vw;
  background:var(--ink-2);border-left:1px solid var(--border-2);
  z-index:61;transform:translateX(100%);transition:transform .25s ease;
  display:flex;flex-direction:column;
}
.drawer.open{transform:translateX(0)}
.drawer-head{
  height:42px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;padding:0 16px;
}
.drawer-title{font-size:13px;color:var(--text);font-weight:500;text-transform:uppercase;letter-spacing:.06em}
.drawer-close{font-size:18px;color:var(--muted);cursor:pointer;padding:4px;line-height:1}
.drawer-close:hover{color:var(--text)}
.drawer-body{padding:18px 18px 0;overflow:auto;flex:1}
.drawer-foot{
  padding:14px 18px;border-top:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;gap:12px;
}
.fld{margin-bottom:16px}
.fld label{
  display:block;font-size:10.5px;color:var(--muted);
  text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px;
}
.fld input,.fld textarea,.fld select{
  width:100%;background:var(--ink);border:1px solid var(--border-2);border-radius:3px;
  padding:8px 10px;color:var(--text);font:inherit;font-size:12px;outline:0;
  transition:border-color .12s;
}
.fld input:focus,.fld textarea:focus,.fld select:focus{border-color:var(--primary)}
.fld textarea{min-height:120px;resize:vertical;font-family:'Geist Mono',monospace}
.fld .hint{font-size:10.5px;color:var(--muted-2);margin-top:6px}

.btn-app{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 14px;border-radius:3px;font-size:11.5px;font-weight:500;
  text-transform:uppercase;letter-spacing:.06em;cursor:pointer;
  transition:all .12s;
}
.btn-app.primary{background:var(--primary);color:#fff}
.btn-app.primary:hover{background:var(--primary-2)}
.btn-app.ghost{color:var(--muted);border:1px solid var(--border-2)}
.btn-app.ghost:hover{color:var(--text);border-color:var(--muted)}

/* ============ TIMELINE (detail page) ============ */
.timeline{
  display:grid;grid-template-columns:repeat(7,1fr);gap:0;
  background:var(--ink-2);border:1px solid var(--border);border-radius:4px;
  padding:0;overflow:hidden;
}
.tl-stage{
  padding:14px 12px;border-right:1px solid var(--border);
  display:flex;flex-direction:column;gap:6px;position:relative;
  cursor:default;
}
.tl-stage:last-child{border-right:0}
.tl-stage .tl-name{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.tl-stage .tl-days{font-size:18px;font-weight:500;color:var(--muted-2);font-variant-numeric:tabular-nums}
.tl-stage .tl-sub{font-size:10px;color:var(--muted-2)}
.tl-stage.past .tl-name{color:var(--muted-2)}
.tl-stage.past .tl-days{color:var(--muted-2)}
.tl-stage.current{background:var(--ink-3)}
.tl-stage.current::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:currentColor;
}
.tl-stage.current .tl-name,.tl-stage.current .tl-days{color:var(--text)}
.tl-stage.future .tl-days{color:var(--muted-3)}
.tl-stage[data-stage="active"].current{color:var(--st-active)}
.tl-stage[data-stage="expiring"].current{color:var(--st-expiring)}
.tl-stage[data-stage="expired"].current{color:var(--st-expired)}
.tl-stage[data-stage="grace"].current{color:var(--st-expired)}
.tl-stage[data-stage="redemption"].current{color:var(--st-redemption)}
.tl-stage[data-stage="pending"].current{color:var(--st-pending)}
.tl-stage[data-stage="drop"].current{color:var(--st-drop)}

/* scrollbars */
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:var(--ink)}
::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:var(--border-3)}

/* ============ AUTH ADDITIONS ============ */
.auth-shell{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  padding:40px 20px;background:var(--ink);
}
.auth-card{
  width:100%;max-width:420px;background:var(--ink-2);
  border:1px solid var(--border);border-radius:6px;
  padding:36px 32px;display:flex;flex-direction:column;gap:18px;
}
.auth-logo{display:flex;justify-content:center;margin-bottom:8px;color:var(--text)}
.auth-logo img{width:140px;height:auto}
.auth-form{display:flex;flex-direction:column;gap:14px}
.auth-title{
  font-family:'Inter',sans-serif;font-size:20px;font-weight:500;
  letter-spacing:-.01em;color:var(--text);margin:0 0 4px;text-align:center;
}
.auth-error{
  font-size:11.5px;color:var(--st-redemption);
  background:rgba(229,86,86,.08);border:1px solid rgba(229,86,86,.3);
  border-radius:3px;padding:8px 10px;
}
.auth-label{
  display:flex;flex-direction:column;gap:6px;
  font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;
}
.auth-input{
  width:100%;background:var(--ink);border:1px solid var(--border-2);border-radius:3px;
  padding:9px 11px;color:var(--text);font:inherit;font-size:13px;outline:0;
  transition:border-color .12s;text-transform:none;letter-spacing:0;
}
.auth-input:focus{border-color:var(--primary)}
.auth-submit{
  background:var(--primary);color:#fff;border:0;border-radius:3px;
  padding:10px 14px;font:inherit;font-size:12px;font-weight:500;
  text-transform:uppercase;letter-spacing:.06em;cursor:pointer;
  transition:background .12s;margin-top:6px;
}
.auth-submit:hover{background:var(--primary-2)}
.auth-hint{
  font-size:11.5px;color:var(--muted);text-align:center;margin:8px 0 0;
}
.auth-hint a{color:var(--primary)}
.auth-hint a:hover{color:var(--primary-2)}

/* ============ DASHBOARD ADD-DOMAIN INLINE FORM ============ */
.add-form{
  display:flex;align-items:center;gap:8px;padding:8px 12px;
  background:var(--ink-2);border-bottom:1px solid var(--border);
}
.add-form input{
  background:var(--ink);border:1px solid var(--border-2);border-radius:3px;
  padding:7px 10px;color:var(--text);font:inherit;font-size:12px;outline:0;
  transition:border-color .12s;
}
.add-form input:focus{border-color:var(--primary)}
.add-form input.dom{flex:1;max-width:360px}
.add-form input.lbl{width:200px}
.add-form button{
  background:var(--primary);color:#fff;border:0;border-radius:3px;
  padding:7px 14px;font:inherit;font-size:11.5px;font-weight:500;
  text-transform:uppercase;letter-spacing:.06em;cursor:pointer;
}
.add-form button:hover{background:var(--primary-2)}

.row-action{
  background:transparent;color:var(--muted);border:1px solid var(--border-2);
  border-radius:3px;padding:3px 8px;font-size:10.5px;cursor:pointer;
  text-transform:uppercase;letter-spacing:.06em;
}
.row-action:hover{color:var(--st-redemption);border-color:rgba(229,86,86,.3)}

.empty-state{
  padding:48px 24px;text-align:center;color:var(--muted-2);font-size:12.5px;
}

/* ============ TAGS (inline edit on dashboard) ============ */
.dv-tags{display:inline-flex;gap:4px;flex-wrap:wrap;align-items:center;cursor:pointer;min-height:20px}
.dv-tags-editor{display:inline-flex;gap:6px;flex-wrap:wrap;align-items:center}
.dv-tags-editor form{display:inline-flex;gap:4px;align-items:center}
.dv-tags-chips{display:inline-flex;gap:4px;flex-wrap:wrap}
.dv-tag{display:inline-flex;align-items:center;gap:3px;font-size:10.5px;padding:1px 6px;border-radius:2px;border:1px solid;line-height:1.4}
.dv-tag-owned{color:var(--st-auction);border-color:rgba(255,107,157,.32);background:rgba(255,107,157,.08)}
.dv-tag-watching{color:var(--primary);border-color:rgba(91,143,192,.32);background:rgba(91,143,192,.08)}
.dv-tag-user{color:var(--muted);border-color:var(--border-2);background:var(--ink-3)}
.dv-tag-add{font-size:10.5px;color:var(--muted-2);padding:1px 6px;border:1px dashed var(--border-2);border-radius:2px}
.dv-tag-x{background:transparent;border:0;color:inherit;font-size:11px;cursor:pointer;padding:0;line-height:1}
.dv-tag-input{font-size:10.5px;padding:2px 6px;background:var(--ink);border:1px solid var(--border-2);border-radius:2px;color:var(--text);max-width:120px}
.dv-tag-add-btn{font-size:10.5px;padding:2px 8px;background:var(--primary);color:#fff;border:0;border-radius:2px;cursor:pointer}

/* ============ RECOMMENDATION (severity-colored) ============ */
.dv-rec{display:inline-flex;align-items:center;gap:6px;font-size:11.5px}
.dv-rec-empty{color:var(--muted-2)}
.dv-sev-info{color:var(--muted)}
.dv-sev-medium{color:var(--st-expiring)}
.dv-sev-high{color:var(--st-expired)}
.dv-sev-critical{color:var(--st-redemption);font-weight:600}
.dv-rec-card{border-left:3px solid currentColor;padding:14px 18px;margin:0 0 18px;border-radius:0 4px 4px 0;background:var(--ink-2)}
.dv-rec-card-headline{font-size:15px;font-weight:600;margin:0 0 6px;color:var(--text)}
.dv-rec-card-action{font-size:13px;color:var(--muted-2)}
