/* ════════════════════════════════════════════════
   Gnoke Ledger — shared stylesheet (all pages)
   ════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#f7f2ec; --surface:#fff; --surface2:#f7f2ec;
  --topbar-bg:#1c140e; --topbar-txt:rgba(255,255,255,.85); --topbar-h:52px;
  --accent:#2a7a52;
  --accent-dim:color-mix(in srgb,var(--accent) 12%,transparent);
  --accent-lt:color-mix(in srgb,var(--accent) 14%,var(--bg));
  --text:#1c140e; --muted:#a09080; --border:#ede4d8; --danger:#dc2626;
  --radius:10px; --ease:.18s ease;
  --font-sans:'DM Sans',sans-serif;
  --font-mono:'DM Mono',monospace;
  --font-display:'Playfair Display',serif;
}
[data-theme="dark"]{
  --bg:#18120c; --text:#f0e8de; --muted:#7a6a5a;
  --border:#2e2218; --surface:#241a12; --surface2:#1e1610;
}

html,body{background:var(--bg);color:var(--text);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;min-height:100dvh}
input,select,button,textarea{font-family:inherit}

/* ── Topbar ── */
#topbar{height:var(--topbar-h);background:var(--topbar-bg);display:flex;align-items:center;gap:8px;padding:0 14px;position:sticky;top:0;z-index:200}
#hamburger{width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.12);background:transparent;color:var(--topbar-txt);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center}
#brand{display:flex;align-items:baseline;gap:5px;text-decoration:none;flex-shrink:0}
#brand-gnoke{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent)}
#brand-app{font-family:var(--font-display);font-size:1.05rem;font-weight:700;color:var(--topbar-txt);letter-spacing:-.01em}
#context-info{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.04em;color:rgba(255,255,255,.32);margin-left:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px}
.topbar-spacer{flex:1}
.desktop-nav{display:none;gap:2px}
.dnav{background:transparent;border:none;cursor:pointer;color:rgba(255,255,255,.45);font-family:var(--font-sans);font-size:.8rem;padding:6px 10px;border-radius:5px;text-decoration:none;white-space:nowrap;transition:color var(--ease),background var(--ease)}
.dnav:hover{color:#fff;background:rgba(255,255,255,.07)}
.dnav.active{color:var(--accent)}
#topbar-right{display:flex;align-items:center;gap:6px;flex-shrink:0}
#status-chip{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;background:rgba(255,255,255,.08);color:rgba(255,255,255,.4);padding:3px 8px;border-radius:20px;opacity:0;transition:opacity .3s;pointer-events:none}
#status-chip.show{opacity:1}
.icon-btn{width:34px;height:34px;border-radius:50%;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06);color:var(--topbar-txt);cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center;transition:border-color var(--ease),background var(--ease)}
.icon-btn:hover{border-color:var(--accent);background:var(--accent-dim)}

/* ── Drawer ── */
#drawer-overlay{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.5);opacity:0;pointer-events:none;transition:opacity .25s}
#drawer-overlay.open{opacity:1;pointer-events:all}
#drawer{position:fixed;left:0;top:0;bottom:0;width:260px;z-index:400;background:var(--topbar-bg);transform:translateX(-100%);transition:transform .28s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;overflow-y:auto;padding-bottom:24px}
#drawer.open{transform:translateX(0)}
#drawer-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0}
#drawer-brand{display:flex;align-items:baseline;gap:5px}
#drawer-gnoke{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent)}
#drawer-app{font-family:var(--font-display);font-size:1rem;color:rgba(255,255,255,.85)}
#drawer-close{background:none;border:none;color:rgba(255,255,255,.4);cursor:pointer;font-size:16px}
.drawer-section{font-family:var(--font-mono);font-size:.56rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.22);padding:16px 18px 6px}
.drawer-btn,a.drawer-btn{display:flex;align-items:center;gap:10px;background:none;border:none;cursor:pointer;color:rgba(255,255,255,.55);font-family:var(--font-sans);font-size:.88rem;width:100%;padding:11px 18px;text-align:left;text-decoration:none;transition:color var(--ease),background var(--ease)}
.drawer-btn:hover{color:#fff;background:rgba(255,255,255,.04)}
.drawer-btn.active{color:var(--accent)}
.drawer-btn.danger{color:#f87171}

/* ── Loading ── */
#loading-overlay{position:fixed;inset:0;z-index:1000;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px}
.loader-dots{display:flex;gap:8px}
.loader-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);animation:_bounce .8s infinite alternate}
.loader-dot:nth-child(2){animation-delay:.15s}
.loader-dot:nth-child(3){animation-delay:.3s}
@keyframes _bounce{to{transform:translateY(-10px);opacity:.5}}
.loader-text{font-family:var(--font-mono);font-size:.7rem;color:var(--muted);letter-spacing:.15em}

