/* ===========================
   Vless Design System v2
   UI/UX Pro Max Guidelines Applied
   =========================== */

/* --- Reset & Base --- */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  /* Color Tokens (Semantic) */
  --c-primary:#7C3AED;
  --c-primary-soft:#A78BFA;
  --c-primary-deep:#5B21B6;
  --c-primary-bg:rgba(124,58,237,.04);
  --c-primary-border:rgba(124,58,237,.12);

  --c-surface:#0F0A1E;
  --c-surface-mid:#16102B;
  --c-surface-light:#1A1040;

  --c-success:#10B981;
  --c-success-bg:rgba(16,185,129,.06);
  --c-error:#DC2626;
  --c-error-bg:#FEF2F2;
  --c-error-border:#FECACA;
  --c-warning:#F59E0B;

  --c-text:#1B2438;
  --c-text-mid:#4A5568;
  --c-text-muted:#8896AB;

  --c-bg:#FAFBFD;
  --c-white:#FFFFFF;
  --c-border:#E8ECF2;
  --c-border-hover:rgba(124,58,237,.3);

  /* Spacing Scale (8dp rhythm) */
  --sp-1:4px; --sp-2:8px; --sp-3:12px; --sp-4:16px;
  --sp-5:20px; --sp-6:24px; --sp-7:28px; --sp-8:32px;
  --sp-10:40px; --sp-12:48px; --sp-16:64px; --sp-20:80px;

  /* Typography Scale */
  --fs-xs:12px; --fs-sm:13px; --fs-base:15px; --fs-md:16px;
  --fs-lg:18px; --fs-xl:20px; --fs-2xl:24px; --fs-3xl:28px;
  --fs-4xl:32px; --fs-5xl:40px; --fs-6xl:48px;

  /* Border Radius */
  --r-sm:8px; --r-md:12px; --r-lg:16px; --r-xl:20px; --r-2xl:24px; --r-full:9999px;

  /* Shadows (Elevation Scale) */
  --sh-1:0 1px 2px rgba(15,10,30,.04),0 1px 3px rgba(15,10,30,.06);
  --sh-2:0 4px 12px rgba(15,10,30,.06),0 2px 4px rgba(15,10,30,.04);
  --sh-3:0 8px 24px rgba(15,10,30,.08),0 4px 8px rgba(15,10,30,.04);
  --sh-4:0 12px 40px rgba(15,10,30,.1),0 4px 12px rgba(15,10,30,.05);
  --sh-primary:0 8px 28px rgba(124,58,237,.16),0 2px 6px rgba(124,58,237,.08);

  /* Transitions */
  --ease-out:cubic-bezier(.22,1,.36,1);
  --ease-spring:cubic-bezier(.34,1.56,.64,1);
  --dur-fast:150ms;
  --dur-normal:250ms;
  --dur-slow:350ms;
}

/* --- Reduced Motion --- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:0.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:0.01ms!important;
  }
}

html{scroll-behavior:smooth}
body{
  font-family:'DM Sans','Noto Sans JP',system-ui,sans-serif;
  color:var(--c-text);
  background:var(--c-bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  font-size:var(--fs-base);
  line-height:1.7;
}
a{color:var(--c-primary);text-decoration:none;transition:color var(--dur-fast) var(--ease-out)}
a:hover{color:var(--c-primary-deep)}

/* Focus visible (Accessibility) */
:focus-visible{
  outline:2px solid var(--c-primary);
  outline-offset:2px;
  border-radius:var(--r-sm);
}

/* Skip Link (Accessibility) */
.skip-link{
  position:absolute;top:-100%;left:var(--sp-4);
  background:var(--c-primary);color:var(--c-white);
  padding:var(--sp-3) var(--sp-6);border-radius:0 0 var(--r-sm) var(--r-sm);
  font-size:var(--fs-sm);font-weight:600;z-index:200;
  transition:top var(--dur-fast);
}
.skip-link:focus{top:0}

/* --- Animation --- */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.anim-up{animation:fadeUp .6s var(--ease-out) both}
.anim-up.d1{animation-delay:.08s}
.anim-up.d2{animation-delay:.16s}
.anim-up.d3{animation-delay:.24s}
.anim-up.d4{animation-delay:.32s}
.anim-up.d5{animation-delay:.4s}

/* --- Layout --- */
.w{max-width:1080px;margin:0 auto;padding:0 var(--sp-6)}

