
:root {
  --c: #00d4ff;
  --c2: #00aacc;
  --c3: #0077aa;
  --glow: rgba(0,212,255,0.18);
  --glow2: rgba(0,212,255,0.06);
  --bg: #000508;
  --bg2: #00080f;
  --sf: rgba(0,212,255,0.04);
  --sf2: rgba(0,212,255,0.09);
  --bd: rgba(0,212,255,0.14);
  --bd2: rgba(0,212,255,0.28);
  --tx: #e4f4ff;
  --tx2: rgba(228,244,255,0.58);
  --tx3: rgba(228,244,255,0.32);
  --mono: 'JetBrains Mono','Courier New',monospace;
  --sans: 'Inter',-apple-system,sans-serif;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--tx);font-family:var(--sans);overflow-x:hidden;line-height:1.6}

/* ════════════════════════════════
   SHARED CANVAS — BACKGROUND RAIN
   ════════════════════════════════ */
#bg-canvas{
  position:fixed;top:0;left:0;width:100%;height:100%;
  z-index:0;opacity:0.04;pointer-events:none;
  transition:opacity 0.6s ease;
}
/* grid overlay */
body::before{
  content:'';position:fixed;inset:0;
  background-image:
    linear-gradient(rgba(0,212,255,0.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(0,212,255,0.025) 1px,transparent 1px);
  background-size:60px 60px;z-index:1;pointer-events:none;
}

/* ════════════════════════════════
   SPLASH SCREEN
   ════════════════════════════════ */
#splash{
  position:fixed;inset:0;z-index:9000;
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  background:#000508;
  transition:opacity 1s ease, visibility 1s ease;
}
#splash.exit{opacity:0;visibility:hidden;pointer-events:none}

/* splash canvas — denser rain for intro */
#splash-canvas{
  position:absolute;inset:0;width:100%;height:100%;
  opacity:0.22;pointer-events:none;
  transition:opacity 0.4s ease;
}
#splash.exit #splash-canvas{opacity:0}

/* scan lines on splash */
#splash::after{
  content:'';position:absolute;inset:0;
  background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,0,0,0.08) 3px,rgba(0,0,0,0.08) 4px);
  pointer-events:none;z-index:1;
}

.splash-inner{
  position:relative;z-index:2;
  display:flex;flex-direction:column;align-items:center;
  gap:0;text-align:center;
}

/* Logo mark */
.splash-logo-wrap{
  display:flex;align-items:center;gap:16px;
  margin-bottom:20px;
}
.splash-logo-icon{
  width:56px;height:56px;
  border:1.5px solid var(--c);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:22px;color:var(--c);
  position:relative;
  box-shadow:0 0 24px rgba(0,212,255,0.25), inset 0 0 12px rgba(0,212,255,0.08);
}
.splash-logo-icon::before{
  content:'';position:absolute;inset:5px;
  background:rgba(0,212,255,0.07);
}
.splash-logo-text{
  font-family:var(--mono);font-size:20px;font-weight:700;
  color:var(--c);letter-spacing:3px;text-transform:uppercase;
}

/* Tagline */
.splash-tagline{
  font-family:var(--mono);
  font-size:clamp(13px,2vw,17px);
  color:var(--tx2);
  letter-spacing:2px;
  margin-bottom:8px;
}
.splash-subtitle{
  font-family:var(--mono);
  font-size:11px;
  color:var(--tx3);
  letter-spacing:3px;
  text-transform:uppercase;
  margin-bottom:56px;
}

/* decorative line */
.splash-line{
  width:120px;height:1px;
  background:linear-gradient(90deg,transparent,var(--c),transparent);
  margin:0 auto 48px;
  position:relative;
}
.splash-line::before,.splash-line::after{
  content:'';position:absolute;top:-3px;
  width:6px;height:6px;
  border:1px solid var(--c);
  transform:rotate(45deg);
  background:var(--bg);
}
.splash-line::before{left:-3px;}
.splash-line::after{right:-3px;}

/* BELÉPÉS button */
.splash-btn{
  font-family:var(--mono);
  font-size:13px;font-weight:700;
  letter-spacing:4px;text-transform:uppercase;
  padding:16px 48px;
  background:transparent;
  color:var(--c);
  border:1px solid var(--c);
  cursor:pointer;
  position:relative;overflow:hidden;
  transition:all 0.3s ease;
  box-shadow:0 0 20px rgba(0,212,255,0.1);
}
.splash-btn::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(0,212,255,0.15),rgba(0,212,255,0.05));
  transform:translateX(-100%);
  transition:transform 0.35s ease;
}
.splash-btn:hover::before{transform:translateX(0)}
.splash-btn:hover{
  box-shadow:0 0 40px rgba(0,212,255,0.35),0 0 80px rgba(0,212,255,0.1);
  text-shadow:0 0 8px var(--c);
}
.splash-btn.loading{
  color:var(--c2);
  pointer-events:none;
  animation:btn-flicker 0.08s infinite;
}
@keyframes btn-flicker{
  0%,100%{opacity:1}50%{opacity:0.7}
}

.splash-version{
  margin-top:48px;
  font-family:var(--mono);font-size:10px;
  color:var(--tx3);letter-spacing:2px;
}

/* ════════════════════════════════
   MAIN SITE — hidden until enter
   ════════════════════════════════ */
