/* =========================================================================
   1337 OFFENSIVE SECURITY SCHOOL — main.css
   Design tokens + components, derived from the Brand System.
   Dark-by-default · WCAG-minded · responsive · RTL-ready.
   ========================================================================= */

:root {
  /* ---- Surfaces & lines ---- */
  --bg:#08080a;
  --surface:#0e0e11;
  --surface-2:#0a0a0c;
  --elevated:#16161a;
  --line:#232328;
  --line-2:#2e2e34;
  /* ---- Text ---- */
  --text:#f4f4f5;
  --muted:#a9a9b1;
  --faint:#8b8b93;
  --dim:#56565e;
  --ghost:#3a3a40;
  /* ---- Brand / semantic ---- */
  --cyan:#22d3ee;
  --cyan-dim:#0891b2;
  --red:#ff5d52;
  --green:#4ade80;
  --amber:#facc15;
  --cyan-glow:rgba(34,211,238,.5);
  --cyan-soft:rgba(34,211,238,.07);
  --cyan-border:#1b4a52;
  /* ---- Type ---- */
  --f-display:'Space Grotesk',sans-serif;
  --f-body:'IBM Plex Sans',sans-serif;
  --f-mono:'JetBrains Mono',monospace;
  /* ---- Metrics ---- */
  --maxw:1240px;
  --radius:14px;
  --radius-sm:8px;
  --ease:.18s cubic-bezier(.4,0,.2,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--text);
  font-family:var(--f-body);line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
[dir="rtl"] body, [dir="rtl"]{font-family:'Noto Sans Arabic',var(--f-body)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--cyan);color:var(--bg)}
:focus-visible{outline:2px solid var(--cyan);outline-offset:3px;border-radius:3px}

