:root[data-theme="dark"]{
  --bg:#0a0a0a; --surface:#111; --surface-2:#161616; --hover:#1c1c1c;
  --border:#1f1f1f; --border-strong:#2a2a2a;
  --fg:#ededed; --fg-2:#a1a1a1; --fg-3:#666;
  --accent:#00d97e; --accent-fg:#001b0e;
  --warn:#f5a524; --danger:#f43f5e;
  --shadow:0 0 0 1px var(--border), 0 8px 24px rgba(0,0,0,.4);
}
:root[data-theme="light"]{
  --bg:#fafafa; --surface:#fff; --surface-2:#f5f5f5; --hover:#ededed;
  --border:#e5e5e5; --border-strong:#d4d4d4;
  --fg:#0a0a0a; --fg-2:#525252; --fg-3:#a3a3a3;
  --accent:#00a35f; --accent-fg:#fff;
  --warn:#b45309; --danger:#dc2626;
  --shadow:0 0 0 1px var(--border), 0 1px 2px rgba(0,0,0,.04);
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{
  font:14px/1.5 -apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,system-ui,sans-serif;
  background:var(--bg); color:var(--fg);
  -webkit-font-smoothing:antialiased;
  padding:24px 16px 96px;
  transition:background .2s,color .2s;
}
.mono{font-family:'JetBrains Mono',ui-monospace,monospace;font-feature-settings:"calt" 0}
::selection{background:var(--accent);color:var(--accent-fg)}
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}

body{min-height:100vh;display:flex;flex-direction:column}
.wrap{max-width:1260px;width:100%;margin:0 auto;display:flex;flex-direction:column;flex:1}
.app-shell{display:grid;grid-template-columns:1fr;gap:18px;align-items:start}
.app-main{min-width:0}

.usage-guide{min-width:0;display:flex;flex-direction:column;gap:14px}
.guide-card{
  background:transparent;
  border:1px solid var(--border);
  border-radius:14px;
  padding:18px 16px;
}
.guide-privacy{padding:14px 16px}
.guide-privacy p{font-size:12px;line-height:1.6;color:var(--fg-3)}
.guide-privacy code{font-size:11px}
.guide-kicker{
  font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--accent);font-family:'JetBrains Mono',ui-monospace,monospace;
}
.guide-card h2{
  margin-top:10px;font-size:24px;line-height:1.1;
  letter-spacing:-.03em;font-weight:650;
}
.guide-card p{
  margin-top:10px;color:var(--fg-2);font-size:13px;line-height:1.7;
}
.guide-list{
  margin-top:14px;padding-left:18px;
  display:flex;flex-direction:column;gap:10px;
  color:var(--fg);font-size:13px;line-height:1.7;
}
.guide-list code,.guide-card p code{
  background:var(--surface-2);padding:2px 6px;border-radius:6px;
  color:var(--accent);font-size:12px;
}

/* Topbar */
.topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 4px 20px;
}
.brand{display:flex;align-items:center;gap:10px;font-weight:600;letter-spacing:-.01em}
.brand-mark{
  width:22px;height:22px;border-radius:6px;
  background:var(--accent);color:var(--accent-fg);
  display:grid;place-items:center;font-weight:700;font-size:12px;
}
.brand-mark-video{
  background:transparent;overflow:hidden;
  width:24px;height:24px;border-radius:6px;
  position:relative;flex-shrink:0;
}
.brand-mark-video video{
  width:100%;height:100%;object-fit:cover;display:block;
}
.brand-mark-svg{
  background:transparent;color:var(--fg);
  width:24px;height:24px;border-radius:0;
  flex-shrink:0;
}
.brand-mark-svg svg{width:100%;height:100%;display:block}
.brand-name{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:13px}
.topbar-actions{display:flex;align-items:center;gap:6px}
.icon-btn{
  width:32px;height:32px;padding:0;border-radius:8px;border:1px solid var(--border);
  background:var(--surface);color:var(--fg-2);cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  line-height:0;transition:all .15s;
}
.icon-btn:hover{background:var(--hover);color:var(--fg);border-color:var(--border-strong)}
.icon-btn svg{width:14px;height:14px;display:block}

