/* ════════════════════════════════════════════════════════════════
   Shooting Bills — styles.css
   Design system: IN-RIGA / Dark Archery ("paper, ink, one orange").
   Tokens + component classes adopted VERBATIM from the Dark Archery
   design-system source (C:/WebDesign/Design Systems/Dark Archery/
   design-system/index.html <style> block). App-layout styles at the
   bottom are authored for the Shooting Bills shell.

   STANDING RULE: the token blocks (:root + [data-theme="dark"]) and the
   adopted component classes below are a VERBATIM mirror of the Dark Archery
   design system. Do NOT hand-edit token values or component rules here —
   if the design system changes, re-adopt from its source. New app-specific
   styles go in the "App layout" section at the bottom, never interleaved
   with the adopted block.
   ════════════════════════════════════════════════════════════════ */

/* ── Design tokens — light (default) ── */
:root{
  --paper:#f4efe6; --paper-2:#ebe5d8; --paper-3:#e1dac9;
  --ink:#0e0e0c; --ink-soft:#1a1814;
  --orange:#ff4612; --orange-soft:#ff461215;
  --line:#0e0e0c1f; --line-strong:#0e0e0c; --muted:#0e0e0c88; --muted-2:#0e0e0c66;
  --good:#2a8a3e; --bad:#c4321a; --warn:#d99100; --info:#1a4cf2;
  --font-sans:'Archivo',-apple-system,sans-serif;
  --font-display:'Archivo',-apple-system,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;
  --r-sm:6px; --r-md:10px; --r-lg:14px; --r-pill:999px;
}
/* ── Design tokens — dark overrides ── */
[data-theme="dark"]{
  --paper:#14130f; --paper-2:#1d1c17; --paper-3:#26241e;
  --ink:#f4efe6; --ink-soft:#e6dfd0;
  --orange:#ff5a2a; --orange-soft:#ff5a2a1f;
  --line:#f4efe61f; --line-strong:#f4efe6; --muted:#f4efe688; --muted-2:#f4efe666;
  --good:#5fc777; --bad:#ee6a55; --warn:#f0b13d; --info:#6a8af7;
}

/* ── Base / reset ── */
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--paper);color:var(--ink);font-family:var(--font-sans);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
.mono{font-family:var(--font-mono)}
a{color:inherit}

/* ── Bullseye mark (used in the theme toggle + brand) ── */
.bullseye{width:22px;height:22px;border-radius:50%;border:2px solid var(--ink);position:relative;flex-shrink:0}
.bullseye::before{content:"";position:absolute;inset:3px;border-radius:50%;background:var(--orange)}
.bullseye::after{content:"";position:absolute;inset:8px;border-radius:50%;background:var(--ink)}
.bullseye.sm{width:16px;height:16px}.bullseye.sm::before{inset:2px}.bullseye.sm::after{inset:6px}

/* ── Theme toggle ── */
.theme-toggle{display:inline-flex;align-items:center;gap:7px;border:1.5px solid var(--ink);background:var(--paper);color:var(--ink);border-radius:var(--r-pill);padding:7px 13px;font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:0.08em;font-weight:600;cursor:pointer}
.theme-toggle:hover{background:var(--paper-2)}