/* --- SVG Icon Base --- */
.icon{width:20px;height:20px;flex-shrink:0;display:inline-block;vertical-align:middle}
.icon-sm{width:16px;height:16px}
.icon-lg{width:24px;height:24px}

/* =====================
   HEADER / NAVIGATION
   ===================== */
header{
  position:sticky;top:0;z-index:100;
  background:rgba(250,251,253,.88);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(232,236,242,.6);
}
.nav{padding:var(--sp-4) 0;display:flex;align-items:center;justify-content:space-between}
.nav-logo{
  font-size:var(--fs-xl);font-weight:700;color:var(--c-surface);
  letter-spacing:-.4px;display:flex;align-items:center;gap:var(--sp-2);
}
.nav-logo .logo-text{color:var(--c-primary);font-weight:700}

/* Language Switcher */
.lang-links{display:flex;align-items:center;gap:6px;margin-left:0}
.lang-links a{display:flex;align-items:center;gap:4px;font-size:var(--fs-xs);font-weight:500;color:var(--c-text-muted);text-decoration:none;padding:2px 4px;border-radius:var(--r-sm);transition:color var(--dur-fast)}
.lang-links a:hover{color:var(--c-primary)}
.lang-links a.lang-active{color:var(--c-primary);font-weight:700}
.lang-links img{border-radius:2px;display:block}
.lang-sep{color:var(--c-border);font-size:11px}

.nav-links{display:flex;align-items:center;gap:var(--sp-6);overflow:visible}
.nav-links a{
  font-size:var(--fs-sm);font-weight:500;color:var(--c-text-mid);
  transition:color var(--dur-fast);padding:var(--sp-2) 0;
  position:relative;
}
.nav-links a:hover,.nav-links a.active{color:var(--c-primary);text-decoration:none}
.nav-links a.active::after{
  content:'';position:absolute;bottom:0;left:0;right:0;
  height:2px;background:var(--c-primary);border-radius:1px;
}

/* Nav CTA Button */
.nav-cta{
  background:var(--c-primary)!important;color:var(--c-white)!important;
  padding:var(--sp-2) var(--sp-5)!important;border-radius:var(--r-sm);
  font-weight:600!important;font-size:var(--fs-sm)!important;
  box-shadow:var(--sh-primary);
  transition:transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast);
}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 10px 32px rgba(124,58,237,.2)}
.nav-cta::after{display:none!important}

/* Mobile Menu Toggle */
.nav-toggle{
  display:none;
  background:none;border:none;cursor:pointer;
  width:44px;height:44px;
  align-items:center;justify-content:center;
  border-radius:var(--r-sm);
  transition:background var(--dur-fast);
  color:var(--c-text);
}
.nav-toggle:hover{background:rgba(0,0,0,.04)}
.nav-toggle svg{width:22px;height:22px}

/* Mobile Overlay */
.nav-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(15,10,30,.5);z-index:90;
  opacity:0;transition:opacity var(--dur-normal);
}
.nav-overlay.open{display:block;opacity:1}

/* =====================
   PAGE HERO
   ===================== */
.phero{
  position:relative;
  background:linear-gradient(155deg,var(--c-surface) 0%,var(--c-surface-mid) 50%,var(--c-surface-light) 100%);
  border-radius:var(--r-2xl);
  padding:var(--sp-12) var(--sp-10);
  text-align:center;color:white;
  margin:var(--sp-5) 0 var(--sp-10);
  overflow:hidden;
}
.phero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 30% 20%,rgba(124,58,237,.1),transparent 60%);
  pointer-events:none;
}
.phero *{position:relative}
.phero h1{font-size:var(--fs-4xl);font-weight:700;margin-bottom:var(--sp-3);letter-spacing:-.4px}
.phero p{color:rgba(255,255,255,.5);font-size:var(--fs-base);font-weight:300}

/* =====================
   HOME HERO
   ===================== */
.hero{
  position:relative;
  background:linear-gradient(155deg,var(--c-surface) 0%,var(--c-surface-mid) 50%,var(--c-surface-light) 100%);
  border-radius:var(--r-2xl);
  padding:var(--sp-20) var(--sp-16) var(--sp-16);
  margin:var(--sp-5) 0 var(--sp-12);
  overflow:hidden;text-align:center;
}
.hero::before{
  content:'';position:absolute;width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(124,58,237,.12),transparent 70%);
  top:-200px;left:-100px;
}
.hero::after{
  content:'';position:absolute;width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(16,185,129,.06),transparent 70%);
  bottom:-200px;right:-100px;
}
.hero *{position:relative}

