@import url('https://fonts.googleapis.com/css2?family=Space+Mono:wght@400;700&family=Inter:wght@300;400;500&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --paper: #F7F6F4;
  --ink: #1C1C1A;
  --ink2: #5A5A56;
  --ink3: #9A9A94;
  --red: #C8392B;
  --red-tint: #FBF0EE;
  --red-text: #7A1F1A;
  --amb: #8C5A00;
  --amb-tint: #FBF3E6;
  --amb-text: #5C3600;
  --grn: #2D5A0E;
  --grn-tint: #EDF6E3;
  --grn-text: #1A3808;
  --rule: rgba(28,28,26,0.10);
  --rule2: rgba(28,28,26,0.20);
  --hover: rgba(28,28,26,0.04);
  --mono: 'Space Mono', 'Courier New', monospace;
  --sans: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}

body { font-family: var(--sans); background: var(--paper); color: var(--ink); font-size: 13px; line-height: 1; -webkit-font-smoothing: antialiased; }
a { color: inherit; text-decoration: none; }

.shell { display: flex; height: 100vh; overflow: hidden; background: var(--paper); }

.rail { width: 44px; flex-shrink: 0; border-right: 0.5px solid var(--rule2); display: flex; flex-direction: column; align-items: center; padding: 18px 0 16px; gap: 2px; }
.rail-logo { width: 28px; height: 28px; display: flex; align-items: center; justify-content: center; margin-bottom: 18px; }
.rail-logo svg { width: 26px; height: 16px; }
.rib { width: 28px; height: 28px; display: flex; align-items: center; justify-content: center; color: var(--ink3); position: relative; transition: color .15s; }
.rib:hover { color: var(--ink); }
.rib.on { color: var(--ink); }
.rib svg { width: 14px; height: 14px; }
.rib-dot { position: absolute; top: 5px; right: 5px; width: 4px; height: 4px; border-radius: 50%; background: var(--red); }
.rail-sp { flex: 1; }
.rail-av { width: 24px; height: 24px; border-radius: 50%; border: 0.5px solid var(--rule2); display: flex; align-items: center; justify-content: center; font-family: var(--mono); font-size: 9px; color: var(--ink3); }

.side { width: 200px; flex-shrink: 0; border-right: 0.5px solid var(--rule2); display: flex; flex-direction: column; }
.side-tm { padding: 20px 18px 18px; border-bottom: 0.5px solid var(--rule); }
.tm-logobox { width: 36px; height: 36px; border: 0.5px solid var(--rule2); display: flex; align-items: center; justify-content: center; margin-bottom: 12px; }
.tm-logobox svg { width: 30px; height: 19px; }
.tm-label { font-size: 13px; font-weight: 500; color: var(--ink); letter-spacing: -.01em; }
.tm-reg { font-family: var(--mono); font-size: 9px; color: var(--ink3); margin-top: 3px; }
.tm-none { font-size: 12px; color: var(--ink3); }
.tm-none a { color: var(--ink); text-decoration: underline; }
.side-sec { font-family: var(--mono); font-size: 8px; letter-spacing: .12em; color: var(--ink3); padding: 18px 18px 7px; text-transform: uppercase; }
.slink { display: flex; align-items: center; justify-content: space-between; padding: 8px 18px; font-size: 12px; color: var(--ink2); border-left: 2px solid transparent; transition: color .1s; }
.slink:hover { color: var(--ink); }
.slink.on { color: var(--ink); font-weight: 500; border-left-color: var(--ink); }
.slink-n { font-family: var(--mono); font-size: 10px; color: var(--ink3); }
.slink-n.r { color: var(--red); font-weight: 700; }
.side-ft { margin-top: auto; padding: 14px 18px; border-top: 0.5px solid var(--rule); display: flex; align-items: center; justify-content: space-between; }
.ft-name { font-size: 11px; color: var(--ink2); }
.ft-plan { font-family: var(--mono); font-size: 8px; letter-spacing: .08em; padding: 3px 6px; border: 0.5px solid var(--rule2); color: var(--ink3); }