/* ════ COMPONENT STYLES (adopted verbatim from Dark Archery) ════ */
/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:0.08em;font-weight:600;border:1.5px solid var(--ink);border-radius:var(--r-pill);background:var(--paper);color:var(--ink);cursor:pointer;transition:transform .05s,background .1s}
.btn:hover{background:var(--paper-2)}.btn:active{transform:translateY(1px)}
.btn.primary{background:var(--ink);color:var(--paper)}.btn.primary:hover{background:var(--ink-soft)}
.btn.accent{background:var(--orange);border-color:var(--orange);color:#fff}.btn.accent:hover{background:#e63d0e}
[data-theme="dark"] .btn.accent:hover{background:#ff7045}
.btn.danger{background:var(--paper);border-color:var(--bad);color:var(--bad)}.btn.danger:hover{background:#c4321a08}
.btn.danger.solid{background:var(--bad);color:#fff}
.btn.ghost{border-color:var(--line);color:var(--ink)}.btn.ghost:hover{border-color:var(--ink);background:var(--paper-2)}
.btn.sm{padding:6px 12px;font-size:10px}
.btn:disabled,.btn.is-disabled{opacity:.4;cursor:not-allowed;pointer-events:none}

/* State pills */
.state-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:var(--r-pill);border:1.25px solid;font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:0.06em;white-space:nowrap;line-height:1.3;color:var(--muted);background:var(--paper-2);border-color:var(--line)}
.state-pill-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;background:currentColor}
.state-pill-icon{font-size:11px;line-height:1;opacity:.85}
.state-pill-label{text-transform:uppercase;letter-spacing:0.08em}
.state-pill.compact{padding:2px 8px;font-size:10px;gap:5px}
.state-pill.compact .state-pill-label{text-transform:none;letter-spacing:0.03em;font-weight:500}
.state-pill.tone-grey{color:var(--muted);background:var(--paper-2);border-color:var(--line)}
.state-pill.tone-amber{color:var(--warn);background:color-mix(in oklab,var(--warn) 9%,var(--paper));border-color:color-mix(in oklab,var(--warn) 55%,var(--line))}
.state-pill.tone-blue{color:#1f6fd1;background:color-mix(in oklab,#1f6fd1 8%,var(--paper));border-color:color-mix(in oklab,#1f6fd1 50%,var(--line))}
.state-pill.tone-navy{color:#1a3a6d;background:color-mix(in oklab,#1a3a6d 8%,var(--paper));border-color:color-mix(in oklab,#1a3a6d 45%,var(--line))}
[data-theme="dark"] .state-pill.tone-blue{color:#6a8af7}
[data-theme="dark"] .state-pill.tone-navy{color:#8aa2e8}
.state-pill.tone-red{color:var(--bad);background:color-mix(in oklab,var(--bad) 9%,var(--paper));border-color:color-mix(in oklab,var(--bad) 55%,var(--line))}
.state-pill.tone-green{color:var(--good);background:color-mix(in oklab,var(--good) 9%,var(--paper));border-color:color-mix(in oklab,var(--good) 50%,var(--line))}
.state-pill.tone-paid{color:#fff;background:var(--good);border-color:var(--good);font-weight:600}
.state-pill.tone-paid .state-pill-dot{background:#fff}
.state-pill.tone-debug{color:var(--orange);background:var(--orange-soft);border:1.5px dashed var(--orange)}

/* Cards */
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.card-soft{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r-lg)}
.card-head{padding:12px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:10px}
.card-head .title{font-size:13px;font-weight:600;letter-spacing:-0.005em}
.card-body{padding:18px}
.card-head .eyebrow{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:0.12em;color:var(--muted)}

/* Inputs */
.input{width:100%;padding:10px 14px;border:1.5px solid var(--ink);border-radius:var(--r-md);background:var(--paper);font-family:var(--font-mono);font-size:12px;color:var(--ink)}
.input:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px var(--orange-soft)}
.textarea{width:100%;padding:10px 14px;border:1.5px solid var(--ink);border-radius:var(--r-md);background:var(--paper);font-family:var(--font-sans);font-size:13px;line-height:1.5;color:var(--ink);resize:vertical;min-height:80px}
.field-label{display:block;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:0.08em;color:var(--muted);margin-bottom:6px}

/* Table */
.tbl{border:1.5px solid var(--ink);border-radius:var(--r-lg);overflow:hidden}
.thead,.trow{display:grid;grid-template-columns:90px 1fr 110px 130px 70px;gap:14px;padding:11px 16px;align-items:center}
.thead{background:var(--paper-2);border-bottom:1.5px solid var(--ink);font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:0.1em;color:var(--muted)}
.trow{border-bottom:1px dotted var(--line);font-size:13px;text-decoration:none;color:var(--ink)}
.trow:last-child{border-bottom:none}
.trow:hover{background:var(--paper-2)}
.trow .id{font-family:var(--font-mono);color:var(--orange);font-size:12px}
.trow .num{font-family:var(--font-mono);font-feature-settings:"tnum";text-align:right}

/* Filter chips (also used by the app nav) */
.chips{display:flex;gap:6px;flex-wrap:wrap}
.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--r-pill);border:1.25px solid var(--line);background:var(--paper);font-family:var(--font-mono);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--muted);cursor:pointer}
.chip:hover{background:var(--paper-2);color:var(--ink)}
.chip.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.chip .ct{background:rgba(0,0,0,.08);padding:0 6px;border-radius:999px;font-size:10px}
.chip.active .ct{background:rgba(255,255,255,.18)}

/* Empty state */
.empty{border:1px dashed var(--line);border-radius:var(--r-lg);background:var(--paper);padding:36px;text-align:center}
.empty .eb{font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:0.12em;color:var(--muted-2);margin-bottom:8px}
.empty .bd{font-size:12px;color:var(--muted);line-height:1.55}

/* Toast */
.toast{display:flex;align-items:center;gap:10px;width:340px;max-width:100%;border:1.5px solid var(--ink);border-radius:var(--r-md);background:var(--paper);padding:12px 14px;position:relative;overflow:hidden}
.toast::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--good)}
.toast.bad::before{background:var(--bad)}.toast.info::before{background:var(--info)}
.toast .tt{font-size:13px;font-weight:500}
.toast .ts{font-family:var(--font-mono);font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:0.06em;margin-top:1px}

/* Modal / dialog */
.dialog{width:420px;max-width:100%;background:var(--paper);border:1.5px solid var(--ink);border-radius:var(--r-lg);box-shadow:0 20px 60px rgba(0,0,0,.25);overflow:hidden}
.dialog-head{padding:16px 20px;border-bottom:1.5px solid var(--ink);display:flex;align-items:center;gap:12px}
.dialog-eyebrow{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:0.12em;color:var(--muted)}
.dialog-title{font-family:var(--font-display);font-weight:900;font-size:22px;letter-spacing:-0.02em;line-height:1;margin-top:3px}
.dialog-body{padding:18px 20px;font-size:13px;color:var(--ink-soft);line-height:1.55}
.dialog-foot{padding:14px 20px;border-top:1.5px dashed var(--ink);display:flex;gap:10px;justify-content:flex-end}

/* ════ App layout (Shooting Bills shell — authored, not adopted) ════ */
.app-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;padding:14px 28px;border-bottom:1.5px solid var(--ink);background:var(--paper)}
.app-brand{display:flex;align-items:center;gap:12px;min-width:0}
.app-title{font-family:var(--font-display);font-weight:900;font-size:22px;letter-spacing:-0.02em;line-height:1}
.app-title .ac{color:var(--orange)}
.app-eyebrow{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:0.12em;color:var(--muted);margin-top:4px}
.app-nav{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.app-main{padding:32px 28px 80px;max-width:1100px;margin:0 auto}
.view{display:none}
.view.active{display:block}

/* ── Report view (M04 upload & review UI — authored) ── */
/* Dropzone: the .empty dashed pattern doubling as a drag target. The
   .is-dragover state (toggled by app.js) highlights the orange accent. */
.report-dropzone{cursor:pointer}
.report-dropzone.is-dragover{border-color:var(--orange);border-style:solid;background:var(--orange-soft)}
.report-dropzone-actions{margin-top:16px;display:flex;justify-content:center}

.report-results{display:flex;flex-direction:column;gap:18px}
.report-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.report-downloads{display:flex;align-items:center;gap:10px;flex-wrap:wrap}

/* Summary card */
.report-summary .summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px 24px}
.report-summary .summary-metric .k{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:0.1em;color:var(--muted);margin-bottom:4px}
.report-summary .summary-metric .v{font-family:var(--font-display);font-weight:700;font-size:20px;line-height:1.1}
.report-summary .summary-metric .v.grand{color:var(--orange)}
.report-summary .summary-rates{display:flex;flex-direction:column;gap:8px;margin-top:6px}
.report-summary .summary-rate-line{display:flex;align-items:center;gap:10px;font-size:13px}
.report-summary .summary-rate-line .num{font-family:var(--font-mono);font-feature-settings:"tnum";margin-left:auto}
.report-summary .summary-warnings{display:flex;flex-direction:column;gap:8px;margin-top:6px}