.hero-badge{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);
  border-radius:var(--r-full);padding:var(--sp-2) var(--sp-5) var(--sp-2) var(--sp-3);
  font-size:var(--fs-xs);font-weight:500;color:rgba(255,255,255,.5);
  margin-bottom:var(--sp-7);
}
.hero-badge .dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--c-success);
  box-shadow:0 0 10px var(--c-success);
}

.hero h1{
  font-size:var(--fs-6xl);font-weight:700;color:#fff;
  line-height:1.2;letter-spacing:-1px;margin-bottom:var(--sp-5);
}
.hero h1 em{
  font-style:normal;
  background:linear-gradient(135deg,var(--c-primary-soft),var(--c-success));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.hero p{
  font-size:var(--fs-lg);line-height:1.8;color:rgba(255,255,255,.48);
  max-width:540px;margin:0 auto var(--sp-10);font-weight:300;
}
.hero-btns{display:flex;gap:var(--sp-3);justify-content:center;flex-wrap:wrap}

/* =====================
   BUTTONS
   ===================== */
.btn-primary{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  background:var(--c-primary);color:var(--c-white)!important;
  padding:var(--sp-4) var(--sp-8);border-radius:var(--r-md);
  font-size:var(--fs-base);font-weight:600;
  box-shadow:var(--sh-primary);
  transition:transform var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast);
  border:none;cursor:pointer;font-family:inherit;
  min-height:48px;
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 36px rgba(124,58,237,.22);text-decoration:none}
.btn-primary:active{transform:translateY(0) scale(.98)}
.btn-primary-sm{padding:var(--sp-3) var(--sp-6);font-size:var(--fs-sm);min-height:44px}

.btn-secondary{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  color:rgba(255,255,255,.6)!important;
  padding:14px var(--sp-7);border-radius:var(--r-md);
  font-size:var(--fs-sm);font-weight:500;
  border:1.5px solid rgba(255,255,255,.12);
  transition:all var(--dur-normal) var(--ease-out);
  background:transparent;cursor:pointer;font-family:inherit;
  min-height:48px;
}
.btn-secondary:hover{background:rgba(255,255,255,.06);color:rgba(255,255,255,.8)!important;text-decoration:none}

.btn-outline{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  background:transparent;color:var(--c-primary)!important;
  padding:var(--sp-3) var(--sp-6);border-radius:var(--r-md);
  font-size:var(--fs-sm);font-weight:600;
  border:1.5px solid var(--c-border);
  transition:all var(--dur-normal) var(--ease-out);
  cursor:pointer;font-family:inherit;min-height:44px;
}
.btn-outline:hover{border-color:var(--c-primary);text-decoration:none}

/* =====================
   STATS
   ===================== */
.stats{display:flex;justify-content:center;gap:var(--sp-16);padding:var(--sp-2) 0 var(--sp-16)}
.stat{text-align:center}
.stat-n{font-size:var(--fs-4xl);font-weight:700;color:var(--c-surface);letter-spacing:-1px;font-variant-numeric:tabular-nums}
.stat-n span{color:var(--c-primary)}
.stat-l{font-size:var(--fs-xs);font-weight:600;color:var(--c-text-muted);margin-top:var(--sp-1);letter-spacing:.5px;text-transform:uppercase}

/* =====================
   SECTIONS
   ===================== */
.sec{margin-bottom:var(--sp-16)}
.sh{text-align:center;margin-bottom:var(--sp-10)}
.sh h2{font-size:var(--fs-3xl);font-weight:700;color:var(--c-surface);letter-spacing:-.4px;margin-bottom:var(--sp-2)}
.sh h2 em{font-style:normal;color:var(--c-primary)}
.sh p{font-size:var(--fs-base);color:var(--c-text-muted);max-width:460px;margin:0 auto}

/* =====================
   GRIDS
   ===================== */
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-5)}
.g2{display:grid;grid-template-columns:1fr 300px;gap:var(--sp-8)}

/* =====================
   FEATURE CARDS
   ===================== */
.fc{
  background:var(--c-white);border:1px solid var(--c-border);
  border-radius:var(--r-xl);padding:var(--sp-7) var(--sp-6);
  transition:all var(--dur-normal) var(--ease-out);
}
.fc:hover{border-color:var(--c-border-hover);box-shadow:var(--sh-2);transform:translateY(-2px)}
.fi{
  width:44px;height:44px;border-radius:var(--r-md);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:var(--sp-4);
}
.fi svg{width:22px;height:22px}
.fc h3{font-size:var(--fs-md);font-weight:600;margin-bottom:var(--sp-2)}
.fc p{font-size:var(--fs-sm);color:var(--c-text-muted);line-height:1.75}

