:root{
  --bg:#0f1114;
  --bg2:#2b1e12;
  --text:#ffffff;
  --muted:rgba(255,255,255,.82);
  --muted2:rgba(255,255,255,.72);
  --accent:#f0961d;
  --accent2:#f9ba50;
  --btnText:#000000;

  --radius:9999px;
  --shadowGlow:0 0 30px rgba(240,150,29,.4);

  --fontHead:"Orbitron",ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;
  --fontBody:"Space Grotesk",system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;

  --container:1200px;
  --padY:80px;
  --padX:60px;
  --gap:24px;

  --border:rgba(249,186,80,.18);
  --border2:rgba(255,255,255,.10);
  --cardBg:rgba(255,255,255,.04);
  --cardBg2:rgba(255,255,255,.06);
}

*,
*::before,
*::after{
  box-sizing:border-box;
  overflow-wrap:break-word;
}

html{
  font-size:100%;
  overflow-x:hidden;
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
}

body{
  margin:0;
  font-size:1rem;
  font-family:var(--fontBody);
  color:var(--text);
  background:#0f1114;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* Body background gradient - applied after initial paint via pseudo-element */
body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-1;
  background:radial-gradient(1200px 700px at 20% 10%, rgba(240,150,29,.14) 0%, rgba(15,17,20,0) 55%),
             radial-gradient(900px 600px at 85% 30%, rgba(249,186,80,.10) 0%, rgba(15,17,20,0) 60%),
             linear-gradient(180deg, #0f1114 0%, #0b0c0f 100%);
  pointer-events:none;
  contain:strict;
}

p{
  margin:0 0 1rem;
  color:var(--muted);
  -webkit-hyphens:auto;
  hyphens:auto;
}

a{ color:inherit; text-decoration:none; }
a:hover{ text-decoration:underline; }

h1,h2,h3,h4,h5,h6{
  font-family:var(--fontHead);
  color:var(--text);
  margin:0 0 .75rem;
  letter-spacing:.2px;
  hyphens:none;
}

h1{ font-size:clamp(2.5rem, 3.3vw, 3.4rem); line-height:1.18; }
h2{ font-size:clamp(2rem, 2.4vw, 2.5rem); line-height:1.22; }
h3{ font-size:clamp(1.3rem, 1.4vw, 1.6rem); line-height:1.28; }

img{ max-width:100%; height:auto; display:block; }

.container{
  width:min(var(--container), calc(100% - (var(--padX) * 2)));
  margin:0 auto;
}

.section{
  padding:var(--padY) var(--padX);
  position:relative;
}

.section-alt{
  background:
    radial-gradient(900px 600px at 15% 40%, rgba(240,150,29,.10) 0%, rgba(43,30,18,0) 60%),
    linear-gradient(180deg, rgba(43,30,18,.78) 0%, rgba(43,30,18,.60) 100%);
  border-top:1px solid var(--border2);
  border-bottom:1px solid var(--border2);
}

.section-head{
  max-width:920px;
  margin:0 auto 28px;
  text-align:left;
}

.section-head p{ margin:0; color:var(--muted2); }

.features-section,
.how-section,
.faq-section,
.testimonials-section,
.risk-section{
  content-visibility:auto;
  contain-intrinsic-size:auto 500px;
}

.cards-grid,
.features-grid,
.steps-grid,
.testimonials-grid,
.faq-grid-container{
  contain:layout;
}

/* Skip link */
.skip-link{
  position:absolute;
  top:-40px;
  left:0;
  background:var(--accent);
  color:var(--btnText);
  padding:8px;
  z-index:10001;
  font-size:14px;
}
.skip-link:focus{ top:0; }

/* Header */
.site-header{
  position:sticky;
  top:0;
  z-index:999;
  background:rgba(15,17,20,.94);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  border-bottom:1px solid rgba(255,255,255,.08);
  will-change:transform;
}

.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:14px 0;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  font-family:var(--fontHead);
  font-weight:700;
  letter-spacing:.6px;
}