/* 10-column bookings grid (overrides the adopted .thead/.trow 5-col default
   for the report table only). Columns: Nr, Client, Package, Booking date,
   Activity date, Time, People, Cost, Total, Rate. */
.report-grid .thead,.report-grid .trow,.report-grid .report-total{
  display:grid;
  grid-template-columns:70px 1.3fr 2fr 92px 92px 64px 56px 80px 92px 110px;
  gap:10px;padding:11px 14px;align-items:center}
.report-grid .trow{cursor:pointer}
.report-grid .num{font-family:var(--font-mono);font-feature-settings:"tnum";text-align:right}
.report-grid .cell-bad{color:var(--bad);font-weight:700}
.report-total{border-top:1.5px solid var(--ink);background:var(--paper-2);font-weight:700}
.report-total .lbl{grid-column:1 / 9;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:0.08em;font-size:11px}
.report-total .num{font-family:var(--font-mono);font-feature-settings:"tnum";text-align:right}
.report-grid .rate-cell{display:flex;align-items:center;gap:6px;flex-wrap:wrap}

/* ── Fix dialog (M05 — authored) ──
   The .dialog / .dialog-* / .input / .field / .state-pill.tone-blue classes
   are the adopted design-system styles; only the scrim overlay and the
   per-dialog field spacing/error are authored here. */