/* Status pill */
.pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:3px 8px;border-radius:999px;font-size:11px;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  background:var(--surface);border:1px solid var(--border);color:var(--fg-2);
}
.pill .dot{width:6px;height:6px;border-radius:50%;background:var(--fg-3)}
.pill.ok .dot{background:var(--accent);box-shadow:0 0 8px var(--accent)}
.pill.ok{color:var(--fg)}
.pill.bad .dot{background:var(--danger);box-shadow:0 0 8px var(--danger)}
.pill.bad{color:var(--danger);border-color:color-mix(in srgb, var(--danger) 40%, var(--border))}

/* Section */
.section{margin-bottom:18px}
.section-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 4px 10px;
}
.section-title{
  font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--fg-3);font-family:'JetBrains Mono',ui-monospace,monospace;
}
.section-actions{display:flex;gap:6px;align-items:center}

/* Buy link */
.buy-link{
  display:inline-flex;align-items:center;gap:4px;
  padding:4px 10px;border-radius:6px;
  font-size:12px;font-weight:500;text-decoration:none;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  color:var(--accent);background:transparent;
  border:1px solid var(--border);
  transition:all .15s;
}
.buy-link:hover{
  background:var(--accent);color:var(--accent-fg);
  border-color:var(--accent);
}

/* History lookup panel */
.history-lookup{
  padding:18px;border-bottom:1px solid var(--border);
  background:var(--surface-2);
}
.history-lookup[hidden]{display:none}
.history-lookup form{display:flex;gap:8px;flex-wrap:wrap}
.history-lookup input{flex:1;min-width:200px}
#history-result{margin-top:12px}
#history-result .hl-meta{
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  padding-bottom:10px;margin-bottom:8px;
  border-bottom:1px solid var(--border);
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:12px;color:var(--fg-2);
}
#history-result .hl-meta b{color:var(--fg);font-weight:500}
@media (max-width:640px){
  .history-lookup form{flex-direction:column}
  .history-lookup input{min-width:0}
}

.panel{
  background:var(--surface);border:1px solid var(--border);
  border-radius:12px;overflow:hidden;
}

