/* =============================================================
   ToolProof Hub — admin-only styles
   Matches toolproof.dev navy + cyan/amber accents.
   Geist for UI, JetBrains Mono for IDs/timestamps/amounts.
   ============================================================= */

*{box-sizing:border-box}
html,body{margin:0;background:var(--tp-base);color:var(--tp-text);font-family:var(--tp-font-sans);font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased;color-scheme:dark}
button{font-family:inherit}
a{color:inherit;text-decoration:none}

/* ============ layout ============ */
html,body{height:100%}
.app{display:grid;grid-template-columns:var(--tp-sidebar-w) 1fr;height:100vh;overflow:hidden}

/* sidebar */
.sb{background:var(--tp-surface);border-right:1px solid var(--tp-border-subtle);padding:18px 14px;display:flex;flex-direction:column;gap:4px;height:100vh;overflow-y:auto}
.sb .brand{display:flex;align-items:center;gap:10px;padding:4px 6px 22px;margin-bottom:6px;border-bottom:1px solid var(--tp-border-subtle)}
.sb .brand img{width:28px;height:28px}
.sb .brand .name{font-weight:800;color:var(--tp-text-heading);font-size:15px;letter-spacing:-.01em}
.sb .brand .tag{font-family:var(--tp-font-mono);font-size:9.5px;color:var(--tp-cyan);letter-spacing:.15em;text-transform:uppercase;margin-top:2px;font-weight:600}
.sb .brand .stack{display:flex;flex-direction:column;line-height:1.15}
.sb .sec{font-family:var(--tp-font-mono);font-size:9.5px;color:var(--tp-text-faint);letter-spacing:.16em;text-transform:uppercase;padding:14px 8px 6px;font-weight:600}
.sb a.nav{display:flex;align-items:center;gap:11px;padding:7px 10px;border-radius:var(--tp-r-sm);color:var(--tp-text-mute);font-size:13px;font-weight:500;position:relative}
.sb a.nav i{width:15px;text-align:center;font-size:13px;color:var(--tp-text-subtle)}
.sb a.nav:hover{background:rgba(255,255,255,.03);color:var(--tp-text)}
.sb a.nav.active{background:var(--tp-cyan-dim);color:var(--tp-cyan)}
.sb a.nav.active i{color:var(--tp-cyan)}
.sb a.nav .count{margin-left:auto;font-family:var(--tp-font-mono);font-size:10px;color:var(--tp-text-subtle);background:var(--tp-surface-alt);border:1px solid var(--tp-border-subtle);padding:1px 6px;border-radius:10px;min-width:18px;text-align:center}
.sb a.nav.active .count{color:var(--tp-cyan);background:var(--tp-cyan-dim);border-color:transparent}
.sb a.nav .count.hot{background:var(--tp-red-dim);color:var(--tp-red);border-color:transparent}
.sb .spacer{flex:1}
.sb .me{display:flex;align-items:center;gap:10px;padding:10px;border-top:1px solid var(--tp-border-subtle);margin-top:8px;color:var(--tp-text-mute);font-size:12px}
.sb .me .av{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,#1d3678,#10214a);display:flex;align-items:center;justify-content:center;color:var(--tp-text-heading);font-weight:700;font-size:11px}

/* main */
.main{display:flex;flex-direction:column;min-width:0;height:100vh;overflow:hidden}

/* top bar */
.tb{height:var(--tp-header-h);flex:0 0 auto;border-bottom:1px solid var(--tp-border-subtle);background:var(--tp-surface);display:flex;align-items:center;gap:16px;padding:0 22px;z-index:30}
.tb .crumbs{font-family:var(--tp-font-mono);font-size:11px;color:var(--tp-text-mute);display:flex;align-items:center;gap:8px}
.tb .crumbs .sep{color:var(--tp-text-faint)}
.tb .crumbs .cur{color:var(--tp-text-heading)}
.tb .search{flex:1;max-width:520px;margin:0 auto;position:relative}
.tb .search input{width:100%;background:var(--tp-surface-alt);border:1px solid var(--tp-border);border-radius:var(--tp-r-md);color:var(--tp-text);padding:7px 12px 7px 34px;font-family:var(--tp-font-sans);font-size:12.5px;outline:none;transition:border-color .12s}
.tb .search input:focus{border-color:var(--tp-cyan)}
.tb .search i{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--tp-text-subtle);font-size:12px}
.tb .search .kbd{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-family:var(--tp-font-mono);font-size:10px;color:var(--tp-text-subtle);background:var(--tp-base);border:1px solid var(--tp-border-subtle);padding:1px 6px;border-radius:3px}
.tb .right{display:flex;align-items:center;gap:10px;margin-left:auto}
.tb .iconbtn{width:32px;height:32px;border-radius:var(--tp-r-sm);background:transparent;border:1px solid transparent;color:var(--tp-text-mute);display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative}
.tb .iconbtn:hover{background:var(--tp-surface-alt);color:var(--tp-text);border-color:var(--tp-border-subtle)}
.tb .iconbtn .pip{position:absolute;top:6px;right:6px;width:7px;height:7px;border-radius:50%;background:var(--tp-red);border:2px solid var(--tp-surface)}