#site{
  opacity:0;visibility:hidden;
  transition:opacity 0.8s ease 0.3s, visibility 0.8s ease 0.3s;
}
#site.visible{opacity:1;visibility:visible}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  border-bottom:1px solid var(--bd);
  backdrop-filter:blur(20px);
  background:rgba(0,5,8,0.88);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:64px;padding:0 32px;max-width:1400px;margin:0 auto;
}
.nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none;cursor:pointer}
.nav-logo-icon{
  width:30px;height:30px;border:1px solid var(--c);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:13px;color:var(--c);position:relative;
}
.nav-logo-icon::before{content:'';position:absolute;inset:3px;background:var(--glow2)}
.nav-logo-text{font-family:var(--mono);font-size:12px;font-weight:500;color:var(--c);letter-spacing:2px;text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:28px;list-style:none}
.nav-links a{font-family:var(--mono);font-size:11px;color:var(--tx2);text-decoration:none;letter-spacing:1.5px;text-transform:uppercase;transition:color 0.2s}
.nav-links a:hover{color:var(--c)}
.nav-cta{
  font-family:var(--mono);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;
  padding:8px 20px;border:1px solid var(--c);color:var(--c);
  background:transparent;cursor:pointer;text-decoration:none;
  transition:all 0.2s;position:relative;overflow:hidden;
}
.nav-cta::before{
  content:'';position:absolute;inset:0;background:var(--c);
  transform:translateX(-100%);transition:transform 0.2s;
}
.nav-cta:hover::before{transform:translateX(0)}
.nav-cta:hover{color:#000}
.nav-cta span{position:relative;z-index:1}

/* ── TICKER ── */
.ticker-wrap{
  position:relative;z-index:10;overflow:hidden;
  border-bottom:1px solid var(--bd);
  background:rgba(0,212,255,0.02);padding:9px 0;
  margin-top:64px;
}
.ticker-inner{
  display:flex;gap:60px;
  animation:ticker 35s linear infinite;white-space:nowrap;
}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.ti{
  font-family:var(--mono);font-size:10px;color:var(--tx3);
  letter-spacing:1.5px;flex-shrink:0;
  display:flex;align-items:center;gap:8px;
}
.ti .up{color:var(--c)}
.ti .sep{color:var(--bd2);margin:0 4px}

/* ── HERO ── */
.hero{
  min-height:100vh;display:flex;align-items:center;
  position:relative;z-index:10;
}
.hero-inner{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;
  align-items:center;width:100%;
  padding:80px 40px;max-width:1400px;margin:0 auto;
}
.hero-tag{
  font-family:var(--mono);font-size:11px;color:var(--c);
  letter-spacing:3px;text-transform:uppercase;
  margin-bottom:20px;display:flex;align-items:center;gap:10px;
}
.hero-tag::before{content:'';width:20px;height:1px;background:var(--c)}
.hero-title{
  font-size:clamp(34px,3.8vw,58px);font-weight:800;
  line-height:1.1;margin-bottom:10px;color:var(--tx);letter-spacing:-1px;
}
.hero-title .acc{color:var(--c);position:relative;display:inline-block}
.hero-title .acc::after{content:'_';animation:blink 1s step-end infinite}
@keyframes blink{50%{opacity:0}}
.hero-sub{
  font-family:var(--mono);font-size:13px;color:var(--c2);
  margin-bottom:28px;letter-spacing:1px;
}
.hero-desc{font-size:16px;color:var(--tx2);line-height:1.85;margin-bottom:36px;max-width:500px}
.hero-desc strong{color:var(--tx)}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.btn-p{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 26px;background:var(--c);color:#000;
  font-family:var(--mono);font-size:12px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;
  text-decoration:none;border:none;cursor:pointer;
  transition:all 0.2s;
}
.btn-p:hover{background:#fff;box-shadow:0 0 30px rgba(0,212,255,0.4);transform:translateY(-1px)}
.btn-s{
  display:inline-flex;align-items:center;gap:10px;
  padding:13px 26px;background:transparent;color:var(--c);
  font-family:var(--mono);font-size:12px;letter-spacing:2px;
  text-transform:uppercase;text-decoration:none;
  border:1px solid var(--bd2);cursor:pointer;transition:all 0.2s;
}
.btn-s:hover{border-color:var(--c);background:var(--glow2)}
.hero-badges{display:flex;gap:20px;margin-top:44px;flex-wrap:wrap}
.badge{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10px;color:var(--tx3);letter-spacing:1px}
.dot{
  width:6px;height:6px;background:var(--c);border-radius:50%;
  box-shadow:0 0 6px var(--c);animation:pd 2s ease-in-out infinite;
}
@keyframes pd{0%,100%{opacity:1}50%{opacity:0.25}}

/* ── TERMINAL ── */
.hero-term{
  background:#010a10;border:1px solid var(--bd);
  position:relative;font-family:var(--mono);
}
.term-bar{
  display:flex;align-items:center;gap:8px;
  padding:11px 16px;border-bottom:1px solid var(--bd);
  background:rgba(0,212,255,0.02);
}
.td{width:10px;height:10px;border-radius:50%}
.td:nth-child(1){background:#ff5f57}
.td:nth-child(2){background:#febc2e}
.td:nth-child(3){background:#28c840}
.term-title{margin-left:8px;font-size:11px;color:var(--tx3);letter-spacing:1px}
.term-body{padding:22px;font-size:12px;line-height:1.9;min-height:340px}
.tl{display:flex;gap:12px}
.tp{color:var(--c);flex-shrink:0}
.tc{color:#66ccdd}
.to{color:var(--tx2);padding-left:22px}
.tk{color:var(--c)}
.tv{color:var(--tx)}
.tcm{color:#2d5566}
.tb{height:8px}
.tcur::after{content:'▊';color:var(--c);animation:blink 1s step-end infinite}

/* ── STATS BAR ── */
.stats-bar{
  position:relative;z-index:10;
  border-top:1px solid var(--bd);border-bottom:1px solid var(--bd);
  background:var(--sf2);
}
.stats-inner{
  display:grid;grid-template-columns:repeat(4,1fr);
  max-width:1400px;margin:0 auto;
}
.stat-item{
  padding:30px 36px;border-right:1px solid var(--bd);
}
.stat-item:last-child{border-right:none}
.stat-n{
  font-family:var(--mono);font-size:34px;font-weight:700;
  color:var(--c);display:block;margin-bottom:4px;
}
.stat-l{font-size:11px;color:var(--tx3);letter-spacing:1px;text-transform:uppercase}

/* ── SECTION ── */
section{position:relative;z-index:10;padding:96px 0}
.stag{
  font-family:var(--mono);font-size:10px;color:var(--c);
  letter-spacing:3px;text-transform:uppercase;
  margin-bottom:14px;display:flex;align-items:center;gap:10px;
}
.stag::before{content:'//';opacity:0.45}
.stitle{
  font-size:clamp(26px,3.2vw,42px);font-weight:800;
  line-height:1.15;letter-spacing:-0.5px;margin-bottom:14px;color:var(--tx);
}
.stitle .g{color:var(--c)}
.sdesc{font-size:15px;color:var(--tx2);max-width:580px;line-height:1.8}
.shdr{margin-bottom:60px}

/* ── SERVICES ── */
.services-bg{background:linear-gradient(180deg,var(--bg) 0%,var(--bg2) 50%,var(--bg) 100%)}
.svc-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:1px;background:var(--bd);border:1px solid var(--bd);
}
.svc-card{
  background:var(--bg);padding:38px;
  position:relative;overflow:hidden;
  transition:background 0.3s;
}
.svc-card::before{
  content:'';position:absolute;top:0;left:0;
  width:100%;height:2px;background:var(--c);
  transform:scaleX(0);transform-origin:left;transition:transform 0.3s;
}
.svc-card:hover::before{transform:scaleX(1)}
.svc-card:hover{background:var(--sf)}
.svc-id{font-family:var(--mono);font-size:10px;color:var(--tx3);letter-spacing:2px;margin-bottom:18px}
.svc-icon{
  width:46px;height:46px;border:1px solid var(--bd2);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:18px;font-size:19px;color:var(--c);
}
.svc-title{font-size:19px;font-weight:700;margin-bottom:11px;color:var(--tx);letter-spacing:-0.3px}
.svc-desc{font-size:13.5px;color:var(--tx2);line-height:1.8;margin-bottom:22px}
.svc-link{
  font-family:var(--mono);font-size:10px;color:var(--c);
  text-decoration:none;letter-spacing:2px;text-transform:uppercase;
  display:flex;align-items:center;gap:8px;transition:gap 0.2s;
}
.svc-link:hover{gap:16px}
.svc-tags{display:flex;flex-wrap:wrap;gap:7px;margin-top:14px}
.tag{
  font-family:var(--mono);font-size:9px;
  padding:3px 9px;border:1px solid var(--bd);
  color:var(--tx3);letter-spacing:1px;
}

/* ── PROCESS ── */
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);position:relative}
.proc-grid::before{
  content:'';position:absolute;top:31px;left:12%;right:12%;
  height:1px;background:linear-gradient(90deg,transparent,var(--bd2),transparent);
}
.proc-step{padding:0 20px;text-align:center}
.step-n{
  width:62px;height:62px;border:1px solid var(--bd2);background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 26px;font-family:var(--mono);font-size:17px;
  color:var(--c);position:relative;font-weight:700;
}
.step-n::before{content:'';position:absolute;inset:4px;background:var(--glow2)}
.step-t{font-size:14px;font-weight:700;margin-bottom:9px;color:var(--tx)}
.step-d{font-size:13px;color:var(--tx2);line-height:1.7}

/* ── WHY ── */
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.why-list{list-style:none;display:flex;flex-direction:column;gap:20px}
.why-item{
  display:flex;gap:18px;align-items:flex-start;
  padding:18px;border:1px solid transparent;
  transition:border-color 0.2s,background 0.2s;
}
.why-item:hover{border-color:var(--bd);background:var(--sf)}
.why-ic{
  width:34px;height:34px;flex-shrink:0;
  border:1px solid var(--bd2);
  display:flex;align-items:center;justify-content:center;
  color:var(--c);font-size:13px;margin-top:2px;
}
.why-item h4{font-size:14px;font-weight:700;margin-bottom:5px;color:var(--tx)}
.why-item p{font-size:13px;color:var(--tx2);line-height:1.7}

/* ── DATA CARD ── */
.dcard{background:var(--sf);border:1px solid var(--bd);padding:36px;position:relative;overflow:hidden}
.dcard-t{
  font-family:var(--mono);font-size:10px;color:var(--c);
  letter-spacing:2px;text-transform:uppercase;
  margin-bottom:24px;display:flex;align-items:center;gap:8px;
}
.dcard-t::before{content:'▶';font-size:8px}
.drow{
  display:flex;justify-content:space-between;align-items:center;
  padding:11px 0;border-bottom:1px solid var(--bd);font-size:12.5px;
}
.drow:last-of-type{border-bottom:none}
.dk{color:var(--tx2)}
.dv{font-family:var(--mono);color:var(--c);font-size:11px}
.dbar-wrap{margin-top:22px}
.dbar-item{margin-bottom:13px}
.dbar-label{
  display:flex;justify-content:space-between;
  font-size:11px;margin-bottom:5px;color:var(--tx2);
}
.dbar-label span:last-child{font-family:var(--mono);color:var(--c)}
.dbar-track{height:2px;background:var(--bd);position:relative;overflow:hidden}
.dbar-fill{height:100%;background:var(--c);box-shadow:0 0 8px var(--c)}

/* ── TESTIMONIALS ── */
.test-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:var(--bd);border:1px solid var(--bd);
}
.test-card{background:var(--bg);padding:30px;transition:background 0.3s}
.test-card:hover{background:var(--sf)}
.test-stars{color:var(--c);font-size:11px;letter-spacing:2px;margin-bottom:14px;font-family:var(--mono)}
.test-text{font-size:13px;color:var(--tx2);line-height:1.8;margin-bottom:18px;font-style:italic}
.test-name{font-family:var(--mono);font-size:10px;color:var(--c);letter-spacing:1px}
.test-co{font-size:11px;color:var(--tx3);margin-top:2px}

/* ── FAQ ── */
.faq-list{
  display:flex;flex-direction:column;
  border:1px solid var(--bd);max-width:840px;margin:0 auto;
}
.faq-item{border-bottom:1px solid var(--bd);overflow:hidden}
.faq-item:last-child{border-bottom:none}
.faq-q{
  padding:22px 26px;display:flex;justify-content:space-between;
  align-items:center;cursor:pointer;font-size:14px;font-weight:600;
  color:var(--tx);user-select:none;transition:background 0.2s;gap:16px;
}
.faq-q:hover{background:var(--sf)}
.faq-tog{
  font-family:var(--mono);font-size:18px;color:var(--c);
  flex-shrink:0;transition:transform 0.2s;width:22px;text-align:center;
}
.faq-a{max-height:0;overflow:hidden;transition:max-height 0.35s ease}
.faq-ai{
  padding:0 26px 22px;font-size:13px;color:var(--tx2);
  line-height:1.8;border-top:1px solid var(--bd);padding-top:14px;
}
.faq-item.open .faq-a{max-height:200px}
.faq-item.open .faq-tog{transform:rotate(45deg)}

/* ── CTA ── */
.cta-sec{
  background:var(--sf);border-top:1px solid var(--bd);
  border-bottom:1px solid var(--bd);text-align:center;padding:96px 0;
  position:relative;overflow:hidden;
}
.cta-sec::before{
  content:'';position:absolute;top:50%;left:50%;
  transform:translate(-50%,-50%);
  width:600px;height:600px;
  background:radial-gradient(circle,rgba(0,212,255,0.06) 0%,transparent 70%);
  pointer-events:none;
}
.cta-title{font-size:clamp(26px,3.2vw,44px);font-weight:800;margin-bottom:14px;letter-spacing:-0.5px}
.cta-sub{font-size:15px;color:var(--tx2);max-width:480px;margin:0 auto 36px;line-height:1.7}
.cta-form{display:flex;max-width:460px;margin:0 auto}
.cta-in{
  flex:1;padding:13px 18px;background:rgba(0,212,255,0.04);
  border:1px solid var(--bd2);border-right:none;color:var(--tx);
  font-family:var(--mono);font-size:12px;outline:none;
  transition:border-color 0.2s;
}
.cta-in::placeholder{color:var(--tx3)}
.cta-in:focus{border-color:var(--c)}
.cta-sub-btn{
  padding:13px 22px;background:var(--c);color:#000;
  font-family:var(--mono);font-size:11px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;border:none;
  cursor:pointer;transition:background 0.2s;white-space:nowrap;
}
.cta-sub-btn:hover{background:#fff}
.cta-note{font-family:var(--mono);font-size:10px;color:var(--tx3);margin-top:14px;letter-spacing:1px}

/* ── FOOTER ── */
footer{position:relative;z-index:10;border-top:1px solid var(--bd);padding:56px 0 36px;background:var(--bg)}
.foot-inner{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:44px;
  max-width:1400px;margin:0 auto;padding:0 40px;margin-bottom:44px;
}
.foot-name{font-family:var(--mono);font-size:13px;color:var(--c);letter-spacing:2px;margin-bottom:10px;font-weight:700}
.foot-desc{font-size:12px;color:var(--tx3);line-height:1.7;max-width:240px}
.foot-col-t{font-family:var(--mono);font-size:10px;color:var(--tx3);letter-spacing:2px;text-transform:uppercase;margin-bottom:14px}
.foot-links{list-style:none;display:flex;flex-direction:column;gap:9px}
.foot-links a{font-size:13px;color:var(--tx2);text-decoration:none;transition:color 0.2s}
.foot-links a:hover{color:var(--c)}
.foot-bot{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:22px;border-top:1px solid var(--bd);
  max-width:1400px;margin:0 auto;padding-left:40px;padding-right:40px;
}
.foot-copy{font-family:var(--mono);font-size:10px;color:var(--tx3);letter-spacing:1px}
.foot-status{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10px;color:var(--c)}

/* ── SUBPAGE FOOTER (compact) ── */
.footer-inner{
  max-width:1400px;margin:0 auto;padding:0 40px;
  display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:16px;text-align:center;
}
.footer-brand{display:flex;align-items:center;gap:10px;margin-bottom:8px;justify-content:center;width:100%}
.footer-logo{font-size:22px;color:var(--c);font-weight:700}
.footer-name{font-family:var(--mono);font-size:14px;color:var(--c);letter-spacing:2px;font-weight:700}
.footer-tagline{font-size:11px;color:var(--tx3);font-family:var(--mono)}
.footer-links{display:flex;gap:20px;flex-wrap:wrap;justify-content:center}
.footer-links a{font-size:13px;color:var(--tx2);text-decoration:none;transition:color 0.2s}
.footer-links a:hover{color:var(--c)}
.footer-legal{display:flex;gap:20px;justify-content:center}
.footer-legal a{font-size:11px;color:var(--tx3);text-decoration:none;transition:color 0.2s}
.footer-legal a:hover{color:var(--c)}
.footer-copy{font-family:var(--mono);font-size:10px;color:var(--tx3);letter-spacing:1px;width:100%;text-align:center;margin-top:8px}

/* ── DIVIDER ── */
.divider{height:1px;background:linear-gradient(90deg,transparent,var(--bd2),transparent);margin:0 40px;position:relative;z-index:10}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(18px);transition:opacity 0.65s,transform 0.65s}
.revealed{opacity:1;transform:translateY(0)}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr;gap:40px;padding:60px 24px}
  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .stat-item:nth-child(2){border-right:none}
  .svc-grid{grid-template-columns:1fr}
  .proc-grid{grid-template-columns:repeat(2,1fr);gap:32px}
  .proc-grid::before{display:none}
  .why-grid{grid-template-columns:1fr;gap:40px}
  .test-grid{grid-template-columns:1fr}
  .foot-inner{grid-template-columns:1fr 1fr;gap:28px}
  .nav-links{display:none}
}

/* ════════════════════════════════
   REGISTRATION MODAL & PORTAL
   ════════════════════════════════ */

/* Modal Overlay */
#reg-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: none;
  align-items: center;
  justify-content: center;
  background: rgba(0, 5, 8, 0.88);
  backdrop-filter: blur(8px);
}