/* =====================
   GENERAL CARD
   ===================== */
.card{
  background:var(--c-white);border:1px solid var(--c-border);
  border-radius:var(--r-xl);padding:var(--sp-7) var(--sp-6);
  transition:all var(--dur-normal) var(--ease-out);
}
.card:hover{border-color:var(--c-border-hover);box-shadow:var(--sh-2);transform:translateY(-2px)}

/* =====================
   PRICING CARDS
   ===================== */
.pc{
  background:var(--c-white);border:1.5px solid var(--c-border);
  border-radius:var(--r-xl);padding:var(--sp-8) var(--sp-7);
  text-align:center;transition:all var(--dur-normal) var(--ease-out);
  position:relative;
}
.pc:hover{box-shadow:var(--sh-2);transform:translateY(-2px)}
.pc.featured{border-color:var(--c-primary);box-shadow:var(--sh-4)}
.pc.featured::before{
  content:attr(data-badge);
  position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--c-primary);color:white;
  font-size:11px;font-weight:600;padding:var(--sp-1) var(--sp-4);
  border-radius:var(--r-full);white-space:nowrap;
}
.pn{font-size:var(--fs-sm);font-weight:600;color:var(--c-text-mid);margin-bottom:var(--sp-4)}
.pp{font-size:var(--fs-5xl);font-weight:700;color:var(--c-surface);letter-spacing:-1.5px;line-height:1;font-variant-numeric:tabular-nums}
.pp small{font-size:var(--fs-sm);font-weight:400;color:var(--c-text-muted);letter-spacing:0}
.pu{font-size:var(--fs-sm);color:var(--c-text-muted);margin-top:var(--sp-2)}
.ps{font-size:var(--fs-xs);font-weight:600;color:var(--c-primary);margin:var(--sp-2) 0 var(--sp-5);min-height:18px}
.pf{text-align:left;font-size:var(--fs-sm);color:var(--c-text-mid);line-height:2.2;margin-bottom:var(--sp-6);padding:0 var(--sp-1)}
.pf-item{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-1) 0}
.pf-item svg{width:16px;height:16px;color:var(--c-success);flex-shrink:0}
.pb{
  display:flex;width:100%;padding:var(--sp-3);border-radius:var(--r-md);
  font-size:var(--fs-sm);font-weight:600;text-align:center;
  transition:all var(--dur-normal) var(--ease-out);
  border:none;cursor:pointer;font-family:inherit;
  align-items:center;justify-content:center;
  min-height:48px;
}

/* =====================
   STEP CARDS
   ===================== */
.sc{
  background:var(--c-white);border:1px solid var(--c-border);
  border-radius:var(--r-xl);padding:var(--sp-10) var(--sp-7);
  text-align:center;transition:all var(--dur-normal) var(--ease-out);
}
.sc:hover{box-shadow:var(--sh-2);transform:translateY(-2px)}
.sn{
  width:48px;height:48px;border-radius:var(--r-lg);
  display:flex;align-items:center;justify-content:center;
  font-size:var(--fs-lg);font-weight:700;
  margin:0 auto var(--sp-5);color:var(--c-white);
}
.sc h3{font-size:var(--fs-md);font-weight:600;margin-bottom:var(--sp-2)}
.sc p{font-size:var(--fs-sm);color:var(--c-text-muted);line-height:1.75}

/* =====================
   STEP LIST (How-to)
   ===================== */
.step{
  display:flex;gap:var(--sp-4);align-items:flex-start;
  padding:var(--sp-5);background:var(--c-white);
  border:1px solid var(--c-border);border-radius:var(--r-lg);
  margin-bottom:var(--sp-3);
  transition:all var(--dur-normal) var(--ease-out);
}
.step:hover{border-color:var(--c-border-hover);box-shadow:var(--sh-1)}
.step-n{
  width:36px;height:36px;border-radius:var(--r-sm);
  background:var(--c-primary);color:white;
  display:flex;align-items:center;justify-content:center;
  font-size:var(--fs-sm);font-weight:700;flex-shrink:0;
}
.step h4{font-size:var(--fs-base);font-weight:600;margin-bottom:var(--sp-1)}
.step p{font-size:var(--fs-sm);color:var(--c-text-muted);line-height:1.75}

