/* Admin + visitor gate — load after css/main.css */
:root{
  --lapis:#1B3D6E;--lapisD:#0F2444;--lapisL:#2E5FA3;
  --gold:#C9921A;--goldL:#E8B84B;
  --sand:#F5E6C3;--papyrus:#FDF6E8;--cream:#FFFDF7;
  --txt:#0D1F35;--txts:#5A6E85;
  --grn:#1A6B4A;--grnL:#ECFDF5;
  --red:#C0392B;--redL:#FEF2F2;
  --amber:#92400E;--amberL:#FFFBEB;
  --border:rgba(201,146,26,0.25);
  --shadow:0 4px 24px rgba(27,61,110,0.1);
  --font:'Cairo',sans-serif;
}
html,body{min-height:100vh;background:var(--papyrus);font-family:var(--font);direction:rtl;color:var(--txt)}
html.admin-html,html.admin-html body{height:100%;margin:0}
/* Column flex so #admin-root flex:1 fills the viewport (avoids zero-height main when nested flex collapses). */
html.admin-html body{
  min-height:100vh;min-height:100dvh;
  display:flex;flex-direction:column;
}

/* LAYOUT — sidebar fixed; #main = column flex (header + flex‑1 scroll shell). More reliable than grid % heights across browsers. */
html.admin-html #app{
  display:flex;
  flex:1;
  min-height:0;
  min-width:0;
  width:100%;
  position:relative;
}
#sidebar{width:260px;background:var(--lapisD);position:fixed;top:0;right:0;bottom:0;display:flex;flex-direction:column;z-index:100;box-shadow:-4px 0 24px rgba(0,0,0,0.3)}
/* Mobile drawer backdrop — fixed + display:none so it never steals flex space on desktop */
#sidebar-backdrop{position:fixed;inset:0;z-index:115;display:none;pointer-events:none;background:rgba(0,0,0,0.45)}
#sidebar-backdrop.show{display:block;pointer-events:auto}
html.admin-html #main{
  margin-right:260px;
  min-width:0;
  flex:1;
  min-height:0;
  display:flex;
  flex-direction:column;
  align-self:stretch;
  height:auto;
  min-height:100dvh;
  min-height:100svh;
  overflow:hidden;
  box-sizing:border-box;
}
html.admin-html .main-top{
  flex-shrink:0;
}
/* Single scroll container — fills remaining height below topbar */
html.admin-html .main-page-shell{
  flex:1;
  min-height:0;
  overflow-x:hidden;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  position:relative;
  background:var(--papyrus);
}
.admin-demo-banner,.admin-demo-hint,.admin-demo-login-hint{
  font-size:12px;line-height:1.55;margin:0 0 14px;padding:12px 14px;border-radius:14px;
  background:var(--amberL);border:1.5px solid rgba(201,146,26,0.45);color:var(--amber);
}
.admin-demo-banner code,.admin-demo-hint code,.admin-demo-login-hint code{background:rgba(255,255,255,0.5);padding:2px 6px;border-radius:6px}
.admin-demo-hint a{color:var(--lapis);font-weight:800}

/* SIDEBAR */
.sidebar-logo{padding:24px 20px 20px;border-bottom:1px solid rgba(201,146,26,0.2)}
.sidebar-admin{padding:16px 20px;border-bottom:1px solid rgba(255,255,255,0.07);display:flex;align-items:center;gap:12px}
.admin-av{width:42px;height:42px;background:var(--gold);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.admin-info h3{color:white;font-size:13px;font-weight:800}
.admin-info p{color:rgba(255,255,255,0.45);font-size:11px}
.nav-section{padding:16px 12px 8px}
.nav-label{color:rgba(255,255,255,0.3);font-size:10px;font-weight:700;letter-spacing:2px;padding:0 8px;margin-bottom:6px}
.nav-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:14px;cursor:pointer;transition:all .2s;color:rgba(255,255,255,0.55);font-size:13px;font-weight:700;margin-bottom:4px;border:1px solid transparent;text-decoration:none}
.nav-item:hover{background:rgba(255,255,255,0.08);color:white}
.nav-item.active{background:rgba(201,146,26,0.2);color:var(--goldL);border-color:rgba(201,146,26,0.35)}
.nav-item .icon{font-size:18px;flex-shrink:0}
.nav-badge{background:var(--red);color:white;font-size:10px;font-weight:800;padding:2px 7px;border-radius:20px;margin-right:auto}
.sidebar-bottom{margin-top:auto;padding:16px;border-top:1px solid rgba(255,255,255,0.07)}
.logout-btn{display:flex;align-items:center;gap:10px;color:rgba(255,255,255,0.4);font-size:13px;cursor:pointer;padding:10px 14px;border-radius:12px;transition:all .2s}
.logout-btn:hover{background:rgba(192,57,43,0.2);color:#F87171}

/* TOPBAR */
#topbar{background:var(--cream);border-bottom:1.5px solid var(--border);padding:16px 28px;display:flex;align-items:center;justify-content:space-between;gap:12px;position:sticky;top:0;z-index:50;box-shadow:var(--shadow);flex-wrap:wrap;flex-shrink:0}
#topbar .page-title{flex:1;min-width:0}
.page-title h2{font-size:20px;font-weight:900;color:var(--lapis)}
.page-title p{font-size:12px;color:var(--txts);margin-top:2px}
.topbar-actions{display:flex;gap:10px;align-items:center}
.notif-btn{width:40px;height:40px;background:var(--papyrus);border:1.5px solid var(--border);border-radius:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;position:relative;font-size:18px}
.notif-dot{position:absolute;top:8px;right:8px;width:7px;height:7px;background:var(--red);border-radius:50%;border:1.5px solid var(--cream)}
.refresh-btn{padding:9px 18px;background:var(--lapis);color:white;border:none;border-radius:12px;cursor:pointer;font-family:var(--font);font-weight:800;font-size:13px;display:flex;align-items:center;gap:6px;transition:all .2s}
.refresh-btn:hover{background:var(--lapisL)}
.admin-api-error{
  margin:0 24px 12px;padding:12px 16px;border-radius:14px;font-size:13px;line-height:1.55;text-align:right;
  color:#991b1b;background:rgba(254,242,242,0.95);border:1px solid rgba(239,68,68,0.35);
  max-width:calc(100% - 48px);box-sizing:border-box;
  flex-shrink:0;
}

/* PAGE — shell scrolls; panels are block (no nested flex collapse). No opacity animation on active (could stick invisible). */
html.admin-html .main-page-shell .page{display:none;padding:28px;box-sizing:border-box}
html.admin-html .main-page-shell .page.active{
  display:block !important;
  overflow:visible;
  opacity:1 !important;
  visibility:visible !important;
  animation:none;
  min-height:auto;
}

/* STATS GRID */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}
.stat-card{background:var(--cream);border-radius:20px;padding:20px;border:1.5px solid var(--border);box-shadow:var(--shadow);position:relative;overflow:hidden}
.stat-card::before{content:'';position:absolute;top:-20px;left:-20px;width:80px;height:80px;border-radius:50%;opacity:.08}
.stat-card.blue::before{background:var(--lapis)}
.stat-card.gold::before{background:var(--gold)}
.stat-card.green::before{background:var(--grn)}
.stat-card.red::before{background:var(--red)}
.stat-icon{font-size:28px;margin-bottom:12px}
.stat-val{font-size:32px;font-weight:900;color:var(--lapis);margin-bottom:4px}
.stat-label{font-size:12px;color:var(--txts);font-weight:600}
.stat-change{font-size:11px;font-weight:800;margin-top:6px}
.stat-change.up{color:var(--grn)}
.stat-change.down{color:var(--red)}

