/*
 * Pinky Creative Studio — Werkplatform
 * klantenservice@stopmetzoeken.store · +31 638909416
 * Design system: dark/light, animated mesh, shine, tilt, shimmer, magnetic — premium 2026
 */

/* ── Font: Geist Variable (Vercel) + Inter fallback ──────────── */
@font-face{
  font-family:'Geist';
  src:url('https://cdn.jsdelivr.net/npm/geist@latest/dist/fonts/geist-sans/Geist-Variable.woff2') format('woff2-variations'),
      url('https://cdn.jsdelivr.net/npm/geist@latest/dist/fonts/geist-sans/Geist-Variable.woff2') format('woff2');
  font-weight:100 900;font-display:swap;
}

*{margin:0;padding:0;box-sizing:border-box}
*::selection{background:var(--primary);color:#fff}

:root{
  --primary:#8b5cf6;--primary-dark:#6d28d9;--primary-light:rgba(139,92,246,.14);
  --accent-2:#ec4899;--accent-3:#3b82f6;
  --bg:#f7f7fb;--bg-subtle:#f0f2f5;--card:#ffffff;--card-hover:#fafbff;
  --text:#0f172a;--text2:#5f6368;--text3:#9aa0a6;
  --border:rgba(15,23,42,.08);--border-strong:rgba(15,23,42,.14);
  --success:#10b981;--warning:#f59e0b;--danger:#ef4444;--purple:#8b5cf6;
  --sidebar-bg:#0b1120;--sidebar-text:#94a3b8;--sidebar-hover:rgba(255,255,255,.06);--sidebar-active:rgba(139,92,246,.18);
  --radius:12px;--radius-lg:18px;
  --shadow:0 1px 3px rgba(15,23,42,.06),0 1px 2px rgba(15,23,42,.04);
  --shadow-md:0 4px 14px rgba(15,23,42,.08);
  --shadow-lg:0 20px 50px rgba(15,23,42,.12);
  --shadow-glow:0 0 0 1px rgba(139,92,246,.25),0 10px 30px rgba(139,92,246,.15);
  --ease:cubic-bezier(.22,1,.36,1);
  --font:'Geist','Inter',ui-sans-serif,-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
}
html[data-theme="dark"]{
  --bg:#05070e;--bg-subtle:#0b1120;--card:#0f172a;--card-hover:#131c31;
  --text:#e4e7eb;--text2:#94a3b8;--text3:#64748b;
  --border:rgba(255,255,255,.08);--border-strong:rgba(255,255,255,.14);
  --sidebar-bg:#020510;--sidebar-hover:rgba(255,255,255,.05);
  --shadow:0 1px 3px rgba(0,0,0,.4);
  --shadow-md:0 4px 20px rgba(0,0,0,.5);
  --shadow-lg:0 20px 60px rgba(0,0,0,.6);
}
html{color-scheme:light dark}
html[data-theme="dark"]{color-scheme:dark}

html,body{min-height:100vh}
body{
  font-family:var(--font);background:var(--bg);color:var(--text);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  font-feature-settings:'cv11','ss01','ss03';letter-spacing:-.01em;
  display:flex;flex-direction:column;min-height:100vh;
  opacity:0;transition:opacity .45s var(--ease);
}
body.is-ready{opacity:1}

a{color:var(--primary);text-decoration:none;transition:color .15s var(--ease)}
a:hover{color:var(--primary-dark);text-decoration:none}
code{font-family:'Geist Mono',ui-monospace,Menlo,Consolas,monospace;font-size:.85em}
.muted{color:var(--text2)}

/* ── Scrollbar ─────────────────────────────────────────────── */
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-track{background:transparent}
*::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:10px}
*::-webkit-scrollbar-thumb:hover{background:var(--text3)}

/* ─────────────────────────────────────────────────────────────
   AUTH PAGE — animated mesh gradient + blobs + noise overlay
   ───────────────────────────────────────────────────────────── */