#reg-modal.active {
  display: flex;
}

.modal-content {
  position: relative;
  background: var(--bg2);
  border: 1px solid var(--bd);
  border-radius: 8px;
  width: 90%;
  max-width: 600px;
  max-height: 85vh;
  overflow-y: auto;
  padding: 40px;
  box-shadow: 0 0 40px rgba(0, 212, 255, 0.15);
}

.modal-close {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1px solid var(--bd);
  color: var(--tx2);
  cursor: pointer;
  font-family: var(--mono);
  font-size: 18px;
  transition: all 0.2s;
}

.modal-close:hover {
  color: var(--c);
  border-color: var(--c);
  box-shadow: 0 0 12px rgba(0, 212, 255, 0.3);
}

.modal-title {
  font-family: var(--mono);
  font-size: 18px;
  font-weight: 700;
  color: var(--c);
  margin-bottom: 28px;
  letter-spacing: 1px;
}

.form-section {
  margin-bottom: 32px;
}

.form-section-title {
  font-family: var(--mono);
  font-size: 12px;
  color: var(--c2);
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: 14px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--bd);
}

.form-group {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 16px;
}

.form-group.full {
  grid-template-columns: 1fr;
}

.form-label {
  font-family: var(--mono);
  font-size: 10px;
  color: var(--tx3);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 6px;
  display: block;
}