/* SECTION */
.section{background:var(--cream);border-radius:20px;border:1.5px solid var(--border);box-shadow:var(--shadow);margin-bottom:24px;overflow:hidden}
.section-header{padding:18px 22px;border-bottom:1.5px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.section-title{font-size:16px;font-weight:900;color:var(--lapis);display:flex;align-items:center;gap:8px}
.section-title::before{content:'';width:4px;height:18px;background:var(--gold);border-radius:4px;display:block;flex-shrink:0}
.section-body{padding:0}

/* TABLE */
table{width:100%;border-collapse:collapse}
th{padding:12px 20px;font-size:11px;font-weight:800;color:var(--txts);letter-spacing:1px;background:var(--papyrus);text-align:right;border-bottom:1px solid var(--border)}
td{padding:14px 20px;font-size:13px;border-bottom:1px solid rgba(201,146,26,0.1);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(27,61,110,0.02)}
.tutor-row{display:flex;align-items:center;gap:12px}
.tutor-av{width:40px;height:40px;background:#EEF2FF;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;font-family:'Segoe UI Emoji','Apple Color Emoji','Noto Color Emoji','Twemoji Mozilla',sans-serif;line-height:1}
.tutor-name{font-weight:800;font-size:14px;color:var(--txt)}
.tutor-meta{font-size:11px;color:var(--txts);margin-top:2px}

/* BADGES */
.badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:800;white-space:nowrap}
.badge-pending{background:var(--amberL);color:var(--amber)}
.badge-approved{background:var(--grnL);color:var(--grn)}
.badge-rejected{background:var(--redL);color:var(--red)}
.badge-blue{background:#EEF2FF;color:var(--lapis)}

/* ACTION BUTTONS */
.action-btns{display:flex;gap:8px}
.btn-approve{padding:7px 16px;background:var(--grnL);color:var(--grn);border:1.5px solid rgba(26,107,74,0.3);border-radius:10px;cursor:pointer;font-family:var(--font);font-weight:800;font-size:12px;transition:all .2s}
.btn-approve:hover{background:var(--grn);color:white}
.btn-reject{padding:7px 16px;background:var(--redL);color:var(--red);border:1.5px solid rgba(192,57,43,0.3);border-radius:10px;cursor:pointer;font-family:var(--font);font-weight:800;font-size:12px;transition:all .2s}
.btn-reject:hover{background:var(--red);color:white}
.btn-view{padding:7px 16px;background:var(--papyrus);color:var(--lapis);border:1.5px solid var(--border);border-radius:10px;cursor:pointer;font-family:var(--font);font-weight:800;font-size:12px;transition:all .2s}
.btn-view:hover{background:var(--lapis);color:white}

/* CHARTS */
.chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:28px}
.chart-card{background:var(--cream);border-radius:20px;border:1.5px solid var(--border);box-shadow:var(--shadow);padding:22px}
.chart-title{font-size:15px;font-weight:900;color:var(--lapis);margin-bottom:18px;display:flex;align-items:center;gap:8px}
.chart-title::before{content:'';width:4px;height:16px;background:var(--gold);border-radius:4px;display:block}
.bar-chart{display:flex;align-items:flex-end;gap:8px;height:120px}
.bar-wrap{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}
.bar{width:100%;background:linear-gradient(180deg,var(--lapisL),var(--lapisD));border-radius:8px 8px 0 0;transition:height .6s ease;position:relative}
.bar:hover{background:linear-gradient(180deg,var(--goldL),var(--gold))}
.bar-label{font-size:10px;color:var(--txts);font-weight:700}
.bar-val{font-size:10px;color:var(--lapis);font-weight:800}
.donut{width:140px;height:140px;margin:0 auto 16px;position:relative}
.donut svg{transform:rotate(-90deg)}
.donut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.donut-val{font-size:22px;font-weight:900;color:var(--lapis)}
.donut-lbl{font-size:10px;color:var(--txts)}
.legend{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--txts);font-weight:700}
.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}