.brand-mark{
  width:14px;
  height:14px;
  border-radius:9999px;
  background:linear-gradient(135deg, var(--accent), var(--accent2));
  box-shadow:var(--shadowGlow);
}

nav[aria-label="Main navigation"]{
  display:flex;
  align-items:center;
  gap:14px;
}

.nav-links{
  display:flex;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
}

.nav-links a{
  font-family:var(--fontBody);
  font-weight:600;
  color:rgba(255,255,255,.86);
  padding:10px 12px;
  border-radius:var(--radius);
}

.nav-links a:hover{
  text-decoration:none;
  background:rgba(255,255,255,.06);
}

.nav-cta{
  border:1px solid rgba(240,150,29,.55);
  box-shadow:0 0 0 rgba(0,0,0,0);
}

/* Hamburger */
.hamburger-lines{
  width:22px;
  height:2px;
  background:currentColor;
  display:block;
  position:relative;
}
.hamburger-lines::before,
.hamburger-lines::after{
  content:"";
  position:absolute;
  left:0;
  width:22px;
  height:2px;
  background:currentColor;
}
.hamburger-lines::before{ top:-7px; }
.hamburger-lines::after{ top:7px; }

/* Mobile menu colors required */
.mobile-menu{ background:var(--bg); }

/* Language dropdown (required base + theme fit) */
.lang-menu{ position:relative; }
.lang-btn{
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:.25rem;
  padding:.35rem .6rem;
  border:1px solid currentColor;
  border-radius:4px;
  font-size:.85rem;
  color:inherit;
  opacity:.75;
}
.lang-btn:hover{ opacity:1; }
.lang-arrow{ font-size:.7rem; transition:transform .2s; }
.lang-dropdown{
  display:none;
  position:absolute;
  top:100%;
  right:0;
  margin-top:.25rem;
  background:#fff;
  border:1px solid #ddd;
  border-radius:6px;
  box-shadow:0 4px 12px rgba(0,0,0,.1);
  max-height:320px;
  overflow-y:auto;
  z-index:1000;
  min-width:160px;
  padding:.25rem 0;
}
.lang-menu:hover .lang-dropdown,
.lang-menu:focus-within .lang-dropdown{ display:block; }
.lang-menu:hover .lang-arrow,
.lang-menu:focus-within .lang-arrow{ transform:rotate(180deg); }
.lang-option{
  display:block;
  padding:.4rem 1rem;
  text-decoration:none;
  color:#333;
  font-size:.85rem;
  white-space:nowrap;
}
.lang-option:hover{ background:#f0f0f0; }
.lang-option.active{ font-weight:700; background:#f5f5f5; }

/* Icons CLS reservation */
.trust-badge i,
[class*="fa-"]{
  display:inline-block;
  width:1em;
  height:1em;
  vertical-align:middle;
  line-height:1;
  aspect-ratio:1/1;
}

/* Touch optimizations for mobile */
@media (pointer:coarse){
  .nav-links a,
  .btn,
  .submit-btn,
  .faq-card summary,
  .risk-item summary,
  .lang-option,
  .mobile-menu a{
    min-height:44px;
    min-width:44px;
  }
  .field input{
    min-height:48px;
    font-size:16px; /* Prevents iOS zoom on focus */
  }
}

/* Hero */
.hero-section{
  padding:80px 60px;
  min-height:600px;
  position:relative;
;contain:layout style}

.hero-inner{
  display:flex;
  align-items:flex-start;
  gap:40px;
  position:relative;
  z-index:1;
}

.hero-left{ flex:1; }

.hero-kicker{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:18px;
}

.kicker-pill{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:8px 14px;
  border-radius:var(--radius);
  background:rgba(255,255,255,.05);
  border:1px solid rgba(249,186,80,.18);
  color:rgba(255,255,255,.90);
  font-weight:600;
  font-family:var(--fontBody);
}

.hero-lead{
  font-size:1.05rem;
  max-width:64ch;
  color:var(--muted);
  margin-bottom:18px;
}

.hero-quicklist{
  list-style:none;
  padding:0;
  margin:0 0 18px;
  display:flex;
  flex-wrap:wrap;
  gap:14px;
}

.quick-item{
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:12px 14px;
  border-radius:18px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  min-width:min(340px, 100%);
}

.quick-item span{ color:rgba(255,255,255,.88); }

.trust-row{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:12px;
  contain:content;
}

.trust-badge{
  display:flex;
  align-items:center;
  gap:10px;
  padding:12px 14px;
  border-radius:18px;
  background:rgba(43,30,18,.35);
  border:1px solid rgba(240,150,29,.22);
  color:rgba(255,255,255,.88);
}

.hero-form{
  width:100%;
  max-width:460px;
  flex-shrink:0;
}

.form-shell{
  background:
    linear-gradient(180deg, rgba(255,255,255,.06) 0%, rgba(255,255,255,.03) 100%);
  border:1px solid rgba(249,186,80,.22);
  border-radius:28px;
  padding:22px;
  box-shadow:var(--shadowGlow);
}

.form-title{
  font-size:1.35rem;
  line-height:1.25;
  margin-bottom:8px;
}

.form-subtitle{
  margin:0 0 14px;
  color:rgba(255,255,255,.82);
  font-size:.98rem;
}

/* Form (required IDs/classes preserved) */
.form-wrapper{ width:100%; }

.form-message{
  padding:10px 12px;
  border-radius:14px;
  font-size:.9rem;
  display:none;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  margin-bottom:12px;
}
.form-message.error{ display:block; background:rgba(255,40,40,.10); border-color:rgba(255,40,40,.25); }
.form-message.success{ display:block; background:rgba(34,197,94,.10); border-color:rgba(34,197,94,.25); }

.field{
  position:relative;
  margin-bottom:14px;
}

.field input{
  width:100%;
  height:48px;
  padding:14px 16px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(15,17,20,.55);
  color:var(--text);
  font-family:var(--fontBody);
  font-size:1rem;
  outline:none;
}

.field input:focus{
  box-shadow:0 0 0 2px rgba(240,150,29,.18), var(--shadowGlow);
}

.field label{
  position:absolute;
  left:14px;
  top:50%;
  transform:translateY(-50%);
  padding:0 8px;
  border-radius:9999px;
  background:rgba(15,17,20,.85);
  color:rgba(255,255,255,.80);
  font-size:.9rem;
  pointer-events:none;
}

.field input:not(:placeholder-shown) + label,
.field input:focus + label{
  top:0;
  transform:translateY(-50%);
  font-size:.78rem;
  color:rgba(255,255,255,.90);
}

.phone-field label{
  position:static;
  transform:none;
  display:block;
  margin-top:8px;
  margin-left:6px;
  background:transparent;
  padding:0;
  font-size:.9rem;
  color:rgba(255,255,255,.82);
}

.phone-input-wrapper{
  display:flex;
  align-items:center;
  border:1px solid rgba(255,255,255,.14);
  border-radius:18px;
  background:rgba(15,17,20,.55);
}

.phone-input-wrapper:focus-within{
  box-shadow:0 0 0 2px rgba(240,150,29,.18), var(--shadowGlow);
}

.phone-prefix{
  padding:0 12px;
  min-width:64px;
  height:48px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:rgba(255,255,255,.90);
  font-weight:700;
  border-right:1px solid rgba(255,255,255,.10);
  white-space:nowrap;
  background:linear-gradient(180deg, rgba(240,150,29,.18), rgba(240,150,29,.06));
}

.phone-input-wrapper input{
  border:none !important;
  background:transparent;
  height:48px;
  padding:14px 14px;
}

.submit-btn{
  width:100%;
  min-height:50px;
  border-radius:var(--radius);
  border:1px solid rgba(240,150,29,.70);
  background:transparent;
  color:var(--text);
  font-weight:800;
  letter-spacing:.6px;
  text-transform:uppercase;
  cursor:pointer;
  box-shadow:0 0 0 rgba(0,0,0,0);
  transition:transform .2s ease;
}
.submit-btn:hover:not(:disabled){
  transform:translateY(-2px);
}
.submit-btn:disabled{ opacity:.65; cursor:not-allowed; }

/* Form disclaimer text (required) */
.form-disclaimer{ font-size:.85rem; color:inherit; line-height:1.4; margin-top:.5rem; }
.form-disclaimer a{ text-decoration:underline; }

/* Decorative hero - contain:strict prevents CLS, transform promotes to compositor layer */
.hero-decor{ position:absolute; inset:0; overflow:hidden; pointer-events:none; z-index:-1; contain:strict; transform:translateZ(0); ;will-change:transform}
.orb{
  position:absolute;
  border-radius:50%;
  filter:blur(60px);
  opacity:.55;
  contain:strict;
;will-change:transform;backface-visibility:hidden}
.orb-a{
  width:420px; height:420px;
  left:-140px; top:-120px;
  background:rgba(240,150,29,.30);
;will-change:transform;backface-visibility:hidden}
.orb-b{
  width:360px; height:360px;
  right:-120px; bottom:-140px;
  background:rgba(249,186,80,.22);
}
.grid-glow{
  position:absolute;
  inset:-2px;
  background:
    linear-gradient(rgba(249,186,80,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(249,186,80,.06) 1px, transparent 1px);
  background-size:56px 56px;
  opacity:.25;
  mask-image:radial-gradient(circle at 40% 30%, rgba(0,0,0,1) 0%, rgba(0,0,0,.2) 55%, rgba(0,0,0,0) 78%);
}

/* Feature cards */
.features-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
  margin-top:28px;
}

.card{
  background:linear-gradient(180deg, rgba(255,255,255,.06) 0%, rgba(255,255,255,.03) 100%);
  border:1px solid rgba(255,255,255,.10);
  border-radius:26px;
  padding:22px;
  box-shadow:0 12px 30px rgba(0,0,0,.35);
  transition:transform .2s ease;
  contain:content;
}

.card:hover{
  transform:translateY(-2px);
}

.icon-wrap{
  width:56px; height:56px;
  border-radius:22px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:radial-gradient(circle at 30% 30%, rgba(240,150,29,.22), rgba(255,255,255,.02) 60%);
  border:1px solid rgba(240,150,29,.30);
  box-shadow:0 0 0 rgba(0,0,0,0);
  margin-bottom:12px;
}

.icon-wrap i{ font-size:1.2rem; color:var(--accent2); }

.card p{ color:rgba(255,255,255,.78); margin:0; }

/* Steps */
.steps-grid{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:24px;
  margin-top:28px;
}

.step-card{ position:relative; }
.step-number{
  position:absolute;
  top:16px;
  right:16px;
  z-index:0;
  font-family:var(--fontHead);
  font-weight:800;
  font-size:2.2rem;
  color:rgba(249,186,80,.20);
  letter-spacing:.5px;
}
.step-card h3,
.step-card p{ position:relative; z-index:1; }
.step-card p{ margin:0; }

/* FAQ two col */
.faq-two-col{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  margin-top:18px;
}

.faq-column{ display:flex; flex-direction:column; gap:14px; }

.faq-card{
  background:linear-gradient(180deg, rgba(255,255,255,.06) 0%, rgba(255,255,255,.03) 100%);
  border:1px solid rgba(255,255,255,.10);
  border-radius:22px;
  padding:0;
}

.faq-card summary{
  cursor:pointer;
  padding:16px 18px;
  font-weight:800;
  font-family:var(--fontBody);
  color:rgba(255,255,255,.92);
  list-style:none;
}
.faq-card summary::-webkit-details-marker{ display:none; }
.faq-card .faq-answer{ padding:0 18px 16px; }
.faq-card .faq-answer p{ margin:0; color:rgba(255,255,255,.78); }

/* CTA floating card */
.cta-floating-card{
  max-width:900px;
  margin:0 auto;
  text-align:center;
  border-radius:32px;
  padding:44px 34px;
  background:
    radial-gradient(700px 260px at 50% 0%, rgba(240,150,29,.22) 0%, rgba(15,17,20,0) 70%),
    linear-gradient(180deg, rgba(255,255,255,.06) 0%, rgba(255,255,255,.03) 100%);
  border:1px solid rgba(249,186,80,.22);
  box-shadow:var(--shadowGlow);
}

.cta-actions{
  display:flex;
  justify-content:center;
  gap:14px;
  flex-wrap:wrap;
  margin-top:18px;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 18px;
  border-radius:var(--radius);
  font-family:var(--fontBody);
  font-weight:800;
  text-decoration:none;
  transition:transform .2s ease;
}

.btn-outline{
  border:1px solid rgba(240,150,29,.70);
  background:transparent;
}
.btn-outline:hover{ transform:translateY(-2px); text-decoration:none; }

.btn-ghost{
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.04);
}
.btn-ghost:hover{ transform:translateY(-2px); text-decoration:none; }

/* Testimonials */
.testimonials-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
  margin-top:28px;
}

