/* ── RESET & TOKENS ─────────────────────────────────── */
:root {
  --bg:       #0c0c10;
  --bg2:      #111118;
  --bg3:      #18181f;
  --border:   rgba(255,255,255,.08);
  --border2:  rgba(255,255,255,.14);
  --text:     #f1f1f3;
  --muted:    #a8a8b8; /* ≥4.5:1 contrast on --bg */
  --accent:   #6366f1;
  --accent2:  #4f52de;
  --green:    #22c55e;
  --amber:    #f59e0b;
  --red:      #ef4444;
  --r:        14px;
  --r-sm:     9px;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:100%; }
body {
  font-family: 'Plus Jakarta Sans', sans-serif;
  background: var(--bg);
  color: var(--text);
  line-height: 1.65;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* ── A11Y MODES ─────────────────────────────────────── */
/* Scoped to page content only — widget stays visible always */
body.txt-lg { font-size: 180% !important; }
body.txt-lg h1 { font-size: 180% !important; }
body.txt-lg h2 { font-size: 180% !important; }
body.txt-lg h3 { font-size: 180% !important; }
body.txt-lg p { font-size: 180% !important; }
body.txt-lg .section-sub { font-size: 180% !important; }
body.txt-lg .points li { font-size: 180% !important; }
body.txt-lg .hero-desc { font-size: 180% !important; }
body.txt-lg .col-explain p { font-size: 180% !important; }
body.txt-lg .field input, body.txt-lg .field select, body.txt-lg .field textarea { font-size: 180% !important; }
body.txt-lg .btn-primary, body.txt-lg .btn-ghost { font-size: 180% !important; }

/* High contrast: target content wrapper, not the fixed overlay widgets */
body.hi-con #main,
body.hi-con nav#main-nav,
body.hi-con footer,
body.hi-con .demo-banner { filter: contrast(2.2) brightness(1.15); }

body.gray #main,
body.gray nav#main-nav,
body.gray footer,
body.gray .demo-banner { filter: grayscale(1); }

/* Screen reader only */
.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;
}

/* Skip link */
.skip-link {
  position: fixed; top: 8px; right: 8px; z-index: 99999;
  background: var(--accent); color: #fff;
  padding: 10px 18px; border-radius: var(--r-sm);
  font-weight: 700; font-size: 14px; text-decoration: none;
  transform: translateY(-120%); transition: transform .2s;
}
.skip-link:focus { transform: translateY(0); }

/* Global focus ring */
:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
  border-radius: 4px;
}

/* ── COOKIE ─────────────────────────────────────────── */
#cookie {
  position: fixed; bottom:0; left:0; right:0; z-index:9000;
  background: rgba(17,17,24,.97);
  backdrop-filter: blur(20px);
  border-top: 1px solid var(--border2);
  padding: 14px 5%;
  display: flex; align-items:center; gap:16px; flex-wrap:wrap;
}
#cookie p { font-size:13px; color:var(--muted); flex:1; min-width:220px; }
#cookie a { color:var(--accent); text-decoration:underline; }
.cookie-btns { display:flex; gap:8px; flex-shrink:0; }
.cookie-btns button {
  padding: 9px 20px; border-radius:50px;
  font-family:inherit; font-size:13px; font-weight:700;
  cursor:pointer; border:none; background:var(--accent); color:#fff; transition:.2s;
}
.cookie-btns button:hover { background:var(--accent2); }
.cookie-btns button.outline {
  background:transparent; color:var(--muted);
  border:1px solid rgba(255,255,255,.2);
}
.cookie-btns button.outline:hover { color:var(--text); border-color:var(--border2); }