/* SEARCH & FILTER */
.filter-bar{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;gap:12px;align-items:center}
.search-input{flex:1;background:var(--papyrus);border:1.5px solid var(--border);border-radius:12px;padding:10px 16px;font-family:var(--font);font-size:13px;color:var(--txt);outline:none;direction:rtl}
.search-input:focus{border-color:var(--lapis)}
.filter-select{background:var(--papyrus);border:1.5px solid var(--border);border-radius:12px;padding:10px 14px;font-family:var(--font);font-size:13px;color:var(--txt);outline:none;cursor:pointer}

/* TOAST */
#toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(16px);background:rgba(15,36,68,0.95);color:white;padding:12px 24px;border-radius:24px;font-size:13px;font-weight:700;opacity:0;transition:all .3s;pointer-events:none;z-index:999;border:1px solid rgba(201,146,26,0.4);white-space:nowrap}

/* LOADING */
.loading{display:flex;align-items:center;justify-content:center;padding:48px;gap:12px;color:var(--txts);font-size:14px}
.spinner{width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--lapis);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* EMPTY */
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;color:var(--txts)}
.empty-icon{font-size:48px;margin-bottom:12px;opacity:.5}
.empty-txt{font-size:15px;font-weight:700;margin-bottom:6px}
.empty-sub{font-size:12px;opacity:.7}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:200;display:none;align-items:center;justify-content:center;padding:20px}
.modal-overlay.show{display:flex}
.modal{background:var(--cream);border-radius:24px;padding:28px;max-width:500px;width:100%;border:1.5px solid var(--border);box-shadow:0 24px 80px rgba(0,0,0,0.3);animation:modalIn .3s ease}
@keyframes modalIn{from{opacity:0;transform:scale(0.95)}to{opacity:1;transform:none}}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.modal-title{font-size:18px;font-weight:900;color:var(--lapis)}
.modal-close{width:36px;height:36px;background:var(--papyrus);border:1.5px solid var(--border);border-radius:12px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center}
.modal-close:hover{background:var(--redL);color:var(--red);border-color:rgba(192,57,43,0.3)}
.modal-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px dashed var(--border);font-size:13px}
.modal-row:last-of-type{border-bottom:none}
.modal-key{color:var(--txts);font-weight:700}
.modal-val{color:var(--txt);font-weight:800}
.modal-actions{display:flex;gap:10px;margin-top:20px}
.btn-primary{flex:1;padding:13px;background:var(--lapisD);color:white;border:2px solid rgba(201,146,26,0.4);border-radius:14px;cursor:pointer;font-family:var(--font);font-weight:900;font-size:14px}
.btn-danger{flex:1;padding:13px;background:var(--red);color:white;border:none;border-radius:14px;cursor:pointer;font-family:var(--font);font-weight:900;font-size:14px}

/* REVENUE CARDS */
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;padding:20px}
.rev-card{background:var(--papyrus);border-radius:16px;padding:18px;border:1px solid var(--border);text-align:center}
.rev-val{font-size:24px;font-weight:900;color:var(--lapis);margin-bottom:4px}
.rev-label{font-size:11px;color:var(--txts);font-weight:700}

/* NOTIFICATION */
.notif-item{padding:14px 20px;border-bottom:1px solid rgba(201,146,26,0.1);display:flex;gap:14px;align-items:flex-start}
.notif-item:last-child{border-bottom:none}
.notif-item.unread{background:rgba(27,61,110,0.03)}
.notif-icon{width:40px;height:40px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.notif-body h4{font-size:13px;font-weight:800;color:var(--txt);margin-bottom:3px}
.notif-body p{font-size:12px;color:var(--txts)}
.notif-time{font-size:11px;color:var(--txts);margin-right:auto;flex-shrink:0;margin-top:2px}

/* RESPONSIVE */
@media(max-width:900px){
  #sidebar{width:220px}
  html.admin-html #main{margin-right:220px}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .chart-grid{grid-template-columns:1fr}
}
@media(max-width:600px){
  #sidebar{transform:translateX(100%);transition:transform .3s;z-index:120}
  #sidebar.open{transform:none}
  html.admin-html #main{margin-right:0}
  .stats-grid{grid-template-columns:1fr 1fr}
}
.admin-menu-toggle{
  display:none;align-items:center;justify-content:center;width:44px;height:44px;
  background:var(--papyrus);border:1.5px solid var(--border);border-radius:14px;
  cursor:pointer;font-size:20px;color:var(--lapis);flex-shrink:0;
}
@media(max-width:600px){.admin-menu-toggle{display:flex}}
.topbar-home{
  display:inline-flex;align-items:center;gap:6px;padding:9px 16px;background:var(--papyrus);
  border:1.5px solid var(--border);border-radius:12px;color:var(--lapis);font-size:13px;font-weight:800;
  text-decoration:none;transition:all .2s;flex-shrink:0;
}
.topbar-home:hover{background:var(--lapis);color:white;border-color:var(--lapis)}
.sidebar-site-link{
  display:flex;align-items:center;gap:10px;margin:0 12px 12px;padding:11px 14px;border-radius:14px;
  background:rgba(255,255,255,0.06);border:1px solid rgba(201,146,26,0.25);color:var(--goldL);
  font-size:13px;font-weight:800;text-decoration:none;transition:all .2s;
}
.sidebar-site-link:hover{background:rgba(201,146,26,0.15);color:white}
.admin-gate-screen{position:fixed;inset:0;z-index:1000;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--papyrus);color:var(--lapis);text-align:center;padding:24px;overflow-y:auto}
.admin-gate-screen h1{font-size:22px;font-weight:900;margin-bottom:12px}
.admin-gate-screen .admin-gate-msg,.admin-gate-screen p{font-size:14px;color:var(--txts);max-width:420px;line-height:1.6;margin-bottom:12px}
.admin-gate-screen a{color:var(--lapis);font-weight:800}

