/* ============================================================
   Allard Volker — dashboard (offerte-/contractarchief)
   Donker terminal-thema met amber-signaal, Hanken Grotesk +
   JetBrains Mono. Tokens uit colors_and_type.css (de signatuur-look).
   ============================================================ */

@font-face {
  font-family: 'Hanken Grotesk'; font-style: normal; font-weight: 100 900; font-display: swap;
  src: url('fonts/HankenGrotesk-VariableFont_wght.ttf') format('truetype-variations');
}
@font-face {
  font-family: 'JetBrains Mono'; font-style: normal; font-weight: 100 800; font-display: swap;
  src: url('fonts/JetBrainsMono-VariableFont_wght.ttf') format('truetype-variations');
}

:root {
  --bg-0:#08090A; --bg-1:#0D0E10; --bg-2:#141619; --bg-3:#1C1F23; --bg-4:#262A2F;
  --line:rgba(255,255,255,0.07); --line-strong:rgba(255,255,255,0.13); --line-signal:rgba(245,181,68,0.42);
  --fg-0:#F3F5F4; --fg-1:#AEB4B2; --fg-2:#6B716F; --fg-3:#3F4543; --fg-inv:#08090A;
  --signal:#F5B544; --signal-hi:#FFCB6B; --signal-dim:#A9781F; --signal-glow:rgba(245,181,68,0.28);
  --threat:#FF5C57; --threat-dim:#7A2B2A;
  --font-display:'Hanken Grotesk',ui-sans-serif,system-ui,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,'SF Mono',Menlo,monospace;
  --glass:rgba(13,14,16,0.9);
  --r-sm:4px; --r-md:8px; --r-lg:14px; --r-pill:999px;
  --ease:cubic-bezier(0.22,1,0.36,1);
}

*,*::before,*::after { box-sizing: border-box; }
html,body { margin:0; padding:0; }
body {
  font-family: var(--font-display);
  background:
    repeating-linear-gradient(0deg, transparent 0 31px, rgba(255,255,255,0.012) 31px 32px),
    var(--bg-0);
  color: var(--fg-0);
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
}

/* ---------- shared brand bits ---------- */
.mono-badge {
  display:grid; place-items:center; flex:0 0 auto;
  width:38px; height:38px; border-radius:var(--r-sm);
  font-family:var(--font-mono); font-weight:700; font-size:16px; letter-spacing:.02em;
  color:var(--signal); background:var(--bg-1); border:1px solid var(--line-signal);
}

/* ---------- topbar ---------- */
.topbar {
  position:sticky; top:0; z-index:40;
  display:flex; align-items:center; gap:24px; flex-wrap:wrap;
  padding:14px 28px;
  background:var(--glass); backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line-strong);
}
.brand { display:flex; align-items:center; gap:12px; }
.brand .bt { display:flex; flex-direction:column; line-height:1.15; }
.brand .bt b { font-weight:600; font-size:15px; letter-spacing:-.01em; }
.brand .bt span { font-family:var(--font-mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--fg-2); }
.controls { display:flex; align-items:center; gap:8px; margin-left:auto; flex-wrap:wrap; }

#search, #type, #sort {
  font-family:var(--font-mono); font-size:12px; color:var(--fg-0);
  background:var(--bg-1); border:1px solid var(--line); border-radius:var(--r-sm);
  padding:8px 12px; outline:none; transition:border-color var(--ease) .2s;
}
#search { min-width:200px; }
#search:focus, #type:focus, #sort:focus { border-color:var(--line-signal); }
#search::placeholder { color:var(--fg-3); }
select { cursor:pointer; appearance:none; padding-right:26px;
  background-image:linear-gradient(45deg,transparent 50%,var(--fg-2) 50%),linear-gradient(135deg,var(--fg-2) 50%,transparent 50%);
  background-position:calc(100% - 14px) 16px, calc(100% - 9px) 16px; background-size:5px 5px,5px 5px; background-repeat:no-repeat; }

.ghost {
  font-family:var(--font-mono); font-size:11px; letter-spacing:.04em;
  padding:8px 14px; border-radius:var(--r-sm); cursor:pointer;
  background:var(--bg-1); color:var(--fg-1); border:1px solid var(--line);
  transition:all var(--ease) .2s;
}
.ghost:hover { color:var(--fg-0); border-color:var(--line-strong); }
.ghost.active { background:var(--signal); color:var(--fg-inv); border-color:var(--signal); }