.form-input {
  background: var(--bg);
  border: 1px solid var(--bd);
  padding: 10px 12px;
  font-family: var(--mono);
  font-size: 12px;
  color: var(--tx);
  outline: none;
  transition: all 0.2s;
  border-radius: 4px;
}

.form-input::placeholder {
  color: var(--tx3);
}

.form-input:focus {
  border-color: var(--c);
  background: rgba(0, 212, 255, 0.03);
  box-shadow: 0 0 12px rgba(0, 212, 255, 0.1);
}

.toggle-row {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 20px;
}

.toggle-label {
  font-size: 14px;
  color: var(--tx2);
  flex: 1;
}

.toggle-switch {
  position: relative;
  width: 56px;
  height: 28px;
  background: var(--bg);
  border: 1px solid var(--bd);
  border-radius: 14px;
  cursor: pointer;
  transition: all 0.2s;
}

.toggle-switch.active {
  background: rgba(0, 212, 255, 0.15);
  border-color: var(--c);
}

.toggle-slider {
  position: absolute;
  top: 2px;
  left: 2px;
  width: 22px;
  height: 22px;
  background: var(--bd);
  border-radius: 50%;
  transition: all 0.2s;
}

.toggle-switch.active .toggle-slider {
  left: 30px;
  background: var(--c);
}

.conditional-section {
  margin-top: 20px;
  padding: 16px;
  background: rgba(0, 212, 255, 0.03);
  border-left: 2px solid var(--c);
  border-radius: 4px;
  display: none;
}

.conditional-section.active {
  display: block;
}

.info-text {
  font-size: 12px;
  color: var(--tx2);
  line-height: 1.6;
  margin-bottom: 12px;
}

.document-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: rgba(0, 212, 255, 0.08);
  border: 1px solid var(--bd);
  color: var(--c);
  text-decoration: none;
  font-family: var(--mono);
  font-size: 11px;
  border-radius: 4px;
  transition: all 0.2s;
  margin-right: 8px;
  margin-bottom: 8px;
}

.document-link:hover {
  background: rgba(0, 212, 255, 0.15);
  box-shadow: 0 0 12px rgba(0, 212, 255, 0.2);
}

.insurance-entries {
  margin-top: 16px;
}