/* Inline admin login (email / password) */
.admin-gate-login .admin-login-card{width:100%;max-width:400px;background:var(--cream);border:1.5px solid var(--border);border-radius:20px;padding:28px 24px 22px;box-shadow:var(--shadow);text-align:right}
.admin-login-kicker{font-size:12px;font-weight:800;color:var(--gold);margin:0 0 8px;letter-spacing:0.02em}
.admin-gate-login h1{font-size:20px;margin:0 0 10px;color:var(--lapisD)}
.admin-login-lead{font-size:13px;color:var(--txts);margin:0 0 20px;line-height:1.55;max-width:none}
.admin-login-field{margin-bottom:14px}
.admin-login-field label{display:block;font-size:12px;font-weight:800;color:var(--txts);margin-bottom:6px}
.admin-login-field input{width:100%;box-sizing:border-box;padding:11px 14px;border-radius:12px;border:1.5px solid var(--border);background:var(--papyrus);font-family:var(--font);font-size:14px;color:var(--txt);outline:none}
.admin-login-field input:focus{border-color:var(--lapis)}
.admin-login-show-pass{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--txts);cursor:pointer;margin-bottom:18px}
.admin-login-show-pass input{width:auto}
.admin-login-error{display:block;padding:10px 12px;border-radius:12px;background:var(--redL);color:var(--red);font-size:13px;font-weight:700;margin-bottom:14px;text-align:right}
.admin-login-submit{width:100%;padding:13px;border:none;border-radius:14px;background:var(--lapisD);color:#fff;font-family:var(--font);font-size:15px;font-weight:900;cursor:pointer;transition:background .2s}
.admin-login-submit:hover{background:var(--lapis)}
.admin-login-submit:disabled{opacity:0.65;cursor:not-allowed}
.admin-login-links{margin:18px 0 0;font-size:13px;color:var(--txts)}
.admin-login-links a{font-weight:800}
.admin-login-subdomain-hint{
  font-size:12px;line-height:1.55;color:var(--amber);background:var(--amberL);
  border:1px solid rgba(201,146,26,0.45);border-radius:12px;padding:10px 12px;margin:0 0 16px;
}
.admin-login-subdomain-hint a{font-weight:800;color:var(--lapis)}
#admin-root{display:none}
#admin-root.admin-root--open{
  display:flex !important;
  flex-direction:column;
  flex:1;
  min-height:100vh;
  min-height:100dvh;
  box-sizing:border-box;
}