/* ---------- list ---------- */
main { padding:28px; max-width:1320px; margin:0 auto; }
.month {
  font-family:var(--font-mono); font-size:11px; font-weight:600; letter-spacing:.18em; text-transform:uppercase;
  color:var(--signal-dim); margin:28px 0 14px; padding-bottom:8px;
  border-bottom:1px solid var(--line);
}
.month:first-child { margin-top:0; }
.grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:20px; }

.card {
  background:var(--bg-2); border:1px solid var(--line); border-radius:var(--r-lg);
  overflow:hidden; cursor:pointer; outline:none;
  transition:border-color var(--ease) .2s, transform var(--ease) .2s, box-shadow var(--ease) .2s;
}
.card:hover, .card:focus-visible {
  border-color:var(--line-signal); transform:translateY(-2px);
  box-shadow:0 0 0 1px var(--line-signal), 0 14px 36px rgba(0,0,0,.5);
}

.thumb {
  position:relative; aspect-ratio:1123/794; background:var(--bg-3);
  border-bottom:1px solid var(--line); overflow:hidden;
  display:flex; align-items:center; justify-content:center;
}
.thumb img { width:100%; height:100%; object-fit:cover; object-position:top center; display:block; }
.thumb-fallback {
  width:100%; height:100%; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-mono); font-weight:700; font-size:34px; color:var(--fg-3);
  background:repeating-linear-gradient(135deg, var(--bg-3) 0 10px, var(--bg-2) 10px 20px);
}
.card.contract .thumb { aspect-ratio:794/1123; }

.card-archive, .card-delete {
  position:absolute; top:8px; width:30px; height:30px; display:grid; place-items:center;
  border-radius:var(--r-sm); cursor:pointer; opacity:0; transition:opacity var(--ease) .15s, background var(--ease) .15s;
  background:var(--glass); color:var(--fg-1); border:1px solid var(--line-strong); backdrop-filter:blur(6px);
}
.card-archive { right:8px; }
.card-delete { right:44px; }
.card:hover .card-archive, .card:hover .card-delete, .card:focus-within .card-archive, .card:focus-within .card-delete { opacity:1; }
.card-archive:hover { color:var(--signal); border-color:var(--line-signal); }
.card-delete:hover { color:var(--threat); border-color:var(--threat-dim); }
.card-archive svg, .card-delete svg { width:16px; height:16px; }