/* content */
.content{padding:28px 32px 80px;max-width:1440px;width:100%;margin:0}

/* page header */
.ph{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:22px;flex-wrap:wrap}
.ph h1{margin:0 0 4px;font-size:22px;font-weight:700;color:var(--tp-text-heading);letter-spacing:-.01em}
.ph .sub{color:var(--tp-text-mute);font-size:12.5px}

/* cards */
.card{background:var(--tp-elevated);border:1px solid var(--tp-border);border-radius:var(--tp-r-lg);overflow:hidden}
.card > .ch{padding:14px 18px;border-bottom:1px solid var(--tp-border-subtle);display:flex;align-items:center;justify-content:space-between;gap:12px}
.card > .ch h3{margin:0;font-size:13px;font-weight:700;color:var(--tp-text-heading);display:flex;align-items:center;gap:8px}
.card > .ch .m{color:var(--tp-text-subtle);font-family:var(--tp-font-mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.08em}

/* button */
.btn{display:inline-flex;align-items:center;gap:7px;background:var(--tp-surface-alt);border:1px solid var(--tp-border);color:var(--tp-text);border-radius:var(--tp-r-sm);padding:6px 11px;font-size:12px;font-weight:500;cursor:pointer;font-family:var(--tp-font-sans);transition:border-color .1s,background .1s}
.btn:hover{border-color:var(--tp-border-hot);background:var(--tp-hover)}
.btn.primary{background:var(--tp-amber);border-color:var(--tp-amber);color:#0b0f1a;font-weight:700}
.btn.primary:hover{background:#ffb93a;border-color:#ffb93a}
.btn.ghost{background:transparent;border-color:transparent}
.btn.ghost:hover{background:var(--tp-surface-alt);border-color:var(--tp-border-subtle)}
.btn.danger{color:var(--tp-red);border-color:rgba(255,107,107,.3)}
.btn.danger:hover{background:var(--tp-red-dim);border-color:var(--tp-red)}
.btn.cyan{color:var(--tp-cyan);border-color:rgba(0,200,255,.3)}
.btn.cyan:hover{background:var(--tp-cyan-dim);border-color:var(--tp-cyan)}
.btn .spin{animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* chip */
.chip{display:inline-flex;align-items:center;gap:5px;font-family:var(--tp-font-mono);font-size:10.5px;font-weight:600;padding:2px 7px;border-radius:3px;text-transform:uppercase;letter-spacing:.05em;border:1px solid transparent;line-height:1.5}
.chip::before{content:'';width:5px;height:5px;border-radius:50%;background:currentColor}
.chip.ok{color:var(--tp-green);background:var(--tp-green-dim)}
.chip.warn{color:var(--tp-amber);background:var(--tp-amber-dim)}
.chip.err{color:var(--tp-red);background:var(--tp-red-dim)}
.chip.info{color:var(--tp-cyan);background:var(--tp-cyan-dim)}
.chip.muted{color:var(--tp-text-subtle);background:rgba(139,151,181,.08)}
.chip.violet{color:var(--tp-violet);background:var(--tp-violet-dim)}
.chip.bare{background:transparent;padding:0;border:none}

/* mono inline */
.mono{font-family:var(--tp-font-mono)}
.mono-small{font-family:var(--tp-font-mono);font-size:11px;color:var(--tp-text-mute)}
.amt{font-family:var(--tp-font-mono);color:var(--tp-text-heading);font-weight:600}
.amt.pos{color:var(--tp-green)}
.amt.neg{color:var(--tp-red)}

/* table */
.tbl{width:100%;border-collapse:collapse;font-size:12px}
.tbl thead th{background:var(--tp-surface);text-align:left;font-family:var(--tp-font-mono);font-size:9.5px;letter-spacing:.13em;text-transform:uppercase;font-weight:600;color:var(--tp-text-subtle);padding:9px 14px;border-bottom:1px solid var(--tp-border-subtle)}
.tbl thead th:last-child{text-align:right}
.tbl tbody td{padding:11px 14px;border-bottom:1px solid rgba(21,40,90,0.5);vertical-align:middle}
.tbl tbody tr{cursor:default;transition:background .08s}
.tbl tbody tr:hover{background:rgba(255,255,255,.015)}
.tbl tbody tr.rowlink{cursor:pointer}
.tbl tbody tr.rowlink:hover{background:var(--tp-hover)}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl td.r{text-align:right}
.tbl td .m{color:var(--tp-text-mute)}
.tbl td .sub{color:var(--tp-text-subtle);font-size:11px;margin-top:2px;font-family:var(--tp-font-mono)}

/* three-dot row menu button */
.rowmenu{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--tp-r-sm);border:1px solid transparent;background:transparent;color:var(--tp-text-mute);cursor:pointer;opacity:.55;transition:all .1s}
tr:hover .rowmenu{opacity:1}
.rowmenu:hover{background:var(--tp-surface-alt);border-color:var(--tp-border-subtle);color:var(--tp-text)}
.rowmenu.open{background:var(--tp-surface-alt);border-color:var(--tp-border);color:var(--tp-text);opacity:1}

/* popover menu (row menu / header menu) */
.menu{position:absolute;background:var(--tp-elevated);border:1px solid var(--tp-border);border-radius:var(--tp-r-md);padding:5px;min-width:220px;box-shadow:var(--tp-shadow-menu);z-index:100;font-size:12.5px}
.menu .mi{display:flex;align-items:center;gap:10px;padding:7px 10px;border-radius:var(--tp-r-sm);color:var(--tp-text);cursor:pointer}
.menu .mi i{width:14px;text-align:center;color:var(--tp-text-subtle);font-size:12px}
.menu .mi:hover{background:var(--tp-hover)}
.menu .mi:hover i{color:var(--tp-cyan)}
.menu .mi.danger{color:var(--tp-red)}
.menu .mi.danger i{color:var(--tp-red)}
.menu .mi.danger:hover{background:var(--tp-red-dim)}
.menu .mi .kbd{margin-left:auto;font-family:var(--tp-font-mono);font-size:10px;color:var(--tp-text-subtle);background:var(--tp-surface-alt);border:1px solid var(--tp-border-subtle);padding:1px 5px;border-radius:3px}
.menu .sep{height:1px;background:var(--tp-border-subtle);margin:5px 0}
.menu .lbl{font-family:var(--tp-font-mono);font-size:9.5px;color:var(--tp-text-faint);letter-spacing:.12em;text-transform:uppercase;padding:6px 10px 3px}

/* KPI card */
.kpi{background:var(--tp-elevated);border:1px solid var(--tp-border);border-radius:var(--tp-r-lg);padding:16px 18px;display:flex;flex-direction:column;gap:4px;position:relative}
.kpi .lbl{font-family:var(--tp-font-mono);font-size:10px;color:var(--tp-text-subtle);letter-spacing:.12em;text-transform:uppercase;font-weight:600}
.kpi .val{font-family:var(--tp-font-mono);font-size:26px;font-weight:700;color:var(--tp-text-heading);letter-spacing:-.01em}
.kpi .delta{font-family:var(--tp-font-mono);font-size:11px;display:flex;align-items:center;gap:5px}
.kpi .delta.up{color:var(--tp-green)}
.kpi .delta.down{color:var(--tp-red)}
.kpi .delta.flat{color:var(--tp-text-subtle)}
.kpi .chart{position:absolute;right:16px;top:16px;bottom:16px;width:80px;pointer-events:none;opacity:.55}

/* attention row */
.att{display:flex;gap:12px;padding:12px 16px;border-bottom:1px solid var(--tp-border-subtle);align-items:center;font-size:12.5px}
.att:last-child{border-bottom:none}
.att .ic{width:30px;height:30px;border-radius:var(--tp-r-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:13px}
.att .body{flex:1;min-width:0}
.att .body .ttl{color:var(--tp-text-heading);font-weight:600;margin-bottom:2px}
.att .body .det{color:var(--tp-text-mute);font-size:11.5px}
.att .body .det .mono{color:var(--tp-text)}
.att .time{font-family:var(--tp-font-mono);font-size:10.5px;color:var(--tp-text-subtle);text-align:right;white-space:nowrap}
.att .act{margin-left:8px}
.att.red .ic{background:var(--tp-red-dim);color:var(--tp-red)}
.att.amber .ic{background:var(--tp-amber-dim);color:var(--tp-amber)}
.att.cyan .ic{background:var(--tp-cyan-dim);color:var(--tp-cyan)}
.att.green .ic{background:var(--tp-green-dim);color:var(--tp-green)}

/* activity feed row */
.act-row{display:flex;gap:12px;padding:10px 16px;border-bottom:1px solid var(--tp-border-subtle);cursor:pointer;align-items:flex-start;font-size:12px}
.act-row:last-child{border-bottom:none}
.act-row:hover{background:var(--tp-hover)}
.act-row .ic{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;flex-shrink:0;margin-top:1px}
.act-row .ic.cyan{background:var(--tp-cyan-dim);color:var(--tp-cyan)}
.act-row .ic.green{background:var(--tp-green-dim);color:var(--tp-green)}
.act-row .ic.amber{background:var(--tp-amber-dim);color:var(--tp-amber)}
.act-row .ic.red{background:var(--tp-red-dim);color:var(--tp-red)}
.act-row .ic.violet{background:var(--tp-violet-dim);color:var(--tp-violet)}
.act-row .body{flex:1;min-width:0}
.act-row .body .line{color:var(--tp-text)}
.act-row .body .line .mono{color:var(--tp-text-heading);font-weight:500}
.act-row .time{font-family:var(--tp-font-mono);font-size:10px;color:var(--tp-text-subtle);white-space:nowrap;margin-top:3px}

/* webhook health */
.wh{display:grid;grid-template-columns:1fr auto;padding:12px 16px;border-bottom:1px solid var(--tp-border-subtle);align-items:center;gap:12px;font-size:12px}
.wh:last-child{border-bottom:none}
.wh .nm{color:var(--tp-text);font-weight:500}
.wh .nm .sub{color:var(--tp-text-subtle);font-family:var(--tp-font-mono);font-size:10.5px;margin-top:2px}
.wh .spark{display:flex;gap:2px;align-items:flex-end;height:20px}
.wh .spark span{width:3px;background:var(--tp-green);border-radius:1px;opacity:.75}
.wh .spark span.err{background:var(--tp-red)}
.wh .stats{font-family:var(--tp-font-mono);font-size:10.5px;color:var(--tp-text-mute);text-align:right;white-space:nowrap}

/* empty state */
.empty{padding:64px 20px;text-align:center;color:var(--tp-text-mute)}
.empty i{font-size:28px;color:var(--tp-text-faint);margin-bottom:14px;display:block}
.empty h4{margin:0 0 6px;color:var(--tp-text-heading);font-size:15px;font-weight:600}
.empty p{margin:0 0 16px;font-size:12.5px}

/* filters bar */
.filters{display:flex;align-items:center;gap:8px;padding:10px 16px;border-bottom:1px solid var(--tp-border-subtle);background:var(--tp-surface-alt);flex-wrap:wrap}
.filters .fchip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border:1px solid var(--tp-border-subtle);border-radius:99px;font-size:11.5px;color:var(--tp-text-mute);cursor:pointer}
.filters .fchip:hover{border-color:var(--tp-border-hot);color:var(--tp-text)}
.filters .fchip.on{background:var(--tp-cyan-dim);border-color:var(--tp-cyan);color:var(--tp-cyan)}
.filters .fchip i{font-size:10px}
.filters .count{font-family:var(--tp-font-mono);font-size:10px;color:var(--tp-text-subtle);margin-left:auto}

/* modal (typed-confirm) */
.scrim{position:fixed;inset:0;background:rgba(2,5,15,.72);z-index:200;display:none;align-items:center;justify-content:center;backdrop-filter:blur(2px)}
.scrim.open{display:flex}
.dlg{background:var(--tp-elevated);border:1px solid var(--tp-border);border-radius:var(--tp-r-lg);width:520px;max-width:calc(100vw - 40px);box-shadow:0 40px 100px rgba(0,0,0,.7)}
.dlg .dh{padding:16px 20px;border-bottom:1px solid var(--tp-border-subtle);display:flex;align-items:center;gap:12px}
.dlg .dh .ic{width:36px;height:36px;border-radius:var(--tp-r-md);background:var(--tp-red-dim);color:var(--tp-red);display:flex;align-items:center;justify-content:center;font-size:15px}
.dlg .dh h3{margin:0;font-size:15px;font-weight:700;color:var(--tp-text-heading)}
.dlg .db{padding:18px 20px;font-size:13px;color:var(--tp-text-mute);line-height:1.55}
.dlg .db b{color:var(--tp-text-heading);font-weight:600}
.dlg .db .confirm-copy{font-family:var(--tp-font-mono);background:var(--tp-base);border:1px solid var(--tp-border-subtle);color:var(--tp-amber);padding:2px 6px;border-radius:3px;font-size:12px}
.dlg .db input{width:100%;margin-top:14px;background:var(--tp-base);border:1px solid var(--tp-border);border-radius:var(--tp-r-sm);color:var(--tp-text);padding:9px 12px;font-family:var(--tp-font-mono);font-size:12.5px;outline:none}
.dlg .db input:focus{border-color:var(--tp-red)}
.dlg .dfoot{padding:12px 20px;border-top:1px solid var(--tp-border-subtle);display:flex;justify-content:flex-end;gap:8px}

/* toast */
.toasts{position:fixed;bottom:20px;right:20px;z-index:300;display:flex;flex-direction:column;gap:10px;pointer-events:none}
.toast{pointer-events:auto;background:var(--tp-elevated);border:1px solid var(--tp-border);border-left:3px solid var(--tp-green);border-radius:var(--tp-r-md);padding:11px 14px;display:flex;gap:10px;align-items:flex-start;min-width:320px;max-width:420px;box-shadow:var(--tp-shadow-menu);animation:toastin .2s ease-out}
.toast.err{border-left-color:var(--tp-red)}
.toast.warn{border-left-color:var(--tp-amber)}
.toast.info{border-left-color:var(--tp-cyan)}
.toast .ic{color:var(--tp-green);margin-top:1px}
.toast.err .ic{color:var(--tp-red)}
.toast.warn .ic{color:var(--tp-amber)}
.toast.info .ic{color:var(--tp-cyan)}
.toast .body{flex:1;min-width:0}
.toast .body .ttl{font-weight:600;color:var(--tp-text-heading);font-size:12.5px}
.toast .body .det{color:var(--tp-text-mute);font-size:11.5px;margin-top:2px;font-family:var(--tp-font-mono)}
.toast .x{color:var(--tp-text-subtle);cursor:pointer;font-size:11px;padding:2px 4px}
.toast .x:hover{color:var(--tp-text)}
.toast .undo{color:var(--tp-cyan);cursor:pointer;font-weight:600;font-size:11.5px;padding:2px 6px}
@keyframes toastin{from{transform:translateX(16px);opacity:0}to{transform:translateX(0);opacity:1}}

/* command palette */
.cp-scrim{position:fixed;inset:0;background:rgba(2,5,15,.65);z-index:250;display:none;align-items:flex-start;justify-content:center;padding-top:88px;backdrop-filter:blur(3px)}
.cp-scrim.open{display:flex}
.cp{width:640px;max-width:calc(100vw - 40px);background:var(--tp-elevated);border:1px solid var(--tp-border);border-radius:var(--tp-r-lg);box-shadow:0 40px 100px rgba(0,0,0,.7);overflow:hidden}
.cp .head{padding:12px 14px;border-bottom:1px solid var(--tp-border-subtle);display:flex;align-items:center;gap:10px}
.cp .head i{color:var(--tp-cyan);font-size:14px}
.cp .head input{flex:1;background:transparent;border:none;outline:none;color:var(--tp-text);font-size:14px;font-family:var(--tp-font-sans)}
.cp .head input::placeholder{color:var(--tp-text-subtle)}
.cp .head .kbd{font-family:var(--tp-font-mono);font-size:10px;color:var(--tp-text-subtle);background:var(--tp-surface-alt);border:1px solid var(--tp-border-subtle);padding:2px 6px;border-radius:3px}
.cp .lbl{font-family:var(--tp-font-mono);font-size:9.5px;color:var(--tp-text-faint);letter-spacing:.15em;text-transform:uppercase;padding:10px 14px 4px}
.cp .cpit{padding:9px 14px;display:flex;align-items:center;gap:12px;cursor:pointer}
.cp .cpit:hover, .cp .cpit.sel{background:var(--tp-hover)}
.cp .cpit i{width:16px;text-align:center;color:var(--tp-text-subtle)}
.cp .cpit.sel i{color:var(--tp-cyan)}
.cp .cpit .t{color:var(--tp-text);font-size:12.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1}
.cp .cpit .s{color:var(--tp-text-subtle);font-size:11px;margin-left:auto;font-family:var(--tp-font-mono);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:48%;flex-shrink:0;padding-left:12px}
.cp .cpit .hit{background:rgba(245,166,35,.2);color:var(--tp-amber);border-radius:2px;padding:0 2px}
.cp .list{max-height:400px;overflow-y:auto;padding-bottom:6px}
.cp .hint{padding:8px 14px;border-top:1px solid var(--tp-border-subtle);background:var(--tp-surface);font-size:11px;color:var(--tp-text-subtle);display:flex;gap:12px;font-family:var(--tp-font-mono);flex-wrap:wrap;row-gap:4px}
.cp .hint span{white-space:nowrap}
.cp .hint b{color:var(--tp-text-mute)}

/* section grid helpers */
.grid{display:grid;gap:16px}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.g-2-1{grid-template-columns:2fr 1fr}

/* avatar (customer) */
.av{width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:var(--tp-text-heading);font-weight:700;font-size:11px;font-family:var(--tp-font-sans);background:linear-gradient(135deg,#1d3678,#10214a);flex-shrink:0}

/* notes panel */
.notes .note{padding:12px 16px;border-bottom:1px solid var(--tp-border-subtle);font-size:12px;color:var(--tp-text)}
.notes .note:last-child{border-bottom:none}
.notes .note .meta{font-family:var(--tp-font-mono);font-size:10.5px;color:var(--tp-text-subtle);margin-bottom:6px;display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.notes .note .meta > span:first-child{color:var(--tp-text-mute);font-weight:600}
.notes .addnote{padding:12px 16px;display:flex;gap:8px;border-top:1px solid var(--tp-border-subtle);background:var(--tp-surface-alt)}
.notes .addnote textarea{flex:1;background:var(--tp-base);border:1px solid var(--tp-border);border-radius:var(--tp-r-sm);color:var(--tp-text);padding:7px 10px;font-family:var(--tp-font-sans);font-size:12px;resize:none;height:32px;outline:none}
.notes .addnote textarea:focus{border-color:var(--tp-cyan)}

/* shortcuts sheet */
.shcuts{display:grid;grid-template-columns:1fr 1fr;gap:8px 24px;padding:14px 18px;font-size:12px}
.shcuts .row{display:flex;justify-content:space-between;align-items:center;padding:4px 0}
.shcuts .row .lbl{color:var(--tp-text-mute)}
.shcuts .kbd{font-family:var(--tp-font-mono);font-size:10px;color:var(--tp-text-subtle);background:var(--tp-base);border:1px solid var(--tp-border-subtle);padding:1px 6px;border-radius:3px}

/* Login (unchanged — used by admin-login.mjs). */
.login-body { display:flex; align-items:center; justify-content:center; min-height:100vh; background:var(--tp-base); }
.login-card { background:var(--tp-surface); border:1px solid var(--tp-border); border-radius:10px; padding:36px 40px; width:400px; max-width:90vw; }
.login-brand { font-family:var(--tp-font-mono); font-size:18px; color:var(--tp-amber); letter-spacing:0.5px; margin-bottom:4px; }
.login-brand .suffix { color:var(--tp-text-subtle); font-weight:500; }
.login-sub { color:var(--tp-text-mute); font-size:13px; margin-bottom:22px; }
.login-card input { display:block; width:100%; background:var(--tp-surface-alt); border:1px solid var(--tp-border); color:var(--tp-text); padding:10px 12px; border-radius:6px; font-family:var(--tp-font-sans); font-size:14px; margin-bottom:10px; }
.login-card button { display:block; width:100%; background:var(--tp-cyan); color:var(--tp-base); border:none; padding:10px 12px; border-radius:6px; font-family:var(--tp-font-sans); font-size:14px; font-weight:600; cursor:pointer; }
.login-card button:hover { background:#33d6ff; }
.login-status { margin-top:14px; font-size:12px; color:var(--tp-text-mute); min-height:1em; }