/* =====================
   TABS
   ===================== */
.tabs{
  display:flex;gap:var(--sp-2);justify-content:center;flex-wrap:wrap;
  margin-bottom:var(--sp-7);
}
.tab{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  padding:var(--sp-3) var(--sp-5);font-size:var(--fs-sm);font-weight:600;
  cursor:pointer;border-radius:var(--r-sm);color:var(--c-text-mid);
  transition:all var(--dur-normal) var(--ease-out);
  border:1.5px solid transparent;background:transparent;
  font-family:inherit;min-height:44px;
}
.tab:hover{background:var(--c-white);border-color:var(--c-border)}
.tab.active{background:var(--c-primary);color:var(--c-white);box-shadow:var(--sh-primary);border-color:var(--c-primary)}
.tab svg{width:18px;height:18px}
.panel{display:none}.panel.active{display:block}

/* =====================
   FAQ
   ===================== */
.faq{
  border:1px solid var(--c-border);border-radius:var(--r-lg);
  margin-bottom:var(--sp-3);overflow:hidden;
  transition:border-color var(--dur-normal) var(--ease-out);
}
.faq:hover{border-color:var(--c-border-hover)}
.faq-q{
  padding:var(--sp-5) var(--sp-6);font-size:var(--fs-base);font-weight:600;
  cursor:pointer;display:flex;justify-content:space-between;align-items:center;
  background:var(--c-white);transition:background var(--dur-fast);
  gap:var(--sp-4);min-height:56px;
}
.faq-q:hover{background:var(--c-bg)}
.faq-a{
  padding:0 var(--sp-6);font-size:var(--fs-sm);color:var(--c-text-mid);
  line-height:1.85;max-height:0;overflow:hidden;
  transition:max-height var(--dur-slow) ease,padding var(--dur-slow) ease;
}
.faq.open .faq-a{max-height:600px;padding:0 var(--sp-6) var(--sp-5)}
.faq.open .faq-arr{transform:rotate(180deg)}
.faq-arr{
  transition:transform var(--dur-normal) var(--ease-out);
  color:var(--c-text-muted);flex-shrink:0;
  width:20px;height:20px;
}
.faq-cat{
  font-size:var(--fs-md);font-weight:700;
  margin:var(--sp-8) 0 var(--sp-4);padding-left:var(--sp-1);
  color:var(--c-surface);display:flex;align-items:center;gap:var(--sp-2);
}
.faq-cat svg{width:20px;height:20px;color:var(--c-primary)}

/* =====================
   INFO BOX
   ===================== */
.info{
  background:var(--c-primary-bg);
  border:1px solid var(--c-primary-border);
  border-radius:var(--r-lg);
  padding:var(--sp-5) var(--sp-6);
  margin-bottom:var(--sp-6);
  font-size:var(--fs-sm);color:var(--c-text-mid);line-height:1.85;
  display:flex;align-items:flex-start;gap:var(--sp-3);
}
.info svg{width:20px;height:20px;color:var(--c-primary);flex-shrink:0;margin-top:2px}
.info strong{color:var(--c-text)}

/* =====================
   FORMS
   ===================== */
.form-group{margin-bottom:var(--sp-5)}
.lbl{
  display:block;font-size:var(--fs-xs);font-weight:600;
  color:var(--c-text-muted);letter-spacing:.5px;margin-bottom:var(--sp-2);
}
.inp{
  width:100%;background:var(--c-white);
  border:1.5px solid var(--c-border);border-radius:var(--r-md);
  padding:var(--sp-3) var(--sp-4);
  font-size:var(--fs-sm);color:var(--c-text);font-family:inherit;
  transition:border var(--dur-normal) var(--ease-out),box-shadow var(--dur-normal);
  min-height:48px;
}
.inp:focus{outline:none;border-color:var(--c-primary);box-shadow:0 0 0 3px rgba(124,58,237,.08)}
.inp::placeholder{color:var(--c-text-muted)}
textarea.inp{min-height:140px;resize:vertical}
select.inp{appearance:auto}

/* =====================
   BOTTOM CTA
   ===================== */