.main { flex: 1; display: flex; flex-direction: column; min-width: 0; overflow: hidden; }
.top { height: 42px; border-bottom: 0.5px solid var(--rule2); display: flex; align-items: center; justify-content: space-between; padding: 0 22px; flex-shrink: 0; }
.top-l { display: flex; align-items: baseline; gap: 10px; }
.top-title { font-size: 12px; font-weight: 500; letter-spacing: .01em; color: var(--ink); }
.top-sub { font-family: var(--mono); font-size: 10px; color: var(--ink3); }
.top-r { display: flex; align-items: center; gap: 10px; }
.live { font-family: var(--mono); font-size: 10px; color: var(--ink3); display: flex; align-items: center; gap: 5px; }
.dot { width: 4px; height: 4px; border-radius: 50%; background: var(--grn); animation: blink 3s infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.2} }
.tbtn { font-family: var(--mono); font-size: 10px; padding: 5px 11px; border: 0.5px solid var(--rule2); background: none; color: var(--ink2); cursor: pointer; letter-spacing: .02em; transition: background .1s; }
.tbtn:hover { background: var(--hover); color: var(--ink); }
.tbtn.dk { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.tbtn.dk:hover { opacity: .82; }
.body { flex: 1; overflow-y: auto; }

.stats { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; border-bottom: 0.5px solid var(--rule2); }
.stat { padding: 24px 22px 20px; border-right: 0.5px solid var(--rule); }
.stat:last-child { border-right: none; }
.stat-lbl { font-family: var(--mono); font-size: 8px; letter-spacing: .12em; text-transform: uppercase; color: var(--ink3); margin-bottom: 12px; }
.stat-n { font-family: var(--mono); font-size: 48px; font-weight: 700; line-height: .9; color: var(--ink); letter-spacing: -.02em; }
.stat-n.r { color: var(--red); }
.stat-n.a { color: var(--amb); }
.stat-foot { font-size: 11px; color: var(--ink3); margin-top: 10px; line-height: 1.5; }

.fbar { display: flex; align-items: center; border-bottom: 0.5px solid var(--rule2); height: 38px; padding: 0 22px; }
.fb { font-family: var(--mono); font-size: 10px; padding: 0 12px; height: 38px; border: none; background: none; color: var(--ink3); cursor: pointer; letter-spacing: .04em; border-bottom: 2px solid transparent; margin-bottom: -0.5px; transition: color .1s; text-decoration: none; display: flex; align-items: center; }
.fb:hover { color: var(--ink); }
.fb.on { color: var(--ink); border-bottom-color: var(--ink); }
.fbar-ct { margin-left: auto; font-family: var(--mono); font-size: 10px; color: var(--ink3); }

.thead { display: grid; grid-template-columns: 4px 1fr 106px 68px 68px 78px; padding: 9px 22px; border-bottom: 0.5px solid var(--rule2); align-items: center; }
.th { font-family: var(--mono); font-size: 8px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink3); }
.trow { display: grid; grid-template-columns: 4px 1fr 106px 68px 68px 78px; padding: 13px 22px; border-bottom: 0.5px solid var(--rule); align-items: center; cursor: pointer; transition: background .1s; }
.trow:hover { background: var(--hover); }
.trow.on { background: var(--hover); }
.trow.hl-r { background: var(--red-tint); }
.trow.hl-r:hover { background: #f5e8e6; }
.sbar { width: 3px; height: 18px; }
.sbar.r { background: var(--red); }
.sbar.o { background: var(--amb); }
.sbar.g { background: var(--grn); }
.cell-name { font-size: 13px; font-weight: 500; padding-left: 14px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: var(--ink); }
.cell-meta { font-family: var(--mono); font-size: 10px; color: var(--ink3); margin-top: 3px; padding-left: 14px; }
.cell-date { font-family: var(--mono); font-size: 11px; color: var(--ink2); }
.cell-sc { font-family: var(--mono); font-size: 12px; color: var(--ink); }
.cell-sc.r { color: var(--red); font-weight: 700; }
.cell-sc.a { color: var(--amb); }
.stag { font-family: var(--mono); font-size: 9px; font-weight: 700; letter-spacing: .05em; padding: 3px 7px; display: inline-block; }
.stag.r { background: var(--red-tint); color: var(--red); }
.stag.o { background: var(--amb-tint); color: var(--amb); }
.stag.g { background: var(--grn-tint); color: var(--grn); }
.xrow { display: none; border-bottom: 0.5px solid var(--rule); background: rgba(28,28,26,.02); }
.xrow.on { display: flex; align-items: flex-start; justify-content: space-between; gap: 20px; padding: 14px 22px 16px 40px; }
.xbody { font-size: 12px; max-width: 480px; }
.xexp { color: var(--ink2); line-height: 1.75; }
.xdeadline { font-family: var(--mono); font-size: 10px; color: var(--red); margin-top: 7px; letter-spacing: .02em; }
.xacts { display: flex; gap: 6px; flex-shrink: 0; }
.empty { padding: 40px 22px; font-family: var(--mono); font-size: 11px; color: var(--ink3); }
.empty a { color: var(--ink); text-decoration: underline; }

.tm-pg { padding: 28px; }
.tm-ph { display: flex; align-items: center; justify-content: space-between; margin-bottom: 24px; }
.tm-ph-t { font-size: 13px; font-weight: 500; }
.tm-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 0; border: 0.5px solid var(--rule2); }
.tmc { background: var(--paper); padding: 24px; border-right: 0.5px solid var(--rule); }
.tmc:last-child { border-right: none; }
.tmc-logo-wrap { width: 42px; height: 42px; border: 0.5px solid var(--rule2); display: flex; align-items: center; justify-content: center; margin-bottom: 14px; }
.tmc-logo-wrap svg { width: 36px; height: 22px; }
.tmc-name { font-size: 14px; font-weight: 500; color: var(--ink); margin-bottom: 3px; }
.tmc-reg { font-family: var(--mono); font-size: 10px; color: var(--ink3); }
.tmc-stats { display: grid; grid-template-columns: 1fr 1fr 1fr; margin-top: 18px; border-top: 0.5px solid var(--rule); padding-top: 14px; }
.tmc-sl { font-family: var(--mono); font-size: 8px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink3); margin-bottom: 6px; }
.tmc-sv { font-family: var(--mono); font-size: 24px; font-weight: 700; color: var(--ink); }
.tmc-sv.r { color: var(--red); }
.add-tmc-form { background: rgba(28,28,26,.02); }
.tmc-form-title { font-size: 13px; font-weight: 500; margin-bottom: 16px; color: var(--ink); }
.plan-limit { display: flex; align-items: center; justify-content: center; padding: 24px; font-size: 12px; color: var(--ink2); min-height: 160px; }
.plan-limit a { color: var(--ink); text-decoration: underline; }
.tmc-remove { margin-top: 14px; padding-top: 14px; border-top: 0.5px solid var(--rule); }