/* CDK card */
.cdk{padding:18px}
.cdk.empty form{display:flex;gap:8px}
.cdk.empty form input{flex:1}
.cdk-meta{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.cdk-code{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:13px;color:var(--fg-2)}
.cdk-code b{color:var(--fg);font-weight:500}
.cdk-bar{
  margin-top:14px;height:4px;background:var(--surface-2);border-radius:2px;overflow:hidden;
}
.cdk-bar > i{display:block;height:100%;background:var(--accent);border-radius:2px;transition:width .4s}
.cdk-stat{
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:12px;color:var(--fg-2);
  margin-top:8px;display:flex;justify-content:space-between;
}
.cdk-stat b{color:var(--fg);font-weight:500}

/* CDK history (timeline-ish) */
.cdk-meta-actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.cdk-history{
  margin-top:14px;padding-top:14px;
  border-top:1px solid var(--border);
}
.cdk-history[hidden]{display:none}
.cdk-history-empty{
  font-size:12px;color:var(--fg-3);padding:8px 0;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  display:flex;align-items:center;gap:8px;
}
.cdk-history-empty.err{color:var(--danger)}
.hl-head{
  font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--fg-3);font-family:'JetBrains Mono',ui-monospace,monospace;
  margin-bottom:10px;
}
.hl-list{display:flex;flex-direction:column;gap:2px}
.hl-row{
  display:flex;gap:10px;align-items:flex-start;
  padding:8px 10px;border-radius:8px;
  transition:background .15s;
}
.hl-row:hover{background:var(--surface-2)}
.hl-dot{
  width:8px;height:8px;border-radius:50%;background:var(--accent);
  margin-top:6px;flex-shrink:0;
  box-shadow:0 0 8px var(--accent);
}
.hl-row.bad .hl-dot{background:var(--danger);box-shadow:0 0 8px var(--danger)}
.hl-main{flex:1;min-width:0}
.hl-line{
  display:flex;align-items:baseline;justify-content:space-between;gap:10px;
  font-size:13px;
}
.hl-email{
  color:var(--fg);font-weight:500;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.hl-status{
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:11px;color:var(--accent);flex-shrink:0;
}
.hl-row.bad .hl-status{color:var(--danger)}
.hl-time{
  font-size:11px;color:var(--fg-3);margin-top:2px;
  font-family:'JetBrains Mono',ui-monospace,monospace;
}
.hl-err{
  margin-top:4px;font-size:11px;color:var(--danger);
  font-family:'JetBrains Mono',ui-monospace,monospace;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}

/* Inputs */
input,textarea,select{
  width:100%;padding:10px 12px;border-radius:8px;
  background:var(--surface-2);border:1px solid var(--border);
  color:var(--fg);font:inherit;outline:none;transition:border-color .15s,background .15s;
}
textarea{font-family:'JetBrains Mono',ui-monospace,monospace;font-size:12px;resize:vertical;min-height:88px}
input:focus,textarea:focus{border-color:var(--accent);background:var(--surface)}
input::placeholder,textarea::placeholder{color:var(--fg-3)}
label{display:block;font-size:11px;color:var(--fg-3);margin-bottom:6px;font-family:'JetBrains Mono',ui-monospace,monospace;text-transform:uppercase;letter-spacing:.06em}

/* Buttons */
button{
  font:inherit;cursor:pointer;border:0;border-radius:8px;
  padding:10px 14px;background:var(--accent);color:var(--accent-fg);
  font-weight:600;transition:all .15s;
}
button:hover:not(:disabled){filter:brightness(1.08)}
button:disabled{opacity:.5;cursor:not-allowed}
button.ghost{
  background:transparent;color:var(--fg-2);border:1px solid var(--border);font-weight:500;
}
button.ghost:hover:not(:disabled){background:var(--hover);color:var(--fg);border-color:var(--border-strong)}
button.sm{padding:5px 10px;font-size:12px;border-radius:6px}
button.danger{color:var(--danger)}
button.danger:hover:not(:disabled){background:rgba(244,63,94,.08);border-color:var(--danger)}
.oauth-login{color:var(--accent)}
.oauth-login:hover:not(:disabled){border-color:var(--accent);background:rgba(0,217,126,.08);color:var(--accent)}

/* Token rows */
.tokens{padding:4px}
.tokens.grid-2{
  display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:12px;padding:12px;
}
.tokens.grid-2 .token-card{margin:0}
.tokens.grid-2 .token-card + .token-card{margin-top:0}
.token{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:8px 14px;
  padding:12px 14px;
  border-radius:8px;
  align-items:center;
  transition:background .15s;
}
.token:hover{background:var(--surface-2)}
.token + .token{border-top:1px solid var(--border)}
.t-check{display:flex;align-items:center;cursor:pointer}
.t-check input{cursor:pointer;accent-color:var(--accent)}
.t-main{display:flex;align-items:center;gap:14px;min-width:0;flex-wrap:wrap}
.t-id{display:flex;align-items:center;gap:8px;min-width:0;flex-wrap:wrap}
.t-primary{
  font-weight:500;font-size:13px;color:var(--fg);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px;
}
.t-acct{
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:12px;
  color:var(--fg);background:var(--surface-2);
  padding:3px 8px;border-radius:5px;cursor:pointer;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:240px;
}
.t-acct:hover{color:var(--accent);background:var(--bg)}
.t-stats{
  display:flex;gap:18px;align-items:center;
  font-family:'JetBrains Mono',ui-monospace,monospace;font-size:12px;color:var(--fg-2);
  flex-wrap:wrap;
}
.t-stat{display:inline-flex;align-items:center;gap:6px}
.t-stat .k{color:var(--fg-3);font-size:11px;text-transform:uppercase;letter-spacing:.04em}
.t-stat .v{min-width:38px;text-align:right;font-variant-numeric:tabular-nums;color:var(--fg)}
.t-stat .v.muted{color:var(--fg-3)}
.t-stat .v.warn{color:var(--warn)}
.t-stat .v.bad{color:var(--danger)}
.t-ok{color:var(--accent)}
.t-warn{color:var(--warn)}
.t-bad{color:var(--danger)}
.t-na{color:var(--fg-3)}

/* horizontal usage bar */
.t-bar{
  width:64px;height:5px;border-radius:3px;
  background:var(--surface-2);overflow:hidden;
  display:inline-block;flex-shrink:0;
  border:1px solid var(--border);
}
.t-bar > i{
  display:block;height:100%;border-radius:2px;
  transition:width .3s ease;
}
.t-bar-ok > i{background:var(--accent)}
.t-bar-warn > i{background:var(--warn)}
.t-bar-bad > i{background:var(--danger)}
.t-bar-na > i{background:var(--fg-3);opacity:.3}
.t-credits{margin-left:4px}
/* Action button (used in token cards / row actions) */
button.btn-act{
  display:inline-flex;align-items:center;gap:5px;
  padding:6px 10px;height:28px;border-radius:6px;
  background:transparent;color:var(--fg-2);
  border:1px solid var(--border);
  font-size:12px;font-weight:500;cursor:pointer;
  transition:all .15s;white-space:nowrap;line-height:1;
}
button.btn-act:hover:not(:disabled){
  background:var(--surface-2);color:var(--fg);border-color:var(--border-strong);
  filter:none;
}
button.btn-act.primary{
  background:var(--accent);color:var(--accent-fg);
  border-color:var(--accent);font-weight:600;
}
button.btn-act.primary:hover:not(:disabled){
  background:color-mix(in srgb,var(--accent) 88%,#fff);
  color:var(--accent-fg);
  border-color:var(--accent);
  filter:none;
}
button.btn-act.danger{
  color:#fff;background:var(--danger);border-color:var(--danger);
}
button.btn-act.danger:hover:not(:disabled){
  background:color-mix(in srgb, var(--danger) 88%, #000);
  border-color:color-mix(in srgb, var(--danger) 88%, #000);
  color:#fff;
}
button.btn-act svg{width:12px;height:12px;flex-shrink:0}

.t-actions{display:flex;gap:6px;flex-shrink:0}

.empty{
  padding:32px 16px;text-align:center;color:var(--fg-3);font-size:13px;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  display:flex;justify-content:center;align-items:center;gap:6px;flex-wrap:wrap;
}
.empty a{
  color:var(--accent);text-decoration:none;
  border-bottom:1px dashed var(--accent);
  padding-bottom:1px;transition:opacity .15s;
}
.empty a:hover{opacity:.75}
.empty .muted{color:var(--fg-3)}

/* Token cards */
.token-card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:10px;
  margin:12px;
  overflow:hidden;
  transition:border-color .15s;
}
.token-card:hover{border-color:var(--border-strong)}
.token-card[data-plan="plus"]{border-color:color-mix(in srgb, #2f80ed 28%, var(--border))}
.token-card[data-plan="pro"]{border-color:color-mix(in srgb, var(--accent) 34%, var(--border))}
.token-card[data-plan="team"],
.token-card[data-plan="business"]{border-color:color-mix(in srgb, #c084fc 28%, var(--border))}
.token-card[data-plan="enterprise"]{border-color:color-mix(in srgb, #f59e0b 28%, var(--border))}
.token-card + .token-card{margin-top:0}
.tc-head{
  display:flex;align-items:center;gap:10px;
  padding:12px 14px;
  border-bottom:1px solid var(--border);
}
.tc-refresh{margin-left:auto;flex-shrink:0}
.tc-id{flex:1;min-width:0}
.tc-primary-line{
  display:flex;align-items:center;gap:8px;min-width:0;flex-wrap:wrap;
}
.tc-primary{
  font-size:14px;font-weight:500;color:var(--fg);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.tc-plan{
  display:inline-flex;align-items:center;justify-content:center;
  min-height:20px;padding:0 8px;border-radius:999px;
  border:1px solid var(--border-strong);
  background:var(--surface-2);color:var(--fg-2);
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
}
.tc-plan[data-plan="free"]{color:var(--fg-2)}
.tc-plan[data-plan="plus"]{color:#2f80ed;border-color:color-mix(in srgb, #2f80ed 40%, var(--border-strong));background:color-mix(in srgb, #2f80ed 10%, var(--surface-2))}
.tc-plan[data-plan="pro"]{color:var(--accent);border-color:color-mix(in srgb, var(--accent) 45%, var(--border-strong));background:color-mix(in srgb, var(--accent) 10%, var(--surface-2))}
.tc-plan[data-plan="team"],
.tc-plan[data-plan="business"]{color:#c084fc;border-color:color-mix(in srgb, #c084fc 40%, var(--border-strong));background:color-mix(in srgb, #c084fc 10%, var(--surface-2))}
.tc-plan[data-plan="enterprise"]{color:#f59e0b;border-color:color-mix(in srgb, #f59e0b 40%, var(--border-strong));background:color-mix(in srgb, #f59e0b 12%, var(--surface-2))}
.tc-acct{
  display:inline-block;margin-top:4px;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:11px;color:var(--fg-3);
  background:var(--surface-2);padding:2px 7px;border-radius:4px;
  cursor:pointer;
}
.tc-acct:hover{color:var(--accent);background:var(--bg)}

.tc-stats{
  padding:14px 16px;
  display:flex;flex-direction:column;gap:8px;
  background:var(--surface-2);
}
.tc-stat-row{
  display:grid;
  grid-template-columns:120px 1fr 50px;
  gap:12px;align-items:center;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:12px;
}
.tc-stat-k{color:var(--fg-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tc-stat-v{text-align:right;font-variant-numeric:tabular-nums;font-weight:500}
.tc-bar{
  height:6px;border-radius:3px;
  background:var(--bg);overflow:hidden;
  border:1px solid var(--border);
}
.tc-bar > i{display:block;height:100%;border-radius:2px;transition:width .3s}
.tc-bar-ok > i{background:var(--accent)}
.tc-bar-warn > i{background:var(--warn)}
.tc-bar-bad > i{background:var(--danger)}
.tc-bar-na > i{background:var(--fg-3);opacity:.3}
.tc-credit .tc-bar{visibility:hidden}
.tc-err{color:var(--danger);text-align:center;padding:8px 0;font-size:12px}

.tc-job{
  display:flex;align-items:center;gap:8px;
  padding:8px 16px;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  font-size:12px;line-height:1.4;
  border-top:1px solid var(--border);
  background:var(--surface-2);color:var(--fg-2);
}
.tc-job[hidden]{display:none}
.tc-job.busy{color:var(--accent)}
.tc-job.ok{color:var(--accent);background:color-mix(in srgb, var(--accent) 8%, var(--surface-2))}
.tc-job.err{color:var(--danger);background:color-mix(in srgb, var(--danger) 8%, var(--surface-2))}

.tc-foot{
  display:flex;gap:8px;flex-wrap:wrap;align-items:center;
  padding:10px 12px;
  border-top:1px solid var(--border);
}
.tc-foot .btn-act{padding:6px 12px;height:30px;font-size:12px}
.tc-foot .btn-act.primary{margin-left:0}
.tc-foot [data-act="consume"]{margin-left:auto}
.tc-foot .badge-num{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:18px;height:18px;padding:0 5px;
  border-radius:9px;background:rgba(0,0,0,.18);
  font-size:10px;font-weight:700;
  font-family:'JetBrains Mono',ui-monospace,monospace;
  margin-left:4px;
}

/* Token toolbar */
.t-toolbar{
  display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  padding:10px 14px;border-bottom:1px solid var(--border);
  background:var(--surface-2);
  font-size:12px;line-height:1;
}
.t-toolbar > *{display:flex;align-items:center}
.t-toolbar[hidden]{display:none}
.t-checkall{gap:6px;cursor:pointer;color:var(--fg-2);white-space:nowrap;flex-shrink:0}
.t-checkall input{accent-color:var(--accent);cursor:pointer;margin:0}
.t-toolbar #sel-count{font-size:11px;color:var(--fg-3);flex-shrink:0}
.t-filter{display:flex;align-items:center;gap:10px;flex-shrink:0;margin-right:auto;padding-right:12px}
.t-filter-lbl{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--fg-3);white-space:nowrap;flex-shrink:0}
.t-filter-lbl select{flex-shrink:0}
.t-filter select.ghost.sm{height:26px;padding:0 8px;font-size:11px}
.token-card.is-hidden{display:none}

/* Modal */
dialog.modal{
  border:none;padding:0;background:transparent;color:var(--fg);
  max-width:560px;width:calc(100% - 32px);
  border-radius:12px;overflow:visible;
  position:fixed;top:50%;left:50%;
  transform:translate(-50%,-50%);
  margin:0;
}
dialog.modal::backdrop{
  background:rgba(0,0,0,.6);backdrop-filter:blur(4px);
}
.modal-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:12px;box-shadow:0 12px 48px rgba(0,0,0,.4);
  overflow:hidden;display:flex;flex-direction:column;
}
.modal-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;border-bottom:1px solid var(--border);
  font-size:13px;font-weight:600;color:var(--fg);
}
.modal-head .icon-btn{width:28px;height:28px;border:none;background:transparent;font-size:16px;color:var(--fg-3)}
.modal-head .icon-btn:hover{color:var(--fg);background:var(--surface-2)}
.modal-foot{
  display:flex;justify-content:flex-end;gap:8px;
  padding:12px 16px;border-top:1px solid var(--border);
}
.modal-card textarea{
  width:100%;min-height:200px;padding:12px 14px;
  background:var(--bg);border:none;border-bottom:1px solid var(--border);
  color:var(--fg);font-size:12px;line-height:1.6;resize:vertical;outline:none;
  font-family:'JetBrains Mono',ui-monospace,monospace;
}
.oauth-manual-body{
  padding:16px;display:flex;flex-direction:column;gap:10px;
}
.oauth-manual-body p{
  font-size:13px;line-height:1.7;color:var(--fg-2);
}
.oauth-manual-body input,
.oauth-manual-body textarea{
  width:100%;
}
.oauth-manual-body textarea{
  min-height:140px;border:1px solid var(--border);
}
.modal-card textarea:focus{background:var(--surface-2)}

.confirm-modal .confirm-card{max-width:420px}
.confirm-body{
  padding:16px 18px;color:var(--fg-2);
  font-size:13px;line-height:1.7;white-space:pre-wrap;
  max-height:60vh;overflow:auto;
}
.confirm-modal .modal-foot button.danger{
  background:var(--danger);border-color:var(--danger);color:#fff;
}
.confirm-modal .modal-foot button.danger:hover:not(:disabled){
  background:color-mix(in srgb, var(--danger) 88%, #000);
  border-color:color-mix(in srgb, var(--danger) 88%, #000);
}

/* Dropzone (modal) */
.dropzone{
  margin:16px;padding:48px 24px;
  border:2px dashed var(--border-strong);border-radius:10px;
  text-align:center;cursor:pointer;
  transition:all .15s;color:var(--fg-2);
}
.dropzone:hover,.dropzone.drag{
  border-color:var(--accent);background:var(--surface-2);color:var(--fg);
}
.dz-text{font-size:13px;line-height:1.8}

/* Toast */
.toast{
  position:fixed;left:50%;bottom:20px;transform:translate(-50%,12px);
  padding:10px 16px;border-radius:8px;font-size:13px;font-weight:500;
  background:var(--surface);border:1px solid var(--border-strong);
  box-shadow:var(--shadow);opacity:0;pointer-events:none;
  transition:all .25s cubic-bezier(.2,.8,.2,1);z-index:50;
  max-width:90vw;
}
.toast.show{opacity:1;transform:translate(-50%,0)}
.toast.ok{border-color:var(--accent);color:var(--accent)}
.toast.err{border-color:var(--danger);color:var(--danger)}

/* Footer */
.foot{
  margin-top:auto;padding:24px 0 12px;
  border-top:1px solid var(--border);
}
.foot a{color:var(--accent);text-decoration:none}
.foot a:hover{text-decoration:underline}

.privacy{
  font-size:12px;line-height:1.7;color:var(--fg-3);
  font-family:'JetBrains Mono',ui-monospace,monospace;
}
.privacy-title{
  font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:var(--fg-2);margin-bottom:8px;
}
.privacy p{margin:4px 0}
.privacy code{
  background:var(--surface-2);padding:2px 6px;border-radius:4px;
  color:var(--accent);font-size:11px;
}

/* Privacy disclosure (legacy details fallback) */
details{margin-top:10px;font-size:12px;color:var(--fg-3);font-family:'JetBrains Mono',ui-monospace,monospace}
details summary{cursor:pointer;color:var(--fg-2);user-select:none;padding:2px 0}
details summary:hover{color:var(--fg)}
details > div{margin-top:10px;padding:12px;background:var(--surface-2);border-radius:8px;line-height:1.7}
details code{background:var(--surface);padding:2px 6px;border-radius:4px;color:var(--accent)}

/* Spinner */
.spin{
  width:12px;height:12px;border:1.5px solid var(--border-strong);border-top-color:var(--fg);
  border-radius:50%;animation:spin .8s linear infinite;display:inline-block;vertical-align:-2px;
}
@keyframes spin{to{transform:rotate(360deg)}}

@media (min-width:1200px){
  .app-shell{
    grid-template-columns:minmax(260px,320px) minmax(0,880px);
    gap:28px;
  }
  .usage-guide{
    position:sticky;top:24px;
    padding-top:30px;
  }
}

/* Mobile */
@media (max-width:640px){
  body{padding:16px 12px 96px}
  .topbar{padding:4px 0 16px}
  .guide-card{padding:16px}
  .guide-card h2{font-size:20px}
  .guide-list{gap:8px;font-size:12px}
  .cdk.empty form{flex-direction:column}
  .token{grid-template-columns:1fr;gap:8px}
  .tokens.grid-2{grid-template-columns:1fr;padding:8px;gap:8px}
  .t-actions{justify-content:flex-end;flex-wrap:wrap}
  .t-actions .btn-act span{display:none}
  .t-actions .btn-act{padding:6px;width:32px;justify-content:center}
  .token-card{margin:8px}
  .tc-stat-row{grid-template-columns:96px 1fr 44px;gap:8px;font-size:11px}
  .tc-foot{padding:10px;flex-wrap:wrap}
  .tc-foot .btn-act{flex:1;min-width:0}
  .tc-foot .btn-act.primary{margin-left:0}
  .tc-foot [data-act="consume"]{margin-left:0}
  .t-stats{font-size:11px;gap:12px}
  .t-bar{width:48px}
  .t-acct{max-width:none}
}