/* ── Toast ── */
#toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(10px);background:var(--topbar-bg);color:#fff;padding:10px 22px;border-radius:50px;font-size:12px;font-family:var(--font-mono);opacity:0;transition:all .3s;white-space:nowrap;z-index:600;pointer-events:none}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
#toast.success::before{content:'✓ ';color:var(--accent)}
#toast.error::before{content:'✕ ';color:#e54}
#toast.info::before{content:'ℹ ';color:var(--muted)}

/* ── Page content ── */
.page-content{max-width:680px;margin:0 auto;padding:28px 18px 64px}
.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:24px}
.page-header h1{font-family:var(--font-display);font-size:1.7rem;font-weight:700;color:var(--text)}
.page-header .sub{font-family:var(--font-mono);font-size:.68rem;color:var(--muted);margin-top:3px;letter-spacing:.04em}

/* ── Cards ── */
.card-grid{display:grid;gap:14px}
@media(min-width:560px){.card-grid{grid-template-columns:1fr 1fr}}
.form-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px}
.card-title{font-family:var(--font-display);font-size:1rem;color:var(--text);margin-bottom:12px}
.card-label{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.22em;color:var(--accent);text-transform:uppercase;margin-bottom:14px}
.hint{font-size:.85rem;color:var(--muted);line-height:1.65}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:6px;border:none;border-radius:8px;cursor:pointer;font-family:var(--font-sans);font-size:.85rem;font-weight:500;padding:9px 16px;text-decoration:none;transition:background var(--ease),color var(--ease),border-color var(--ease),filter var(--ease)}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{filter:brightness(.9)}
.btn-ghost{background:transparent;color:var(--muted);border:1.5px solid var(--border)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn-outline{background:none;border:1.5px solid var(--border);color:var(--text);font-family:var(--font-mono);font-size:.72rem}
.btn-outline:hover{border-color:var(--accent);color:var(--accent)}
.btn-danger{background:var(--danger);color:#fff}
.btn-full{width:100%;justify-content:center;padding:14px;font-size:.95rem;font-weight:600;border-radius:var(--radius)}

/* ── Fields ── */
.field{margin-bottom:14px}
.field:last-child{margin-bottom:0}
.field label{display:block;font-family:var(--font-mono);font-size:.68rem;letter-spacing:.06em;color:var(--muted);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;background:var(--surface2);border:1.5px solid var(--border);border-radius:8px;padding:11px 13px;font-size:.9rem;color:var(--text);outline:none;transition:border-color var(--ease);-webkit-appearance:none}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}
.field input::placeholder,.field textarea::placeholder{color:#bbb}

/* ── About table ── */
.about-table{width:100%;border-collapse:collapse}
.about-table td{padding:6px 0;font-size:.83rem;border:none}
.about-table td:first-child{font-family:var(--font-mono);font-size:.7rem;color:var(--muted);width:120px}

/* ── Responsive ── */
@media(min-width:600px){#hamburger{display:none!important}.desktop-nav{display:flex}}
@media(max-width:599px){#hamburger{display:flex}.desktop-nav{display:none}}