.form-group { margin-bottom: 14px; }
.form-group label { display: block; font-family: var(--mono); font-size: 9px; letter-spacing: .08em; text-transform: uppercase; color: var(--ink3); margin-bottom: 6px; }
.form-group input, .form-group textarea { width: 100%; padding: 8px 10px; border: 0.5px solid var(--rule2); background: var(--paper); color: var(--ink); font-size: 13px; font-family: var(--sans); outline: none; transition: border-color .15s; }
.form-group input:focus { border-color: var(--ink); }
.form-group input:disabled { color: var(--ink3); background: rgba(28,28,26,.03); }

.settings-pg { padding: 28px; max-width: 440px; }
.settings-section { margin-bottom: 32px; padding-bottom: 32px; border-bottom: 0.5px solid var(--rule); }
.settings-section:last-child { border-bottom: none; }
.settings-title { font-family: var(--mono); font-size: 8px; letter-spacing: .12em; text-transform: uppercase; color: var(--ink3); margin-bottom: 16px; }
.plan-current { font-size: 13px; color: var(--ink); }
.saved-msg { background: var(--grn-tint); color: var(--grn-text); padding: 10px 14px; margin-bottom: 20px; font-family: var(--mono); font-size: 10px; letter-spacing: .03em; }

.auth-page { background: var(--paper); display: flex; align-items: center; justify-content: center; min-height: 100vh; }
.auth-wrap { background: var(--paper); border: 0.5px solid var(--rule2); padding: 44px; width: 360px; }
.auth-logo { display: flex; align-items: center; gap: 12px; margin-bottom: 32px; }
.auth-logo svg { width: 32px; height: 20px; }
.auth-logo-name { font-size: 15px; font-weight: 500; letter-spacing: -.01em; }
.auth-wrap h1 { font-size: 18px; font-weight: 500; margin-bottom: 24px; letter-spacing: -.01em; }
.auth-error { background: var(--red-tint); color: var(--red-text); padding: 10px 14px; font-family: var(--mono); font-size: 10px; margin-bottom: 16px; letter-spacing: .02em; }
.auth-wrap form .form-group { margin-bottom: 16px; }
.auth-wrap form button { width: 100%; padding: 11px; background: var(--ink); color: var(--paper); border: none; font-family: var(--mono); font-size: 11px; letter-spacing: .06em; cursor: pointer; margin-top: 8px; transition: opacity .15s; }
.auth-wrap form button:hover { opacity: .82; }
.auth-switch { font-size: 12px; color: var(--ink2); margin-top: 18px; text-align: center; }
.auth-switch a { color: var(--ink); text-decoration: underline; }
.auth-demo { font-family: var(--mono); font-size: 10px; color: var(--ink3); margin-top: 10px; text-align: center; letter-spacing: .02em; }

.scan-toast { position: fixed; bottom: 20px; right: 20px; background: var(--ink); color: var(--paper); padding: 10px 16px; font-family: var(--mono); font-size: 10px; letter-spacing: .03em; opacity: 0; transition: opacity .3s; pointer-events: none; z-index: 100; }
.scan-toast.show { opacity: 1; }