.body { padding:14px 16px 16px; display:flex; flex-direction:column; gap:8px; }
.sub { margin:0; font-family:var(--font-mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--signal-dim); }
.body h3 { margin:0; font-family:var(--font-display); font-weight:600; font-size:17px; line-height:1.25; letter-spacing:-.01em; color:var(--fg-0);
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.client { font-family:var(--font-display); font-size:13px; color:var(--fg-1); }
.meta { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-top:2px; }
.time { font-family:var(--font-mono); font-size:10.5px; letter-spacing:.04em; color:var(--fg-3); margin-left:auto; }

.badge {
  font-family:var(--font-mono); font-size:9.5px; letter-spacing:.12em; text-transform:uppercase;
  padding:3px 9px; border-radius:var(--r-pill); border:1px solid var(--line-strong); color:var(--fg-1);
}
.badge.offerte { color:var(--signal); border-color:var(--line-signal); }
.badge.contract { color:var(--fg-1); }
.badge.warn { color:var(--threat); border-color:var(--threat-dim); }

.actions { display:flex; gap:8px; margin-top:6px; }
.actions a, .actions button {
  font-family:var(--font-mono); font-size:11px; letter-spacing:.03em; text-decoration:none; cursor:pointer;
  padding:7px 12px; border-radius:var(--r-sm); border:1px solid var(--line); background:var(--bg-1); color:var(--fg-1);
  transition:all var(--ease) .2s;
}
.actions a:hover, .actions button:hover { color:var(--fg-0); border-color:var(--line-strong); }
.actions .open { background:var(--signal); color:var(--fg-inv); border-color:var(--signal); font-weight:600; }
.actions .open:hover { background:var(--signal-hi); }

.empty {
  text-align:center; color:var(--fg-2); font-family:var(--font-mono); font-size:13px; letter-spacing:.04em;
  padding:80px 24px;
}

/* ---------- login ---------- */
.login-body { display:grid; grid-template-columns:1fr 1fr; min-height:100vh; }
.login-aside {
  position:relative; padding:56px 52px; display:flex; flex-direction:column; justify-content:center; gap:14px;
  background:var(--bg-1); border-right:1px solid var(--line-strong); overflow:hidden;
}
.la-mono {
  width:72px; height:72px; display:grid; place-items:center; border-radius:var(--r-sm);
  font-family:var(--font-mono); font-weight:700; font-size:30px; color:var(--signal);
  background:var(--bg-1); border:1px solid var(--line-signal); margin-bottom:8px;
}
.la-disp { font-family:var(--font-display); font-weight:600; font-size:46px; letter-spacing:-.03em; color:var(--fg-0); line-height:1; }
.la-disp em { color:var(--signal); font-style:normal; }
.la-slash { font-family:var(--font-mono); font-weight:600; font-size:11px; letter-spacing:.3em; color:var(--signal-dim); opacity:.6; margin-top:6px; }
.la-foot { margin-top:18px; font-family:var(--font-mono); font-size:11px; line-height:1.7; letter-spacing:.06em; color:var(--fg-2); }

.login-card {
  align-self:center; justify-self:center; width:min(360px,86vw);
  display:flex; flex-direction:column; gap:14px; padding:0 32px;
}
.lc-head { display:flex; align-items:center; gap:10px; }
.lc-brand { font-family:var(--font-mono); font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--fg-2); }
.login-card h1 { margin:6px 0 4px; font-family:var(--font-display); font-weight:600; font-size:28px; letter-spacing:-.02em; }
.login-card input {
  font-family:var(--font-mono); font-size:14px; color:var(--fg-0);
  background:var(--bg-2); border:1px solid var(--line-strong); border-radius:var(--r-sm); padding:12px 14px; outline:none;
}
.login-card input:focus { border-color:var(--line-signal); box-shadow:0 0 0 3px var(--signal-glow); }
.login-card button {
  font-family:var(--font-mono); font-size:13px; letter-spacing:.04em; cursor:pointer;
  padding:12px 14px; border-radius:var(--r-sm); border:1px solid var(--signal);
  background:var(--signal); color:var(--fg-inv); font-weight:700; transition:background var(--ease) .2s;
}
.login-card button:hover { background:var(--signal-hi); }
.err { margin:0; color:var(--threat); font-family:var(--font-mono); font-size:12px; }

@media (max-width:760px) { .login-body { grid-template-columns:1fr; } .login-aside { display:none; } }

/* ---------- toast + popconfirm ---------- */
#toast {
  position:fixed; left:50%; bottom:26px; transform:translateX(-50%) translateY(20px);
  display:flex; align-items:center; gap:14px; opacity:0; pointer-events:none;
  background:var(--bg-3); border:1px solid var(--line-strong); border-radius:var(--r-md);
  padding:12px 18px; font-family:var(--font-mono); font-size:12px; color:var(--fg-0);
  box-shadow:0 14px 36px rgba(0,0,0,.5); transition:all var(--ease) .25s; z-index:60;
}
#toast.show { opacity:1; transform:translateX(-50%) translateY(0); pointer-events:auto; }
.toast-action { background:none; border:0; color:var(--signal); font-family:var(--font-mono); font-size:12px; cursor:pointer; padding:0; }
.toast-action.danger { color:var(--threat); }

.popconfirm {
  position:fixed; z-index:70; width:240px; padding:14px;
  background:var(--bg-3); border:1px solid var(--line-strong); border-radius:var(--r-md);
  box-shadow:0 14px 36px rgba(0,0,0,.55);
}
.popconfirm p { margin:0 0 12px; font-family:var(--font-display); font-size:13px; color:var(--fg-0); line-height:1.4; }
.pc-actions { display:flex; gap:8px; justify-content:flex-end; }
.pc-actions button { font-family:var(--font-mono); font-size:11px; padding:7px 12px; border-radius:var(--r-sm); cursor:pointer; }
.pc-cancel { background:var(--bg-1); border:1px solid var(--line); color:var(--fg-1); }
.pc-ok { background:var(--threat); border:1px solid var(--threat); color:#fff; font-weight:600; }