/* ── A11Y WIDGET ─────────────────────────────────────── */
#a11y-widget {
  position: fixed; bottom: 90px; left: 0; z-index: 8500;
}
#a11y-toggle {
  display: flex; align-items:center; gap:8px;
  background: var(--accent); color:#fff;
  border: none; border-radius: 0 var(--r-sm) var(--r-sm) 0;
  padding: 12px 18px 12px 14px;
  font-family:inherit; font-size:14px; font-weight:700;
  cursor:pointer; transition:.2s;
  min-height: 48px; /* accessible touch target */
  box-shadow: 2px 2px 12px rgba(99,102,241,.4);
}
#a11y-toggle:hover { background:var(--accent2); }
#a11y-panel {
  background: var(--bg2);
  border: 1px solid var(--border2);
  border-right: none;
  border-radius: var(--r) var(--r) var(--r) 0;
  padding: 16px;
  min-width: 200px;
  margin-bottom: 4px;
  box-shadow: 4px 4px 24px rgba(0,0,0,.5);
}
.a11y-panel-title {
  font-size:11px; font-weight:700; letter-spacing:.8px;
  text-transform:uppercase; color:var(--muted); margin-bottom:10px;
}
#a11y-panel button {
  display: flex; align-items:center; gap:10px;
  width:100%; background:rgba(255,255,255,.04);
  border:1px solid var(--border); border-radius:var(--r-sm);
  padding:10px 14px; margin-bottom:6px;
  font-family:inherit; font-size:14px; font-weight:600;
  color:var(--text); cursor:pointer; transition:.2s;
  min-height: 44px; /* WCAG touch target */
}
#a11y-panel button:hover { border-color:var(--accent); color:var(--accent); }
#a11y-panel button[aria-pressed="true"] {
  background:rgba(99,102,241,.15);
  border-color:var(--accent); color:#a5b4fc;
}
#a11y-panel hr { border:none; border-top:1px solid var(--border); margin:8px 0; }
.a11y-note { font-size:11px; color:var(--muted); text-align:center; }

/* ── NAV ─────────────────────────────────────────────── */
nav#main-nav {
  position: fixed; top:0; left:0; right:0; z-index:7000;
  height: 64px;
  display: flex; align-items:center; justify-content:space-between;
  padding: 0 5%;
  transition: background .3s, border .3s;
}
nav#main-nav.stuck {
  background: rgba(12,12,16,.95);
  backdrop-filter: blur(24px);
  border-bottom: 1px solid var(--border);
}
.brand {
  display: flex; flex-direction:column;
  background:none; border:none; cursor:pointer; text-align:right;
  padding: 4px 0;
}
.brand-name { font-size:18px; font-weight:800; letter-spacing:-.5px; color:var(--text); }
.brand-name span { color:var(--accent); }
.brand-sub { font-size:10px; color:var(--muted); letter-spacing:.8px; text-transform:uppercase; font-weight:600; }
.nav-links { display:flex; gap:24px; list-style:none; }
.nav-links a {
  font-size:14px; font-weight:500; color:var(--muted);
  text-decoration:none; transition:.2s; padding:4px 0;
}
.nav-links a:hover { color:var(--text); }
.nav-pill {
  background:var(--accent); color:#fff !important;
  padding:8px 18px; border-radius:50px; font-weight:700 !important;
}
.nav-pill:hover { background:var(--accent2) !important; }
.hamburger {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:6px;
}
.hamburger span { width:22px; height:2px; background:var(--muted); border-radius:2px; display:block; transition:.3s; }
#mob-menu {
  position:fixed; top:64px; left:0; right:0; z-index:6999;
  background:rgba(12,12,16,.98);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  flex-direction:column;
}
#mob-menu:not([hidden]) { display:flex; }
#mob-menu a {
  display:block; padding:16px 5%; font-size:15px;
  color:var(--muted); text-decoration:none;
  border-bottom:1px solid var(--border); font-weight:500;
}
#mob-menu a:hover { color:var(--text); }

