/* Pulse Service — component & layout styles (complements tokens.css) */
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--fg);font-family:var(--font-sans);height:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
input,select,textarea{font-family:var(--font-sans)}
svg.lucide{stroke-width:1.75px}
.mono{font-family:var(--font-mono);font-variant-numeric:tabular-nums}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:var(--ink-300);border-radius:99px;border:2px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-track{background:transparent}

@keyframes pulseDot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.7)}}
@keyframes drawerIn{from{transform:translateX(28px);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes fadeUp{from{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}

/* layout shell */
.app{height:100vh;display:flex;flex-direction:column;overflow:hidden}
.toprail{height:58px;flex:0 0 58px;background:var(--ink-950);display:flex;align-items:center;gap:20px;padding:0 22px;border-bottom:1px solid #000;position:relative;z-index:30}
.brandmark{display:flex;align-items:flex-end;gap:2.5px;height:22px}
.brandmark span{width:3.5px;border-radius:2px}
.body{flex:1;display:flex;min-height:0}
.navrail{width:228px;flex:0 0 228px;background:var(--ink-900);display:flex;flex-direction:column;padding:18px 14px;gap:3px;border-right:1px solid #000}
.navlink{position:relative;display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--r-md);font-size:13.5px;font-weight:500;color:var(--ink-300);cursor:pointer}
.navlink:hover{background:var(--ink-800)}
.navlink.active{font-weight:600;color:#fff;background:var(--ink-800)}
.navlink .nav-ind{position:absolute;left:-14px;top:50%;transform:translateY(-50%);width:3px;height:20px;border-radius:0 3px 3px 0;background:var(--amber-500);opacity:0}
.navlink.active .nav-ind{opacity:1}
.navlink .nav-icon{display:inline-flex;color:var(--ink-400)}
.navlink.active .nav-icon{color:var(--amber-400)}
.navlink .nav-count{font-family:var(--font-mono);font-size:11px;color:var(--ink-600)}
.navlink.active .nav-count{color:var(--ink-300)}
.workspace{flex:1;overflow-y:auto;background:var(--bg)}
.wrap{max-width:1280px;margin:0 auto;padding:28px 32px 56px}
.pagehead{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:18px}

/* buttons */
.btn{height:38px;padding:0 15px;display:inline-flex;align-items:center;gap:7px;border-radius:var(--r-md);font-size:13px;font-weight:600;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--fg);box-shadow:var(--shadow-xs);text-decoration:none}
.btn:hover{background:var(--ink-50)}
.btn-primary{background:var(--accent);border-color:var(--accent-hover);color:var(--accent-fg);box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--accent-hover)}
.btn-sm{height:30px;padding:0 11px;font-size:12px;gap:6px;border-radius:var(--r-sm)}
.iconbtn{width:34px;height:34px;border-radius:var(--r-md);border:1px solid var(--ink-800);background:var(--ink-900);color:var(--ink-300);cursor:pointer;display:inline-flex;align-items:center;justify-content:center}

/* cards & tables */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}
table.data{width:100%;border-collapse:collapse}
table.data th{text-align:left;padding:11px 16px;font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--fg-muted);font-weight:600;border-bottom:1px solid var(--border);background:var(--ink-50)}
table.data td{padding:11px 16px;border-bottom:1px solid var(--divider);font-size:13px}
table.data tbody tr.click{cursor:pointer}
table.data tbody tr.click:hover{background:var(--accent-tint)}
.avatar{width:28px;height:28px;border-radius:50%;background:var(--ink-800);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex:0 0 auto}

/* chips */
.chip{height:32px;padding:0 13px;border-radius:var(--r-pill);font-size:12.5px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);background:var(--surface);color:var(--fg-muted);text-decoration:none}
.chip.active{border-color:var(--accent);background:var(--accent-tint);color:var(--amber-700)}

/* forms */
.field{display:flex;flex-direction:column;gap:6px}
.field>span{font-size:12px;font-weight:600;color:var(--fg-muted)}
.field input,.field select,.field textarea{height:40px;padding:0 11px;background:var(--surface-inset);border:1px solid var(--border);border-radius:var(--r-md);font-size:13.5px;color:var(--fg);outline:none}
.field textarea{height:auto;padding:10px 11px;line-height:1.5;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);box-shadow:var(--glow-accent)}
.req{color:var(--neg)}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:15px}

/* drawer + modal */
.scrim{position:fixed;inset:0;background:rgba(19,20,25,.45);backdrop-filter:blur(2px);z-index:42}
.drawer{position:fixed;top:0;right:0;bottom:0;width:480px;max-width:94vw;background:var(--surface);box-shadow:var(--shadow-lg);z-index:43;display:flex;flex-direction:column;animation:drawerIn .26s var(--ease-out)}
.drawer-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:22px 24px;border-bottom:1px solid var(--divider);background:var(--ink-950)}
.drawer-body{flex:1;overflow-y:auto;padding:22px 24px}
.modal-scrim{position:fixed;inset:0;background:rgba(19,20,25,.45);backdrop-filter:blur(2px);z-index:50;display:flex;align-items:flex-start;justify-content:center;padding:52px 24px;overflow-y:auto}
.modal{width:520px;max-width:96vw;background:var(--surface);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);animation:fadeUp .26s var(--ease-out);overflow:hidden}

/* toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:60;display:flex;align-items:center;gap:10px;padding:12px 18px;background:var(--ink-950);color:#fff;border-radius:var(--r-md);box-shadow:var(--shadow-pop);animation:fadeUp .3s var(--ease-out);font-size:13.5px;font-weight:500}

@media print{
  .no-print{display:none!important}
  .workspace{overflow:visible!important;height:auto!important}
  body,html{height:auto!important;background:#fff!important}
  .app{height:auto!important;overflow:visible!important}
}