/* Non-admin: fancy visitor UX */
#admin-gate-visitor.visitor-ux{--va:#C9921A;--va2:#E8B84B;--vb:rgba(27,61,110,0.08);--vc:#1B3D6E;padding:0;align-items:stretch}
#admin-gate-visitor[data-visitor-theme="emerald"]{--va:#059669;--va2:#34d399;--vb:rgba(5,150,105,0.1);--vc:#064e3b}
#admin-gate-visitor[data-visitor-theme="dusk"]{--va:#7c3aed;--va2:#a78bfa;--vb:rgba(124,58,237,0.1);--vc:#4c1d95}
#admin-gate-visitor[data-visitor-theme="rose"]{--va:#e11d48;--va2:#fb7185;--vb:rgba(225,29,72,0.08);--vc:#9f1239}
.visitor-ux-bg{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(ellipse 80% 60% at 20% 20%, rgba(232,184,75,0.35), transparent 50%),
    radial-gradient(ellipse 70% 50% at 80% 80%, rgba(27,61,110,0.2), transparent 55%),
    linear-gradient(165deg, #fdf8ee 0%, #eef2ff 45%, #faf5eb 100%);
  transition:opacity 1.2s ease, filter 1.2s ease;
}
#admin-gate-visitor[data-visitor-theme="emerald"] .visitor-ux-bg{
  background:
    radial-gradient(ellipse 80% 60% at 15% 25%, rgba(52,211,153,0.35), transparent 50%),
    radial-gradient(ellipse 70% 50% at 85% 75%, rgba(5,150,105,0.2), transparent 55%),
    linear-gradient(165deg, #ecfdf5 0%, #f0fdf4 50%, #e8fff4 100%);
}
#admin-gate-visitor[data-visitor-theme="dusk"] .visitor-ux-bg{
  background:
    radial-gradient(ellipse 80% 60% at 20% 20%, rgba(167,139,250,0.4), transparent 50%),
    radial-gradient(ellipse 70% 50% at 80% 80%, rgba(124,58,237,0.25), transparent 55%),
    linear-gradient(165deg, #f5f3ff 0%, #ede9fe 50%, #faf5ff 100%);
}
#admin-gate-visitor[data-visitor-theme="rose"] .visitor-ux-bg{
  background:
    radial-gradient(ellipse 80% 60% at 25% 15%, rgba(251,113,133,0.35), transparent 50%),
    radial-gradient(ellipse 70% 50% at 75% 85%, rgba(225,29,72,0.15), transparent 55%),
    linear-gradient(165deg, #fff1f2 0%, #ffe4e6 50%, #fdf2f8 100%);
}
.visitor-ux-bg::after{
  content:'';position:absolute;inset:0;opacity:0.04;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:overlay;
}
@keyframes visitor-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes visitor-shimmer{0%{background-position:0% 50%}100%{background-position:200% 50%}}
.admin-gate-visitor-inner{
  position:relative;z-index:1;max-width:560px;width:100%;margin:0 auto;padding:28px 20px 32px;
}
.visitor-sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}
.visitor-hero-icon{
  font-size:44px;margin-bottom:6px;display:inline-block;animation:visitor-float 4s ease-in-out infinite;
  filter:drop-shadow(0 6px 14px rgba(27,61,110,0.2));
}
.visitor-toolbar{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;align-items:center;margin-bottom:18px}
#visitor-theme-shuffle{
  padding:10px 18px;border:none;border-radius:999px;font-family:var(--font);font-weight:800;font-size:13px;cursor:pointer;
  background:linear-gradient(135deg,var(--va),var(--va2));color:#fff;box-shadow:0 6px 20px rgba(201,146,26,0.35);
  transition:transform .2s,box-shadow .2s;
}
#visitor-theme-shuffle:hover{transform:scale(1.03);box-shadow:0 8px 26px rgba(27,61,110,0.2)}
#admin-gate-visitor[data-visitor-theme="emerald"] #visitor-theme-shuffle{box-shadow:0 6px 20px rgba(5,150,105,0.35)}
.admin-gate-promo{display:grid;grid-template-columns:1fr;gap:10px;margin-bottom:20px;text-align:right}
@media(min-width:480px){.admin-gate-promo{grid-template-columns:1fr 1fr}}
.admin-gate-promo a{
  display:flex;align-items:center;gap:10px;padding:14px 16px;border-radius:18px;
  background:rgba(255,255,255,0.72);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,0.85);text-decoration:none;color:var(--lapis);font-weight:800;font-size:14px;
  box-shadow:0 4px 20px rgba(27,61,110,0.08);transition:transform .2s,box-shadow .2s,border-color .2s;
}
.admin-gate-promo a:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(27,61,110,0.12);border-color:var(--va2)}
.admin-gate-promo a span{font-size:22px}

.visitor-tabs-wrap{
  border-radius:24px;padding:4px;margin-bottom:8px;
  background:linear-gradient(135deg,rgba(255,255,255,0.95),rgba(255,253,247,0.88));
  box-shadow:0 8px 40px rgba(27,61,110,0.1),0 0 0 1px rgba(201,146,26,0.15);
  backdrop-filter:blur(12px);
}
.visitor-tabs{
  display:flex;gap:6px;padding:10px 10px 0;flex-wrap:wrap;justify-content:center;
}
.visitor-tab{
  flex:1;min-width:100px;padding:12px 10px;border:none;border-radius:16px 16px 0 0;font-family:var(--font);
  font-weight:800;font-size:12px;cursor:pointer;background:transparent;color:var(--txts);
  transition:background .25s,color .25s,transform .2s;
}
.visitor-tab:hover{background:var(--vb);color:var(--vc)}
.visitor-tab.is-active{
  background:linear-gradient(180deg,var(--vb),rgba(255,255,255,0.5));color:var(--vc);
  box-shadow:inset 0 -2px 0 var(--va);
}
.visitor-panels{position:relative;min-height:200px;padding:8px 12px 16px}
.visitor-panel{display:none;animation:visitor-panel-in .45s ease}
.visitor-panel.is-active{display:block}
@keyframes visitor-panel-in{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

#visitor-mini-game{border:none;border-radius:18px;padding:16px;text-align:center;background:linear-gradient(165deg,rgba(255,255,255,0.65),var(--vb))}
#visitor-mini-game h2{font-size:16px;font-weight:900;color:var(--vc);margin-bottom:8px}
#visitor-game-area{
  position:relative;height:188px;background:rgba(255,255,255,0.75);border-radius:18px;margin:12px 0;
  border:1px solid rgba(201,146,26,0.2);overflow:hidden;direction:ltr;
  box-shadow:inset 0 2px 12px rgba(27,61,110,0.06);
}
#visitor-game-target{
  display:none;position:absolute;left:0;top:0;width:46px;height:46px;align-items:center;justify-content:center;
  cursor:pointer;font-size:26px;border-radius:50%;
  background:linear-gradient(145deg,var(--va2),var(--va));
  box-shadow:0 6px 18px rgba(201,146,26,0.45);user-select:none;transition:transform .1s;
}
#visitor-game-target:active{transform:scale(0.92)}
.visitor-game-meta{display:flex;justify-content:center;gap:28px;font-weight:800;font-size:14px;color:var(--vc);margin-bottom:6px}
#visitor-game-start{
  margin-top:8px;padding:12px 28px;border:none;border-radius:999px;
  background:linear-gradient(135deg,var(--vc),#2E5FA3);color:white;font-family:var(--font);font-weight:900;font-size:14px;cursor:pointer;
  box-shadow:0 6px 20px rgba(27,61,110,0.25);transition:transform .15s,filter .15s;
}
#visitor-game-start:hover:not(:disabled){transform:translateY(-1px);filter:brightness(1.05)}
#visitor-game-start:disabled{opacity:.55;cursor:not-allowed}
#visitor-game-hint{font-size:13px;color:var(--txts);margin-top:10px;min-height:2.6em;line-height:1.5}