/* ── DEMO BANNER ─────────────────────────────────────── */
.demo-banner {
  margin-top: 64px;
  background: linear-gradient(90deg,rgba(99,102,241,.12),rgba(139,92,246,.08),rgba(99,102,241,.12));
  border-bottom: 1px solid rgba(99,102,241,.2);
  padding: 10px 5%;
  display: flex; align-items:center; gap:12px; flex-wrap:wrap;
}
.demo-pill {
  background:rgba(99,102,241,.2); border:1px solid rgba(99,102,241,.3);
  color:#a5b4fc; font-size:11px; font-weight:700;
  letter-spacing:.6px; text-transform:uppercase;
  padding:3px 12px; border-radius:50px; flex-shrink:0;
}
.demo-banner p { font-size:13px; color:var(--muted); flex:1; }
.demo-banner strong { color:var(--text); }
.banner-link {
  font-size:13px; color:rgba(165,180,252,.9); background:none; border:none;
  cursor:pointer; text-decoration:underline; text-underline-offset:3px;
  font-family:inherit; font-weight:600; white-space:nowrap;
}
.banner-link:hover { color:#a5b4fc; }

/* ── HERO ─────────────────────────────────────────────── */
.hero {
  min-height: 90vh;
  display:flex; align-items:center;
  padding: 100px 5% 80px;
  position:relative; overflow:hidden;
}
.hero-bg {
  position:absolute; inset:0; z-index:0;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 56px 56px;
}
.hero-bg::after {
  content:''; position:absolute; inset:0;
  background: radial-gradient(ellipse 70% 60% at 60% 40%, rgba(99,102,241,.13) 0%, transparent 70%);
}
.hero-inner { position:relative; z-index:1; max-width:680px; }
.eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(99,102,241,.1); border:1px solid rgba(99,102,241,.25);
  color:#a5b4fc; font-size:12px; font-weight:700;
  letter-spacing:.8px; text-transform:uppercase;
  padding:6px 16px; border-radius:50px; margin-bottom:28px;
}
.live-dot {
  width:7px; height:7px; border-radius:50%; background:var(--green);
  /* Slow pulse — safe, well under 3Hz */
  animation: livepulse 2s ease-in-out infinite;
}
@keyframes livepulse {
  0%,100% { opacity:1; }
  50%      { opacity:.3; }
}
/* Respect reduced motion preference */
@media (prefers-reduced-motion: reduce) {
  .live-dot { animation: none; }
  * { transition-duration:.01ms !important; animation-duration:.01ms !important; }
}
h1 {
  font-size: clamp(36px, 5.5vw, 68px);
  font-weight: 800; line-height:1.08;
  letter-spacing: -2px; margin-bottom:22px;
}
h1 em {
  font-style:normal;
  background: linear-gradient(135deg,#6366f1,#8b5cf6);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
}
.hero-desc { font-size:clamp(15px,2vw,18px); color:var(--muted); max-width:520px; margin-bottom:36px; }
.hero-btns { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:52px; }
.btn-primary {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--accent); color:#fff; border:none;
  padding:14px 28px; border-radius:50px;
  font-family:inherit; font-size:15px; font-weight:700;
  cursor:pointer; transition:.2s;
  box-shadow: 0 0 24px rgba(99,102,241,.35);
  min-height:48px;
}
.btn-primary:hover { background:var(--accent2); transform:translateY(-1px); }
.btn-ghost {
  display:inline-flex; align-items:center;
  background:transparent; color:var(--muted);
  border:1px solid rgba(255,255,255,.15); padding:13px 24px;
  border-radius:50px; font-family:inherit; font-size:15px; font-weight:600;
  cursor:pointer; transition:.2s; text-decoration:none;
  min-height:48px;
}
.btn-ghost:hover { color:var(--text); border-color:var(--border2); }
.hero-stats { display:flex; gap:36px; flex-wrap:wrap; }
.stat { display:flex; flex-direction:column; }
.stat strong { font-size:26px; font-weight:800; letter-spacing:-1px; }
.stat span   { font-size:12px; color:var(--muted); font-weight:500; margin-top:2px; }

/* ── SECTIONS ─────────────────────────────────────────── */
section { padding:88px 5%; }
.section-alt { background:var(--bg2); }
.section-inner { max-width:1140px; margin:0 auto; }
.section-header { text-align:center; margin-bottom:48px; }
.section-header h2 { margin-bottom:12px; }
.section-sub { color:var(--muted); font-size:16px; max-width:520px; margin:0 auto; }
.tag {
  display:inline-block; font-size:11px; font-weight:700;
  letter-spacing:.8px; text-transform:uppercase;
  color:var(--accent); background:rgba(99,102,241,.1);
  border:1px solid rgba(99,102,241,.2);
  padding:4px 14px; border-radius:50px; margin-bottom:14px;
}
h2 { font-size:clamp(24px,3.5vw,42px); font-weight:800; letter-spacing:-1px; line-height:1.1; margin-bottom:12px; }
h3 { font-size:clamp(16px,2vw,20px); font-weight:800; margin-bottom:8px; }