.testimonial-header{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:10px;
}

.avatar{
  width:44px;
  height:44px;
  border-radius:9999px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-family:var(--fontHead);
  font-weight:800;
  background:linear-gradient(135deg, rgba(240,150,29,.25), rgba(249,186,80,.10));
  border:1px solid rgba(240,150,29,.35);
}

.testimonial-name{
  font-family:var(--fontBody);
  font-weight:800;
  margin:0 0 4px;
  font-size:1rem;
}

.testimonial-stars i{ color:var(--accent2); }

.testimonial-text{ margin:0; color:rgba(255,255,255,.78); }

/* Risk accordion */
.risk-accordion{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  margin-top:18px;
}

.risk-item{
  background:linear-gradient(180deg, rgba(255,255,255,.06) 0%, rgba(255,255,255,.03) 100%);
  border:1px solid rgba(255,255,255,.10);
  border-radius:22px;
  padding:0;
}

.risk-item summary{
  list-style:none;
  cursor:pointer;
  padding:16px 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  font-weight:900;
  font-family:var(--fontBody);
}
.risk-item summary::-webkit-details-marker{ display:none; }

.risk-sum{
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.risk-plus{
  font-family:var(--fontHead);
  color:rgba(249,186,80,.85);
}

.risk-body{ padding:0 18px 16px; }
.risk-body p{ margin:0; color:rgba(255,255,255,.78); }

.risk-cta-card{
  margin-top:18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
  padding:20px 22px;
  border-radius:28px;
  background:rgba(43,30,18,.40);
  border:1px solid rgba(240,150,29,.22);
}

.risk-cta-text h3{ margin:0 0 6px; }
.risk-cta-text p{ margin:0; }

.site-footer{
  background:linear-gradient(180deg, rgba(43,30,18,.55) 0%, rgba(15,17,20,1) 100%);
  border-top:1px solid rgba(255,255,255,.08);
  padding:60px 60px 26px;
}

.footer-top{
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  gap:24px;
  align-items:start;
}

.footer-title{
  font-size:1.1rem;
  margin-bottom:10px;
}

.footer-links{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.footer-links a{ color:rgba(255,255,255,.82); }
.footer-links a:hover{ color:#fff; text-decoration:underline; }

.footer-disclaimer-wrap{
  margin-top:34px;
  padding:0;
}

.footer-disclaimer{
  width:100%;
  height:auto;
  max-width:1200px;
  margin:0 auto;
}

.footer-bottom{
  margin-top:22px;
  border-top:1px solid rgba(255,255,255,.08);
  padding-top:16px;
  text-align:center;
}
.footer-bottom p{ margin:0; color:rgba(255,255,255,.72); }

/* Focus */
:focus-visible{
  outline:2px solid var(--accent2);
  outline-offset:2px;
}

/* ===== MANDATORY POPUP CSS (verbatim) ===== */
/* Cookie Consent - fixed bottom banner with BLACK text */
.cookie-consent { display:none; position:fixed; bottom:0; left:0; right:0; background:#ffffff; border-top:1px solid rgba(0,0,0,.1); padding:16px 24px; z-index:9999; box-shadow:0 -2px 10px rgba(0,0,0,.1); }
.cookie-content { max-width:1200px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; color:#000000; }
.cookie-content p { color:#000000; margin:0; }
.cookie-content a { color:#0066cc !important; text-decoration:underline; font-weight:600; }
.cookie-content a:hover { color:#004499 !important; }
.cookie-btn { padding:10px 24px; background:var(--accent); color:#000; border:none; border-radius:4px; font-weight:700; cursor:pointer; }

/* Disclaimer Popup - Full width bottom banner with Read More */
.disclaimer-popup-overlay { position:fixed; bottom:0; left:0; width:100%; z-index:10000; pointer-events:none; opacity:0; transition:opacity 0.3s ease; }
.disclaimer-popup-overlay.active { opacity:1; pointer-events:auto; }
.disclaimer-popup { background:#ffffff; color:#333; width:100%; box-shadow:0 -2px 15px rgba(0,0,0,.1); border-top:1px solid #e5e5e5; transform:translateY(100%); transition:transform 0.3s ease; pointer-events:auto; }
.disclaimer-popup-overlay.active .disclaimer-popup { transform:translateY(0); }
.disclaimer-popup-header { display:flex; justify-content:flex-start; align-items:center; padding:10px 30px; border-bottom:1px solid #eee; }
.disclaimer-popup-header h4 { margin:0; font-size:13px; font-weight:600; color:#1a1a1a; flex:1; }
.disclaimer-close-btn { background:none; border:none; font-size:18px; color:#999; cursor:pointer; padding:0; line-height:1; }
.disclaimer-close-btn:hover { color:#333; }
.disclaimer-popup-body { padding:12px 30px; }
.disclaimer-popup-row { display:flex; align-items:flex-start; justify-content:space-between; gap:24px; }
.disclaimer-popup-content { flex:1; }
.disclaimer-main-text { font-size:12px; line-height:1.5; color:#555; margin:0 0 6px 0; }
.disclaimer-main-text a,.disclaimer-popup-body a { color:#0066cc !important; text-decoration:underline; font-weight:600; }
.disclaimer-main-text a:hover,.disclaimer-popup-body a:hover { color:#004499 !important; }
.disclaimer-read-more { font-size:12px; color:#0066cc; text-decoration:underline; cursor:pointer; }
.disclaimer-read-more:hover { color:#004499; }
.disclaimer-more-text { max-height:0; overflow:hidden; transition:max-height 0.4s ease, margin 0.3s ease, padding 0.3s ease; margin-top:0; padding-top:0; border-top:none; }
.disclaimer-more-text.expanded { max-height:400px; margin-top:12px; padding-top:12px; border-top:1px solid #eee; overflow-y:auto; }
.popup-svg { width:100%; height:auto; max-width:540px; display:block; margin:0 auto; }
.popup-svg-mobile { display:none; }
.disclaimer-popup-footer { flex-shrink:0; }
.disclaimer-understand-btn { padding:10px 24px; background:var(--accent); color:#000; border:none; border-radius:4px; font-weight:600; cursor:pointer; font-size:13px; }
.disclaimer-understand-btn:hover { opacity:0.9; }
@media (max-width:768px) { .disclaimer-popup-header { padding:8px 16px; } .disclaimer-popup-body { padding:10px 16px; } .disclaimer-popup-row { flex-direction:column; gap:12px; } .disclaimer-popup-footer { width:100%; } .popup-svg { display:none; } .popup-svg-mobile { display:block; width:100%; height:auto; } }

/* Terms Popup - centered overlay */
.terms-popup-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.6); z-index:10000; align-items:center; justify-content:center; padding:20px; }
.terms-popup-content { background:#fff; color:#333; border-radius:8px; max-width:700px; width:100%; max-height:90vh; overflow:auto; position:relative; padding:20px; }
.terms-popup-content .close-btn { position:absolute; top:12px; right:12px; background:none; border:none; font-size:28px; color:#333; cursor:pointer; }
.terms-img { width:100%; height:auto; }

/* Desktop/Mobile visibility - CRITICAL: These rules must NOT be overridden! */
.desktop-only { display:block !important; }
.mobile-only { display:none !important; }
@media (max-width:640px) { .desktop-only { display:none !important; } .mobile-only { display:block !important; } }

/* Mobile hamburger toggle - CSS only, no JavaScript */
.mobile-toggle-input { display: none; }
.hamburger { display: none; background: transparent; border: 1px solid currentColor; color: inherit; padding: 10px 12px; cursor: pointer; opacity: 0.75; }
.hamburger:hover { opacity: 1; }
.mobile-menu { display: none; background: var(--bg, #111); border-top: 1px solid rgba(255,255,255,.1); }
.mobile-menu a { display: block; padding: 12px 20px; color: var(--text, #fff); text-decoration: none; border-bottom: 1px solid rgba(255,255,255,.06); }
.mobile-menu a:hover { background: rgba(255,255,255,.08); }
@media (max-width:768px) { .nav-links { display: none; } .hamburger { display: flex; align-items: center; justify-content: center; } .mobile-toggle-input:checked ~ .mobile-menu { display: block; } }

/* Language Dropdown - ALWAYS BLACK TEXT on WHITE background (dropdown only, not the trigger button) */
.lang-dropdown,.lang-list { background:#ffffff; }
.lang-option { color:#000000 !important; background:#ffffff; }
.lang-option:hover { background:rgba(0,0,0,.05); color:#000000 !important; }
.lang-select option { color:#000000; background:#ffffff; }

/* Responsive - Tablet landscape */
@media (max-width:1024px){
  :root{
    --padX:30px;
    --padY:60px;
  }
  .hero-inner{ gap:28px; }
  .hero-form{ max-width:400px; }
  .features-grid{ grid-template-columns:repeat(2, 1fr); }
  .steps-grid{ grid-template-columns:repeat(2, 1fr); }
  .footer-top{ grid-template-columns:1fr 1fr; gap:20px; }
}

/* Responsive - Tablet portrait / Large mobile */
@media (max-width:768px){
  :root{
    --padX:16px;
    --padY:40px;
    --gap:16px;
  }
  .container{ width:min(var(--container), calc(100% - 32px)); }
  section, .section, .section-alt{ padding:30px 16px; }

  .hero-section{ min-height:auto; padding:30px 16px; }
  .hero-inner{ flex-direction:column; align-items:flex-start; padding:0; gap:24px; }
  .hero-left{ text-align:center; }
  .hero-quicklist{ justify-content:center; }
  .hero-kicker{ justify-content:center; }
  .trust-row{ grid-template-columns:1fr; justify-items:center; }
  .hero-form{ width:100%; max-width:520px; }

  h1{ font-size:1.8rem; }
  .features-grid, .steps-grid, .testimonials-grid, .risk-accordion{ grid-template-columns:1fr !important; }
  .faq-two-col{ grid-template-columns:1fr; }

  .footer-top{ grid-template-columns:1fr; text-align:center; }
  .footer-links{ align-items:center; }
  .site-footer{ padding:40px 16px 20px; }

  .cta-floating-card{ padding:28px 18px; border-radius:22px; }
  .cta-actions{ flex-direction:column; align-items:center; }
  .cta-actions .btn{ width:100%; max-width:320px; }

  .risk-cta-card{ flex-direction:column; text-align:center; align-items:center; padding:16px; }

  /* Reduce decorative blur on mobile for performance */
  .orb{ opacity:.3; filter:blur(40px); }
  .grid-glow{ display:none; }

  /* Reduce backdrop-filter on mobile for performance */
  .site-header{
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
    background:rgba(15,17,20,.97);
  }

  body{ overflow-x:hidden; }
}

/* Responsive - Small mobile */
@media (max-width:480px){
  h1{ font-size:1.5rem; }
  h2{ font-size:1.3rem; }
  h3{ font-size:1.1rem; }

  .hero-kicker{ flex-direction:column; align-items:center; }
  .kicker-pill{ font-size:.85rem; padding:6px 12px; }

  .form-shell{ padding:16px; border-radius:20px; }
  .form-title{ font-size:1.15rem; }

  .quick-item{ min-width:100%; padding:10px 12px; }
  .trust-badge{ padding:10px 12px; font-size:.9rem; }

  .card{ padding:16px; border-radius:18px; }
  .cta-floating-card{ padding:20px 14px; }

  .hero-lead{ font-size:.95rem; }
  .section-head p{ font-size:.92rem; }

  /* Ensure buttons are large enough for mobile tap */
  .submit-btn{ height:52px; font-size:.95rem; }
  .btn{ padding:14px 18px; }
}

/* Responsive - Very small mobile */
@media (max-width:360px){
  h1{ font-size:1.3rem; }
  h2{ font-size:1.15rem; }
  .container{ width:calc(100% - 20px); }
  section, .section, .section-alt{ padding:24px 10px; }
  .form-shell{ padding:12px; }
  .field input{ height:44px; padding:10px 12px; font-size:.95rem; }
  .phone-prefix{ min-width:52px; padding:0 8px; }
}

/* Landscape phone */
@media (max-height:500px) and (orientation:landscape){
  .hero-section{ min-height:auto; padding:20px 16px; }
  .hero-inner{ gap:16px; }
}

/* Reduced motion - performance & accessibility */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:0.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.01ms !important;
    scroll-behavior:auto !important;
  }
  .orb,.grid-glow,.hero-decor{ display:none; }
}
/* === translation-safe: prevent text overflow with longer languages (DE, FR, etc.) === */
body {
  overflow-wrap: break-word;
  word-wrap: break-word;
}
h1, h2, h3, h4, p, span, a, li, label, button, .btn, .submit-btn,
.kicker, .kicker-pill, .kicker-chip, .kicker-text,
.chip, .tag, .badge, .pill, .pill-text,
.circular-label, .progress-label,
.stat-title, .stat-desc, .stat-kicker, .stat-label,
.metric-label, .metric-value,
.glow-stat-card, .feature-card, .step-card,
.faq-question, .faq-q,
.card h3, .card p,
.form-disclaimer,
.terms-read-more,
.nav-links a, .mobile-menu a,
.footer-links a {
  overflow-wrap: break-word;
  word-wrap: break-word;
}

/* translation-safe: kicker pills and mobile overflow */
.kicker-pill, .kicker-chip, .kicker-text {
  hyphens: auto;
  -webkit-hyphens: auto;
}
.terms-read-more {
  white-space: normal;
}
@media (max-width: 480px) {
  .kicker-pill, .kicker-chip {
    font-size: 0.8rem;
    padding: 6px 10px;
    white-space: normal;
    text-align: center;
  }
  .phone-prefix {
    min-width: auto;
    padding: 0 6px;
    font-size: 12px;
  }
}

/* translation-safe: mobile layout */
@media (max-width: 768px) {
  .step-card { max-width: 100%; width: 100%; min-width: 0; }
  .steps-arrows, .steps-grid { align-items: stretch; }
  .numbered-card, .feature-card { min-height: auto; overflow: visible; }
  .logo-item { min-width: 0; width: 100%; }
  .logos-grid { flex-direction: column; align-items: stretch; }
  .mini-trust-item { min-width: 0; flex-basis: 100%; }
  .chip { max-width: 100%; }
  .hero-metrics { flex-direction: column; }
  .metric { min-width: 0; width: 100%; }
}
@media (max-width: 480px) {
  .step-card h3 { font-size: 1.15rem; }
  .numbered-card h3, .feature-card h3 { font-size: 1.15rem; }
  .chip { font-size: 0.85rem; padding: 8px 12px; }
  .check-item { font-size: 0.9rem; padding: 12px; }
  .trust-badge { padding: 12px; }
  .trust-badge strong { font-size: 12px; }
  .trust-badge span { font-size:12px; }
}