.insurance-entry {
  background: var(--bg);
  border: 1px solid var(--bd);
  padding: 12px;
  margin-bottom: 12px;
  border-radius: 4px;
  display: grid;
  grid-template-columns: 1fr 1fr auto;
  gap: 12px;
  align-items: flex-end;
}

.entry-remove {
  background: transparent;
  border: 1px solid rgba(255, 0, 0, 0.3);
  color: #ff6b6b;
  padding: 6px 10px;
  font-size: 11px;
  cursor: pointer;
  border-radius: 4px;
  transition: all 0.2s;
}

.entry-remove:hover {
  border-color: #ff6b6b;
  background: rgba(255, 107, 107, 0.1);
}

.add-insurance-btn {
  background: transparent;
  border: 1px dashed var(--c);
  color: var(--c);
  padding: 8px 14px;
  font-family: var(--mono);
  font-size: 11px;
  cursor: pointer;
  border-radius: 4px;
  transition: all 0.2s;
  margin-top: 8px;
}

.add-insurance-btn:hover {
  background: rgba(0, 212, 255, 0.08);
  border-style: solid;
}

.upload-area {
  border: 2px dashed var(--bd);
  border-radius: 6px;
  padding: 24px;
  text-align: center;
  background: rgba(0, 212, 255, 0.02);
  transition: all 0.2s;
  cursor: pointer;
  margin-bottom: 16px;
}

.upload-area:hover {
  border-color: var(--c);
  background: rgba(0, 212, 255, 0.06);
}

.upload-icon {
  font-size: 24px;
  margin-bottom: 8px;
}

.upload-text {
  font-size: 12px;
  color: var(--tx2);
  margin-bottom: 4px;
}

.upload-hint {
  font-size: 10px;
  color: var(--tx3);
}

.form-submit {
  width: 100%;
  padding: 12px;
  background: var(--c);
  color: #000;
  border: none;
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: 4px;
  transition: all 0.2s;
  margin-top: 24px;
}

.form-submit:hover {
  background: #00e4ff;
  box-shadow: 0 0 20px rgba(0, 212, 255, 0.4);
}

.form-submit.success {
  background: #00aa00;
}

.success-message {
  display: none;
  text-align: center;
  padding: 24px;
  background: rgba(0, 170, 0, 0.1);
  border: 1px solid rgba(0, 170, 0, 0.3);
  border-radius: 6px;
  margin-bottom: 24px;
}

.success-message.active {
  display: block;
}

.success-message h3 {
  color: #00cc00;
  margin-bottom: 8px;
  font-family: var(--mono);
}

.success-message p {
  color: var(--tx2);
  font-size: 13px;
}

/* ════════════════════════════════
   CONTRACTS PORTAL
   ════════════════════════════════ */

#portal {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 80px 40px;
  position: relative;
  z-index: 10;
  margin-top: 64px;
}

#portal.hidden {
  display: none;
}

.portal-container {
  width: 100%;
  max-width: 900px;
}

.portal-login {
  text-align: center;
}

.portal-title {
  font-size: 32px;
  font-weight: 700;
  color: var(--c);
  margin-bottom: 16px;
  font-family: var(--mono);
}

.portal-subtitle {
  font-size: 14px;
  color: var(--tx2);
  margin-bottom: 36px;
}

.portal-login-form {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

.portal-email-input {
  width: 100%;
  max-width: 400px;
  padding: 12px 16px;
  background: var(--bg);
  border: 1px solid var(--bd);
  font-family: var(--mono);
  font-size: 13px;
  color: var(--tx);
  border-radius: 4px;
  outline: none;
  transition: all 0.2s;
}

.portal-email-input:focus {
  border-color: var(--c);
  box-shadow: 0 0 12px rgba(0, 212, 255, 0.15);
}

.portal-login-btn {
  padding: 12px 32px;
  background: var(--c);
  color: #000;
  border: none;
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: 4px;
  transition: all 0.2s;
}

.portal-login-btn:hover {
  background: #00e4ff;
  box-shadow: 0 0 20px rgba(0, 212, 255, 0.4);
}

.portal-content {
  display: none;
}

.portal-content.active {
  display: block;
}

.portal-welcome {
  text-align: center;
  margin-bottom: 40px;
}

.portal-welcome h2 {
  font-size: 24px;
  color: var(--c);
  margin-bottom: 8px;
  font-family: var(--mono);
}

.portal-welcome p {
  color: var(--tx2);
  font-size: 13px;
}

.contracts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 24px;
}

.contract-card {
  background: var(--bg2);
  border: 1px solid var(--bd);
  border-radius: 6px;
  padding: 20px;
  transition: all 0.3s;
}

.contract-card:hover {
  border-color: var(--c);
  box-shadow: 0 0 20px rgba(0, 212, 255, 0.15);
  transform: translateY(-2px);
}

.contract-header {
  border-bottom: 1px solid var(--bd);
  padding-bottom: 12px;
  margin-bottom: 16px;
}

.contract-biztosito {
  font-family: var(--mono);
  font-size: 12px;
  color: var(--c);
  letter-spacing: 1px;
  text-transform: uppercase;
}

.contract-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 12px;
}

.contract-label {
  font-family: var(--mono);
  font-size: 9px;
  color: var(--tx3);
  text-transform: uppercase;
  letter-spacing: 1px;
}

.contract-value {
  font-size: 13px;
  color: var(--tx);
  font-family: var(--mono);
}