.fix-scrim{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;padding:20px;background:rgba(0,0,0,.5)}
.fix-details{display:grid;grid-template-columns:auto 1fr;gap:4px 14px;margin-bottom:14px}
.fix-detail{display:contents}
.fix-detail-k{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:0.08em;color:var(--muted)}
.fix-detail-v{font-size:13px;color:var(--ink)}
.fix-field{margin-top:12px}
.fix-field .btn{margin-top:10px}
.fix-manual-inputs{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.fix-or{text-align:center;font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:0.1em;color:var(--muted-2);margin:14px 0 2px}
.fix-error{margin-top:12px;padding:8px 12px;border:1.5px solid var(--bad);border-radius:var(--r-md);background:color-mix(in oklab,var(--bad) 9%,var(--paper));color:var(--bad);font-size:12px;font-weight:600}

/* ── Prices view (M07 price-list editor — authored) ──
   Reuses the adopted .card / .card-head / .card-body / .btn / .input /
   .field-label / .empty / .toast / .dialog / .fix-scrim / .fix-error classes;
   only the editor's own layout (toolbar, per-package card body, period rows,
   the period-editor grid) is authored here. */
.prices-editor{display:flex;flex-direction:column;gap:16px}
.prices-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.prices-exports{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-left:auto}
.price-card-actions{display:flex;align-items:center;gap:8px}
.price-card .card-body{display:flex;flex-direction:column;gap:14px}
.price-period{display:flex;flex-direction:column;gap:8px;padding:12px;border:1px solid var(--line);border-radius:var(--r-md);background:var(--paper-2)}
.price-period-range{font-family:var(--font-mono);font-size:12px;color:var(--ink)}
.price-period-values{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px 18px}
.price-value{display:flex;flex-direction:column;gap:2px}
.price-value .k{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:0.08em;color:var(--muted)}
.price-value .v{font-size:14px;font-weight:600}
.price-value .v.num{font-family:var(--font-mono);font-feature-settings:"tnum"}
.price-value .v.muted{color:var(--muted-2);font-weight:500}
.price-period-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.price-period-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px 14px}
.price-field{margin:0}