/* ---- Animated grid background ---- */
.grid-bg{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(34,211,238,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(34,211,238,.04) 1px,transparent 1px);
  background-size:72px 72px;
  animation:gridmove 14s linear infinite;
  -webkit-mask-image:radial-gradient(ellipse 90% 60% at 50% 0%,#000,transparent 75%);
  mask-image:radial-gradient(ellipse 90% 60% at 50% 0%,#000,transparent 75%);
}
@keyframes gridmove{0%{background-position:0 0,0 0}100%{background-position:72px 72px,72px 72px}}
@keyframes blink{0%,49%{opacity:1}50%,100%{opacity:0}}
@keyframes scan{0%{stroke-dashoffset:0}100%{stroke-dashoffset:-492}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}
@keyframes spin{to{transform:rotate(360deg)}}

/* =========================================================================
   LAYOUT
   ========================================================================= */
.container{max-width:var(--maxw);margin:0 auto;padding-inline:28px}
.section{padding-block:88px;position:relative;z-index:1}
.section--alt{background:var(--surface-2);border-top:1px solid var(--elevated)}
.section--tight{padding-block:64px}
.center{text-align:center}
.grid{display:grid;gap:18px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.stack{display:flex;flex-direction:column}
.row{display:flex;align-items:center}
.wrap{flex-wrap:wrap}
.gap-8{gap:8px}.gap-12{gap:12px}.gap-14{gap:14px}.gap-18{gap:18px}.gap-24{gap:24px}
.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-34{margin-top:34px}
.between{justify-content:space-between}
.end{align-items:flex-end}

/* =========================================================================
   TYPE
   ========================================================================= */
.display{font-family:var(--f-display);font-weight:700;letter-spacing:-2px;line-height:1.0}
.h1{font-family:var(--f-display);font-weight:700;font-size:60px;letter-spacing:-2px;line-height:1.0}
.h2{font-family:var(--f-display);font-weight:600;font-size:42px;letter-spacing:-1.4px;line-height:1.06}
.h3{font-family:var(--f-display);font-weight:600;font-size:21px;line-height:1.12}
.lead{font-size:17px;color:var(--muted);line-height:1.6}
.muted{color:var(--muted)}
.faint{color:var(--faint)}
.dim{color:var(--dim)}
.mono{font-family:var(--f-mono)}
.cyan{color:var(--cyan)}
.eyebrow{font-family:var(--f-mono);font-size:12px;letter-spacing:3px;color:var(--cyan);margin-bottom:14px}
.maxw-680{max-width:680px}.maxw-560{max-width:560px}.maxw-520{max-width:520px}

/* =========================================================================
   BUTTONS / TAGS
   ========================================================================= */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--f-mono);font-size:14px;font-weight:700;
  border-radius:10px;padding:13px 24px;transition:var(--ease);
  border:1px solid transparent;white-space:nowrap;
}
.btn--sm{padding:8px 14px;font-size:12px;border-radius:8px}
.btn--primary{background:var(--cyan);color:var(--bg);box-shadow:0 0 0 rgba(34,211,238,0)}
.btn--primary:hover{box-shadow:0 0 26px var(--cyan-glow)}
.btn--ghost{border-color:var(--line-2);color:var(--text)}
.btn--ghost:hover{border-color:var(--cyan);color:var(--cyan)}
.eyebrow-tag{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--f-mono);font-size:11px;letter-spacing:2px;color:var(--cyan);
  border:1px solid var(--cyan-border);background:var(--cyan-soft);
  border-radius:100px;padding:7px 14px;
}
.dot{width:7px;height:7px;border-radius:50%;background:var(--cyan);box-shadow:0 0 8px var(--cyan)}
.chip{font-family:var(--f-mono);font-size:11px;color:var(--faint);border:1px solid var(--line);border-radius:5px;padding:4px 9px}
.chip--cyan{color:var(--cyan);border-color:var(--cyan-border);background:var(--cyan-soft)}
.chip--red{color:var(--red);border-color:#4a1f1c;background:rgba(255,93,82,.07)}
.chip--green{color:var(--green);border-color:#1c4a30;background:rgba(74,222,128,.07)}

/* =========================================================================
   CARDS
   ========================================================================= */
.card{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);padding:26px}
.card--hover{transition:var(--ease);display:block}
.card--hover:hover{border-color:var(--cyan);box-shadow:0 0 30px -8px var(--cyan-glow);transform:translateY(-3px)}
.card--feature{border-color:var(--cyan-border);background:linear-gradient(180deg,var(--cyan-soft),var(--surface))}
.card-num{font-family:var(--f-mono);font-size:34px;font-weight:700;color:var(--elevated);position:absolute;top:16px;inset-inline-end:18px}

/* =========================================================================
   HEADER / NAV
   ========================================================================= */
.site-header{position:sticky;top:0;z-index:80;background:rgba(8,8,10,.78);backdrop-filter:blur(12px);border-bottom:1px solid var(--elevated)}
.nav{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;gap:22px;padding:14px 28px}
.brand{display:flex;align-items:center;gap:10px;flex:none}
.brand-name{font-family:var(--f-display);font-weight:700;font-size:17px;letter-spacing:1px}
.nav-links{display:flex;align-items:center;gap:4px;margin-inline-start:18px}
.nav-link{font-size:14px;color:var(--muted);padding:8px 12px;border-radius:7px;transition:var(--ease)}
.nav-link:hover{color:var(--text);background:var(--surface)}
.nav-link.active{color:var(--cyan)}
.nav-right{margin-inline-start:auto;display:flex;align-items:center;gap:10px}
.lang-select{font-family:var(--f-mono);font-size:12px;color:var(--muted);background:var(--surface);border:1px solid var(--line);border-radius:7px;padding:8px 10px}
.nav-toggle{display:none;color:var(--text);padding:8px}

/* =========================================================================
   HERO
   ========================================================================= */
.hero{max-width:var(--maxw);margin:0 auto;padding:84px 28px 72px;display:grid;grid-template-columns:1.1fr .9fr;gap:54px;align-items:center;position:relative;z-index:1}
.stats{display:flex;gap:30px;flex-wrap:wrap;margin-top:44px}
.stat-num{font-family:var(--f-display);font-weight:700;font-size:30px;color:var(--cyan)}
.stat-label{font-size:12px;color:var(--faint);margin-top:2px}

/* Terminal */
.term-win{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--surface-2);box-shadow:0 30px 80px -40px var(--cyan-glow)}
.term-bar{background:var(--surface);border-bottom:1px solid var(--line);padding:11px 15px;display:flex;gap:7px;align-items:center}
.term-dot{width:11px;height:11px;border-radius:50%}
.term-title{font-family:var(--f-mono);font-size:11px;color:var(--dim);margin-inline-start:10px}
.term-body{padding:20px;font-family:var(--f-mono);font-size:13px;line-height:1.85;min-height:230px;color:#c9c9d0}

/* =========================================================================
   SESSIONS TABLE
   ========================================================================= */
.table{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.table-head,.table-row{display:grid;align-items:center}
.table-head{background:var(--elevated);font-family:var(--f-mono);font-size:11px;letter-spacing:1px;color:var(--faint)}
.table-head>div,.table-row>div{padding:14px 18px}
.table-row{border-top:1px solid var(--line-2);font-size:14px}
.table-row+.table-row{border-top-color:var(--line)}

/* =========================================================================
   PLACEHOLDER IMAGERY
   ========================================================================= */
.ph{
  border:1px solid var(--line);border-radius:var(--radius);position:relative;overflow:hidden;
  background-image:repeating-linear-gradient(135deg,#0c0c0f,#0c0c0f 12px,#101015 12px,#101015 24px);
  display:flex;align-items:center;justify-content:center;
}
.ph::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 45% 45%,rgba(34,211,238,.08),transparent 60%)}
.ph-label{position:relative;font-family:var(--f-mono);font-size:11px;color:var(--dim)}
.ph-cap{position:absolute;bottom:16px;inset-inline-start:16px;z-index:2}

/* =========================================================================
   TESTIMONIALS
   ========================================================================= */
.quote{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);padding:26px;margin:0}
.quote-mark{font-family:var(--f-mono);color:var(--cyan);font-size:22px}
.quote blockquote{font-size:14.5px;line-height:1.6;color:#c9c9d0;margin:8px 0 18px}
.avatar{width:38px;height:38px;border-radius:50%;background:var(--elevated);border:1px solid var(--line);flex:none}

/* Partners */
.partners{display:flex;flex-wrap:wrap;justify-content:center;gap:38px;align-items:center;opacity:.6}
.partner{font-family:var(--f-display);font-weight:700;font-size:19px;letter-spacing:1px}

/* =========================================================================
   CTA
   ========================================================================= */
.cta{border:1px solid var(--cyan-border);border-radius:20px;background:linear-gradient(150deg,rgba(34,211,238,.09),var(--surface-2) 60%);padding:64px 48px;text-align:center;position:relative;overflow:hidden}
.cta-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(34,211,238,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(34,211,238,.05) 1px,transparent 1px);background-size:40px 40px;-webkit-mask-image:radial-gradient(circle at 50% 50%,#000,transparent 70%);mask-image:radial-gradient(circle at 50% 50%,#000,transparent 70%)}

/* =========================================================================
   FORMS
   ========================================================================= */
.field label{font-size:12px;color:var(--faint);display:block;margin-bottom:6px}
.field input,.field select,.field textarea{
  width:100%;background:var(--bg);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:12px 14px;color:var(--text);font-family:inherit;font-size:14px;transition:var(--ease);
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--cyan);outline:none}
.form-msg{font-family:var(--f-mono);font-size:12px;color:var(--green);text-align:center;display:none}
.form-msg.show{display:block}

/* =========================================================================
   FOOTER
   ========================================================================= */
.site-footer{border-top:1px solid var(--elevated);background:var(--bg);position:relative;z-index:1}
.footer-grid{max-width:var(--maxw);margin:0 auto;padding:60px 28px 30px;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px}
.footer-col-title{font-family:var(--f-mono);font-size:11px;letter-spacing:1px;color:var(--dim);margin-bottom:14px}
.footer-links{display:flex;flex-direction:column;gap:9px;font-size:13.5px;color:var(--muted)}
.footer-links a:hover{color:var(--cyan)}
.footer-bar{max-width:var(--maxw);margin:0 auto;padding:20px 28px;border-top:1px solid var(--elevated);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;font-family:var(--f-mono);font-size:11px;color:var(--ghost)}

/* =========================================================================
   WHATSAPP + LOADER
   ========================================================================= */
.wa{position:fixed;bottom:26px;inset-inline-end:26px;z-index:90;display:flex;align-items:center;gap:10px;background:#16161A;color:#fff;border-radius:100px;padding:13px 18px 13px 14px;box-shadow:0 12px 30px -8px #22D3EE ;animation:floaty 3.5s ease-in-out infinite}
.wa span{font-family:var(--f-mono);font-size:13px;font-weight:700}
.loader{position:fixed;inset:0;z-index:9999;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:26px;transition:opacity .5s ease,visibility .5s}
.loader.hide{opacity:0;visibility:hidden}
.loader-track{width:220px;height:3px;background:var(--elevated);border-radius:2px;overflow:hidden}
.loader-bar{height:100%;width:0;background:var(--cyan);border-radius:2px;transition:width 1s ease;box-shadow:0 0 12px var(--cyan)}

/* =========================================================================
   INNER PAGE HERO / BREADCRUMB / MISC
   ========================================================================= */
.page-hero{max-width:var(--maxw);margin:0 auto;padding:72px 28px 40px;position:relative;z-index:1}
.breadcrumb{font-family:var(--f-mono);font-size:12px;color:var(--dim);margin-bottom:20px}
.breadcrumb a:hover{color:var(--cyan)}
.divider{height:1px;background:var(--line);width:100%}

/* Syllabus / accordion */
.accordion-item{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);overflow:hidden;margin-bottom:12px}
.accordion-head{width:100%;display:flex;justify-content:space-between;align-items:center;padding:18px 22px;text-align:start;font-family:var(--f-display);font-weight:600;font-size:16px}
.accordion-body{padding:0 22px;max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease;color:var(--faint);font-size:14px;line-height:1.6}
.accordion-item.open .accordion-body{padding:0 22px 20px;max-height:400px}
.accordion-item.open .acc-icon{transform:rotate(45deg)}
.acc-icon{transition:transform .25s ease;color:var(--cyan)}

/* Pricing */
.price-card{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);padding:32px;position:relative}
.price-card--featured{border-color:var(--cyan-border);background:linear-gradient(180deg,var(--cyan-soft),var(--surface))}
.price{font-family:var(--f-display);font-weight:700;font-size:42px;letter-spacing:-1px}
.price small{font-size:14px;color:var(--faint);font-weight:500}
.price-feat{display:flex;gap:10px;align-items:flex-start;font-size:14px;color:#c9c9d0;padding:7px 0}
.price-feat svg{flex:none;margin-top:3px;color:var(--cyan)}

/* Instructors / blog */
.person-card{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);overflow:hidden;transition:var(--ease)}
.person-card:hover{border-color:var(--cyan)}
.person-photo{aspect-ratio:1;background-image:repeating-linear-gradient(135deg,#0c0c0f,#0c0c0f 12px,#101015 12px,#101015 24px);position:relative}
.blog-card{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);overflow:hidden;transition:var(--ease);display:block}
.blog-card:hover{border-color:var(--cyan);transform:translateY(-3px)}
.blog-thumb{aspect-ratio:1.7;background-image:repeating-linear-gradient(135deg,#0c0c0f,#0c0c0f 12px,#101015 12px,#101015 24px);position:relative}

/* Dashboard */
.dash{max-width:var(--maxw);margin:0 auto;padding:40px 28px;display:grid;grid-template-columns:240px 1fr;gap:28px;position:relative;z-index:1}
.dash-side{border:1px solid var(--line);border-radius:var(--radius);background:var(--surface);padding:18px;height:max-content}
.dash-nav a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;font-size:13.5px;color:var(--muted);transition:var(--ease)}
.dash-nav a:hover,.dash-nav a.active{background:var(--cyan-soft);color:var(--cyan)}
.progress{height:8px;background:var(--elevated);border-radius:4px;overflow:hidden}
.progress span{display:block;height:100%;background:var(--cyan);border-radius:4px}

/* Auth pages */
.auth-wrap{min-height:calc(100vh - 60px);display:flex;align-items:center;justify-content:center;padding:48px 24px;position:relative;z-index:1}
.auth-card{width:100%;max-width:420px;border:1px solid var(--line);border-radius:18px;background:var(--surface);padding:38px}

/* Map */
.map{height:340px;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;position:relative;background:var(--surface-2)}
.map iframe{width:100%;height:100%;border:0;filter:grayscale(1) invert(.92) hue-rotate(170deg) contrast(.9)}

/* Map — Watch Dogs / ctOS overlay (scoped to .map--ctos, map-only) */
.map--ctos .map iframe,.map--ctos>iframe{filter:grayscale(1) invert(.92) hue-rotate(170deg) contrast(.95) brightness(.78) saturate(1.2);pointer-events:none}
.map-ctos{position:absolute;inset:0;pointer-events:none;z-index:2;overflow:hidden;
  background:radial-gradient(circle at 50% 46%,transparent 30%,rgba(8,8,10,.55) 100%),linear-gradient(180deg,rgba(8,8,10,.30),rgba(8,8,10,.05) 40%,rgba(8,8,10,.45))}
.map-ctos__grid{position:absolute;inset:0;opacity:.5;
  background-image:linear-gradient(rgba(34,211,238,.16) 1px,transparent 1px),linear-gradient(90deg,rgba(34,211,238,.16) 1px,transparent 1px);
  background-size:34px 34px;mask-image:radial-gradient(circle at 50% 46%,#000 55%,transparent 85%)}
.map-ctos__scan{position:absolute;left:0;right:0;height:46%;
  background:linear-gradient(180deg,transparent,rgba(34,211,238,.10) 60%,rgba(34,211,238,.28));
  border-bottom:1px solid rgba(34,211,238,.55);animation:ctosScan 5.5s linear infinite}
.map-ctos__sweep{position:absolute;top:46%;left:50%;width:150%;height:150%;transform-origin:0 0;
  background:conic-gradient(from 0deg,rgba(34,211,238,.22),transparent 28%);
  mask-image:radial-gradient(circle at 0 0,#000 0,#000 38%,transparent 60%);
  animation:ctosSweep 6s linear infinite}
.map-ctos__marker{position:absolute;top:50%;left:50%;width:14px;height:14px;transform:translate(-50%,-50%)}
.map-ctos__marker::before,.map-ctos__marker::after{content:"";position:absolute;inset:0;border-radius:50%;border:1.5px solid rgba(34,211,238,.85)}
.map-ctos__marker::after{animation:ctosPulse 2.4s ease-out infinite}
.map-ctos__marker span{position:absolute;top:50%;left:50%;width:5px;height:5px;border-radius:50%;
  transform:translate(-50%,-50%);background:#22d3ee;box-shadow:0 0 10px 2px rgba(34,211,238,.9)}
.map-ctos__coords{position:absolute;left:12px;bottom:12px;z-index:3;
  font-family:var(--f-mono);font-size:11px;letter-spacing:1px;color:#22d3ee;
  background:rgba(8,8,10,.66);border:1px solid rgba(34,211,238,.35);border-radius:5px;padding:5px 9px}
@keyframes ctosScan{0%{top:-46%}100%{top:100%}}
@keyframes ctosSweep{to{transform:rotate(360deg)}}
@keyframes ctosPulse{0%{transform:scale(1);opacity:.9}100%{transform:scale(3.4);opacity:0}}
@media (prefers-reduced-motion:reduce){
  .map-ctos__scan,.map-ctos__sweep,.map-ctos__marker::after{animation:none}
}

/* 404 */
.notfound{min-height:calc(100vh - 60px);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:18px;padding:48px;position:relative;z-index:1}
.glitch{font-family:var(--f-display);font-weight:700;font-size:120px;letter-spacing:-4px;color:var(--cyan);text-shadow:3px 0 var(--red),-3px 0 var(--cyan-dim)}

/* =========================================================================
   REVEAL ANIMATION
   ========================================================================= */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* =========================================================================
   RTL
   ========================================================================= */
[dir="rtl"] .nav-links{margin-inline-start:18px}
[dir="rtl"] .term-body,[dir="rtl"] .mono{direction:ltr;text-align:start}
[dir="rtl"] .glitch{text-shadow:-3px 0 var(--red),3px 0 var(--cyan-dim)}

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width:980px){
  .hero{grid-template-columns:1fr;gap:36px}
  .cols-4{grid-template-columns:repeat(2,1fr)}
  .dash{grid-template-columns:1fr}
}
/* Nav collapses earlier than content (the full bar runs out of room ~1000px) */
@media (max-width:1024px){
  .nav-links{
    display:none;position:absolute;top:60px;inset-inline:0;flex-direction:column;align-items:stretch;
    background:var(--surface-2);border-bottom:1px solid var(--line);padding:12px 20px;margin:0;gap:2px;
  }
  .nav-links.open{display:flex}
  .nav-toggle{display:block}
  .hide-mobile{display:none !important}
}
@media (max-width:900px){
  .cols-3{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .contact-grid,.cols-2{grid-template-columns:1fr}
  .h1{font-size:46px}.h2{font-size:34px}.glitch{font-size:84px}
  .hide-mobile{display:none !important}
}
@media (max-width:560px){
  .container,.hero,.page-hero{padding-inline:18px}
  .cols-4{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .table-head{display:none}
  .table-row{grid-template-columns:1fr !important;gap:4px;padding:14px 16px}
  .table-row>div{padding:2px 0}
  .cta{padding:44px 24px}
  .wa span{display:none}
  .wa{padding:14px}
}

/* =========================================================================
   RESPONSIVE HARDENING — mobile/tablet only (desktop ≥769px unchanged)
   ========================================================================= */
@media (max-width:768px){
  /* Stack any inline multi-column grid: course-detail body, register,
     contact, hero, and the labs/campus galleries. Tables excluded. */
  [style*="grid-template-columns"]:not(.table-head):not(.table-row){
    grid-template-columns:1fr !important;
    grid-template-rows:auto !important;
  }
  /* Data tables: drop the column header and stack each row so 5-col
     tables (sessions, pricing, dashboard) never exceed the viewport. */
  .table-head{display:none !important}
  .table-row{grid-template-columns:1fr !important;gap:4px;padding:14px 16px}
  .table-row>div{padding:3px 0}
  /* Stacked placeholder tiles keep a usable height once their grid rows
     are flattened (prevents the labs gallery collapsing to 0px). */
  .ph{min-height:140px}
  /* Sticky side cards must not pin once the layout is single-column. */
  [style*="position:sticky"]{position:static !important;top:auto !important}
}
@media (max-width:480px){
  /* Stop large / translated (FR · AR · TN) headings overflowing 320–480px.
     !important also reins in the few inline font-sizes (register/dashboard
     h1, CTA display) without touching their desktop sizes. */
  .h1{font-size:34px !important}
  .h2{font-size:26px !important}
  .display{font-size:30px !important}
  .glitch{font-size:58px}
  .price{font-size:30px}
  .nav{gap:12px;padding:12px 16px}
}

/* =========================================================================
   PREMIUM MICRO-INTERACTIONS — additive layer (tokens reused, desktop-safe)
   Driven by js/main.js interaction IIFE. All effects sit on fixed/absolute
   nodes or inline transforms; none alter existing layout, color, or type.
   ========================================================================= */
.scroll-hud{position:fixed;top:0;left:0;height:2px;width:0;z-index:9998;pointer-events:none;
  background:linear-gradient(90deg,var(--cyan-dim),var(--cyan));box-shadow:0 0 10px var(--cyan-glow)}

/* ── Custom cursor (desktop fine-pointer) ── */
.has-custom-cursor,.has-custom-cursor *{cursor:none!important}
.cur-ring{position:fixed;top:0;left:0;width:26px;height:26px;margin:-13px 0 0 -13px;border:1px solid var(--cyan);
  border-radius:50%;pointer-events:none;z-index:9997;opacity:.5;will-change:transform;
  transition:width .2s ease,height .2s ease,opacity .2s ease,background .2s ease}
.cur-ring.is-active{width:42px;height:42px;margin:-21px 0 0 -21px;opacity:.9;background:var(--cyan-soft)}
.cur-dot{position:fixed;top:0;left:0;width:4px;height:4px;margin:-2px 0 0 -2px;border-radius:50%;
  background:var(--cyan);box-shadow:0 0 8px var(--cyan);pointer-events:none;z-index:9997;will-change:transform}
.cur-trail{position:fixed;width:3px;height:3px;margin:-1.5px 0 0 -1.5px;border-radius:50%;background:var(--cyan);
  box-shadow:0 0 6px var(--cyan);pointer-events:none;z-index:9996;opacity:.45;animation:curTrail .6s ease-out forwards}
@keyframes curTrail{to{opacity:0;transform:scale(.3)}}

/* ── Global page splash (click / touch — all devices) ── */
.page-splash{
  position:fixed;border-radius:50%;pointer-events:none;z-index:9995;
  width:0;height:0;
  transform:translate(-50%,-50%);
  border:1.5px solid var(--cyan);
  box-shadow:0 0 14px var(--cyan-glow),inset 0 0 8px rgba(34,211,238,.08);
  animation:pageSplash .7s cubic-bezier(.15,0,.45,1) forwards}
@keyframes pageSplash{
  0%  {width:0;    height:0;    opacity:.95}
  60% {opacity:.4}
  100%{width:140px;height:140px;opacity:0}}

/* ── Touch tap particles (mobile — replaces cursor trail) ── */
.tap-dot{
  position:fixed;width:5px;height:5px;border-radius:50%;
  background:var(--cyan);box-shadow:0 0 8px var(--cyan);
  pointer-events:none;z-index:9994;
  transform:translate(-50%,-50%);
  animation:tapDot .55s ease-out forwards}
@keyframes tapDot{
  0%  {transform:translate(-50%,-50%) scale(1.8);opacity:1}
  100%{transform:translate(-50%,-50%) scale(0);opacity:0}}

/* ── Language picker custom dropdown ── */
.lang-picker{position:relative;display:inline-flex}
.lang-picker-btn{
  display:flex;align-items:center;gap:6px;
  background:transparent;border:1px solid var(--border);border-radius:6px;
  padding:5px 9px;cursor:pointer;color:var(--fg-dim);
  font:500 11px/1 var(--font-mono);letter-spacing:.8px;
  transition:border-color .2s,color .2s;white-space:nowrap}
.lang-picker-btn:hover,.lang-picker.is-open .lang-picker-btn{border-color:var(--cyan-dim);color:var(--fg)}
.lang-caret{transition:transform .2s}
.lang-picker.is-open .lang-caret{transform:rotate(180deg)}
.lang-menu{
  position:absolute;top:calc(100% + 6px);right:0;
  background:var(--surface);border:1px solid var(--border);border-radius:8px;
  padding:4px;min-width:86px;list-style:none;margin:0;
  box-shadow:0 8px 24px rgba(0,0,0,.45);
  opacity:0;transform:translateY(-6px);pointer-events:none;
  transition:opacity .15s,transform .15s;z-index:1001}
.lang-picker.is-open .lang-menu{opacity:1;transform:none;pointer-events:all}
.lang-opt{
  display:flex;align-items:center;gap:7px;
  padding:7px 10px;border-radius:5px;cursor:pointer;
  font:500 11px/1 var(--font-mono);letter-spacing:.8px;color:var(--fg-dim);
  transition:background .1s,color .1s}
.lang-opt:hover{background:var(--surface-2);color:var(--fg)}
.lang-opt.is-active{color:var(--cyan)}
.lang-flag{display:inline-flex;width:20px;height:14px;border-radius:2px;overflow:hidden;
  flex-shrink:0;box-shadow:0 0 0 1px rgba(255,255,255,.1)}

/* ── Button ripple ── */
.btn.has-ripple{position:relative;overflow:hidden}
.ripple{position:absolute;border-radius:50%;background:rgba(34,211,238,.30);pointer-events:none;
  transform:translate(-50%,-50%) scale(0);animation:rippleFx .6s ease-out forwards}
@keyframes rippleFx{to{transform:translate(-50%,-50%) scale(1);opacity:0}}

@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important;scroll-behavior:auto !important}
  .reveal{opacity:1;transform:none}
}