.contract-statusz {
  display: inline-block;
  padding: 4px 10px;
  border-radius: 3px;
  font-family: var(--mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-top: 12px;
}

.contract-statusz.aktiv {
  background: rgba(0, 170, 0, 0.15);
  color: #00dd00;
  border: 1px solid rgba(0, 170, 0, 0.3);
}

.contract-statusz.lejart {
  background: rgba(255, 100, 100, 0.15);
  color: #ff6b6b;
  border: 1px solid rgba(255, 100, 100, 0.3);
}

.no-contracts {
  text-align: center;
  padding: 40px;
  border: 1px dashed var(--bd);
  border-radius: 6px;
}

.no-contracts p {
  color: var(--tx2);
  font-size: 14px;
  line-height: 1.6;
}

.portal-logout-btn {
  display: block;
  margin-top: 32px;
  padding: 10px 20px;
  background: transparent;
  border: 1px solid var(--bd);
  color: var(--tx2);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 1px;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: 4px;
  transition: all 0.2s;
}

.portal-logout-btn:hover {
  border-color: var(--c);
  color: var(--c);
}

/* ════════════════════════════════
   FLOATING BUTTON
   ════════════════════════════════ */

.floating-btn {
  position: fixed;
  bottom: 32px;
  right: 32px;
  z-index: 999;
  display: flex;
  align-items: center;
  justify-content: center;
  width: auto;
  padding: 14px 20px;
  background: var(--bg2);
  border: 1.5px solid var(--c);
  border-radius: 50px;
  cursor: pointer;
  transition: all 0.3s;
  box-shadow: 0 0 24px rgba(0, 212, 255, 0.2);
  font-family: var(--mono);
  font-size: 12px;
  color: var(--c);
  letter-spacing: 1px;
  text-align: center;
  gap: 10px;
  animation: pulse-glow 2.5s ease-in-out infinite;
}

@keyframes pulse-glow {
  0%, 100% {
    box-shadow: 0 0 24px rgba(0, 212, 255, 0.2);
  }
  50% {
    box-shadow: 0 0 40px rgba(0, 212, 255, 0.4);
  }
}

.floating-btn:hover {
  background: rgba(0, 212, 255, 0.08);
  transform: translateY(-3px);
  box-shadow: 0 0 50px rgba(0, 212, 255, 0.5);
}

.floating-btn-icon {
  font-size: 16px;
}

@media (max-width: 768px) {
  .floating-btn {
    bottom: 20px;
    right: 20px;
    padding: 12px 16px;
    font-size: 11px;
  }
  
  .modal-content {
    width: 95%;
    padding: 24px;
  }
  
  .hero-inner {
    grid-template-columns: 1fr;
    gap: 40px;
    padding: 60px 20px;
  }
  
  .contracts-grid {
    grid-template-columns: 1fr;
  }
}


/* ════════════════════════════════
   ESEDÉKES (lensflare glow) + BEFIZETEM BTN
════════════════════════════════ */
.contract-statusz.esedekes {
  background: rgba(255,187,0,0.12);
  color: #ffbb00;
  border-color: rgba(255,187,0,0.4);
}
.befizetem-wrap { position: relative; display: flex; align-items: center; justify-content: flex-end; }
.lensflare {
  position: absolute;
  width: 60px; height: 60px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,187,0,0.3) 0%, transparent 70%);
  pointer-events: none;
  animation: lensflare-pulse 2s ease-in-out infinite;
}
@keyframes lensflare-pulse {
  0%, 100% { transform: scale(1); opacity: 0.6; }
  50% { transform: scale(1.4); opacity: 1; }
}
.befizetem-btn {
  position: relative;
  padding: 10px 20px;
  background: linear-gradient(135deg, #ffbb00, #ff8800);
  color: #000;
  border: none;
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: 4px;
  transition: all 0.2s;
  box-shadow: 0 0 16px rgba(255,187,0,0.4);
}
.befizetem-btn:hover {
  box-shadow: 0 0 28px rgba(255,187,0,0.7);
  transform: translateY(-1px);
}
.contract-osszeg {
  font-family: var(--mono);
  font-size: 16px;
  font-weight: 700;
  color: var(--c);
}
.contract-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--bd);
}
/* ════════════════════════════════
   PASSWORD CHANGE FORM
════════════════════════════════ */
.pw-change-form {
  display: none;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  max-width: 420px;
  margin: 0 auto;
  text-align: center;
}
.pw-change-form.active { display: flex; }
.pw-change-form h2 {
  font-family: var(--mono);
  font-size: 22px;
  color: var(--c);
  margin-bottom: 4px;
}
.pw-change-form .pw-info {
  font-size: 13px;
  color: var(--tx2);
  line-height: 1.6;
}
.pw-change-form input {
  width: 100%;
  max-width: 400px;
  padding: 12px 16px;
  background: rgba(0,15,30,0.9);
  border: 1px solid rgba(0,212,255,0.4);
  font-family: var(--mono);
  font-size: 13px;
  color: #fff;
  border-radius: 4px;
  outline: none;
}
.pw-change-form input:focus { border-color: var(--c); }
.pw-change-form .pw-error {
  display: none;
  color: #ff6b6b;
  font-size: 12px;
  font-family: var(--mono);
}
.pw-change-form .pw-submit {
  padding: 12px 32px;
  background: var(--c);
  color: #000;
  border: none;
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 2px;
  cursor: pointer;
  border-radius: 4px;
  transition: all 0.2s;
}
.pw-change-form .pw-submit:hover {
  background: #00e4ff;
  box-shadow: 0 0 20px rgba(0,212,255,0.4);
}
/* ════════════════════════════════
   ADMIN PANEL
════════════════════════════════ */
.admin-panel {
  display: none;
  max-width: 900px;
  margin: 0 auto;
}
.admin-panel.active { display: block; }
.admin-panel h2 {
  font-family: var(--mono);
  font-size: 24px;
  color: var(--c);
  margin-bottom: 6px;
  text-align: center;
}
.admin-panel .admin-subtitle {
  font-size: 13px;
  color: var(--tx2);
  font-family: var(--mono);
  text-align: center;
  margin-bottom: 32px;
}
.admin-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 16px;
  margin-bottom: 28px;
}
.admin-stat-card {
  background: rgba(0,212,255,0.05);
  border: 1px solid rgba(0,212,255,0.15);
  border-radius: 6px;
  padding: 20px;
  text-align: center;
}
.admin-stat-card .stat-num {
  font-family: var(--mono);
  font-size: 28px;
  font-weight: 700;
  color: var(--c);
}
.admin-stat-card .stat-label {
  font-size: 11px;
  color: var(--tx2);
  margin-top: 4px;
  letter-spacing: 1px;
}
.admin-table-wrap { overflow-x: auto; margin-top: 20px; }
.admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.admin-table th {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--c);
  padding: 10px 14px;
  text-align: left;
  border-bottom: 1px solid rgba(0,212,255,0.2);
  white-space: nowrap;
}
.admin-table td {
  padding: 10px 14px;
  color: var(--tx);
  border-bottom: 1px solid rgba(0,212,255,0.07);
  font-size: 12px;
}
.admin-table tr:hover td { background: rgba(0,212,255,0.04); }
.admin-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 11px;
  font-family: var(--mono);
  border: 1px solid;
}
.admin-badge.active { background: rgba(0,170,0,0.15); color: #00dd00; border-color: rgba(0,200,0,0.3); }
.admin-badge.pending { background: rgba(255,180,0,0.15); color: #ffbb00; border-color: rgba(255,180,0,0.3); }
.admin-export-btn {
  padding: 10px 24px;
  background: transparent;
  border: 1px solid rgba(0,212,255,0.4);
  color: var(--c);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: 4px;
  transition: all 0.2s;
}
.admin-export-btn:hover {
  border-color: var(--c);
  background: rgba(0,212,255,0.08);
}
.admin-actions { margin-bottom: 20px; display: flex; align-items: center; gap: 12px; }
/* ════════════════════════════════
   PAYMENT MODAL
════════════════════════════════ */
.payment-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.85);
  z-index: 1000;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.payment-overlay.active { display: flex; }
.payment-box {
  background: #000e1c;
  border: 1px solid rgba(0,212,255,0.3);
  border-radius: 8px;
  padding: 36px;
  max-width: 480px;
  width: 100%;
  position: relative;
}
.payment-close {
  position: absolute;
  top: 14px; right: 18px;
  background: none;
  border: none;
  color: var(--tx2);
  font-size: 22px;
  cursor: pointer;
  line-height: 1;
  transition: color 0.2s;
}
.payment-close:hover { color: var(--tx); }
.payment-box h3 {
  font-family: var(--mono);
  font-size: 18px;
  color: var(--c);
  margin-bottom: 6px;
}
.payment-subtitle {
  font-size: 12px;
  color: var(--tx2);
  font-family: var(--mono);
  margin-bottom: 24px;
}
.payment-field {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  padding: 12px 0;
  border-bottom: 1px solid rgba(0,212,255,0.08);
}
.payment-field-label {
  font-size: 11px;
  color: var(--tx2);
  font-family: var(--mono);
  letter-spacing: 1px;
  flex-shrink: 0;
}
.payment-field-value {
  font-family: var(--mono);
  font-size: 13px;
  color: var(--tx);
  text-align: right;
}
.payment-field-value.highlight { color: var(--c); font-weight: 700; font-size: 15px; }
.payment-notice {
  margin-top: 20px;
  padding: 14px;
  background: rgba(255,187,0,0.07);
  border: 1px solid rgba(255,187,0,0.2);
  border-radius: 4px;
  font-size: 12px;
  color: rgba(228,244,255,0.7);
  line-height: 1.6;
}
.payment-notice strong { color: #ffbb00; }
.payment-unavailable {
  text-align: center;
  padding: 20px 0;
  color: var(--tx2);
  font-size: 14px;
}
/* ════════════════════════════════
   NAV EXTRAS
════════════════════════════════ */
.nav-portal-link {
  background: rgba(0,212,255,0.08);
  border: 1px solid rgba(0,212,255,0.3);
  padding: 6px 14px !important;
  border-radius: 4px;
  color: var(--c) !important;
  font-weight: 600;
  transition: all 0.2s !important;
}
.nav-portal-link:hover {
  background: rgba(0,212,255,0.15) !important;
  border-color: var(--c) !important;
}
.nav-mobile-portal {
  display: none;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--c);
  text-decoration: none;
  border: 1px solid rgba(0,212,255,0.3);
  padding: 6px 12px;
  border-radius: 4px;
}
.nav-hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 6px;
}
.nav-hamburger span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--tx);
  transition: all 0.2s;
}
.nav-mobile-menu {
  display: none;
  flex-direction: column;
  background: rgba(0,5,10,0.97);
  border-bottom: 1px solid var(--bd);
  padding: 16px 24px;
}
.nav-mobile-menu.open { display: flex; }
.nav-mobile-menu a {
  font-family: var(--mono);
  font-size: 13px;
  color: var(--tx2);
  text-decoration: none;
  padding: 10px 0;
  border-bottom: 1px solid var(--bd);
  letter-spacing: 1px;
}
.nav-mobile-menu a:last-child { border-bottom: none; }
/* ════════════════════════════════
   REGISTRATION MODAL
════════════════════════════════ */
.reg-modal {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.88);
  z-index: 1000;
  align-items: center;
  justify-content: center;
  padding: 20px;
  overflow-y: auto;
}
.reg-modal.active { display: flex; }
.reg-modal-box {
  background: #000e1c;
  border: 1px solid rgba(0,212,255,0.25);
  border-radius: 8px;
  padding: 40px 36px;
  max-width: 660px;
  width: 100%;
  position: relative;
  max-height: 90vh;
  overflow-y: auto;
}
.reg-modal-close {
  position: absolute;
  top: 14px; right: 18px;
  background: none;
  border: none;
  color: var(--tx2);
  font-size: 22px;
  cursor: pointer;
}
.reg-modal-title {
  font-family: var(--mono);
  font-size: 22px;
  color: var(--c);
  margin-bottom: 8px;
}
.reg-modal-sub {
  font-size: 13px;
  color: var(--tx2);
  margin-bottom: 28px;
  line-height: 1.6;
}
.reg-form { display: flex; flex-direction: column; gap: 0; }
.form-section { margin-bottom: 24px; }
.form-section-title {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--c);
  margin-bottom: 14px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--bd);
}
.form-group {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 14px;
}
.form-group.full { grid-template-columns: 1fr; }
.form-label {
  display: block;
  font-family: var(--mono);
  font-size: 11px;
  color: var(--tx2);
  margin-bottom: 6px;
  letter-spacing: 1px;
}
.form-input {
  width: 100%;
  padding: 10px 14px;
  background: rgba(0,15,30,0.9);
  border: 1px solid rgba(0,212,255,0.2);
  font-family: var(--mono);
  font-size: 12px;
  color: #fff;
  border-radius: 4px;
  outline: none;
  transition: border-color 0.2s;
}
.form-input:focus { border-color: var(--c); }
.form-input option { background: #000e1c; }
.form-submit {
  padding: 12px 32px;
  background: var(--c);
  color: #000;
  border: none;
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 2px;
  cursor: pointer;
  border-radius: 4px;
  transition: all 0.2s;
  width: 100%;
  margin-top: 8px;
}
.form-submit:hover { background: #00e4ff; }
.toggle-row { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.toggle-label { font-size: 13px; color: var(--tx2); flex: 1; padding-right: 16px; }
.toggle-switch {
  width: 44px; height: 24px;
  background: rgba(0,212,255,0.15);
  border: 1px solid rgba(0,212,255,0.3);
  border-radius: 12px;
  cursor: pointer;
  position: relative;
  transition: all 0.2s;
  flex-shrink: 0;
}
.toggle-switch.active { background: rgba(0,212,255,0.4); }
.toggle-slider {
  position: absolute;
  width: 18px; height: 18px;
  background: var(--c);
  border-radius: 50%;
  top: 2px; left: 2px;
  transition: transform 0.2s;
}
.toggle-switch.active .toggle-slider { transform: translateX(20px); }
.conditional-section { display: none; margin-top: 12px; }
.conditional-section.active { display: block; }
.info-text { font-size: 13px; color: var(--tx2); line-height: 1.6; }
.insurance-entries { display: flex; flex-direction: column; gap: 14px; margin-bottom: 12px; }
.insurance-entry {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr auto;
  gap: 10px;
  align-items: end;
  padding: 14px;
  background: rgba(0,212,255,0.03);
  border: 1px solid var(--bd);
  border-radius: 4px;
}
.entry-remove {
  background: rgba(255,80,80,0.1);
  border: 1px solid rgba(255,80,80,0.3);
  color: #ff6b6b;
  width: 32px; height: 32px;
  border-radius: 4px;
  cursor: pointer;
  font-size: 14px;
  transition: all 0.2s;
}
.add-insurance-btn {
  background: transparent;
  border: 1px dashed rgba(0,212,255,0.3);
  color: var(--c);
  padding: 8px 16px;
  font-family: var(--mono);
  font-size: 11px;
  cursor: pointer;
  border-radius: 4px;
  transition: all 0.2s;
  width: 100%;
}
.add-insurance-btn:hover { border-color: var(--c); background: rgba(0,212,255,0.05); }
.document-link {
  display: inline-block;
  margin-right: 12px;
  margin-bottom: 8px;
  padding: 8px 16px;
  background: rgba(0,212,255,0.08);
  border: 1px solid rgba(0,212,255,0.25);
  color: var(--c);
  text-decoration: none;
  font-family: var(--mono);
  font-size: 11px;
  border-radius: 4px;
  transition: all 0.2s;
}
.document-link:hover { background: rgba(0,212,255,0.15); }
.upload-area {
  border: 2px dashed rgba(0,212,255,0.25);
  border-radius: 6px;
  padding: 28px;
  text-align: center;
  cursor: pointer;
  transition: all 0.2s;
}
.upload-area:hover { border-color: var(--c); background: rgba(0,212,255,0.04); }
.upload-icon { font-size: 28px; color: var(--c); margin-bottom: 8px; }
.upload-text { font-size: 13px; color: var(--tx2); margin-bottom: 4px; }
.upload-hint { font-size: 11px; color: rgba(228,244,255,0.3); }
/* ════════════════════════════════
   LEGAL CONTENT
════════════════════════════════ */
#legal-content h2 { font-family: var(--mono); color: var(--c); font-size: 18px; margin-bottom: 16px; }
#legal-content h3 { font-family: var(--mono); color: var(--tx); font-size: 14px; margin: 16px 0 8px; }
#legal-content p { color: var(--tx2); font-size: 13px; line-height: 1.7; margin-bottom: 10px; }
/* ════════════════════════════════
   RESPONSIVE
════════════════════════════════ */
@media (max-width: 768px) {
  .nav-links { display: none; }
  .nav-mobile-portal { display: inline-block; }
  .nav-hamburger { display: flex; }
  .nav-cta { display: none; }
  .form-group { grid-template-columns: 1fr; }
  .insurance-entry { grid-template-columns: 1fr 1fr; }
  .insurance-entry > div:last-of-type { grid-column: 1 / -1; }
  .admin-stats { grid-template-columns: repeat(2, 1fr); }
  .landing-buttons { flex-direction: column; }
  .landing-btn { min-width: 100%; }
  .reg-modal-info-btn { font-size: 12px; padding: 10px; }
}

/* ════════════════════════════════
   GLOW FOREVER EFFECT
   ════════════════════════════════ */
@keyframes glowPulse {
  0%, 100% {
    text-shadow:
      0 0 10px rgba(0,212,255,0.8),
      0 0 20px rgba(0,212,255,0.6),
      0 0 40px rgba(0,212,255,0.4),
      0 0 80px rgba(0,212,255,0.2);
    color: #00f0ff;
  }
  50% {
    text-shadow:
      0 0 15px rgba(0,212,255,1),
      0 0 30px rgba(0,212,255,0.8),
      0 0 60px rgba(0,212,255,0.5),
      0 0 100px rgba(0,212,255,0.3),
      0 0 140px rgba(0,212,255,0.15);
    color: #fff;
  }
}
.glow-forever {
  animation: glowPulse 2.5s ease-in-out infinite;
  font-weight: 800;
  letter-spacing: 3px;
}

/* ════════════════════════════════
   LANDING CHOICE SCREEN
   ════════════════════════════════ */
.landing-choice {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 900;
  background: rgba(0,5,8,0.97);
  justify-content: center;
  align-items: center;
  flex-direction: column;
}
.landing-choice.active {
  display: flex;
}
.landing-inner {
  text-align: center;
  max-width: 600px;
  padding: 40px 24px;
}
.landing-logo {
  font-size: 52px;
  color: var(--c);
  font-weight: 700;
  margin-bottom: 16px;
  text-shadow: 0 0 30px rgba(0,212,255,0.5);
}
.landing-title {
  font-family: var(--sans);
  font-size: 28px;
  font-weight: 700;
  color: var(--tx);
  margin-bottom: 8px;
  letter-spacing: -0.5px;
}
.landing-sub {
  font-family: var(--mono);
  font-size: 12px;
  color: var(--tx3);
  letter-spacing: 2px;
  margin-bottom: 48px;
}
.landing-buttons {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}
.landing-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 28px 24px 22px;
  min-width: 170px;
  border: 1px solid var(--bd);
  border-radius: 12px;
  background: rgba(0,212,255,0.03);
  cursor: pointer;
  transition: all 0.3s ease;
  text-decoration: none;
}
.landing-btn:hover {
  border-color: var(--c);
  background: rgba(0,212,255,0.08);
  transform: translateY(-4px);
  box-shadow: 0 8px 32px rgba(0,212,255,0.15);
}
.landing-btn-icon {
  font-size: 28px;
  color: var(--c);
  font-weight: 700;
  margin-bottom: 4px;
}
.landing-btn-label {
  font-family: var(--mono);
  font-size: 15px;
  font-weight: 700;
  color: var(--tx);
  letter-spacing: 0.5px;
}
.landing-btn-desc {
  font-size: 11px;
  color: var(--tx3);
  font-family: var(--mono);
}
.landing-btn-primary { border-color: rgba(0,212,255,0.3); }
.landing-btn-primary .landing-btn-icon { font-size: 32px; }
.landing-btn-primary:hover {
  background: rgba(0,212,255,0.12);
  box-shadow: 0 8px 40px rgba(0,212,255,0.25);
}
.landing-btn-accent { border-color: rgba(0,255,136,0.2); }
.landing-btn-accent .landing-btn-icon { color: #00ff88; }
.landing-btn-accent .landing-btn-label { color: #00ff88; }
.landing-btn-accent:hover {
  border-color: #00ff88;
  background: rgba(0,255,136,0.08);
  box-shadow: 0 8px 32px rgba(0,255,136,0.15);
}
.landing-btn-ghost {
  border-style: dashed;
  background: transparent;
}
.landing-btn-ghost .landing-btn-icon { color: var(--tx2); font-size: 24px; }
.landing-btn-ghost .landing-btn-label { color: var(--tx2); }
.landing-btn-ghost:hover {
  border-color: var(--tx2);
  background: rgba(228,244,255,0.03);
}

/* ═══ REG MODAL "Mi ez?" BUTTON ═══ */
.reg-modal-info-btn {
  display: block;
  width: 100%;
  margin-top: 12px;
  padding: 12px;
  background: transparent;
  border: 1px dashed var(--bd);
  border-radius: 8px;
  color: var(--tx3);
  font-family: var(--mono);
  font-size: 13px;
  cursor: pointer;
  transition: all 0.25s;
  text-align: center;
}
.reg-modal-info-btn:hover {
  border-color: var(--c);
  color: var(--c);
  background: rgba(0,212,255,0.04);
}