/* Two-column layout */
.two-col {
  display:grid; grid-template-columns:1fr 1fr;
  gap:60px; align-items:start;
}
.two-col.reverse { direction:ltr; }
.two-col.reverse > * { direction:rtl; }
.col-explain { padding-top:8px; }
.col-explain p { color:var(--muted); font-size:15px; margin-bottom:24px; line-height:1.75; }

/* Point list */
.points { list-style:none; display:flex; flex-direction:column; gap:14px; margin-top:8px; }
.points li { display:flex; gap:12px; align-items:flex-start; font-size:14px; color:var(--muted); line-height:1.6; }
.pt-icon {
  width:24px; height:24px; flex-shrink:0; margin-top:1px;
  background:rgba(99,102,241,.1); border:1px solid rgba(99,102,241,.2);
  border-radius:6px; display:flex; align-items:center; justify-content:center;
  font-size:11px;
}
.points strong { color:var(--text); display:block; margin-bottom:2px; }

/* Demo box */
.demo-box {
  background:var(--bg2); border:1px solid var(--border);
  border-radius:var(--r); overflow:hidden;
  box-shadow: 0 0 0 1px rgba(255,255,255,.04), 0 12px 40px rgba(0,0,0,.5);
}
.demo-box-bar {
  background:var(--bg3); border-bottom:1px solid var(--border);
  padding:12px 16px; display:flex; align-items:center; gap:8px;
}
.dot { width:10px; height:10px; border-radius:50%; }
.dot.red    { background:#ff5f57; }
.dot.yellow { background:#febc2e; }
.dot.green  { background:#28c840; }
.demo-box-label { font-size:12px; color:var(--muted); flex:1; text-align:center; font-weight:600; }
.demo-box-body  { padding:22px; }

/* ── FORM ─────────────────────────────────────────────── */
.form-note {
  font-size:13px; color:rgba(34,197,94,.85);
  background:rgba(34,197,94,.07); border:1px solid rgba(34,197,94,.2);
  border-radius:var(--r-sm); padding:10px 14px; margin-bottom:16px;
}
.field { margin-bottom:14px; }
.field label { display:block; font-size:12px; font-weight:700; color:var(--muted); letter-spacing:.4px; text-transform:uppercase; margin-bottom:6px; }
.field input, .field select, .field textarea {
  width:100%; background:rgba(255,255,255,.04);
  border:1.5px solid var(--border); border-radius:var(--r-sm);
  padding:11px 14px; font-family:inherit; font-size:15px;
  color:var(--text); outline:none; transition:.2s;
}
.field input:focus, .field select:focus, .field textarea:focus {
  border-color:rgba(99,102,241,.6); background:rgba(99,102,241,.05);
  box-shadow:0 0 0 3px rgba(99,102,241,.12);
}
.field select option { background:var(--bg2); }
.field textarea  { resize:vertical; height:80px; }
.field-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.required { color:var(--red); }
.field-err { display:block; font-size:12px; color:var(--red); margin-top:4px; min-height:16px; }
.success-box { text-align:center; padding:24px 16px; }
.success-icon { font-size:48px; display:block; margin-bottom:12px; }
.success-box h3 { color:var(--green); margin-bottom:8px; }
.success-box p  { color:var(--muted); font-size:14px; margin-bottom:20px; }

/* ── SEO ──────────────────────────────────────────────── */
.seo-grid { display:grid; grid-template-columns:1fr 1fr 1fr; gap:12px; margin-bottom:16px; }
.seo-card { background:rgba(255,255,255,.03); border:1px solid var(--border); border-radius:var(--r-sm); padding:16px; }
.seo-icon { font-size:20px; margin-bottom:8px; }
.seo-card h3 { font-size:13px; font-weight:700; margin-bottom:4px; }
.seo-card p  { font-size:12px; color:var(--muted); line-height:1.5; }
.score-row { display:flex; gap:10px; }
.score { flex:1; text-align:center; border-radius:var(--r-sm); padding:14px 8px; }
.score.green { background:rgba(34,197,94,.08); border:1px solid rgba(34,197,94,.2); }
.score.blue  { background:rgba(99,102,241,.08); border:1px solid rgba(99,102,241,.2); }
.score strong { display:block; font-size:24px; font-weight:800; letter-spacing:-1px; color:var(--green); }
.score.blue strong { color:#a5b4fc; }
.score span { font-size:11px; color:var(--muted); }

/* ── SECURITY ─────────────────────────────────────────── */
.sec-stack { list-style:none; display:flex; flex-direction:column; gap:8px; }
.sec-row {
  display:flex; align-items:center; gap:12px;
  background:rgba(255,255,255,.03); border:1px solid var(--border);
  border-radius:var(--r-sm); padding:12px 14px; transition:.2s;
}
.sec-row:hover { border-color:var(--border2); }
.sec-ico {
  width:34px; height:34px; flex-shrink:0;
  background:rgba(99,102,241,.1); border-radius:8px;
  display:flex; align-items:center; justify-content:center; font-size:16px;
}
.sec-row > div { flex:1; }
.sec-row strong { font-size:13px; display:block; margin-bottom:1px; }
.sec-row small  { font-size:11px; color:var(--muted); }
.badge-green {
  font-size:10px; font-weight:700; letter-spacing:.6px; text-transform:uppercase;
  color:var(--green); background:rgba(34,197,94,.1); border:1px solid rgba(34,197,94,.25);
  padding:3px 8px; border-radius:50px; white-space:nowrap;
}

/* ── ACCESSIBILITY DEMO ───────────────────────────────── */
.a11y-demo-btns { display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-bottom:14px; }
.a11y-demo-btns button {
  display:flex; flex-direction:column; align-items:center; gap:6px;
  background:rgba(255,255,255,.04); border:1px solid var(--border);
  border-radius:var(--r-sm); padding:14px 8px;
  font-family:inherit; font-size:13px; font-weight:600;
  color:var(--muted); cursor:pointer; transition:.2s;
  min-height:72px;
}
.a11y-demo-btns button:hover { border-color:rgba(99,102,241,.4); color:var(--text); }
.a11y-demo-btns button[aria-pressed="true"] {
  background:rgba(99,102,241,.12); border-color:var(--accent); color:#a5b4fc;
}
.wcag-badge {
  display:flex; justify-content:space-between; align-items:center;
  padding:12px 14px; background:rgba(34,197,94,.07);
  border:1px solid rgba(34,197,94,.2); border-radius:var(--r-sm);
}
.wcag-badge span  { font-size:13px; color:var(--muted); }
.wcag-badge strong { font-size:13px; color:var(--green); }

/* ── ADMIN TEASE ──────────────────────────────────────── */
.admin-tease { display:grid; grid-template-columns:1fr 1fr; gap:52px; align-items:center; }
.tease-info h3 { font-size:22px; font-weight:800; margin-bottom:12px; }
.tease-info p  { color:var(--muted); font-size:15px; line-height:1.75; margin-bottom:20px; }
.feature-chips { display:flex; flex-wrap:wrap; gap:8px; }
.feature-chips span {
  font-size:12px; background:rgba(255,255,255,.05);
  border:1px solid var(--border); color:var(--muted);
  padding:5px 12px; border-radius:50px; font-weight:600;
}
.logo-click-box {
  display:flex; flex-direction:column; align-items:center; gap:14px;
  background:linear-gradient(135deg, rgba(99,102,241,.05), rgba(79,70,229,.05)); border:1px solid rgba(99,102,241,.15); backdrop-filter:blur(10px);
  padding:32px; cursor:pointer; transition:border-color .2s;
}
.logo-click-box:hover { border-color:var(--accent); transform:scale(1.02); }
.logo-big { font-size:28px; font-weight:900; padding:16px 28px; background:linear-gradient(135deg, var(--accent), #4f46e5); color:#fff; border-radius:12px; box-shadow:0 4px 12px rgba(99,102,241,.2); letter-spacing:-1px; }
.logo-big span { color:#fff; }
.brand-name { font-size:20px; font-weight:900; letter-spacing:-.8px; background:linear-gradient(135deg, var(--text), var(--accent)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.brand-name span { color:var(--accent); }
.footer-inner { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:44px; margin-bottom:44px; max-width:1140px; margin-left:auto; margin-right:auto; }
.footer-brand p { font-size:13px; color:var(--muted); margin-top:10px; line-height:1.7; max-width:240px; }
footer h4 { font-size:11px; font-weight:700; letter-spacing:.8px; text-transform:uppercase; color:var(--muted); margin-bottom:14px; }
footer a { display:block; font-size:13px; color:rgba(255,255,255,.4); text-decoration:none; margin-bottom:9px; transition:.2s; }
footer a:hover { color:var(--text); }
.footer-bottom {
  max-width:1140px; margin:0 auto;
  border-top:1px solid var(--border); padding-top:20px;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px;
  font-size:12px; color:rgba(255,255,255,.3);
}

/* ── LOGIN MODAL ──────────────────────────────────────── */
#login-overlay {
  position:fixed; inset:0; z-index:9200;
  background:rgba(0,0,0,.8); backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center; padding:20px;
}
#login-overlay[hidden] { display:none; }
.modal {
  background:var(--bg2); border:1px solid var(--border2);
  border-radius:var(--r); width:100%; max-width:400px;
  padding:36px; position:relative;
  box-shadow:0 0 0 1px rgba(255,255,255,.06), 0 20px 60px rgba(0,0,0,.6);
}
.modal-close {
  position:absolute; top:14px; left:14px;
  background:none; border:none; color:var(--muted);
  font-size:20px; cursor:pointer; line-height:1; padding:4px;
}
.modal-close:hover { color:var(--text); }
.modal h2 { font-size:22px; font-weight:800; margin-bottom:6px; }
.modal > p { font-size:13px; color:var(--muted); margin-bottom:22px; }
.login-hint {
  margin-top:14px; padding:12px;
  background:rgba(99,102,241,.07); border:1px solid rgba(99,102,241,.15);
  border-radius:var(--r-sm); font-size:12px; color:#a5b4fc; text-align:center; line-height:1.7;
}
.login-hint code { background:rgba(99,102,241,.15); padding:1px 6px; border-radius:4px; font-family:monospace; }

/* ── ADMIN PANEL ──────────────────────────────────────── */
#admin-panel {
  position:fixed; inset:0; z-index:9500;
  background:var(--bg); overflow-y:auto;
}
#admin-panel[hidden] { display:none; }
.ap-nav {
  position:sticky; top:0; z-index:10;
  background:rgba(12,12,16,.97); backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border);
  height:56px; padding:0 24px;
  display:flex; align-items:center; justify-content:space-between;
}
.ap-brand { font-size:16px; font-weight:800; }
.ap-brand span { color:var(--accent); }
.ap-sub { color:var(--muted); font-weight:400; font-size:13px; margin-right:8px; }
.ap-nav-r { display:flex; align-items:center; gap:12px; }
.ap-live { font-size:12px; color:var(--green); display:flex; align-items:center; gap:5px; }
.ap-live::before { content:''; width:7px; height:7px; border-radius:50%; background:var(--green); display:inline-block; }
.ap-close {
  background:rgba(255,255,255,.06); border:1px solid var(--border);
  color:var(--muted); padding:7px 16px; border-radius:50px;
  font-family:inherit; font-size:12px; font-weight:600; cursor:pointer;
}
.ap-close:hover { color:var(--text); }
.ap-body { max-width:1240px; margin:0 auto; padding:28px 24px; }
.ap-top { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:24px; flex-wrap:wrap; gap:14px; }
.ap-top h2 { font-size:22px; font-weight:800; }
.ap-top p  { font-size:13px; color:var(--muted); margin-top:2px; }
.period-tabs { display:flex; gap:6px; flex-wrap:wrap; }
.ptab {
  background:var(--bg3); border:1px solid var(--border); color:var(--muted);
  padding:7px 16px; border-radius:50px; font-family:inherit;
  font-size:12px; font-weight:700; cursor:pointer; transition:.2s; min-height:36px;
}
.ptab.on, .ptab:hover { background:var(--accent); color:#fff; border-color:var(--accent); }
.kpis { display:grid; grid-template-columns:repeat(6,1fr); gap:14px; margin-bottom:20px; }
.kpi { background:var(--bg2); border:1px solid var(--border); border-radius:var(--r-sm); padding:18px 14px; }
.kpi-l { font-size:11px; font-weight:700; letter-spacing:.4px; text-transform:uppercase; color:var(--muted); margin-bottom:8px; }
.kpi-v { font-size:28px; font-weight:800; letter-spacing:-1px; line-height:1; }
.kpi-v.green { color:var(--green); }
.kpi-v.amber { color:var(--amber); }
.kpi-t { font-size:11px; font-weight:600; margin-top:5px; color:var(--muted); }
.kpi-t.up { color:var(--green); }
.charts-row { display:grid; grid-template-columns:7fr 5fr; gap:16px; margin-bottom:16px; }
.ch-card { background:var(--bg2); border:1px solid var(--border); border-radius:var(--r-sm); padding:20px; }
.ch-card h3 { font-size:14px; font-weight:800; margin-bottom:2px; }
.ch-card p  { font-size:12px; color:var(--muted); margin-bottom:16px; }
.leads-card { background:var(--bg2); border:1px solid var(--border); border-radius:var(--r-sm); overflow:hidden; margin-top:16px; }
.leads-top { display:flex; justify-content:space-between; align-items:center; padding:16px 20px; border-bottom:1px solid var(--border); flex-wrap:wrap; gap:10px; }
.leads-top h3 { font-size:14px; font-weight:800; }
.filter-row { display:flex; gap:6px; flex-wrap:wrap; }
.social-links { display:flex; gap:12px; margin-top:12px; }
.social-links a { display:flex; align-items:center; gap:6px; padding:6px 10px; background:var(--bg); border:1px solid var(--border); border-radius:var(--r-sm); color:var(--muted); text-decoration:none; font-size:12px; transition:.2s; }
.social-links a:hover { border-color:var(--accent); color:var(--text); }
.social-links svg { flex-shrink:0; }
.fb {
  background:var(--bg3); border:1px solid var(--border); color:var(--muted);
  padding:6px 14px; border-radius:50px;
  font-family:inherit; font-size:12px; font-weight:700; cursor:pointer; transition:.2s;
  min-height:34px;
}
.fb.on, .fb:hover { background:var(--accent); color:#fff; border-color:var(--accent); }
.fb.export { background:rgba(34,197,94,.1); color:var(--green); border-color:rgba(34,197,94,.3); }
.fb.export:hover { background:var(--green); color:#fff; }
.tbl-wrap { overflow-x:auto; }
table { width:100%; border-collapse:collapse; }
th { text-align:right; padding:10px 14px; font-size:11px; font-weight:700; letter-spacing:.4px; text-transform:uppercase; color:var(--muted); border-bottom:1px solid var(--border); white-space:nowrap; background:var(--bg3); }
td { padding:12px 14px; font-size:13px; border-bottom:1px solid rgba(255,255,255,.04); vertical-align:middle; white-space:nowrap; }
tr:last-child td { border-bottom:none; }
tr:hover td { background:rgba(255,255,255,.02); }
.sbadge { display:inline-flex; padding:3px 10px; border-radius:50px; font-size:11px; font-weight:700; }
.s-new  { background:rgba(34,197,94,.1);  color:var(--green); }
.s-con  { background:rgba(99,102,241,.1); color:#a5b4fc; }
.s-cls  { background:rgba(245,158,11,.1); color:var(--amber); }
.src-chip { font-size:11px; background:rgba(255,255,255,.05); border:1px solid var(--border); border-radius:50px; padding:2px 9px; color:var(--muted); }
.act-btn {
  background:rgba(255,255,255,.04); border:1px solid var(--border);
  color:var(--muted); padding:5px 10px; border-radius:6px;
  font-family:inherit; font-size:11px; font-weight:600; cursor:pointer; transition:.2s; margin:0 2px;
  min-height:30px;
}
.act-btn:hover { border-color:var(--accent); color:#a5b4fc; }
.act-btn.del:hover { border-color:var(--red); color:var(--red); }

/* ── AI CHAT ──────────────────────────────────────────── */
#ai-fab {
  position:fixed; bottom:24px; left:24px; z-index:8400;
  width:54px; height:54px; border-radius:50%;
  background:var(--accent); color:#fff; border:none;
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  box-shadow:0 0 24px rgba(99,102,241,.45); transition:.25s;
}
#ai-fab:hover { transform:scale(1.08); }
#ai-win {
  position:fixed; bottom:90px; left:24px; width:340px;
  background:var(--bg2); border:1px solid var(--border2);
  border-radius:var(--r); overflow:hidden; z-index:8401;
  flex-direction:column;
  box-shadow:0 0 0 1px rgba(255,255,255,.05), 0 16px 48px rgba(0,0,0,.6);
}
#ai-win:not([hidden]) { display:flex; }
.ai-head { background:var(--bg3); border-bottom:1px solid var(--border); padding:14px 16px; display:flex; justify-content:space-between; align-items:flex-start; }
.ai-head h3 { font-size:14px; font-weight:800; }
.ai-head p  { font-size:11px; color:var(--muted); margin-top:2px; }
.ai-head button { background:none; border:none; color:var(--muted); font-size:18px; cursor:pointer; line-height:1; padding:2px; }
.ai-head button:hover { color:var(--text); }
.ai-msgs { overflow-y:auto; max-height:300px; padding:14px; display:flex; flex-direction:column; gap:10px; }
.msg { font-size:13px; line-height:1.6; padding:10px 13px; border-radius:10px; max-width:88%; }
.msg.bot { background:var(--bg3); border:1px solid var(--border); align-self:flex-start; border-radius:4px 10px 10px 10px; }
.msg.usr { background:var(--accent); color:#fff; align-self:flex-end; border-radius:10px 4px 10px 10px; }
.ai-row { display:flex; gap:8px; padding:10px; border-top:1px solid var(--border); }
.ai-input { flex:1; background:rgba(255,255,255,.05); border:1.5px solid var(--border); border-radius:50px; padding:9px 14px; font-family:inherit; font-size:13px; color:var(--text); outline:none; }
.ai-input:focus { border-color:rgba(99,102,241,.5); }
.ai-send { background:var(--accent); border:none; color:#fff; width:36px; height:36px; border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:14px; flex-shrink:0; }

/* ── TOAST ────────────────────────────────────────────── */
#toast {
  position:fixed; bottom:24px; right:24px; z-index:99999;
  background:var(--bg3); border:1px solid var(--border2);
  color:var(--text); padding:12px 18px; border-radius:var(--r-sm);
  font-size:13px; font-weight:600; max-width:300px;
  box-shadow:0 4px 20px rgba(0,0,0,.5);
  transform:translateY(16px); opacity:0; transition:.25s; pointer-events:none;
}
#toast.show { transform:translateY(0); opacity:1; }

/* ── RESPONSIVE ───────────────────────────────────────── */
@media (max-width: 960px) {
  .two-col, .two-col.reverse { grid-template-columns:1fr; }
  .two-col.reverse { direction:rtl; }
  .admin-tease { grid-template-columns:1fr; }
  .charts-row { grid-template-columns:1fr; }
  .kpis { grid-template-columns:repeat(3,1fr); }
  .seo-grid { grid-template-columns:1fr 1fr; }
  .footer-inner { grid-template-columns:1fr 1fr; }
}
@media (max-width: 600px) {
  .nav-links { display:none; }
  .hamburger { display:flex; }
  section { padding:60px 5%; }
  .hero { padding:90px 5% 60px; }
  .hero-stats { gap:20px; }
  .kpis { grid-template-columns:1fr 1fr; }
  .seo-grid { grid-template-columns:1fr; }
  .footer-inner { grid-template-columns:1fr; }
  .field-row { grid-template-columns:1fr; }
  .a11y-demo-btns { grid-template-columns:1fr 1fr; }
  #ai-win { width:calc(100vw - 32px); left:16px; }
  .ap-body { padding:16px 12px; }
}