/* ── Auth / sign-in gate (M08 — authored) ──
   AppAuth (auth.js) sets <html data-auth="out|in|denied">. These rules gate
   what is visible WITHOUT touching app.js's view router (which toggles
   `.view[data-view].active`). Reuses the adopted .card / .btn / .toast classes;
   only the gate + the sign-in/account layout is authored here.

   STANDING RULE — the visibility gate is driven SOLELY by <html data-auth>.
     #view-signin is intentionally NOT a `.view[data-view]` so the router never
     touches it. Any future signed-in-only content should live inside the existing
     `.app-main > .view` sections (gated below) or be hidden when data-auth!="in".
     Do not gate by toggling inline display in JS — keep the gate declarative. */

/* Account area in the header. */
.account-area{display:flex;align-items:center;gap:10px}
.account-area .account-email{font-family:var(--font-mono);font-size:11px;color:var(--muted);max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Sign-in view layout. */
.view-signin{display:none}
.signin-card{max-width:440px;margin:48px auto}
.signin-note{font-size:13px;color:var(--ink-soft);line-height:1.55;margin-bottom:18px}
.signin-card .btn.primary{width:100%;justify-content:center}
.signin-denied{margin-top:16px;flex-direction:column;align-items:flex-start;width:100%}
.signin-denied .tt{font-size:13px;font-weight:600;color:var(--bad)}
.signin-denied .ts{font-family:var(--font-mono);font-size:11px;color:var(--muted);margin-top:3px}
.signin-denied-actions{margin-top:14px;display:none}

/* ── The GATE ──
   Default (no data-auth yet, or "out"): show ONLY the sign-in view. */
html:not([data-auth="in"]) .app-nav .chips,
html:not([data-auth="in"]) #account-area,
html:not([data-auth="in"]) .app-main > .view{display:none}
html:not([data-auth="in"]) .view-signin{display:block}

/* Signed in: hide the sign-in view, reveal the app (the router shows the
   active .view; .view.active already = display:block). */
html[data-auth="in"] .view-signin{display:none}
html[data-auth="in"] #account-area{display:flex}

/* Not authorized: like signed-out, but reveal the denied message + the
   "different account" action inside the sign-in card. */
html[data-auth="denied"] .signin-denied-actions{display:block}

/* ── Google Drive storage (M09 — authored) ──
   Reuses the adopted .card / .btn / .toast / .dialog / .fix-scrim / .empty
   classes; only the History list layout, the month-save status line, the
   Open-from-Drive dialog list, and the signed-in gate for the new controls are
   authored here.

   STANDING RULE — Drive-only controls are gated declaratively by <html
   data-auth="in">, mirroring the M08 sign-in gate. Mark any signed-in-only
   control with the .drive-only class; do NOT toggle their visibility from JS.
   The handlers also re-check AppAuth.isSignedIn() as a belt-and-braces guard. */
.drive-only{display:none}
html[data-auth="in"] .drive-only{display:inline-flex}
html[data-auth="in"] span.drive-only{display:inline}

.report-month-status{font-family:var(--font-mono);font-size:11px;color:var(--muted);align-self:center}

/* History view (rendered by drive.js into #history-view). */
.history-section{margin-bottom:20px}
.history-section-title{font-family:var(--font-display);font-weight:900;font-size:18px;letter-spacing:-0.02em;margin-bottom:10px}
.history-year{margin:8px 0 8px 4px}
.history-year-label{font-family:var(--font-mono);font-size:12px;text-transform:uppercase;letter-spacing:0.1em;color:var(--muted);margin-bottom:6px}
.history-month{margin:6px 0 6px 12px}
.history-month-label{font-size:13px;font-weight:600;color:var(--ink-soft);margin-bottom:4px}
.history-file{display:flex;align-items:center;gap:12px;padding:7px 10px;margin:4px 0 4px 12px;border:1.5px solid var(--ink);border-radius:var(--r-md);background:var(--paper)}
.history-file-name{flex:1;font-size:13px;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.history-file-date{font-family:var(--font-mono);font-size:11px;color:var(--muted)}
.history-file-actions{display:flex;gap:8px}

/* Open-from-Drive dialog list. */
.drive-open-list{display:flex;flex-direction:column;gap:8px}
.drive-open-item{justify-content:flex-start;text-align:left}
