:root {
  --blush:    #F2DDD8;
  --blush2:   #E8C8C2;
  --blush3:   #D4A89F;
  --black:    #1A0F0D;
  --darkrose: #2C1614;
  --card:     #231210;
  --text:     #F2DDD8;
  --muted:    rgba(242,221,216,0.5);
  --accent:   #FF6B8A;
  --gold:     #F5C842;
  --success:  #5EEAD4;
  --error:    #FF4757;
  --mid:      #1E0F0D;
}
* { margin:0; padding:0; box-sizing:border-box; -webkit-tap-highlight-color:transparent; }
html,body { width:100%; height:100%; overflow:hidden; background:var(--black); font-family:'Nunito',sans-serif; color:var(--text); }

.screen { position:absolute; inset:0; display:flex; flex-direction:column; transition:opacity 0.4s, transform 0.4s; }
.screen.hidden { opacity:0; pointer-events:none; transform:scale(0.97); }

/* ── BACKGROUND TEXTURE ── */
.space-bg {
  position:absolute; inset:0; z-index:0;
  background:
    radial-gradient(ellipse at 15% 40%, rgba(242,221,216,0.12) 0%, transparent 55%),
    radial-gradient(ellipse at 85% 20%, rgba(212,168,159,0.15) 0%, transparent 50%),
    radial-gradient(ellipse at 60% 85%, rgba(255,107,138,0.08) 0%, transparent 45%),
    #1A0F0D;
}
.space-grid {
  position:absolute; inset:0; z-index:0;
  background-image:
    linear-gradient(rgba(242,221,216,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(242,221,216,0.04) 1px, transparent 1px);
  background-size:55px 55px;
}

/* ─────────────────────────
   KIOSK SCREEN
───────────────────────── */
#kiosk { background:var(--black); overflow:hidden; }

.kiosk-inner {
  position:relative; z-index:1;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  height:100%; padding:24px 40px; gap:18px;
}

.logo-lockup {
  display:flex; flex-direction:column; align-items:center; gap:6px;
}
.logo-img {
  width:80px; height:80px; border-radius:50%;
  box-shadow: 0 0 0 2px rgba(242,221,216,0.2), 0 8px 32px rgba(0,0,0,0.5);
  object-fit:cover;
}
.logo-name {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(42px,7vw,68px);
  line-height:0.9; letter-spacing:4px;
  color:var(--blush);
  text-align:center;
}
.logo-sub {
  font-size:11px; font-weight:800; letter-spacing:6px;
  text-transform:uppercase; color:var(--muted);
}

/* Staff on duty bar */
.staff-on-duty-bar {
  display:flex; align-items:center; gap:12px;
  background:rgba(242,221,216,0.06);
  border:1px solid rgba(242,221,216,0.15);
  border-radius:16px; padding:10px 18px;
  width:100%; max-width:520px; min-height:48px; flex-wrap:wrap;
}
.sod-label { font-size:10px; font-weight:800; letter-spacing:3px; text-transform:uppercase; color:var(--muted); white-space:nowrap; }
.sod-names { display:flex; gap:8px; flex-wrap:wrap; flex:1; }
.sod-chip {
  display:flex; align-items:center; gap:6px;
  background:rgba(245,200,66,0.12); border:1px solid rgba(245,200,66,0.3);
  border-radius:20px; padding:4px 12px 4px 6px;
  font-size:12px; font-weight:800; color:var(--gold);
}
.sod-avatar {
  width:22px; height:22px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:10px; font-weight:800; font-family:'Bebas Neue',sans-serif;
  background:var(--gold); color:var(--black);
}
.sod-none { font-size:12px; color:rgba(242,221,216,0.25); font-weight:700; font-style:italic; }

/* Code entry card */
.code-card {
  background:rgba(242,221,216,0.06);
  border:1.5px solid rgba(242,221,216,0.14);
  border-radius:28px; padding:26px 34px;
  width:100%; max-width:520px;
  backdrop-filter:blur(20px);
}
.code-label { font-size:11px; font-weight:800; letter-spacing:4px; text-transform:uppercase; color:var(--muted); text-align:center; margin-bottom:14px; }
.inputs-row { display:flex; justify-content:center; align-items:center; gap:8px; margin-bottom:18px; }
.code-sep { width:10px; height:2px; background:rgba(242,221,216,0.2); border-radius:2px; flex-shrink:0; }
.code-input {
  width:56px; height:64px; text-align:center;
  font-family:'Bebas Neue',sans-serif; font-size:32px;
  border:2px solid rgba(242,221,216,0.15); border-radius:14px;
  background:rgba(242,221,216,0.06); color:var(--blush);
  outline:none; caret-color:transparent; text-transform:uppercase;
  transition:border-color 0.15s, background 0.15s, transform 0.1s, box-shadow 0.15s;
}
.code-input:focus {
  border-color:var(--accent);
  background:rgba(255,107,138,0.1);
  transform:scale(1.06);
  box-shadow: 0 0 20px rgba(255,107,138,0.25);
}
.code-input.filled {
  border-color:var(--blush3);
  background:rgba(212,168,159,0.15);
  color:var(--blush);
}

.checkin-btn {
  width:100%; padding:16px; border-radius:16px; border:none;
  background:var(--blush);
  color:var(--black); font-family:'Bebas Neue',sans-serif;
  font-size:24px; letter-spacing:3px;
  cursor:pointer; transition:transform 0.15s, box-shadow 0.15s;
  box-shadow: 0 4px 24px rgba(242,221,216,0.2);
}
.checkin-btn:hover { box-shadow: 0 6px 32px rgba(242,221,216,0.35); }
.checkin-btn:active { transform:scale(0.98); }

.kiosk-bottom { display:flex; align-items:center; justify-content:space-between; width:100%; max-width:520px; }
.live-count { display:flex; align-items:center; gap:8px; font-size:13px; font-weight:700; color:var(--muted); }
.live-dot { width:8px; height:8px; border-radius:50%; background:var(--success); box-shadow:0 0 8px var(--success); animation:pulse 2s infinite; }
@keyframes pulse { 0%,100%{transform:scale(1);opacity:1;} 50%{transform:scale(1.4);opacity:0.7;} }
.live-count strong { color:var(--success); font-size:15px; }
.new-here { font-size:13px; color:var(--muted); font-weight:700; }
.new-here button { background:none; border:none; color:var(--blush2); font-family:'Nunito',sans-serif; font-weight:800; font-size:13px; cursor:pointer; text-decoration:underline; text-underline-offset:3px; }
.bsd { position:absolute; top:16px; right:20px; font-size:13px; font-weight:800; color:rgba(242,221,216,0.35); font-family:'Nunito',sans-serif; direction:rtl; user-select:none; z-index:1; }
.staff-btn { position:absolute; bottom:20px; right:24px; z-index:10; background:rgba(242,221,216,0.07); border:1px solid rgba(242,221,216,0.12); border-radius:12px; padding:9px 16px; color:var(--muted); font-family:'Nunito',sans-serif; font-size:12px; font-weight:700; cursor:pointer; transition:all 0.2s; }
.staff-btn:hover { background:rgba(242,221,216,0.12); color:var(--text); }

/* ── TOAST ── */
.toast { position:fixed; top:32px; left:50%; transform:translateX(-50%) translateY(-80px); z-index:999; padding:14px 28px; border-radius:20px; font-family:'Bebas Neue',sans-serif; font-size:22px; letter-spacing:2px; transition:transform 0.35s cubic-bezier(0.34,1.56,0.64,1); pointer-events:none; white-space:nowrap; }
.toast.show { transform:translateX(-50%) translateY(0); }
.toast.success { background:var(--success); color:#000; }
.toast.error { background:var(--error); color:#fff; }
.toast.info { background:var(--blush); color:var(--black); }

/* ── WELCOME OVERLAY ── */
#welcome-overlay { position:fixed; inset:0; z-index:100; background:rgba(26,15,13,0.96); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; opacity:0; pointer-events:none; transition:opacity 0.3s; }
#welcome-overlay.show { opacity:1; pointer-events:all; }
.welcome-logo { width:60px; height:60px; border-radius:50%; animation:bounceIn 0.5s cubic-bezier(0.34,1.56,0.64,1); }
@keyframes bounceIn { from{transform:scale(0.3);opacity:0;} to{transform:scale(1);opacity:1;} }
.welcome-name { font-family:'Bebas Neue',sans-serif; font-size:clamp(52px,10vw,84px); color:var(--blush); text-align:center; line-height:1; animation:slideUp 0.4s 0.1s both; }
.welcome-sub { font-size:18px; font-weight:700; color:var(--muted); animation:slideUp 0.4s 0.2s both; }
.welcome-detail { font-size:13px; font-weight:600; color:rgba(242,221,216,0.3); animation:slideUp 0.4s 0.25s both; }
@keyframes slideUp { from{transform:translateY(20px);opacity:0;} to{transform:translateY(0);opacity:1;} }
.welcome-staff-note { font-size:13px; font-weight:800; color:var(--gold); background:rgba(245,200,66,0.1); border:1px solid rgba(245,200,66,0.3); border-radius:12px; padding:8px 20px; animation:slideUp 0.4s 0.3s both; }
.welcome-bar { width:180px; height:3px; background:rgba(242,221,216,0.1); border-radius:3px; overflow:hidden; margin-top:10px; animation:slideUp 0.4s 0.35s both; }
.welcome-bar-fill { height:100%; background:linear-gradient(90deg,var(--accent),var(--blush)); border-radius:3px; width:0%; transition:width linear; }

/* ── PIN MODAL ── */
#pin-modal { position:fixed; inset:0; z-index:200; background:rgba(26,15,13,0.92); display:flex; align-items:center; justify-content:center; opacity:0; pointer-events:none; transition:opacity 0.3s; }
#pin-modal.show { opacity:1; pointer-events:all; }
.pin-card { background:var(--card); border:1.5px solid rgba(242,221,216,0.1); border-radius:28px; padding:40px; width:340px; text-align:center; }
.pin-title { font-family:'Bebas Neue',sans-serif; font-size:34px; color:var(--blush); margin-bottom:4px; }
.pin-sub { font-size:12px; color:var(--muted); font-weight:600; margin-bottom:24px; }
.pin-dots { display:flex; justify-content:center; gap:12px; margin-bottom:24px; }
.pin-dot { width:15px; height:15px; border-radius:50%; border:2px solid rgba(242,221,216,0.2); transition:all 0.15s; }
.pin-dot.filled { background:var(--accent); border-color:var(--accent); box-shadow:0 0 12px rgba(255,107,138,0.5); }
.pin-pad { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.pin-key { height:58px; border-radius:14px; border:none; background:rgba(242,221,216,0.07); color:var(--blush); font-family:'Bebas Neue',sans-serif; font-size:26px; cursor:pointer; transition:background 0.15s,transform 0.1s; }
.pin-key:active { background:rgba(242,221,216,0.18); transform:scale(0.94); }
.pin-key.del { font-family:'Nunito',sans-serif; font-size:18px; }
.pin-key.cancel { grid-column:1/-1; font-size:13px; font-family:'Nunito',sans-serif; font-weight:800; color:var(--muted); background:transparent; border:1px solid rgba(242,221,216,0.1); }

/* ── REGISTER ── */
#register { background:var(--black); overflow-y:auto; }
.reg-inner { position:relative; z-index:1; max-width:580px; margin:0 auto; padding:36px 24px; }
.reg-back { display:flex; align-items:center; gap:8px; background:none; border:none; color:var(--muted); font-family:'Nunito',sans-serif; font-weight:800; font-size:13px; cursor:pointer; margin-bottom:24px; }
.reg-back:hover { color:var(--text); }
.reg-logo-row { display:flex; align-items:center; gap:14px; margin-bottom:6px; }
.reg-logo { width:52px; height:52px; border-radius:50%; box-shadow:0 4px 16px rgba(0,0,0,0.4); }
.reg-title { font-family:'Bebas Neue',sans-serif; font-size:46px; color:var(--blush); line-height:0.95; }
.reg-sub { font-size:13px; color:var(--muted); font-weight:700; margin-bottom:24px; margin-top:4px; }

.staff-toggle-row { display:flex; align-items:center; gap:14px; background:rgba(245,200,66,0.06); border:1.5px solid rgba(245,200,66,0.2); border-radius:16px; padding:14px 18px; margin-bottom:18px; cursor:pointer; transition:background 0.2s; }
.staff-toggle-row:hover { background:rgba(245,200,66,0.1); }
.toggle-switch { position:relative; width:44px; height:24px; flex-shrink:0; }
.toggle-switch input { opacity:0; width:0; height:0; position:absolute; }
.toggle-track { position:absolute; inset:0; background:rgba(242,221,216,0.15); border-radius:12px; cursor:pointer; transition:background 0.2s; }
.toggle-track::after { content:''; position:absolute; top:3px; left:3px; width:18px; height:18px; background:var(--blush3); border-radius:50%; transition:transform 0.2s; }
.toggle-switch input:checked + .toggle-track { background:var(--gold); }
.toggle-switch input:checked + .toggle-track::after { transform:translateX(20px); background:#000; }
.toggle-info { flex:1; }
.toggle-title { font-size:14px; font-weight:800; color:var(--gold); }
.toggle-sub { font-size:11px; color:var(--muted); font-weight:600; margin-top:2px; }

.passcode-row { margin-bottom:16px; animation:slideUp 0.3s both; }
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.form-group { display:flex; flex-direction:column; gap:5px; }
.form-group.full { grid-column:1/-1; }
.form-label { font-size:10px; font-weight:800; letter-spacing:3px; text-transform:uppercase; color:var(--muted); }
.form-input { padding:13px 15px; border-radius:12px; border:2px solid rgba(242,221,216,0.1); background:rgba(242,221,216,0.05); color:var(--blush); font-family:'Nunito',sans-serif; font-size:15px; font-weight:600; outline:none; transition:border-color 0.15s,background 0.15s; }
.form-input:focus { border-color:var(--accent); background:rgba(255,107,138,0.07); }
.form-input::placeholder { color:rgba(242,221,216,0.2); }
.form-input.staff-focus:focus { border-color:var(--gold); background:rgba(245,200,66,0.07); }
.staff-section-divider { border:none; border-top:1px solid rgba(242,221,216,0.08); margin:16px 0; }

.reg-btn { width:100%; padding:18px; border-radius:16px; border:none; background:var(--blush); color:var(--black); font-family:'Bebas Neue',sans-serif; font-size:24px; letter-spacing:3px; cursor:pointer; margin-top:18px; transition:transform 0.15s, box-shadow 0.15s; box-shadow:0 4px 24px rgba(242,221,216,0.2); }
.reg-btn:active { transform:scale(0.98); }

/* ── ADMIN DASHBOARD ── */
#admin { background:#100808; overflow:hidden; flex-direction:row; }
.admin-sidebar { width:230px; flex-shrink:0; background:var(--mid); border-right:1px solid rgba(242,221,216,0.07); display:flex; flex-direction:column; padding:22px 0; }
.sidebar-logo-wrap { padding:0 18px 18px; border-bottom:1px solid rgba(242,221,216,0.07); margin-bottom:14px; display:flex; align-items:center; gap:10px; }
.sidebar-logo-img { width:36px; height:36px; border-radius:50%; }
.sidebar-logo-text { font-family:'Bebas Neue',sans-serif; font-size:18px; color:var(--blush); line-height:1; }
.sidebar-logo-sub { font-size:10px; font-weight:700; color:var(--muted); letter-spacing:2px; text-transform:uppercase; }
.nav-item { display:flex; align-items:center; gap:10px; padding:12px 18px; cursor:pointer; font-size:13px; font-weight:700; color:var(--muted); border-left:3px solid transparent; transition:all 0.2s; }
.nav-item:hover { color:var(--text); background:rgba(242,221,216,0.04); }
.nav-item.active { color:var(--blush); border-left-color:var(--accent); background:rgba(255,107,138,0.08); }
.nav-icon { font-size:15px; }
.sidebar-bottom { margin-top:auto; padding:16px 18px 0; border-top:1px solid rgba(242,221,216,0.07); }
.exit-btn { width:100%; padding:11px; border-radius:11px; border:1px solid rgba(242,221,216,0.1); background:transparent; color:var(--muted); font-family:'Nunito',sans-serif; font-weight:800; font-size:12px; cursor:pointer; transition:all 0.2s; }
.exit-btn:hover { background:rgba(255,71,87,0.15); color:var(--error); border-color:var(--error); }

.admin-main { flex:1; overflow-y:auto; padding:26px; display:flex; flex-direction:column; gap:18px; }
.admin-header { display:flex; align-items:center; justify-content:space-between; }
.admin-title { font-family:'Bebas Neue',sans-serif; font-size:34px; line-height:1; color:var(--blush); }
.admin-date { font-size:11px; font-weight:700; color:var(--muted); }
.live-badge { display:flex; align-items:center; gap:6px; background:rgba(94,234,212,0.1); border:1px solid rgba(94,234,212,0.25); border-radius:20px; padding:5px 13px; font-size:11px; font-weight:800; color:var(--success); letter-spacing:2px; }

.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
.stat-card { background:var(--card); border:1px solid rgba(242,221,216,0.07); border-radius:16px; padding:16px; }
.stat-label { font-size:10px; font-weight:800; letter-spacing:3px; text-transform:uppercase; color:var(--muted); margin-bottom:5px; }
.stat-value { font-family:'Bebas Neue',sans-serif; font-size:38px; line-height:1; }
.stat-value.blush { color:var(--blush); }
.stat-value.accent { color:var(--accent); }
.stat-value.gold { color:var(--gold); }
.stat-value.teal { color:var(--success); }
.stat-sub { font-size:11px; color:var(--muted); font-weight:600; margin-top:3px; }

.panels-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.panel { background:var(--card); border:1px solid rgba(242,221,216,0.07); border-radius:16px; padding:18px; overflow:hidden; display:flex; flex-direction:column; }
.panel-title { font-family:'Bebas Neue',sans-serif; font-size:16px; color:var(--muted); letter-spacing:1px; margin-bottom:12px; }
.whos-in-list { display:flex; flex-direction:column; gap:6px; overflow-y:auto; flex:1; }
.person-row { display:flex; align-items:center; gap:10px; padding:9px 12px; border-radius:10px; background:rgba(242,221,216,0.04); transition:background 0.15s; }
.person-row:hover { background:rgba(242,221,216,0.07); }
.person-avatar { width:32px; height:32px; border-radius:8px; display:flex; align-items:center; justify-content:center; font-family:'Bebas Neue',sans-serif; font-size:14px; flex-shrink:0; }
.person-info { flex:1; }
.person-name { font-size:13px; font-weight:800; color:var(--blush); }
.person-meta { font-size:11px; color:var(--muted); font-weight:600; }
.person-time { font-size:11px; font-weight:700; color:var(--success); }
.person-badge { font-size:9px; font-weight:800; letter-spacing:1px; padding:3px 7px; border-radius:5px; }
.badge-staff { background:rgba(245,200,66,0.15); color:var(--gold); }
.badge-member { background:rgba(242,221,216,0.1); color:var(--blush2); }

.timesheet-entry { display:flex; align-items:center; gap:10px; padding:9px 12px; border-radius:10px; background:rgba(242,221,216,0.04); }
.ts-date { font-size:11px; font-weight:700; color:var(--muted); min-width:78px; }
.ts-time { font-size:12px; font-weight:800; flex:1; color:var(--blush); }
.ts-duration { font-family:'Bebas Neue',sans-serif; font-size:18px; color:var(--gold); min-width:52px; text-align:right; }
.ts-pending { font-size:11px; color:var(--accent); font-weight:700; }

.chart-bars { display:flex; align-items:flex-end; gap:6px; height:88px; flex:1; margin-top:8px; }
.bar-col { flex:1; display:flex; flex-direction:column; align-items:center; gap:4px; }
.bar-wrap { flex:1; display:flex; align-items:flex-end; width:100%; }
.bar { width:100%; border-radius:5px 5px 0 0; background:linear-gradient(180deg,var(--blush3),rgba(212,168,159,0.4)); min-height:3px; transition:height 0.7s cubic-bezier(0.34,1.2,0.64,1); }
.bar.today { background:linear-gradient(180deg,var(--accent),rgba(255,107,138,0.5)); }
.bar-label { font-size:9px; font-weight:700; color:var(--muted); white-space:nowrap; }
.bar-count { font-size:10px; font-weight:800; color:var(--blush2); }

/* ── PRIVACY LIGHTBOX ── */
#privacy-lightbox { position:fixed; inset:0; z-index:300; background:rgba(26,15,13,0.94); display:flex; align-items:center; justify-content:center; opacity:0; pointer-events:none; transition:opacity 0.3s; padding:20px; }
#privacy-lightbox.show { opacity:1; pointer-events:all; }
.privacy-card { background:var(--card); border:1.5px solid rgba(242,221,216,0.12); border-radius:28px; max-width:560px; width:100%; max-height:88vh; overflow-y:auto; position:relative; }
.privacy-hero { background:linear-gradient(135deg,rgba(255,107,138,0.15),rgba(212,168,159,0.1)); border-radius:26px 26px 0 0; padding:32px 32px 24px; text-align:center; border-bottom:1px solid rgba(242,221,216,0.08); }
.privacy-emoji-row { display:flex; justify-content:center; gap:14px; font-size:32px; margin-bottom:14px; }
.privacy-hero-title { font-family:'Bebas Neue',sans-serif; font-size:36px; color:var(--blush); letter-spacing:2px; margin-bottom:6px; }
.privacy-hero-sub { font-size:13px; font-weight:700; color:var(--muted); line-height:1.6; }
.privacy-body { padding:24px 32px 28px; }
.privacy-section { margin-bottom:20px; }
.privacy-section-title { display:flex; align-items:center; gap:8px; font-size:11px; font-weight:800; letter-spacing:3px; text-transform:uppercase; color:var(--accent); margin-bottom:10px; }
.privacy-item { display:flex; align-items:flex-start; gap:10px; padding:10px 14px; border-radius:12px; margin-bottom:6px; }
.privacy-item.good { background:rgba(94,234,212,0.07); border:1px solid rgba(94,234,212,0.15); }
.privacy-item.bad { background:rgba(255,107,138,0.07); border:1px solid rgba(255,107,138,0.15); }
.privacy-item-icon { font-size:16px; flex-shrink:0; margin-top:1px; }
.privacy-item-text { font-size:12px; font-weight:700; color:var(--blush); line-height:1.5; }
.privacy-item-text span { font-weight:600; color:var(--muted); }
.privacy-close-btn { width:100%; padding:14px; border-radius:0 0 26px 26px; border:none; border-top:1px solid rgba(242,221,216,0.08); background:rgba(242,221,216,0.06); color:var(--blush); font-family:'Bebas Neue',sans-serif; font-size:20px; letter-spacing:3px; cursor:pointer; transition:background 0.2s; }
.privacy-close-btn:hover { background:rgba(242,221,216,0.1); }
.privacy-link-row { display:flex; justify-content:center; margin-top:10px; }
.privacy-full-link { font-size:11px; font-weight:700; color:var(--muted); text-decoration:underline; text-underline-offset:3px; cursor:pointer; background:none; border:none; font-family:'Nunito',sans-serif; }
.privacy-full-link:hover { color:var(--blush2); }

/* ── FULL PRIVACY POLICY MODAL ── */
#policy-modal { position:fixed; inset:0; z-index:400; background:rgba(26,15,13,0.97); display:flex; align-items:center; justify-content:center; opacity:0; pointer-events:none; transition:opacity 0.3s; padding:20px; }
#policy-modal.show { opacity:1; pointer-events:all; }
.policy-card { background:var(--card); border:1.5px solid rgba(242,221,216,0.1); border-radius:24px; max-width:620px; width:100%; max-height:90vh; display:flex; flex-direction:column; }
.policy-header { padding:24px 28px 16px; border-bottom:1px solid rgba(242,221,216,0.08); display:flex; align-items:center; justify-content:space-between; flex-shrink:0; }
.policy-header-title { font-family:'Bebas Neue',sans-serif; font-size:26px; color:var(--blush); letter-spacing:2px; }
.policy-close-x { background:rgba(242,221,216,0.07); border:1px solid rgba(242,221,216,0.12); border-radius:10px; width:36px; height:36px; display:flex; align-items:center; justify-content:center; cursor:pointer; font-size:16px; color:var(--muted); transition:all 0.15s; }
.policy-close-x:hover { background:rgba(242,221,216,0.14); color:var(--blush); }
.policy-body { padding:24px 28px; overflow-y:auto; flex:1; }
.policy-body h3 { font-family:'Bebas Neue',sans-serif; font-size:16px; color:var(--accent); letter-spacing:1px; margin:18px 0 6px; }
.policy-body p, .policy-body li { font-size:12px; font-weight:600; color:rgba(242,221,216,0.7); line-height:1.8; }
.policy-body ul { padding-left:18px; margin:6px 0; }
.policy-body strong { color:var(--blush); font-weight:800; }
.policy-org { font-size:11px; color:var(--muted); font-weight:600; margin-top:20px; padding-top:14px; border-top:1px solid rgba(242,221,216,0.08); line-height:1.7; }

/* ── REPORTS TAB ── */
.report-card { background:rgba(242,221,216,0.04); border:1px solid rgba(242,221,216,0.1); border-radius:14px; padding:16px 18px; display:flex; align-items:center; gap:14px; transition:background 0.15s; }
.report-card:hover { background:rgba(242,221,216,0.07); }
.report-icon { font-size:26px; flex-shrink:0; }
.report-info { flex:1; }
.report-name { font-size:13px; font-weight:800; color:var(--blush); margin-bottom:2px; }
.report-meta { font-size:11px; color:var(--muted); font-weight:600; }
.report-status { display:flex; align-items:center; gap:6px; font-size:10px; font-weight:800; letter-spacing:1px; padding:4px 10px; border-radius:20px; white-space:nowrap; }
.status-generated { background:rgba(94,234,212,0.1); color:var(--success); border:1px solid rgba(94,234,212,0.25); }
.status-pending { background:rgba(245,200,66,0.1); color:var(--gold); border:1px solid rgba(245,200,66,0.25); }
.status-signed { background:rgba(255,107,138,0.1); color:var(--accent); border:1px solid rgba(255,107,138,0.25); }
.report-actions { display:flex; gap:8px; flex-shrink:0; }
.rep-btn { padding:7px 13px; border-radius:9px; border:1px solid rgba(242,221,216,0.15); background:rgba(242,221,216,0.06); color:var(--blush2); font-family:'Nunito',sans-serif; font-size:11px; font-weight:800; cursor:pointer; transition:all 0.15s; white-space:nowrap; }
.rep-btn:hover { background:rgba(242,221,216,0.12); color:var(--blush); }
.rep-btn.primary { background:rgba(242,221,216,0.15); color:var(--blush); border-color:rgba(242,221,216,0.3); }
.generate-section { background:rgba(255,107,138,0.05); border:1px solid rgba(255,107,138,0.15); border-radius:16px; padding:20px; }
.generate-section .panel-title { color:var(--accent); margin-bottom:14px; }
.gen-row { display:flex; align-items:center; gap:12px; flex-wrap:wrap; margin-bottom:10px; }
.gen-label { font-size:12px; font-weight:800; color:var(--blush2); min-width:110px; }
.gen-select { padding:8px 12px; border-radius:9px; border:1px solid rgba(242,221,216,0.15); background:rgba(242,221,216,0.06); color:var(--blush); font-family:'Nunito',sans-serif; font-size:12px; font-weight:700; outline:none; }
.gen-select option { background:#231210; }
.email-input { padding:8px 12px; border-radius:9px; border:1px solid rgba(242,221,216,0.15); background:rgba(242,221,216,0.06); color:var(--blush); font-family:'Nunito',sans-serif; font-size:12px; font-weight:700; outline:none; min-width:220px; }
.email-input::placeholder { color:rgba(242,221,216,0.25); }
.gen-btn { padding:10px 20px; border-radius:10px; border:none; background:var(--accent); color:#1A0F0D; font-family:'Bebas Neue',sans-serif; font-size:18px; letter-spacing:2px; cursor:pointer; transition:all 0.15s; }
.gen-btn:hover { background:var(--blush); }
.gen-btn:disabled { opacity:0.4; cursor:not-allowed; }

.empty-state { display:flex; flex-direction:column; align-items:center; justify-content:center; height:100px; color:var(--muted); font-size:12px; font-weight:700; gap:8px; }
.empty-emoji { font-size:24px; }

::-webkit-scrollbar { width:3px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:rgba(242,221,216,0.15); border-radius:3px; }
/* ── SELECT DROPDOWNS ── */
select.form-input { appearance:none; -webkit-appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='rgba(242,221,216,0.4)' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:36px; cursor:pointer; }
select.form-input option { background:#231210; color:var(--blush); }