.auth-page{
  flex:1;display:flex;align-items:center;justify-content:center;
  padding:40px 16px;position:relative;overflow:hidden;
  background:radial-gradient(ellipse at top,#1e1b4b 0%,#0b1120 60%,#05070e 100%);
  isolation:isolate;
}
.auth-page::before,
.auth-page::after{
  content:'';position:absolute;inset:-20%;pointer-events:none;z-index:-1;
  filter:blur(90px);opacity:.55;
}
.auth-page::before{
  background:
    radial-gradient(circle at 20% 30%,#ec4899 0%,transparent 45%),
    radial-gradient(circle at 80% 20%,#8b5cf6 0%,transparent 45%),
    radial-gradient(circle at 70% 80%,#3b82f6 0%,transparent 45%),
    radial-gradient(circle at 15% 85%,#06b6d4 0%,transparent 45%);
  animation:meshShift 22s ease-in-out infinite alternate;
}
.auth-page::after{
  background:conic-gradient(from 0deg at 50% 50%,#8b5cf6,#ec4899,#3b82f6,#06b6d4,#8b5cf6);
  opacity:.18;animation:meshRotate 40s linear infinite;mix-blend-mode:screen;
}
@keyframes meshShift{
  0%{transform:translate(0,0) scale(1)}
  50%{transform:translate(4%,-3%) scale(1.08)}
  100%{transform:translate(-3%,4%) scale(1.02)}
}
@keyframes meshRotate{to{transform:rotate(360deg)}}

.auth-page .noise{
  position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='200' height='200' filter='url(%23n)' opacity='.5'/></svg>");
  opacity:.06;mix-blend-mode:overlay;
}

.auth-card{
  position:relative;z-index:1;background:rgba(255,255,255,.92);backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.4);
  border-radius:22px;padding:44px 40px;width:460px;max-width:100%;
  box-shadow:var(--shadow-lg),0 0 60px rgba(139,92,246,.2);
  animation:cardIn .7s var(--ease) both;
}
html[data-theme="dark"] .auth-card{background:rgba(15,23,42,.88);border-color:rgba(255,255,255,.08)}
@keyframes cardIn{
  from{opacity:0;transform:translateY(14px) scale(.98)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
.auth-card .logo{text-align:center;margin-bottom:28px}
.auth-card .logo-icon{
  width:72px;height:72px;border-radius:20px;display:inline-flex;align-items:center;
  justify-content:center;font-size:28px;font-weight:800;color:#fff;
  background:linear-gradient(135deg,#ec4899 0%,#8b5cf6 50%,#3b82f6 100%);
  box-shadow:0 10px 30px rgba(139,92,246,.35);position:relative;overflow:hidden;
}
.auth-card .logo-icon img{width:100%;height:100%;object-fit:cover;border-radius:20px}
.auth-card .logo-icon::after{
  content:'';position:absolute;inset:0;border-radius:inherit;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.35) 50%,transparent 70%);
  transform:translateX(-120%);animation:sheen 3.5s ease-in-out infinite 1s;
}
@keyframes sheen{to{transform:translateX(120%)}}
.auth-card .logo h1{font-size:24px;margin-top:16px;font-weight:700;letter-spacing:-.02em}
.auth-card .logo p{color:var(--text2);font-size:13px;margin-top:4px}
.auth-card form{display:flex;flex-direction:column;gap:16px}
.auth-card .hint{text-align:center;color:var(--text2);font-size:12px;margin-top:16px}

/* ── App shell ─────────────────────────────────────────────── */
.app{display:flex;flex:1;min-height:0}

.sidebar{
  width:260px;background:var(--sidebar-bg);color:var(--sidebar-text);
  display:flex;flex-direction:column;flex-shrink:0;position:fixed;
  height:100vh;z-index:100;transition:transform .25s var(--ease);
  border-right:1px solid rgba(255,255,255,.04);
}
.sidebar-header{padding:22px 20px;border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:12px}
.sidebar-header .s-icon{
  width:42px;height:42px;border-radius:12px;display:flex;align-items:center;
  justify-content:center;font-size:18px;font-weight:800;color:#fff;flex-shrink:0;overflow:hidden;
  background:linear-gradient(135deg,#ec4899,#8b5cf6,#3b82f6);
  box-shadow:0 4px 14px rgba(139,92,246,.4);
}
.sidebar-header .s-icon img{width:100%;height:100%;object-fit:cover}
.sidebar-header h1{font-size:15px;color:#fff;font-weight:700;line-height:1.2;letter-spacing:-.01em}
.sidebar-header span{font-size:11px;color:var(--sidebar-text);text-transform:uppercase;letter-spacing:.5px}

.nav-menu{list-style:none;padding:14px 10px;flex:1;overflow-y:auto}
.nav-section{font-size:10px;text-transform:uppercase;letter-spacing:1.2px;padding:18px 14px 8px;color:rgba(255,255,255,.35);font-weight:600}
.nav-item{
  display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:10px;
  cursor:pointer;font-size:13px;margin-bottom:2px;transition:all .15s var(--ease);
  color:var(--sidebar-text);text-decoration:none;position:relative;
}
.nav-item:hover{background:var(--sidebar-hover);color:#fff;text-decoration:none;transform:translateX(2px)}
.nav-item.active{background:var(--sidebar-active);color:#fff}
.nav-item.active::before{content:'';position:absolute;left:-10px;top:10px;bottom:10px;width:3px;background:var(--primary);border-radius:0 3px 3px 0}
.nav-item i{width:18px;text-align:center;font-size:14px}
.nav-item .badge-pill{
  margin-left:auto;background:rgba(255,255,255,.1);color:#fff;font-size:10px;
  padding:2px 8px;border-radius:999px;font-weight:600;text-transform:uppercase;letter-spacing:.4px
}

.sidebar-footer{padding:14px;border-top:1px solid rgba(255,255,255,.06)}
.sidebar-footer .user-info{display:flex;align-items:center;gap:10px;padding:8px;border-radius:10px}
.sidebar-footer .avatar{
  width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:13px;font-weight:700;flex-shrink:0;
  background:linear-gradient(135deg,#ec4899,#8b5cf6,#3b82f6);
}
.sidebar-footer .user-name{font-size:13px;color:#fff;line-height:1.2;font-weight:600}
.sidebar-footer .user-email{font-size:11px;color:var(--sidebar-text)}
.sidebar-footer form{margin-top:8px}
.sidebar-footer .logout-btn{
  width:100%;background:transparent;border:1px solid rgba(255,255,255,.1);color:var(--sidebar-text);
  padding:9px;border-radius:10px;cursor:pointer;font-size:12px;font-family:inherit;font-weight:500;
  transition:all .15s var(--ease);display:flex;align-items:center;justify-content:center;gap:6px;
}
.sidebar-footer .logout-btn:hover{background:var(--sidebar-hover);color:#fff;border-color:rgba(255,255,255,.2)}

.content{flex:1;margin-left:260px;padding:24px 32px 0;min-height:100vh;display:flex;flex-direction:column}
.content>main{flex:1;padding-bottom:24px}

/* ── Topbar ───────────────────────────────────────────────── */
.topbar{
  display:flex;justify-content:space-between;align-items:center;padding:12px 0 16px;margin-bottom:20px;
  border-bottom:1px solid var(--border);gap:12px;flex-wrap:wrap;position:sticky;top:0;z-index:50;
  background:var(--bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
}
.topbar .topbar-title{font-size:13px;color:var(--text2)}
.topbar .topbar-right{display:flex;align-items:center;gap:12px}
.theme-toggle{
  background:var(--card);border:1px solid var(--border);width:36px;height:36px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;color:var(--text2);cursor:pointer;
  transition:all .15s var(--ease);font-size:14px;
}
.theme-toggle:hover{background:var(--card-hover);color:var(--text);transform:rotate(20deg)}
html[data-theme="dark"] .theme-toggle .fa-sun{display:inline-block}
html[data-theme="dark"] .theme-toggle .fa-moon{display:none}
.theme-toggle .fa-sun{display:none}

/* ── Page header ──────────────────────────────────────────── */
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.page-header h2{font-size:26px;font-weight:700;letter-spacing:-.025em;line-height:1.2}
.page-header p{color:var(--text2);font-size:14px;margin-top:6px}
.page-header .actions{display:flex;gap:8px}

/* ── Cards ────────────────────────────────────────────────── */
.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;border:1px solid var(--border);transition:border-color .2s var(--ease),box-shadow .2s var(--ease)}
.card:hover{border-color:var(--border-strong)}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.card-header h3{font-size:15px;font-weight:700;display:flex;align-items:center;gap:8px;letter-spacing:-.01em}
.card-header h3 i{color:var(--primary)}

/* ── Stat cards ───────────────────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px}
.stat-card{
  background:var(--card);border-radius:var(--radius);padding:20px;
  box-shadow:var(--shadow);display:flex;align-items:flex-start;gap:16px;
  border:1px solid var(--border);position:relative;overflow:hidden;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),border-color .25s var(--ease);
}
.stat-card::after{
  content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:linear-gradient(120deg,transparent 30%,rgba(139,92,246,.08) 50%,transparent 70%);
  transform:translateX(-120%);transition:transform .8s var(--ease);
}
.stat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--border-strong)}
.stat-card:hover::after{transform:translateX(120%)}
.stat-card .stat-icon{
  width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;
  font-size:20px;flex-shrink:0;position:relative;
}
.stat-card .stat-icon.blue{background:rgba(59,130,246,.12);color:#3b82f6}
.stat-card .stat-icon.green{background:rgba(16,185,129,.12);color:#10b981}
.stat-card .stat-icon.orange{background:rgba(245,158,11,.12);color:#f59e0b}
.stat-card .stat-icon.red{background:rgba(239,68,68,.12);color:#ef4444}
.stat-card .stat-icon.purple{background:rgba(139,92,246,.14);color:#8b5cf6}
.stat-card .stat-value{font-size:28px;font-weight:700;line-height:1;letter-spacing:-.02em}
.stat-card .stat-label{font-size:12px;color:var(--text2);margin-top:6px;font-weight:500}

/* ── Module cards (portal) with tilt + shine ──────────────── */
.module-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-top:14px}
.module-card{
  background:var(--card);border-radius:var(--radius-lg);padding:24px;
  box-shadow:var(--shadow);display:flex;flex-direction:column;gap:12px;
  text-decoration:none;color:var(--text);transition:all .3s var(--ease);
  border:1px solid var(--border);position:relative;overflow:hidden;will-change:transform;
}
.module-card::before{
  content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;opacity:0;
  background:radial-gradient(600px circle at var(--mx,50%) var(--my,50%),rgba(139,92,246,.12),transparent 40%);
  transition:opacity .3s var(--ease);
}
.module-card:hover::before{opacity:1}
.module-card:hover{border-color:var(--primary);box-shadow:var(--shadow-glow);text-decoration:none;color:var(--text)}
.module-card .m-icon{
  width:54px;height:54px;border-radius:14px;display:flex;align-items:center;justify-content:center;
  font-size:22px;color:#fff;position:relative;flex-shrink:0;
}
.module-card .m-icon.blue{background:linear-gradient(135deg,#3b82f6,#1d4ed8)}
.module-card .m-icon.green{background:linear-gradient(135deg,#10b981,#047857)}
.module-card .m-icon.orange{background:linear-gradient(135deg,#f59e0b,#b45309)}
.module-card .m-icon.purple{background:linear-gradient(135deg,#8b5cf6,#6d28d9)}
.module-card h4{font-size:17px;font-weight:700;letter-spacing:-.015em}
.module-card p{color:var(--text2);font-size:13px;line-height:1.55}
.module-card .m-action{color:var(--primary);font-size:13px;font-weight:600;margin-top:auto;display:flex;align-items:center;gap:6px}
.module-card:hover .m-action i{transform:translateX(4px)}
.module-card .m-action i{transition:transform .25s var(--ease)}

/* ── Forms ─────────────────────────────────────────────────── */
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:12px;font-weight:600;margin-bottom:6px;color:var(--text2);text-transform:uppercase;letter-spacing:.4px}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:10px;
  font-size:14px;font-family:inherit;transition:all .15s var(--ease);
  background:var(--card);color:var(--text);
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-light);
}
.form-group input[type="color"]{height:46px;padding:4px;cursor:pointer}
.form-group input[type="file"]{padding:9px;background:var(--bg-subtle)}
.form-group .help{font-size:11px;color:var(--text2);margin-top:5px;text-transform:none;letter-spacing:0;font-weight:400}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-row.three{grid-template-columns:1fr 1fr 1fr}
.form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}

/* ── Buttons ───────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:8px;padding:11px 20px;border-radius:10px;
  font-size:13px;font-weight:600;cursor:pointer;border:none;
  transition:all .18s var(--ease);font-family:inherit;text-decoration:none;
  position:relative;overflow:hidden;letter-spacing:-.005em;
}
.btn::after{
  content:'';position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.25) 50%,transparent 70%);
  transform:translateX(-120%);transition:transform .7s var(--ease);
}
.btn:hover::after{transform:translateX(120%)}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn:active{transform:translateY(0)}

.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;box-shadow:0 4px 14px rgba(139,92,246,.35)}
.btn-primary:hover{color:#fff;box-shadow:0 6px 20px rgba(139,92,246,.45)}
.btn-secondary{background:var(--bg-subtle);color:var(--text);border:1.5px solid var(--border)}
.btn-secondary:hover{background:var(--card-hover);border-color:var(--border-strong)}
.btn-success{background:linear-gradient(135deg,#10b981,#047857);color:#fff}
.btn-danger{background:linear-gradient(135deg,#ef4444,#b91c1c);color:#fff}
.btn-outline{background:transparent;border:1.5px solid var(--border-strong);color:var(--text)}
.btn-outline:hover{border-color:var(--primary);color:var(--primary)}
.btn-sm{padding:7px 14px;font-size:12px}
.btn-block{width:100%;justify-content:center}
.btn-icon{background:transparent;border:none;cursor:pointer;width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text2);transition:all .12s var(--ease)}
.btn-icon:hover{background:var(--bg-subtle);color:var(--text)}
.btn-icon.danger:hover{background:rgba(239,68,68,.12);color:var(--danger)}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn:disabled::after{display:none}

/* ── Tables ───────────────────────────────────────────────── */
.data-table{width:100%;border-collapse:collapse}
.data-table th{
  text-align:left;padding:12px 14px;font-size:11px;text-transform:uppercase;
  letter-spacing:.5px;color:var(--text2);border-bottom:1px solid var(--border);
  white-space:nowrap;font-weight:600;background:var(--card);position:sticky;top:0;
}
.data-table td{padding:14px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle}
.data-table tr:last-child td{border-bottom:none}
.data-table tr{transition:background .15s var(--ease)}
.data-table tbody tr:hover td{background:var(--bg-subtle)}
.data-table tbody tr{animation:rowIn .4s var(--ease) both;animation-delay:calc(var(--i,0) * 50ms)}
@keyframes rowIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
.data-table .actions{display:flex;gap:2px}
.data-table .avatar-cell{display:flex;align-items:center;gap:10px}
.data-table .tenant-badge{
  width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:700;font-size:13px;flex-shrink:0;overflow:hidden;
  box-shadow:0 2px 8px rgba(0,0,0,.12);
}
.data-table .tenant-badge img{width:100%;height:100%;object-fit:cover}

/* ── Badges ───────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600;gap:5px}
.badge::before{content:'';width:6px;height:6px;border-radius:50%}
.badge-draft{background:var(--bg-subtle);color:var(--text2)}.badge-draft::before{background:var(--text2)}
.badge-sent{background:rgba(59,130,246,.12);color:#3b82f6}.badge-sent::before{background:#3b82f6}
.badge-paid,.badge-active,.badge-accepted{background:rgba(16,185,129,.12);color:#10b981}
.badge-paid::before,.badge-active::before,.badge-accepted::before{background:#10b981}
.badge-overdue,.badge-rejected{background:rgba(239,68,68,.12);color:#ef4444}
.badge-overdue::before,.badge-rejected::before{background:#ef4444}
.badge-paused{background:rgba(245,158,11,.12);color:#f59e0b}.badge-paused::before{background:#f59e0b}
.badge-role{background:var(--primary-light);color:var(--primary);padding:3px 9px;border-radius:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.badge-role::before{display:none}

/* ── Alerts ───────────────────────────────────────────────── */
.alert{padding:13px 16px;border-radius:10px;font-size:13px;display:flex;align-items:flex-start;gap:10px;margin-bottom:16px;border:1px solid transparent}
.alert i{margin-top:2px;font-size:15px}
.alert-danger{background:rgba(239,68,68,.08);color:#c5221f;border-color:rgba(239,68,68,.2)}
.alert-success{background:rgba(16,185,129,.08);color:#047857;border-color:rgba(16,185,129,.2)}
.alert-info{background:var(--primary-light);color:var(--primary-dark);border-color:rgba(139,92,246,.2)}
.alert-warning{background:rgba(245,158,11,.08);color:#b45309;border-color:rgba(245,158,11,.2)}

/* ── Empty state ──────────────────────────────────────────── */
.empty-state{text-align:center;padding:56px 20px;color:var(--text2)}
.empty-state i{font-size:48px;margin-bottom:14px;opacity:.25;display:block}
.empty-state h4{font-size:17px;color:var(--text);margin-bottom:6px;font-weight:700}
.empty-state p{font-size:14px;margin-bottom:18px}

/* ── Skeleton shimmer ─────────────────────────────────────── */
.skeleton{
  background:linear-gradient(90deg,var(--bg-subtle) 25%,var(--card-hover) 50%,var(--bg-subtle) 75%);
  background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:8px;
}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ── Lang switcher ────────────────────────────────────────── */
.lang-switcher{display:inline-flex;gap:2px;background:var(--bg-subtle);padding:3px;border-radius:10px;border:1px solid var(--border)}
.lang-switcher a{padding:5px 10px;font-size:11px;font-weight:700;border-radius:7px;color:var(--text2);text-decoration:none;letter-spacing:.4px;transition:all .15s var(--ease)}
.lang-switcher a:hover{color:var(--text);text-decoration:none}
.lang-switcher a.active{background:var(--card);color:var(--primary);box-shadow:var(--shadow)}
.auth-card .lang-switcher{display:flex;justify-content:center;margin:18px auto 0;width:fit-content}

/* ── Reveal animations ────────────────────────────────────── */
[data-reveal]{opacity:0;transform:translateY(8px);transition:opacity .55s var(--ease),transform .55s var(--ease);transition-delay:var(--reveal-delay,0ms)}
[data-reveal].is-revealed{opacity:1;transform:none}
[data-view-reveal]{opacity:0;transform:translateY(12px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
[data-view-reveal].is-in-view{opacity:1;transform:none}

/* ── Error page ───────────────────────────────────────────── */
.error-page{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:40px 16px;text-align:center;position:relative;overflow:hidden;
  background:radial-gradient(ellipse at top,rgba(139,92,246,.12) 0%,transparent 60%),var(--bg);
}
.error-page .error-code{
  font-size:clamp(80px,14vw,160px);font-weight:800;line-height:1;letter-spacing:-.06em;
  background:linear-gradient(135deg,#ec4899,#8b5cf6,#3b82f6);
  -webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:8px;
}
.error-page h2{font-size:24px;margin-bottom:10px;font-weight:700}
.error-page p{color:var(--text2);margin-bottom:28px;max-width:500px;font-size:15px}
.error-page pre{text-align:left;background:var(--card);padding:18px;border-radius:10px;max-width:800px;width:100%;overflow-x:auto;font-size:12px;border:1px solid var(--border);margin-bottom:20px}

/* ── Footer ───────────────────────────────────────────────── */
.site-footer{
  background:var(--card);border-top:1px solid var(--border);padding:18px 32px;
  margin-left:260px;font-size:12px;color:var(--text2);
}
.site-footer.full{margin-left:0}
.site-footer__inner{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.site-footer a{color:var(--primary)}
.site-footer .brand{font-weight:600;color:var(--text)}
.site-footer .heart{color:#ec4899;display:inline-block;animation:beat 1.4s ease-in-out infinite}
@keyframes beat{0%,100%{transform:scale(1)}50%{transform:scale(1.2)}}

/* ── Mobile toggle ────────────────────────────────────────── */
.mobile-toggle{display:none;position:fixed;top:14px;left:14px;z-index:200;background:linear-gradient(135deg,#ec4899,#8b5cf6);color:#fff;width:42px;height:42px;border-radius:12px;border:none;font-size:18px;cursor:pointer;box-shadow:var(--shadow-lg)}

@media(max-width:768px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .mobile-toggle{display:flex;align-items:center;justify-content:center}
  .content{margin-left:0;padding:64px 16px 20px}
  .site-footer{margin-left:0;padding:16px}
  .form-row,.form-row.three{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
  .page-header h2{font-size:22px}
}
@media(max-width:480px){
  .stats-grid{grid-template-columns:1fr}
  .page-header{flex-direction:column;align-items:flex-start}
  .auth-card{padding:32px 22px}
}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .auth-page::before,.auth-page::after{animation:none}
}

/* Pinky Creative Studio — klantenservice@stopmetzoeken.store — +31 638909416 */