.bcta{
  background:linear-gradient(155deg,var(--c-surface),var(--c-surface-mid));
  border-radius:var(--r-2xl);
  padding:var(--sp-16) var(--sp-10);
  text-align:center;color:white;
  position:relative;overflow:hidden;
  margin-bottom:var(--sp-12);
}
.bcta::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at center,rgba(124,58,237,.1),transparent 65%);
}
.bcta *{position:relative}
.bcta h2{font-size:var(--fs-2xl);font-weight:700;margin-bottom:var(--sp-3)}
.bcta p{color:rgba(255,255,255,.42);font-size:var(--fs-base);margin-bottom:var(--sp-7);font-weight:300}

/* =====================
   FOOTER
   ===================== */
footer{
  border-top:1px solid var(--c-border);
  padding:var(--sp-7) 0;
  display:flex;justify-content:space-between;align-items:center;
  font-size:var(--fs-xs);color:var(--c-text-muted);
}
.fl{display:flex;gap:var(--sp-6)}
.fl a{color:var(--c-text-muted);font-weight:500;padding:var(--sp-2) 0}
.fl a:hover{color:var(--c-primary)}

/* =====================
   RESPONSIVE
   ===================== */
@media(max-width:768px){
  :root{--sp-6:20px}
  .nav-links{
    display:none;flex-direction:column;
    position:fixed;top:0;right:0;bottom:0;width:280px;
    background:var(--c-white);z-index:100;
    padding:var(--sp-20) var(--sp-6) var(--sp-6);
    box-shadow:-8px 0 32px rgba(15,10,30,.12);
    gap:var(--sp-1);
    transform:translateX(100%);
    transition:transform var(--dur-normal) var(--ease-out);
  }
  .nav-links.open{display:flex;transform:translateX(0)}
  .nav-links a{font-size:var(--fs-md);padding:var(--sp-3) var(--sp-4);border-radius:var(--r-sm)}
  .nav-links a.active::after{display:none}
  .nav-cta{margin-top:var(--sp-4);width:100%;text-align:center;justify-content:center;padding:var(--sp-3)!important}
  .nav-toggle{display:flex}
  .lang-links{margin-left:auto;margin-right:var(--sp-2);gap:var(--sp-1)}
  .lang-links a{font-size:10px;gap:3px;padding:var(--sp-1)}
  .lang-links img{width:14px;height:10px}
  .lang-sep{font-size:9px}

  .hero{padding:var(--sp-12) var(--sp-6) var(--sp-10);border-radius:var(--r-xl);margin:var(--sp-3) 0 var(--sp-8)}
  .hero h1{font-size:var(--fs-3xl);letter-spacing:-.5px}
  .hero p{font-size:var(--fs-base)}
  .phero{padding:var(--sp-10) var(--sp-6);border-radius:var(--r-xl)}
  .phero h1{font-size:var(--fs-2xl)}

  .stats{gap:var(--sp-6);flex-wrap:wrap;padding-bottom:var(--sp-10)}
  .stat-n{font-size:var(--fs-2xl)}

  .g3{grid-template-columns:1fr}
  .g2{grid-template-columns:1fr}
  .sh h2{font-size:var(--fs-xl)}

  .tabs{gap:var(--sp-1)}.tab{padding:var(--sp-2) var(--sp-4);font-size:var(--fs-sm)}

  footer{flex-direction:column;gap:var(--sp-4);text-align:center}
  .fl{justify-content:center;flex-wrap:wrap;gap:var(--sp-4)}

  .bcta{padding:var(--sp-10) var(--sp-6)}
}

@media(max-width:480px){
  .hero-btns{flex-direction:column;align-items:center}
  .btn-primary,.btn-secondary{width:100%;justify-content:center}
  .stats{gap:var(--sp-4)}
}

/* Testimonials */
.testi-wrap{overflow:hidden;margin-bottom:64px;padding:8px 0}
.testi-track{display:flex;gap:18px;width:max-content;animation:testi-scroll 60s linear infinite}
.testi-track:hover{animation-play-state:paused}
@keyframes testi-scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.testi-card{flex-shrink:0;width:320px;background:var(--c-white);border:1px solid var(--c-border);border-radius:var(--r-xl);padding:24px;transition:box-shadow var(--dur-normal) var(--ease-out),transform var(--dur-normal) var(--ease-out)}
.testi-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}
.testi-stars{color:#F59E0B;font-size:14px;letter-spacing:2px;margin-bottom:10px}
.testi-text{font-size:var(--fs-sm);color:var(--c-text-mid);line-height:1.8;margin-bottom:14px}
.testi-author{font-size:var(--fs-xs);font-weight:600;color:var(--c-text-muted)}