.visitor-activity-card{
  border:none;border-radius:18px;padding:16px;text-align:center;
  background:linear-gradient(165deg,rgba(255,255,255,0.65),var(--vb));
}
.visitor-activity-card h2{font-size:16px;font-weight:900;color:var(--vc);margin-bottom:12px}
.visitor-fact-text{
  font-size:14px;color:var(--txt);line-height:1.8;text-align:right;min-height:4.8em;margin-bottom:14px;padding:16px 18px;
  background:rgba(255,255,255,0.85);border-radius:16px;border:1px solid rgba(255,255,255,0.9);
  box-shadow:0 4px 16px rgba(27,61,110,0.06);transition:opacity .35s ease,transform .35s ease;
}
.visitor-fact-text.is-updating{opacity:0;transform:scale(0.98)}
#visitor-fact-next,.visitor-quiz-btn#visitor-quiz-next{
  padding:11px 22px;border:none;border-radius:999px;
  background:linear-gradient(135deg,var(--va),var(--va2));color:#fff;font-family:var(--font);font-weight:800;font-size:13px;cursor:pointer;
  box-shadow:0 4px 16px rgba(201,146,26,0.35);transition:transform .15s;
}
#visitor-fact-next:hover,.visitor-quiz-btn#visitor-quiz-next:hover{transform:translateY(-2px)}
.visitor-quiz-btn{
  padding:10px 20px;border:none;border-radius:14px;background:var(--grn);color:white;font-family:var(--font);font-weight:800;font-size:13px;cursor:pointer;
}
.visitor-quiz-btn:hover{filter:brightness(1.05)}
.visitor-quiz-q{font-size:15px;font-weight:800;color:var(--vc);text-align:right;margin-bottom:12px;line-height:1.55}
.visitor-quiz-choices{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}
.visitor-quiz-btn--choice{
  width:100%;text-align:right;background:rgba(255,255,255,0.9);color:var(--lapis);border:1.5px solid rgba(201,146,26,0.2);
  border-radius:14px;padding:12px 14px;font-family:var(--font);font-weight:700;
  transition:background .2s,border-color .2s,transform .15s;
}
.visitor-quiz-btn--choice:hover{border-color:var(--va);background:#fff;transform:translateX(-2px)}
.visitor-quiz-btn--choice.is-wrong{background:var(--redL);border-color:rgba(192,57,43,0.35)}
.visitor-quiz-btn--choice.is-correct{background:var(--grnL);border-color:rgba(26,107,74,0.45)}
.visitor-quiz-feedback{font-size:14px;font-weight:700;min-height:1.8em;margin:8px 0;text-align:center}
.visitor-quiz-feedback.ok{color:var(--grn)}
.visitor-quiz-feedback.bad{color:var(--red)}
.visitor-back-home{margin-top:22px}
.visitor-back-home a{
  display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:999px;
  background:rgba(255,255,255,0.75);border:1px solid rgba(201,146,26,0.25);text-decoration:none;color:var(--vc);font-weight:800;
  transition:background .2s,box-shadow .2s;
}
.visitor-back-home a:hover{background:#fff;box-shadow:0 6px 20px rgba(27,61,110,0.1)}

/* Iraq map (visitor tab) */
.iraq-map-modes{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:12px}
.iraq-mode-btn{
  padding:10px 16px;border-radius:999px;border:1.5px solid rgba(201,146,26,0.35);background:rgba(255,255,255,0.6);
  font-family:var(--font);font-weight:800;font-size:12px;cursor:pointer;color:var(--vc);transition:background .2s,box-shadow .2s;
}
.iraq-mode-btn:hover{background:rgba(255,255,255,0.95)}
.iraq-mode-btn.is-active{
  background:linear-gradient(135deg,var(--va),var(--va2));color:#fff;border-color:transparent;
  box-shadow:0 4px 14px rgba(201,146,26,0.35);
}
.iraq-map-instruction{font-size:13px;color:var(--txts);line-height:1.65;text-align:right;margin-bottom:8px;min-height:3.2em}
.iraq-map-prompt-name{color:var(--vc);font-weight:900}
.iraq-map-hover-hint{font-size:12px;color:rgba(27,61,110,0.78);text-align:right;margin:0 0 8px;min-height:1.4em;font-weight:700}
.iraq-map-mount{
  max-width:100%;border-radius:20px;overflow:hidden;
  background:linear-gradient(165deg,#cfe8f4 0%,#e8f4fc 45%,#f2f7fb 100%);
  border:1px solid rgba(27,61,110,0.18);
  box-shadow:0 8px 32px rgba(27,61,110,0.12),inset 0 1px 0 rgba(255,255,255,0.55);
}
.iraq-map-mount--reduce-motion .iraq-gov--target .iraq-gov-path{animation:none !important}
.iraq-map-svg{width:100%;max-height:min(54vh,400px);display:block;font-family:var(--font),sans-serif;filter:drop-shadow(0 2px 8px rgba(27,61,110,0.07))}
.iraq-country-outline{filter:drop-shadow(0 0.5px 0 rgba(255,255,255,0.45))}
.iraq-gov{cursor:pointer;outline:none}
.iraq-gov:focus-visible .iraq-gov-path{stroke:var(--lapis);stroke-width:0.52}
.iraq-gov-path{
  stroke:rgba(27,61,110,0.36);stroke-width:0.2;vector-effect:non-scaling-stroke;
  transition:fill .18s ease,stroke .18s ease,filter .18s ease,opacity .18s ease;
}
.iraq-gov[data-gov="duhok"] .iraq-gov-path{fill:rgba(130,170,200,0.45)}
.iraq-gov[data-gov="nineveh"] .iraq-gov-path{fill:rgba(120,160,190,0.42)}
.iraq-gov[data-gov="erbil"] .iraq-gov-path{fill:rgba(140,175,205,0.44)}
.iraq-gov[data-gov="sulaymaniyah"] .iraq-gov-path{fill:rgba(100,150,185,0.4)}
.iraq-gov[data-gov="kirkuk"] .iraq-gov-path{fill:rgba(155,130,175,0.4)}
.iraq-gov[data-gov="salahadin"] .iraq-gov-path{fill:rgba(175,165,130,0.42)}
.iraq-gov[data-gov="diyala"] .iraq-gov-path{fill:rgba(165,185,140,0.42)}
.iraq-gov[data-gov="baghdad"] .iraq-gov-path{fill:rgba(200,160,120,0.48)}
.iraq-gov[data-gov="anbar"] .iraq-gov-path{fill:rgba(195,185,160,0.38)}
.iraq-gov[data-gov="karbala"] .iraq-gov-path{fill:rgba(190,150,145,0.42)}
.iraq-gov[data-gov="babil"] .iraq-gov-path{fill:rgba(175,195,155,0.42)}
.iraq-gov[data-gov="najaf"] .iraq-gov-path{fill:rgba(170,175,200,0.42)}
.iraq-gov[data-gov="qadisiyyah"] .iraq-gov-path{fill:rgba(185,170,195,0.4)}
.iraq-gov[data-gov="muthanna"] .iraq-gov-path{fill:rgba(200,175,155,0.4)}
.iraq-gov[data-gov="dhiqar"] .iraq-gov-path{fill:rgba(155,190,175,0.42)}
.iraq-gov[data-gov="maysan"] .iraq-gov-path{fill:rgba(145,195,185,0.42)}
.iraq-gov[data-gov="wasit"] .iraq-gov-path{fill:rgba(175,190,165,0.42)}
.iraq-gov[data-gov="basra"] .iraq-gov-path{fill:rgba(130,175,195,0.44)}
.iraq-gov:hover .iraq-gov-path{filter:brightness(1.07);stroke:rgba(201,146,26,0.88);stroke-width:0.36}
.iraq-gov--target .iraq-gov-path{
  filter:brightness(1.08);stroke:var(--gold);stroke-width:0.42;
  animation:iraq-pulse 1.12s ease-in-out infinite;
}
.iraq-gov--mine .iraq-gov-path{fill:rgba(26,107,74,0.52) !important;stroke:#0d4d32 !important;stroke-width:0.4 !important;filter:none}
.iraq-gov--wrong .iraq-gov-path{fill:rgba(192,57,43,0.5) !important;stroke:#8b2418 !important}
@keyframes iraq-pulse{0%,100%{opacity:1}50%{opacity:0.82}}
.iraq-map-caption{font-size:2.6px;fill:rgba(55,75,100,0.88);font-weight:700}
.iraq-map-score{font-size:14px;font-weight:800;color:var(--vc);margin-top:10px;line-height:1.55}
.iraq-map-score .iraq-map-stat-muted{font-size:12px;font-weight:600;color:var(--txts);display:block;margin-top:4px}
.iraq-map-legend{margin-top:14px;text-align:right;font-size:12px;color:var(--txts)}
.iraq-map-legend summary{cursor:pointer;font-weight:800;color:var(--vc);padding:6px 0;list-style-position:outside}
.iraq-map-legend-grid{display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end;margin-top:8px}
.iraq-map-legend-btn{
  padding:6px 10px;border-radius:10px;border:1px solid rgba(201,146,26,0.32);background:rgba(255,255,255,0.55);
  font-family:var(--font);font-size:11px;font-weight:700;cursor:pointer;color:var(--vc);transition:background .15s,transform .1s;
}
.iraq-map-legend-btn:hover{background:#fff;transform:translateY(-1px)}
.iraq-map-legend-btn:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
@media (prefers-reduced-motion:reduce){
  .iraq-gov-path{transition:none}
  .iraq-gov--target .iraq-gov-path{animation:none}
}

body.with-pre-banner #sidebar{top:var(--pre-banner-stack,118px)}
body.with-pre-banner #topbar{top:var(--pre-banner-stack,118px)}

/* Sidebar brand — matches site nav wordmark */
.admin-sidebar-brand{
  display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--goldL);
  margin-bottom:4px;
}
.admin-sidebar-brand .nav-logo-word{
  font-size:1.55rem;font-weight:900;letter-spacing:0.02em;color:var(--goldL);
  font-family:'Amiri','Cairo',serif;
}
.admin-sidebar-brand .nav-logo-mark{display:flex;align-items:center}
.admin-sidebar-kicker{
  color:rgba(255,255,255,0.42);font-size:10px;font-weight:800;letter-spacing:0.18em;
  text-transform:uppercase;margin:0;
}

/* Supabase info panel (settings) */
.admin-supabase-panel{padding:20px 22px 24px}
.admin-supabase-lead{
  font-size:14px;line-height:1.75;color:var(--txt);margin:0 0 16px;font-weight:600;
}
.admin-supabase-lead strong{color:var(--lapis)}
.admin-supabase-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:18px;
}
@media(max-width:720px){.admin-supabase-grid{grid-template-columns:1fr}}
.admin-supabase-card{
  background:var(--papyrus);border-radius:16px;padding:16px 18px;border:1.5px solid var(--border);
  box-shadow:0 4px 18px rgba(27,61,110,0.06);
}
.admin-supabase-card dt{font-size:11px;font-weight:800;color:var(--txts);margin-bottom:6px}
.admin-supabase-card dd{font-size:13px;font-weight:800;color:var(--lapis);margin:0;word-break:break-all}
.admin-supabase-card dd code{font-family:ui-monospace,monospace;font-size:12px;font-weight:700}
.admin-supabase-links{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}
.admin-supabase-links a{
  display:inline-flex;align-items:center;gap:6px;padding:10px 16px;border-radius:999px;
  background:linear-gradient(135deg,var(--lapisD),var(--lapis));color:#fff;font-size:12px;font-weight:800;
  text-decoration:none;border:1px solid rgba(201,146,26,0.35);transition:transform .2s,box-shadow .2s;
}
.admin-supabase-links a:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(27,61,110,0.2)}
.admin-supabase-links a.admin-supabase-links--ghost{
  background:var(--cream);color:var(--lapis);border-color:var(--border);
}
.admin-supabase-tables{
  background:var(--lapisD);border-radius:16px;padding:18px 20px;color:rgba(255,255,255,0.88);
  font-size:13px;line-height:1.65;border:1px solid rgba(201,146,26,0.25);
}
.admin-supabase-tables h4{color:var(--goldL);font-size:12px;font-weight:900;margin:0 0 10px;letter-spacing:0.04em}
.admin-supabase-tables ul{margin:0;padding:0 1.1em 0 0;list-style:disc}
.admin-supabase-tables li{margin-bottom:6px}
.admin-supabase-note{margin-top:14px;font-size:12px;color:rgba(255,255,255,0.65);line-height:1.6}

/* Admin-only: email / Auth ops (not shown on public help) */
.admin-supabase-ops{
  margin-top:18px;padding-top:18px;border-top:1px solid rgba(201,146,26,0.28);
}
.admin-supabase-ops-title{
  margin:0 0 10px;font-size:13px;font-weight:900;color:var(--goldL);letter-spacing:0.03em;
}
.admin-supabase-ops-lead{
  margin:0 0 12px;font-size:13px;line-height:1.75;color:rgba(255,255,255,0.88);
}
.admin-supabase-ops-lead code{font-size:12px;background:rgba(0,0,0,0.2);padding:2px 6px;border-radius:6px}
.admin-supabase-ops-lead a{color:var(--goldL);font-weight:800}
.admin-supabase-ops-repo{
  margin:0;font-size:11px;line-height:1.55;color:rgba(255,255,255,0.55);
}
.admin-supabase-ops-repo a{color:var(--goldL);font-weight:700}

/* Scroll progress — same idea as main site #prog */
#prog{
  position:fixed;top:0;left:0;height:3px;z-index:200;width:0%;
  background:linear-gradient(90deg,var(--gold),var(--goldL));transition:width .1s;
}
body.with-pre-banner #prog{top:var(--pre-banner-stack,118px)}

/* Google Looker Studio embed */
.admin-looker-hint{
  font-size:13px;line-height:1.7;color:var(--txts);margin:0 0 16px;max-width:720px;
}
.admin-looker-card{
  background:var(--cream);border-radius:16px;border:1px solid var(--border);
  padding:12px;box-shadow:var(--shadow);
}
.admin-looker-embed{
  position:relative;width:100%;padding-bottom:75%;
  height:0;overflow:hidden;border-radius:12px;background:rgba(13,34,64,0.06);
}
.admin-looker-embed iframe{
  position:absolute;inset:0;width:100%;height:100%;
  border:0;
}
@media (max-width:768px){
  .admin-looker-embed{padding-bottom:100%}
}

/* WhatsApp leads (manual CRM) */
.admin-whatsapp-intro{
  font-size:13px;line-height:1.65;color:var(--txts);margin:0 0 18px;max-width:720px;
}
.admin-whatsapp-form{
  display:grid;grid-template-columns:1fr 1fr;gap:14px 18px;margin-bottom:8px;
}
.admin-whatsapp-form label{
  display:block;font-size:11px;font-weight:800;color:var(--txts);margin-bottom:5px;
}
.admin-whatsapp-form .full-row{grid-column:1/-1}
.admin-whatsapp-form .search-input{width:100%;box-sizing:border-box}
#whatsapp-leads-table{
  overflow-x:auto;-webkit-overflow-scrolling:touch;
}
.admin-whatsapp-table{min-width:920px}
.admin-whatsapp-table .wa-lead-notes{font-size:12px;padding:8px 10px}
@media (max-width:900px){
  .admin-whatsapp-form{grid-template-columns:1fr}
}
