/* ============================================
   SUBTRACK — Landing Page
   Design: glassmorphism · light gradients · expressive motion
   ============================================ */

:root{
  /* ---- Palette ---- */
  --violet:#7B6BFF;
  --violet-deep:#5A4DC9;
  --magenta:#C56BFF;
  --rose:#FF6BB5;
  --orange:#FF6B47;
  --orange-soft:#FF9B6B;
  --amber:#FFB36B;
  --sun:#FFD16B;
  --cyan:#6BD8FF;
  --mint:#7BFFC8;
  --green:#5BD17A;
  --ink:#1A1530;
  --ink-2:#241B47;
  --ink-soft:rgba(26,21,48,.7);
  --ink-mute:rgba(26,21,48,.55);
  --ink-faint:rgba(26,21,48,.08);
  --paper:#fff;

  /* ---- Glass ---- */
  --glass:rgba(255,255,255,.62);
  --glass-strong:rgba(255,255,255,.78);
  --glass-edge:rgba(255,255,255,.92);
  --glass-dark:rgba(26,21,48,.84);
  --glass-dark-edge:rgba(255,255,255,.08);

  /* ---- Shadows (multi-layer, colored) ---- */
  --sh-soft:
    0 1px 1px rgba(80,60,180,.04),
    0 2px 4px rgba(80,60,180,.06),
    0 8px 16px -8px rgba(80,60,180,.08);
  --sh-card:
    0 1px 2px rgba(80,60,180,.04),
    0 8px 18px -8px rgba(123,107,255,.18),
    0 24px 40px -24px rgba(255,107,181,.22);
  --sh-card-hover:
    0 2px 4px rgba(80,60,180,.06),
    0 14px 28px -8px rgba(123,107,255,.30),
    0 38px 64px -24px rgba(255,107,181,.32);
  --sh-phone:
    0 1px 2px rgba(20,10,60,.12),
    0 30px 60px -20px rgba(80,60,180,.30),
    0 60px 120px -30px rgba(255,107,181,.20);
  --sh-cta:
    0 1px 2px rgba(80,60,180,.08),
    0 14px 30px -8px rgba(123,107,255,.50),
    0 30px 60px -20px rgba(255,107,181,.35),
    inset 0 1px 0 rgba(255,255,255,.30);

  /* ---- Easings ---- */
  --ease-out: cubic-bezier(.22, 1, .36, 1);
  --ease-out-q: cubic-bezier(.16, 1, .3, 1);
  --ease-in-out: cubic-bezier(.65, 0, .35, 1);
  --ease-back: cubic-bezier(.34, 1.56, .64, 1);
  --ease-spring: cubic-bezier(.5, -0.5, .25, 1.5);

  /* ---- Durations ---- */
  --d-fast: .2s;
  --d-base: .35s;
  --d-slow: .6s;
  --d-xslow: 1.1s;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:'Inter',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;
  color:var(--ink);
  background:#F4ECFB;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  font-feature-settings:"ss01","cv11";
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
ul{padding:0;margin:0;list-style:none}
input,textarea,select,button{font-family:inherit;font-size:inherit;color:inherit}

::selection{background:rgba(123,107,255,.25);color:var(--ink)}

/* ============================================
   BACKGROUND — gradient + colored glow blobs + noise
   ============================================ */
.bg-gradient{
  position:fixed;inset:0;z-index:-2;overflow:hidden;
  background:
    radial-gradient(1200px 800px at 10% -10%, #EADCFB 0%, transparent 60%),
    radial-gradient(900px 700px at 100% 0%, #FDE0E8 0%, transparent 55%),
    radial-gradient(900px 700px at 50% 50%, #F5E6FF 0%, transparent 60%),
    radial-gradient(800px 600px at 50% 100%, #FFE7D6 0%, transparent 60%),
    linear-gradient(180deg,#F5EBFB 0%, #FDE5E8 50%, #FFEDD9 100%);
}
.glow{
  position:absolute;border-radius:50%;
  filter:blur(90px);opacity:.55;
  pointer-events:none;will-change:transform,scale;
}
/* `scale` is independent from `transform` so the JS parallax (transform) and
   the CSS breathing animation (scale + opacity) don't fight each other */
.glow-1{width:560px;height:560px;top:-140px;left:-120px;background:#B89BFF;animation:glowBreathe 22s ease-in-out infinite}
.glow-2{width:520px;height:520px;top:30%;right:-180px;background:#FFB1C7;animation:glowBreathe 26s ease-in-out -8s infinite}
.glow-3{width:640px;height:640px;bottom:-220px;left:25%;background:#FFCFA8;animation:glowBreathe 30s ease-in-out -14s infinite}
.glow-4{width:440px;height:440px;top:60%;right:10%;background:#A8CFFF;opacity:.4;animation:glowBreathe 18s ease-in-out -4s infinite}
@keyframes glowBreathe{
  0%,100%{scale:1;opacity:.55}
  50%{scale:1.18;opacity:.40}
}
.noise{
  position:absolute;inset:-50%;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='.35'/></svg>");
  opacity:.5;mix-blend-mode:overlay;pointer-events:none;
}

/* ============================================
   SCROLL PROGRESS (top thin bar)
   ============================================ */
.scroll-progress{
  position:fixed;top:0;left:0;right:0;height:2px;z-index:200;pointer-events:none;
  background:rgba(255,255,255,.15);
}
#scrollProgress{
  display:block;height:100%;width:0%;
  background:linear-gradient(90deg,var(--violet),var(--rose),var(--orange));
  transition:width .1s linear;
}

/* ============================================
   NAVIGATION
   ============================================ */
.nav{
  position:sticky;top:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  gap:24px;padding:16px 40px;
  background:rgba(255,255,255,.55);
  backdrop-filter:blur(22px) saturate(180%);
  -webkit-backdrop-filter:blur(22px) saturate(180%);
  border-bottom:1px solid rgba(255,255,255,.7);
  transition:padding .3s var(--ease-out), background .3s var(--ease-out), box-shadow .3s var(--ease-out);
}
.nav.is-scrolled{
  padding-top:11px;padding-bottom:11px;
  background:rgba(255,255,255,.78);
  box-shadow:0 8px 24px -12px rgba(80,60,180,.15);
}
.nav-brand{display:flex;align-items:center;gap:10px;position:relative;z-index:1}
.logo-mark{display:inline-flex;filter:drop-shadow(0 6px 14px rgba(123,107,255,.25))}
.logo-mark img{display:block;width:40px;height:40px;border-radius:11px;object-fit:cover}
.footer-brand .logo-mark img{width:32px;height:32px;border-radius:9px}
.brand-name{font-weight:800;font-size:22px;letter-spacing:-.02em}

.nav-links{display:flex;gap:30px}
.nav-links a{
  position:relative;font-size:14px;font-weight:500;color:rgba(26,21,48,.7);
  transition:color .2s;
}
.nav-links a::after{
  content:"";position:absolute;left:50%;right:50%;bottom:-6px;height:2px;border-radius:2px;
  background:linear-gradient(90deg,var(--violet),var(--rose));
  transition:left .3s var(--ease-out), right .3s var(--ease-out);
}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{left:0;right:0}

.nav-actions{display:flex;align-items:center;gap:14px}

.lang-switch{
  display:inline-flex;padding:3px;border-radius:99px;
  background:rgba(255,255,255,.6);
  border:1px solid rgba(255,255,255,.9);
  box-shadow:0 1px 2px rgba(26,21,48,.04);
}
.lang-btn{
  padding:6px 12px;border-radius:99px;
  font-size:12px;font-weight:700;letter-spacing:.04em;
  color:rgba(26,21,48,.55);transition:color .2s, background .25s var(--ease-out), box-shadow .2s;
}
.lang-btn.active{
  background:var(--ink);color:#fff;
  box-shadow:0 4px 14px rgba(26,21,48,.25);
}

/* Burger (mobile) */
.nav-burger{
  display:none;width:38px;height:38px;border-radius:11px;
  background:rgba(255,255,255,.6);border:1px solid rgba(255,255,255,.9);
  flex-direction:column;align-items:center;justify-content:center;gap:4px;
  transition:background .2s;
}
.nav-burger span{display:block;width:18px;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s var(--ease-out), opacity .2s}
.nav-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav-burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

.drawer{
  position:fixed;top:62px;left:0;right:0;z-index:55;
  padding:16px 20px 24px;
  display:flex;flex-direction:column;gap:6px;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(24px);
  border-bottom:1px solid var(--ink-faint);
  transform:translateY(-110%);
  transition:transform .4s var(--ease-out);
}
.drawer.is-open{transform:translateY(0)}
.drawer a{padding:12px 14px;border-radius:14px;font-weight:600;font-size:15px;color:var(--ink)}
.drawer a:hover{background:rgba(123,107,255,.08)}
.drawer .btn{margin-top:8px;justify-content:center}

/* ============================================
   BUTTONS
   ============================================ */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 22px;border-radius:99px;
  font-weight:600;font-size:15px;letter-spacing:-.005em;
  white-space:nowrap;
  transition:transform .25s var(--ease-out), box-shadow .3s var(--ease-out), background .25s;
  position:relative;
  will-change:transform;
}
.btn-sm{padding:9px 16px;font-size:13px}
.btn-primary{
  background:linear-gradient(135deg,var(--violet) 0%,var(--magenta) 50%,var(--rose) 100%);
  color:#fff;
  box-shadow:var(--sh-cta);
  background-size:200% 200%;
  animation:gradientShift 8s ease infinite;
}
.btn-primary:hover{transform:translateY(-2px)}
.btn-primary:active{transform:translateY(0) scale(.98)}
@keyframes gradientShift{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}
}
.btn-ghost{
  background:rgba(255,255,255,.65);
  border:1px solid rgba(255,255,255,.95);
  color:var(--ink);
  backdrop-filter:blur(10px);
}
.btn-ghost:hover{background:rgba(255,255,255,.92);transform:translateY(-1px)}

/* ============================================
   HERO
   ============================================ */
.hero{
  position:relative;
  display:grid;grid-template-columns:1.05fr 1fr;gap:60px;align-items:center;
  max-width:1280px;margin:0 auto;padding:90px 40px 60px;
}
.pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:7px 14px 7px 11px;border-radius:99px;
  font-size:12.5px;font-weight:600;
  background:rgba(255,255,255,.72);
  border:1px solid rgba(255,255,255,.95);
  color:var(--violet-deep);
  backdrop-filter:blur(10px);
  box-shadow:0 6px 18px rgba(123,107,255,.14);
  margin-bottom:24px;
}
.pill-dot{
  width:8px;height:8px;border-radius:50%;
  background:linear-gradient(135deg,var(--violet),var(--rose));
  position:relative;
}
.pill-dot::before{
  content:"";position:absolute;inset:-3px;border-radius:50%;
  background:inherit;opacity:.5;animation:pulse 2s ease infinite;
}
@keyframes pulse{
  0%{transform:scale(1);opacity:.5}
  70%{transform:scale(1.7);opacity:0}
  100%{transform:scale(1);opacity:0}
}

.hero-title{
  font-size:clamp(40px, 6.4vw, 76px);
  font-weight:900;letter-spacing:-.035em;line-height:1.0;
  margin:0 0 22px;
}
.hero-title > span{display:block}
.hero-title-italic em{
  font-style:italic;
  font-family:'Instrument Serif',serif;
  font-weight:400;
  background:linear-gradient(135deg,var(--violet) 0%, var(--magenta) 40%, var(--rose) 80%, var(--orange) 100%);
  background-size:200% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  animation:gradientShift 10s ease infinite;
}
.hero-sub{
  font-size:clamp(17px, 1.4vw, 19.5px);color:var(--ink-soft);
  max-width:540px;margin:0 0 32px;line-height:1.55;
}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:32px}
.hero-meta{display:flex;gap:24px;flex-wrap:wrap}
.hero-meta li{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:var(--ink-mute)}
.hero-meta .dot{
  width:6px;height:6px;border-radius:50%;
  background:linear-gradient(135deg,var(--violet),var(--rose));
}

/* Hero mockups */
.hero-mockups{position:relative;height:620px;perspective:1500px}
.phone{
  position:absolute;width:280px;height:580px;
  border-radius:42px;
  background:linear-gradient(140deg,#fff 0%,#F5F0FF 100%);
  border:1px solid rgba(255,255,255,.9);
  box-shadow:var(--sh-phone);
  padding:10px;
  overflow:hidden;
  transform-style:preserve-3d;
  will-change:transform;
}
.phone.phone-dark{
  background:linear-gradient(140deg,#241a45 0%,#1a1330 100%);
  border-color:rgba(255,255,255,.06);
  box-shadow:
    0 1px 2px rgba(15,5,40,.20),
    0 30px 60px -20px rgba(20,10,60,.55),
    0 60px 120px -30px rgba(123,107,255,.30);
}
.phone-halo{
  position:absolute;inset:-30%;z-index:-1;pointer-events:none;
  background:radial-gradient(closest-side, rgba(255,107,181,.45), transparent 60%),
             radial-gradient(closest-side at 30% 40%, rgba(123,107,255,.4), transparent 60%);
  filter:blur(40px);opacity:.6;
  animation:haloPulse 6s ease-in-out infinite;
}
.phone-halo-dark{
  background:radial-gradient(closest-side, rgba(123,107,255,.6), transparent 60%),
             radial-gradient(closest-side at 70% 60%, rgba(255,107,181,.4), transparent 60%);
  animation:haloPulse 6s ease-in-out -3s infinite;
}
@keyframes haloPulse{
  0%,100%{opacity:.5;transform:scale(1)}
  50%{opacity:.85;transform:scale(1.08)}
}
.phone-1{top:0;left:-20px;transform:rotate(-4deg);z-index:2;animation:float 7s ease-in-out infinite}
.phone-2{top:50px;right:-30px;transform:rotate(5deg);z-index:1;animation:float 7s ease-in-out -3.5s infinite}
.phone-img{
  width:100%;height:100%;
  object-fit:cover;object-position:top center;
  border-radius:32px;display:block;
}
@keyframes float{
  0%,100%{transform:translateY(0) rotate(var(--rot,-4deg))}
  50%{transform:translateY(-14px) rotate(var(--rot,-4deg))}
}
.phone-1{--rot:-4deg}
.phone-2{--rot:5deg}

/* Floating decorative cards in hero */
.float-card{
  position:absolute;z-index:3;
  display:flex;align-items:center;gap:10px;
  padding:10px 14px 10px 10px;border-radius:18px;
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,1);
  box-shadow:
    0 10px 24px -8px rgba(80,60,180,.20),
    0 30px 50px -20px rgba(255,107,181,.18);
  font-size:13px;
  will-change:transform;
}
.float-card-1{top:18%;left:-40px;animation:floatSlow 9s ease-in-out infinite}
.float-card-2{bottom:24%;right:-30px;animation:floatSlow 9s ease-in-out -4.5s infinite}
.float-card-3{
  bottom:10%;left:6%;
  flex-direction:column;align-items:flex-start;gap:6px;padding:12px 14px;
  animation:floatSlow 11s ease-in-out -2s infinite;
}
@keyframes floatSlow{
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
}
.fc-ico{
  width:30px;height:30px;border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 10px -2px rgba(0,0,0,.18);
}
.fc-text{display:flex;flex-direction:column;line-height:1.2}
.fc-text strong{font-weight:800;font-size:13px}
.fc-text small{font-size:10.5px;color:var(--ink-mute)}
.fc-amount{
  font-weight:800;font-size:15px;letter-spacing:-.01em;color:var(--ink);
  margin-left:4px;
}
.fc-amount small{font-size:11px;font-weight:700;opacity:.55}
.float-card-stats{min-width:130px}
.float-card-stats small{font-size:10.5px;color:var(--ink-mute);font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.float-card-stats strong{font-size:20px;font-weight:900;letter-spacing:-.02em}
.fc-bars{display:flex;align-items:flex-end;gap:4px;height:28px;margin-top:2px}
.fc-bar{width:8px;border-radius:3px;height:var(--h);animation:barRise 1.2s var(--ease-out) backwards}
.fc-bar:nth-child(1){animation-delay:.1s}
.fc-bar:nth-child(2){animation-delay:.2s}
.fc-bar:nth-child(3){animation-delay:.3s}
.fc-bar:nth-child(4){animation-delay:.4s}
.fc-bar:nth-child(5){animation-delay:.5s}
@keyframes barRise{from{height:0}to{height:var(--h)}}

/* ============================================
   KPI strip
   ============================================ */
.kpi{
  max-width:1280px;margin:60px auto 0;padding:28px 40px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
  background:rgba(255,255,255,.55);
  backdrop-filter:blur(22px);
  border:1px solid rgba(255,255,255,.92);
  border-radius:32px;
  box-shadow:var(--sh-card);
}
.kpi-item{text-align:center;padding:8px;position:relative}
.kpi-item + .kpi-item::before{
  content:"";position:absolute;left:0;top:20%;bottom:20%;width:1px;
  background:linear-gradient(180deg,transparent,var(--ink-faint),transparent);
}
.kpi-value{
  font-size:clamp(28px,3vw,40px);font-weight:900;letter-spacing:-.02em;
  background:linear-gradient(135deg,var(--violet),var(--rose),var(--orange));
  background-size:200% 200%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  margin-bottom:6px;
  animation:gradientShift 8s ease infinite;
}
.kpi-label{font-size:13.5px;color:var(--ink-soft);line-height:1.4;max-width:200px;margin:0 auto}

/* ============================================
   TICKER (marquee of supported services)
   ============================================ */
.ticker{padding:60px 0 30px;max-width:1280px;margin:0 auto;text-align:center}
.ticker-intro{
  font-size:12.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-mute);margin:0 0 24px;
}
.ticker-mask{
  overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
          mask-image:linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
}
.ticker-track{
  display:flex;width:max-content;
  animation:ticker 45s linear infinite;
}
.ticker:hover .ticker-track{animation-play-state:paused}
.ticker-row{
  display:flex;align-items:center;gap:42px;padding:0 21px;flex-shrink:0;
}
.ticker-item{
  display:inline-flex;align-items:center;gap:10px;
  font-weight:700;font-size:17px;letter-spacing:-.01em;
  color:rgba(26,21,48,.55);
  white-space:nowrap;
  transition:color .25s, opacity .25s;
}
.ticker-item:hover{color:var(--ink)}
.ti-mark{
  width:30px;height:30px;border-radius:9px;
  display:inline-flex;align-items:center;justify-content:center;
  font-weight:800;font-size:13px;letter-spacing:0;
  box-shadow:0 4px 10px -2px rgba(0,0,0,.18);
}
.ti-logo{
  width:26px;height:26px;flex-shrink:0;object-fit:contain;
  transition:transform .25s ease, filter .25s ease;
  filter:saturate(.85) opacity(.78);
}
.ticker-item:hover .ti-logo{filter:none;transform:scale(1.1)}
@keyframes ticker{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}

/* ============================================
   SECTION HEAD
   ============================================ */
.eyebrow{
  display:inline-block;padding:5px 14px;border-radius:99px;
  background:linear-gradient(135deg, rgba(123,107,255,.10), rgba(255,107,181,.10));
  border:1px solid rgba(123,107,255,.15);
  color:var(--violet-deep);
  font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  margin-bottom:20px;
}
.section-head{text-align:center;max-width:720px;margin:0 auto 56px}
.section-title{
  font-size:clamp(32px,4.8vw,56px);font-weight:900;letter-spacing:-.03em;line-height:1.04;
  margin:0 0 16px;color:var(--ink);
}
.section-title em{
  font-style:italic;
  font-family:'Instrument Serif',serif;
  font-weight:400;
  background:linear-gradient(135deg,var(--violet),var(--magenta),var(--rose));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.section-sub{font-size:clamp(16px,1.4vw,18.5px);color:var(--ink-soft);margin:0;line-height:1.55}

/* ============================================
   FEATURES
   ============================================ */
.features{max-width:1280px;margin:0 auto;padding:120px 40px 60px;position:relative}
.feature-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  grid-auto-rows:minmax(220px,auto);
  gap:18px;
  perspective:1500px;
}
.feature-card{
  position:relative;
  background:rgba(255,255,255,.68);
  backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.92);
  border-radius:28px;
  padding:28px;
  box-shadow:var(--sh-card);
  transform-style:preserve-3d;
  transition:transform .5s var(--ease-out), box-shadow .5s var(--ease-out);
  will-change:transform;
  overflow:hidden;
}
.feature-card::after{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:radial-gradient(600px circle at var(--mx,50%) var(--my,50%), rgba(255,255,255,.7), transparent 35%);
  opacity:0;transition:opacity .3s;
}
.feature-card:hover{box-shadow:var(--sh-card-hover)}
.feature-card:hover::after{opacity:.45}
.feature-card.feature-lg{grid-column:span 2}
.feature-card.feature-lg:first-child{grid-column:span 2}
.feature-ico{
  width:54px;height:54px;border-radius:17px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 24px -8px rgba(123,107,255,.45);
  margin-bottom:18px;
  transform:translateZ(20px);
}
.feature-card h3{font-size:22px;font-weight:800;letter-spacing:-.02em;margin:0 0 10px;transform:translateZ(15px)}
.feature-card p{font-size:15px;color:var(--ink-soft);margin:0;line-height:1.55;transform:translateZ(10px)}

/* ============================================
   HOW IT WORKS
   ============================================ */
.how{max-width:1280px;margin:0 auto;padding:80px 40px;position:relative}
.steps{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  position:relative;
}
.steps-line{
  position:absolute;top:32px;left:14%;right:14%;height:2px;
  background:rgba(123,107,255,.12);border-radius:2px;
  overflow:hidden;
}
.steps-line-fill{
  display:block;height:100%;width:0%;
  background:linear-gradient(90deg,var(--violet),var(--rose),var(--orange));
  transition:width 1.4s var(--ease-out-q);
}
.steps.is-active .steps-line-fill{width:100%}
.step{
  position:relative;z-index:1;text-align:center;padding:0 16px;
}
.step-num{
  width:64px;height:64px;border-radius:50%;
  background:linear-gradient(135deg,var(--violet) 0%,var(--magenta) 60%,var(--rose) 100%);
  color:#fff;font-weight:900;font-size:24px;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 22px;
  box-shadow:0 14px 30px -10px rgba(123,107,255,.55), inset 0 1px 0 rgba(255,255,255,.4);
  position:relative;
}
.step-num::after{
  content:"";position:absolute;inset:-6px;border-radius:50%;
  background:linear-gradient(135deg,var(--violet),var(--rose));
  opacity:.25;filter:blur(10px);z-index:-1;
}
.step h3{font-size:20px;font-weight:800;letter-spacing:-.02em;margin:0 0 8px}
.step p{font-size:15px;color:var(--ink-soft);margin:0 auto;max-width:280px}

/* ============================================
   SHOWCASE
   ============================================ */
.showcase{
  max-width:1280px;margin:0 auto;padding:80px 40px;
  display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;
}
.check-list{margin-top:24px;display:flex;flex-direction:column;gap:12px}
.check-list li{
  display:flex;align-items:center;gap:12px;
  font-size:16px;font-weight:500;color:rgba(26,21,48,.8);
}
.check-list .check{
  width:22px;height:22px;border-radius:50%;
  background:linear-gradient(135deg,var(--green),var(--cyan));
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  position:relative;
  box-shadow:0 6px 14px -4px rgba(91,209,122,.45);
}
.check-list .check::before{
  content:"";position:absolute;left:5px;top:11px;width:4px;height:8px;
  border-right:2px solid #fff;border-bottom:2px solid #fff;
  transform:rotate(45deg);
}
.show-tags{
  margin-top:24px;display:flex;flex-wrap:wrap;gap:10px;list-style:none;padding:0;
}
.show-tag{
  display:inline-flex;align-items:center;
  padding:9px 16px;border-radius:99px;
  font-size:13.5px;font-weight:600;letter-spacing:-.005em;
  color:var(--violet);
  background:rgba(123,107,255,.08);
  border:1px solid rgba(123,107,255,.18);
  backdrop-filter:blur(10px);
  transition:background .25s, border-color .25s, transform .25s var(--ease-out);
}
.show-tag:hover{background:rgba(123,107,255,.14);border-color:rgba(123,107,255,.32);transform:translateY(-1px)}
.show-tag:nth-child(2){color:var(--rose);background:rgba(255,107,181,.08);border-color:rgba(255,107,181,.2)}
.show-tag:nth-child(2):hover{background:rgba(255,107,181,.14);border-color:rgba(255,107,181,.34)}
.show-tag:nth-child(3){color:#1aa15e;background:rgba(91,209,122,.12);border-color:rgba(91,209,122,.26)}
.show-tag:nth-child(3):hover{background:rgba(91,209,122,.2);border-color:rgba(91,209,122,.4)}
.showcase-right{display:flex;justify-content:center;perspective:1500px}
.phone-static{position:relative;transform:rotate(-3deg)}

/* ============================================
   GALLERY
   ============================================ */
.gallery{max-width:1280px;margin:0 auto;padding:80px 40px}
.gallery-grid{
  display:grid;grid-template-columns:1fr 1.15fr 1fr;
  gap:30px;align-items:end;justify-items:center;
  margin-top:24px;perspective:1500px;
}
.gallery-item{
  margin:0;text-align:center;display:flex;flex-direction:column;align-items:center;gap:22px;
}
.gallery-item .phone{position:relative;width:260px;height:540px}
.gallery-featured .phone{width:290px;height:600px}
.phone-tilt-l{transform:rotate(-5deg)}
.phone-tilt-r{transform:rotate(5deg)}
.gallery-item figcaption{max-width:260px;display:flex;flex-direction:column;gap:6px}
.gallery-item figcaption strong{font-size:18px;font-weight:800;letter-spacing:-.01em}
.gallery-item figcaption span{font-size:14.5px;color:var(--ink-soft);line-height:1.5}

/* ============================================
   APPS — Studio Ledcles
   ============================================ */
.apps{max-width:1280px;margin:0 auto;padding:100px 40px 80px}
.apps-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;perspective:1500px;
}
.app-card{
  position:relative;
  border-radius:30px;
  padding:30px;
  background:rgba(255,255,255,.7);
  backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.95);
  box-shadow:var(--sh-card);
  transform-style:preserve-3d;
  transition:transform .5s var(--ease-out), box-shadow .5s var(--ease-out);
  overflow:hidden;
  isolation:isolate;
  display:flex;flex-direction:column;gap:18px;
}
.app-card:hover{box-shadow:var(--sh-card-hover);transform:translateY(-4px)}
.app-card-glow{
  position:absolute;inset:0;z-index:-1;border-radius:inherit;
  background:radial-gradient(closest-side, var(--glow-c, rgba(123,107,255,.3)), transparent 70%);
  opacity:0;transition:opacity .5s var(--ease-out);
}
.app-beamo{--glow-c:rgba(255,209,107,.4)}
.app-kado{--glow-c:rgba(255,107,181,.4)}
.app-tibou{--glow-c:rgba(123,255,200,.4)}
.app-card:hover .app-card-glow{opacity:.5}

.app-icon{
  width:64px;height:64px;border-radius:18px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 14px 30px -8px rgba(80,60,180,.25);
  transform:translateZ(20px);
  overflow:hidden;
}
.app-icon img{width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit}
.app-meta{display:flex;flex-direction:column;gap:4px;transform:translateZ(15px)}
.app-meta h3{margin:0;font-size:26px;font-weight:900;letter-spacing:-.025em}
.app-tag{
  font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;
  color:var(--ink-mute);
}
.app-card p{margin:0;font-size:15px;color:var(--ink-soft);line-height:1.55;transform:translateZ(10px)}
.app-cta{
  display:inline-flex;align-items:center;gap:8px;
  margin-top:auto;
  padding:10px 14px;border-radius:99px;
  font-weight:700;font-size:14px;
  background:rgba(26,21,48,.06);color:var(--ink);
  align-self:flex-start;
  transition:background .25s, gap .25s var(--ease-out);
  transform:translateZ(10px);
}
.app-card:hover .app-cta{background:rgba(26,21,48,.10);gap:12px}

/* ============================================
   PRIVACY
   ============================================ */
.privacy{padding:80px 40px}
.privacy-card{
  max-width:1100px;margin:0 auto;
  background:linear-gradient(135deg,rgba(26,21,48,.94),rgba(60,40,120,.94));
  color:#fff;
  border-radius:40px;
  padding:64px 56px;
  box-shadow:0 40px 80px -30px rgba(26,21,48,.5);
  position:relative;overflow:hidden;
}
.privacy-card::before{
  content:"";position:absolute;width:480px;height:480px;border-radius:50%;
  background:radial-gradient(circle,var(--rose) 0%,transparent 70%);
  top:-180px;right:-120px;opacity:.4;
}
.privacy-card::after{
  content:"";position:absolute;width:560px;height:560px;border-radius:50%;
  background:radial-gradient(circle,var(--violet) 0%,transparent 70%);
  bottom:-220px;left:-180px;opacity:.35;
}
.privacy-card > *{position:relative;z-index:1}
.privacy-card .section-title{color:#fff;max-width:680px}
.privacy-card .section-sub{color:rgba(255,255,255,.7);max-width:680px;margin-bottom:36px}
.privacy-badge{
  display:inline-block;padding:5px 14px;border-radius:99px;
  background:rgba(255,255,255,.1);color:rgba(255,255,255,.9);
  font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  margin-bottom:20px;border:1px solid rgba(255,255,255,.15);
}
.privacy-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:8px;
}
.privacy-item{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  border-radius:20px;padding:22px;
  backdrop-filter:blur(20px);
  transition:transform .35s var(--ease-out), background .35s;
}
.privacy-item:hover{transform:translateY(-3px);background:rgba(255,255,255,.12)}
.privacy-ico{
  width:42px;height:42px;border-radius:13px;
  background:linear-gradient(135deg,rgba(255,255,255,.15),rgba(255,255,255,.05));
  border:1px solid rgba(255,255,255,.18);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.9);
  margin-bottom:14px;
}
.privacy-item strong{display:block;font-size:17px;font-weight:800;margin-bottom:6px}
.privacy-item span{font-size:14px;color:rgba(255,255,255,.7);line-height:1.55}

/* ============================================
   CONTACT
   ============================================ */
.contact{padding:100px 40px 60px;max-width:1280px;margin:0 auto}
.contact-wrap{
  display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:start;
}
.contact-left .section-title{text-align:left;font-size:clamp(28px,3.5vw,42px)}
.contact-left .section-sub{margin-bottom:32px}
.contact-info{display:flex;flex-direction:column;gap:14px}
.contact-info-row{
  display:flex;align-items:center;gap:14px;
  padding:14px 16px;border-radius:18px;
  background:rgba(255,255,255,.55);
  border:1px solid rgba(255,255,255,.9);
  backdrop-filter:blur(20px);
  transition:transform .25s var(--ease-out), background .25s;
}
a.contact-info-row:hover{background:rgba(255,255,255,.8);transform:translateY(-2px)}
.contact-info-ico{
  width:40px;height:40px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--violet),var(--rose));
  color:#fff;
  box-shadow:0 8px 18px -6px rgba(123,107,255,.40);
  flex-shrink:0;
}
.contact-info-row > div{display:flex;flex-direction:column;line-height:1.3}
.contact-info-row span{font-size:11.5px;color:var(--ink-mute);font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.contact-info-row strong{font-size:15px;font-weight:700;color:var(--ink)}

/* Contact form */
.contact-form{
  background:rgba(255,255,255,.72);
  backdrop-filter:blur(22px);
  border:1px solid rgba(255,255,255,.95);
  border-radius:30px;
  padding:32px;
  box-shadow:var(--sh-card);
  display:flex;flex-direction:column;gap:18px;
}
.field{position:relative}
.field input,.field textarea,.field select{
  width:100%;padding:22px 18px 12px;border-radius:16px;
  background:rgba(255,255,255,.6);
  border:1px solid rgba(255,255,255,.95);
  color:var(--ink);font-size:15px;
  transition:border-color .25s, background .25s, box-shadow .25s;
  outline:none;
  font-family:inherit;
}
.field textarea{resize:vertical;min-height:120px;padding-top:24px;line-height:1.5}
.field select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%231A1530' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><path d='m6 9 6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 16px center;padding-right:42px;cursor:pointer}
.field label{
  position:absolute;left:18px;top:18px;
  font-size:14px;color:var(--ink-mute);font-weight:500;
  pointer-events:none;
  transition:transform .25s var(--ease-out), color .25s, font-size .25s;
  transform-origin:left center;
  background:transparent;
}
.field input:focus,.field textarea:focus,.field select:focus{
  border-color:rgba(123,107,255,.5);
  background:rgba(255,255,255,.85);
  box-shadow:0 0 0 4px rgba(123,107,255,.15);
}
.field input:focus + label,
.field input:not(:placeholder-shown) + label,
.field textarea:focus + label,
.field textarea:not(:placeholder-shown) + label,
.field select:focus + label,
.field select:valid + label,
.field.has-value label{
  transform:translateY(-9px) scale(.82);
  color:var(--violet-deep);
}
.field-textarea label{top:18px}

/* Select fields: label always floated so it doesn't overlap the placeholder option text */
.field-select label{
  transform:translateY(-9px) scale(.82);
  color:var(--violet-deep);
}
.field-select select{color:var(--ink-mute)}
.field-select select:valid{color:var(--ink)}
.field-select option{color:var(--ink)}
.field-select option[disabled]{color:var(--ink-mute)}

.field.is-error input,.field.is-error textarea,.field.is-error select{
  border-color:rgba(255,75,99,.6);
  box-shadow:0 0 0 4px rgba(255,75,99,.12);
}
.field-error{
  display:none;font-size:12.5px;color:#D43159;
  margin-top:6px;padding-left:4px;
}
.field.is-error .field-error{display:block}

.btn-form{justify-content:center;width:100%;position:relative;overflow:hidden;padding-top:16px;padding-bottom:16px;font-size:15px}
.btn-form .btn-loading,.btn-form .btn-success{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transform:translateY(20px);
  transition:opacity .25s, transform .25s var(--ease-out);
}
.btn-form .btn-loading svg{animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.btn-form.is-loading .btn-label{opacity:0;transform:translateY(-20px);transition:opacity .25s, transform .25s var(--ease-out)}
.btn-form.is-loading .btn-loading{opacity:1;transform:translateY(0)}
.btn-form.is-success{background:linear-gradient(135deg,#5BD17A,#6BD8FF) !important;animation:none}
.btn-form.is-success .btn-label{opacity:0;transform:translateY(-20px);transition:opacity .25s, transform .25s var(--ease-out)}
.btn-form.is-success .btn-success{opacity:1;transform:translateY(0)}

.form-status{margin:0;font-size:14px;font-weight:500;min-height:0;color:var(--ink-soft);transition:color .25s}
.form-status.is-error{color:#D43159}
.form-status.is-ok{color:#1F8F3E}
.form-fine{margin:0;font-size:12.5px;color:var(--ink-mute);text-align:center}

/* ============================================
   FAQ
   ============================================ */
.faq{max-width:880px;margin:0 auto;padding:80px 40px}
.faq-list{display:flex;flex-direction:column;gap:12px}
.faq details{
  background:rgba(255,255,255,.6);
  backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.95);
  border-radius:20px;padding:20px 24px;
  transition:background .25s, box-shadow .25s;
}
.faq details[open]{background:rgba(255,255,255,.92);box-shadow:var(--sh-soft)}
.faq summary{
  list-style:none;cursor:pointer;
  font-weight:700;font-size:16.5px;letter-spacing:-.01em;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
}
.faq summary::-webkit-details-marker{display:none}
.faq-chev{
  flex-shrink:0;width:24px;height:24px;border-radius:50%;
  background:rgba(26,21,48,.06);
  position:relative;transition:transform .35s var(--ease-out), background .25s;
}
.faq-chev::before,.faq-chev::after{
  content:"";position:absolute;left:50%;top:50%;
  width:10px;height:2px;background:var(--ink);border-radius:2px;
  transform-origin:center;
}
.faq-chev::before{transform:translate(-50%,-50%)}
.faq-chev::after{transform:translate(-50%,-50%) rotate(90deg);transition:transform .35s var(--ease-out)}
.faq details[open] .faq-chev{background:linear-gradient(135deg,var(--violet),var(--rose));}
.faq details[open] .faq-chev::before,.faq details[open] .faq-chev::after{background:#fff}
.faq details[open] .faq-chev::after{transform:translate(-50%,-50%) rotate(0deg)}
.faq-content{
  display:grid;grid-template-rows:0fr;
  transition:grid-template-rows .45s var(--ease-out);
}
.faq details[open] .faq-content{grid-template-rows:1fr}
.faq-inner{overflow:hidden;min-height:0}
.faq-inner p{
  margin:14px 0 0;color:var(--ink-soft);font-size:15px;line-height:1.6;
  opacity:0;transform:translateY(-6px);
  transition:opacity .35s var(--ease-out) .1s, transform .35s var(--ease-out) .1s;
}
.faq details[open] .faq-inner p{opacity:1;transform:translateY(0)}

/* ============================================
   CTA
   ============================================ */
.cta{padding:60px 40px 100px}
.cta-card{
  max-width:980px;margin:0 auto;
  text-align:center;
  background:rgba(255,255,255,.7);
  backdrop-filter:blur(30px);
  border:1px solid rgba(255,255,255,.95);
  border-radius:40px;
  padding:68px 40px;
  box-shadow:var(--sh-card);
  position:relative;overflow:hidden;
}
.cta-card::before{
  content:"";position:absolute;width:640px;height:640px;border-radius:50%;
  background:radial-gradient(circle,#FFB1C7 0%,transparent 65%);
  top:-220px;left:-120px;opacity:.5;z-index:-1;
}
.cta-card::after{
  content:"";position:absolute;width:640px;height:640px;border-radius:50%;
  background:radial-gradient(circle,#B89BFF 0%,transparent 65%);
  bottom:-220px;right:-120px;opacity:.45;z-index:-1;
}
.cta-shine{
  position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.9) 50%,transparent 70%);
  background-size:200% 100%;background-position:-100% 0;
  opacity:.5;mix-blend-mode:overlay;
  animation:shine 6s linear infinite;
}
@keyframes shine{
  0%{background-position:-100% 0}
  100%{background-position:200% 0}
}
.cta-title{font-size:clamp(34px,5.2vw,56px);font-weight:900;letter-spacing:-.03em;line-height:1.04;margin:0 0 16px}
.cta-title em{
  font-family:'Instrument Serif',serif;font-style:italic;font-weight:400;
  background:linear-gradient(135deg,var(--violet),var(--rose),var(--orange));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.cta-sub{font-size:18px;color:var(--ink-soft);max-width:560px;margin:0 auto 32px}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-bottom:20px}
.store-btn{
  display:inline-flex;align-items:center;gap:12px;
  padding:13px 22px;border-radius:16px;
  background:var(--ink);color:#fff;
  transition:transform .25s var(--ease-out), box-shadow .25s;
  box-shadow:0 10px 24px -8px rgba(26,21,48,.5);
  will-change:transform;
}
.store-btn:hover{transform:translateY(-2px);box-shadow:0 14px 28px -8px rgba(26,21,48,.6)}
.store-btn-text{display:flex;flex-direction:column;align-items:flex-start;line-height:1.1}
.store-btn-text small{font-size:10px;opacity:.75;letter-spacing:.04em}
.store-btn-text strong{font-size:18px;font-weight:700}
.cta-fine{font-size:13px;color:var(--ink-mute);margin:0}

/* ============================================
   FOOTER
   ============================================ */
.footer{padding:60px 40px 24px;background:rgba(26,21,48,.04);border-top:1px solid rgba(255,255,255,.6);margin-top:40px}
.footer-inner{
  max-width:1280px;margin:0 auto;
  display:grid;grid-template-columns:1.2fr 2fr;gap:40px;
  padding-bottom:30px;border-bottom:1px solid var(--ink-faint);
}
.footer-brand-col{display:flex;flex-direction:column;gap:16px;max-width:380px}
.footer-brand{display:flex;align-items:center;gap:10px}
.footer-tagline{font-size:14px;color:var(--ink-soft);line-height:1.6;margin:0}
.footer-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.footer-cols strong{display:block;font-size:13px;font-weight:700;margin-bottom:12px;color:var(--ink)}
.footer-cols a{display:block;font-size:14px;color:var(--ink-soft);padding:4px 0;transition:color .2s}
.footer-cols a:hover{color:var(--ink)}
.footer-base{
  max-width:1280px;margin:24px auto 0;text-align:center;
  font-size:13px;color:var(--ink-mute);
}

/* ============================================
   ANIMATION SYSTEM — Reveal
   ============================================ */
[data-reveal]{
  opacity:0;transform:translateY(28px);
  transition:opacity .8s var(--ease-out), transform .8s var(--ease-out);
  will-change:opacity, transform;
}
[data-reveal].is-revealed{opacity:1;transform:translateY(0)}

/* Word-by-word split reveal */
[data-split-words]{display:inline-block}
.split-word{
  display:inline-block;
  opacity:0;
  transform:translateY(50%);
  filter:blur(6px);
  animation:wordReveal .9s var(--ease-out) forwards;
  animation-delay:calc(var(--i,0) * 0.06s + 0.15s);
  will-change:opacity,transform,filter;
}
@keyframes wordReveal{
  to{opacity:1;transform:translateY(0);filter:blur(0)}
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 1100px){
  .nav{padding:14px 28px}
  .nav-links{gap:22px}
  .nav-links a{font-size:13.5px}
  .hero{gap:40px;padding:64px 28px 48px}
  .features,.how,.showcase,.gallery,.apps,.privacy,.faq,.cta,.contact{padding-left:28px;padding-right:28px}
  .feature-grid{grid-template-columns:repeat(2,1fr)}
  .feature-card.feature-lg,.feature-card.feature-lg:first-child{grid-column:span 2}
  .gallery-grid{grid-template-columns:1fr 1.1fr 1fr;gap:18px}
  .gallery-item .phone{width:220px;height:460px}
  .gallery-featured .phone{width:250px;height:520px}
  .apps-grid{grid-template-columns:repeat(3,1fr);gap:16px}
  .app-card{padding:24px}
}

@media (max-width: 960px){
  .nav{padding:12px 20px;gap:10px}
  .nav-links{display:none}
  .nav-burger{display:flex}
  .hero{
    grid-template-columns:1fr;
    padding:36px 20px 24px;
    gap:48px;text-align:left;
  }
  .hero-content{order:1}
  .hero-mockups{
    order:2;position:relative;height:auto;max-width:560px;margin:0 auto;
    display:flex;justify-content:center;align-items:flex-start;gap:14px;
    padding:30px 0;
  }
  .phone-1,.phone-2{
    position:relative;top:0;left:0;right:0;
    width:clamp(180px, 38vw, 240px);
    height:clamp(380px, 78vw, 500px);
    animation:none;transform:none;
  }
  .float-card{display:none}
  .kpi{
    grid-template-columns:repeat(2,1fr);
    margin:24px 20px 0;padding:24px;gap:20px;
  }
  .kpi-item + .kpi-item::before{display:none}
  .ticker{padding:48px 0 24px}
  .ticker-item{font-size:15px;gap:8px}
  .ti-mark{width:26px;height:26px;font-size:11px;border-radius:8px}
  .ti-logo{width:22px;height:22px}
  .ticker-row{gap:32px;padding:0 16px}
  .features,.how,.showcase,.gallery,.apps,.privacy,.faq,.cta,.contact{
    padding-left:20px;padding-right:20px;
  }
  .features,.how,.showcase,.gallery,.faq,.contact{padding-top:64px;padding-bottom:48px}
  .apps{padding-top:72px;padding-bottom:48px}
  .privacy,.cta{padding-top:48px;padding-bottom:48px}
  .feature-grid{grid-template-columns:1fr;gap:14px}
  .feature-card{padding:24px;border-radius:22px}
  .feature-card.feature-lg,.feature-card.feature-lg:first-child{grid-column:span 1}
  .steps{grid-template-columns:1fr;gap:32px}
  .steps-line{display:none}
  .showcase{grid-template-columns:1fr;gap:40px}
  .gallery-grid{grid-template-columns:1fr;gap:56px;justify-items:center}
  .gallery-item .phone,.gallery-featured .phone{
    width:clamp(220px, 70vw, 280px);
    height:clamp(460px, 145vw, 580px);
  }
  .phone-tilt-l,.phone-tilt-r{transform:none}
  .apps-grid{grid-template-columns:1fr;gap:14px}
  .privacy-card{padding:40px 22px;border-radius:26px}
  .privacy-grid{grid-template-columns:1fr;gap:14px}
  .contact-wrap{grid-template-columns:1fr;gap:36px}
  .contact-form{padding:26px;border-radius:24px}
  .cta-card{padding:48px 22px;border-radius:26px}
  .cta-title{font-size:clamp(30px,6vw,42px)}
  .section-head{margin-bottom:36px}
  .footer{padding:40px 20px 20px}
  .footer-inner{grid-template-columns:1fr;gap:28px}
  .footer-cols{grid-template-columns:repeat(3,1fr);gap:20px}
}

@media (max-width: 680px){
  .hero-title{font-size:clamp(34px,9vw,46px);letter-spacing:-.03em}
  .hero-sub{font-size:17px}
  .section-title{font-size:clamp(28px,7vw,38px)}
  .section-sub{font-size:16px}
  .btn{padding:12px 18px;font-size:14px}
  .hero-cta{gap:10px}
  .hero-cta .btn{flex:1 1 auto;justify-content:center}
  .hero-meta{gap:14px}
  .hero-meta li{font-size:13px}
  .kpi-value{font-size:30px}
  .kpi-label{font-size:12px}
  .footer-cols{grid-template-columns:repeat(2,1fr)}
  .store-btn{padding:10px 18px}
  .store-btn-text strong{font-size:16px}
}

@media (max-width: 480px){
  .nav{padding:10px 16px}
  .nav-actions{gap:8px}
  .brand-name{font-size:19px}
  .lang-switch{padding:2px}
  .lang-btn{padding:5px 9px;font-size:11px}
  .btn-sm{padding:8px 13px;font-size:12px}

  .hero{padding:26px 16px 12px;gap:36px}
  .pill{font-size:11.5px;padding:5px 12px}
  .hero-mockups{gap:10px;padding:20px 0}
  .phone-1,.phone-2{
    width:clamp(150px, 40vw, 190px);
    height:clamp(310px, 82vw, 400px);
    padding:7px;
  }
  .phone-img{border-radius:26px}

  .kpi{
    grid-template-columns:1fr 1fr;
    gap:14px;padding:18px;margin:18px 16px 0;border-radius:22px;
  }
  .kpi-value{font-size:26px}

  .features,.how,.showcase,.gallery,.faq,.contact{padding:48px 16px}
  .apps{padding:56px 16px 36px}
  .privacy,.cta{padding:36px 16px}
  .feature-card{padding:20px;border-radius:20px}
  .feature-card h3{font-size:19px}
  .feature-card p{font-size:14px}
  .feature-ico{width:46px;height:46px;border-radius:14px;margin-bottom:14px}

  .step-num{width:56px;height:56px;font-size:20px;margin-bottom:14px}
  .step h3{font-size:18px}
  .step p{font-size:14px}

  .app-card{padding:22px;border-radius:24px;gap:14px}
  .app-icon{width:54px;height:54px;border-radius:15px}
  .app-meta h3{font-size:22px}
  .app-card p{font-size:14px}

  .gallery-item .phone,.gallery-featured .phone{
    width:clamp(200px, 78vw, 250px);
    height:clamp(420px, 162vw, 520px);
  }
  .gallery-item figcaption strong{font-size:16.5px}
  .gallery-item figcaption span{font-size:13.5px}

  .privacy-card{padding:32px 18px;border-radius:22px}
  .privacy-item{padding:18px;border-radius:16px}

  .contact-form{padding:22px;border-radius:22px;gap:14px}
  .field input,.field textarea,.field select{padding-top:24px;padding-bottom:10px;font-size:14px}
  .field label{font-size:13.5px}

  .faq details{padding:16px 18px;border-radius:16px}
  .faq summary{font-size:15px}
  .faq p{font-size:14px}

  .cta-card{padding:40px 20px;border-radius:24px}
  .cta-title{font-size:clamp(26px,7vw,34px)}
  .cta-sub{font-size:16px}
  .cta-actions{gap:10px}
  .store-btn{padding:10px 16px;gap:10px;flex:1 1 calc(50% - 10px);justify-content:center}

  .footer{padding:32px 16px 16px}
  .footer-cols{grid-template-columns:1fr 1fr;gap:18px}
}

@media (max-width: 360px){
  .footer-cols{grid-template-columns:1fr}
  .kpi{grid-template-columns:1fr}
  .hero-cta{flex-direction:column}
  .hero-cta .btn{width:100%}
}

/* ---- Reduce motion ---- */
@media (prefers-reduced-motion: reduce){
  .phone-1,.phone-2,.float-card,.float-card-1,.float-card-2,.float-card-3,.btn-primary,.kpi-value,.cta-shine,.pill-dot::before,.hero-title-italic em{animation:none !important}
  *{transition-duration:.01ms !important;animation-duration:.01ms !important}
  [data-reveal]{opacity:1 !important;transform:none !important}
}

/* ---- Pause animations when element is off-screen ---- */
.is-offscreen,
.is-offscreen *{
  animation-play-state:paused !important;
}

/* ---- Lite mode: low-end devices, touch, or reduced motion ----
   Disables the most GPU-expensive effects (blur filters, backdrop-filter,
   infinite breathing animations) while keeping the visual identity. */
.lite-mode .glow{
  filter:blur(40px);
  animation:none !important;
}
.lite-mode .glow-4{display:none}
.lite-mode .noise{display:none}
.lite-mode .phone-halo,
.lite-mode .phone-halo-2{
  filter:blur(20px);
  animation:none !important;
}
.lite-mode .nav,
.lite-mode .drawer,
.lite-mode .btn-ghost,
.lite-mode .float-card,
.lite-mode .pill{
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
}
.lite-mode .nav{background:rgba(255,255,255,.85)}
.lite-mode .drawer{background:rgba(255,255,255,.98)}
.lite-mode .phone-1,
.lite-mode .phone-2,
.lite-mode .float-card,
.lite-mode .float-card-1,
.lite-mode .float-card-2,
.lite-mode .float-card-3,
.lite-mode .btn-primary,
.lite-mode .cta-shine,
.lite-mode .pill-dot::before,
.lite-mode .hero-title-italic em{
  animation:none !important;
}
.lite-mode [data-parallax]{transform:none !important}
.lite-mode *{will-change:auto !important}

/* ============================================
   LEGAL PAGES (Conditions, Confidentialité)
   ============================================ */
.legal-main{max-width:880px;margin:0 auto;padding:140px 28px 80px}
.legal-head{margin-bottom:48px}
.legal-eyebrow{
  display:inline-block;font-size:12.5px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--violet-deep);
  background:rgba(123,107,255,.12);
  padding:6px 12px;border-radius:999px;margin-bottom:18px;
}
.legal-title{
  font-size:clamp(34px,5vw,52px);font-weight:800;
  letter-spacing:-.025em;line-height:1.05;margin:0 0 14px;
  color:var(--ink);
}
.legal-updated{font-size:14px;color:var(--ink-mute);margin:0}
.legal-card{
  background:rgba(255,255,255,.72);
  backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px);
  border:1px solid rgba(255,255,255,.95);
  border-radius:28px;
  padding:40px 44px;
  box-shadow:var(--sh-card);
}
.legal-toc{
  background:rgba(123,107,255,.06);
  border:1px solid rgba(123,107,255,.15);
  border-radius:18px;
  padding:20px 24px;margin-bottom:36px;
}
.legal-toc strong{display:block;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--violet-deep);margin-bottom:10px}
.legal-toc ol{margin:0;padding-left:20px;color:var(--ink-soft);font-size:14.5px;line-height:1.85}
.legal-toc a{color:var(--ink-soft);text-decoration:none;transition:color .2s}
.legal-toc a:hover{color:var(--violet-deep)}
.legal-card h2{
  font-size:22px;font-weight:800;letter-spacing:-.015em;
  margin:36px 0 14px;color:var(--ink);
  scroll-margin-top:100px;
}
.legal-card h2:first-child{margin-top:0}
.legal-card h3{
  font-size:16.5px;font-weight:700;letter-spacing:-.005em;
  margin:24px 0 8px;color:var(--ink);
}
.legal-card p,.legal-card li{
  font-size:15.5px;line-height:1.7;color:var(--ink-soft);margin:0 0 12px;
}
.legal-card ul,.legal-card ol{padding-left:22px;margin:8px 0 16px}
.legal-card li{margin-bottom:6px}
.legal-card a{color:var(--violet-deep);text-decoration:underline;text-underline-offset:3px}
.legal-card a:hover{color:var(--ink)}
.legal-card strong{color:var(--ink);font-weight:700}
.legal-card hr{border:none;border-top:1px solid rgba(26,21,48,.08);margin:32px 0}
.legal-callout{
  background:rgba(123,107,255,.06);
  border-left:3px solid var(--violet);
  border-radius:8px;
  padding:14px 18px;margin:16px 0 20px;
  font-size:14.5px;color:var(--ink-soft);
}
.legal-meta{
  display:grid;grid-template-columns:160px 1fr;gap:10px 20px;
  font-size:14.5px;margin:10px 0 20px;
}
.legal-meta dt{color:var(--ink-mute);font-weight:500}
.legal-meta dd{margin:0;color:var(--ink-soft)}
.legal-back{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--ink-mute);font-size:14px;font-weight:500;
  text-decoration:none;margin-bottom:24px;transition:color .2s;
}
.legal-back:hover{color:var(--violet-deep)}
@media (max-width:680px){
  .legal-main{padding:110px 18px 60px}
  .legal-card{padding:28px 22px;border-radius:22px}
  .legal-meta{grid-template-columns:1fr}
  .legal-meta dt{margin-top:6px}
}

/* ============================================
   LEGAL PAGES — performance overrides
   Static bg, no blur, no noise, no animation
   ============================================ */
.legal-page .bg-gradient{
  background:
    radial-gradient(1200px 800px at 10% -10%, #EADCFB 0%, transparent 60%),
    radial-gradient(900px 700px at 100% 0%, #FDE0E8 0%, transparent 55%),
    linear-gradient(180deg,#F5EBFB 0%, #FDE5E8 60%, #FFEDD9 100%);
}
.legal-page .nav{
  background:rgba(255,255,255,.92);
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
}
.legal-page .legal-card,
.legal-page .legal-toc{
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
}
.legal-page .legal-card{background:#fff}
.legal-page .footer{
  background:rgba(255,255,255,.7);
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
}
.legal-page *,
.legal-page *::before,
.legal-page *::after{
  animation:none !important;
}

/* ============================================
   MOBILE UX IMPROVEMENTS
   Safe-areas, tap-targets, iOS no-zoom, overflow,
   sticky-nav anchor offsets, drawer scroll-lock
   ============================================ */

/* Anchor scroll offset under the sticky nav */
section[id]{scroll-margin-top:88px}
@media (max-width:960px){
  section[id]{scroll-margin-top:72px}
}
@media (max-width:480px){
  section[id]{scroll-margin-top:64px}
}

/* Long-word overflow safety on all text containers */
.hero-title,.section-title,.cta-title,.legal-title,
.hero-sub,.section-sub,.cta-sub,
.pill,.feature-card p,.feature-card h3,
.app-card p,.app-meta h3,
.contact-info-row strong,.faq summary,.faq-inner p,
.footer-cols a,.footer-tagline{
  overflow-wrap:anywhere;
  word-break:break-word;
  hyphens:auto;
}

/* Safe-area insets for notched devices */
.nav{padding-left:max(40px, env(safe-area-inset-left));padding-right:max(40px, env(safe-area-inset-right))}
.drawer{padding-left:max(20px, env(safe-area-inset-left));padding-right:max(20px, env(safe-area-inset-right))}
.footer{padding-left:max(40px, env(safe-area-inset-left));padding-right:max(40px, env(safe-area-inset-right));padding-bottom:max(24px, env(safe-area-inset-bottom))}

/* Lock body scroll when mobile drawer is open */
body.drawer-open{overflow:hidden;touch-action:none}

/* iOS Safari: prevent input zoom on focus (any input <16px triggers zoom).
   Override the small typo from the 480px breakpoint. */
@media (max-width:960px){
  .field input,.field textarea,.field select{font-size:16px !important}
  .field label{font-size:14px}
}

/* Bigger tap-targets on touch where it counts */
@media (hover:none){
  .nav-links a,.footer-cols a,.drawer a,.faq summary,
  .lang-btn,.app-cta,.show-tag,.hero-meta li{
    min-height:40px;
  }
  .drawer a{padding:14px 16px;min-height:48px;display:flex;align-items:center}
  .footer-cols a{padding:8px 0;min-height:36px}
}

/* ----- Mobile nav adjustments (≤960px) ----- */
@media (max-width:960px){
  .nav{
    padding-top:10px;padding-bottom:10px;
    gap:8px;
  }
  /* Use viewport-aware horizontal padding incl. safe area */
  .nav{padding-left:max(16px, env(safe-area-inset-left));padding-right:max(16px, env(safe-area-inset-right))}
  .nav-brand{min-width:0;flex:0 1 auto}
  .brand-name{font-size:20px}
  .nav-actions{gap:8px;flex:0 0 auto}
  /* Drawer sits directly under the sticky nav, full available height */
  .drawer{
    top:60px;
    max-height:calc(100dvh - 60px);
    overflow-y:auto;
    padding-bottom:max(24px, env(safe-area-inset-bottom));
  }
}

/* ----- Compact nav for small screens (≤480px) ----- */
@media (max-width:480px){
  /* The drawer already exposes "Télécharger" — remove the duplicated CTA */
  .nav-actions > .btn-sm{display:none}
  .nav{gap:10px}
  .nav-burger{width:42px;height:42px;border-radius:12px}
  .lang-switch{padding:2px}
  .lang-btn{padding:6px 10px;min-height:32px}
  .brand-name{font-size:18px}
  .logo-mark svg,.logo-mark img{width:34px;height:34px}
}

/* ----- Hero: cleaner small-screen layout for the mockups -----
   Two side-by-side phones become a single hero phone with the second
   peeking behind for depth. Below 480px, focus fully on phone-1. */
@media (max-width:560px){
  .hero{padding-top:28px;gap:32px}
  .hero-mockups{
    gap:0;justify-content:center;align-items:center;
    padding:8px 0 24px;position:relative;
    min-height:clamp(380px, 90vw, 480px);
  }
  .phone-1{
    position:relative;
    width:clamp(220px, 58vw, 270px);
    height:clamp(440px, 120vw, 560px);
    transform:rotate(-3deg);
    margin:0;left:auto;top:auto;right:auto;
    z-index:2;
  }
  .phone-2{
    position:absolute;
    width:clamp(180px, 46vw, 220px);
    height:clamp(370px, 96vw, 450px);
    top:36px;left:58%;
    transform:rotate(8deg);
    z-index:1;opacity:.88;animation:none;
  }
}
@media (max-width:480px){
  .phone-2{display:none}
  .phone-1{transform:rotate(-2deg)}
  .hero-mockups{min-height:clamp(420px, 105vw, 520px)}
}

/* ----- Hero content tweaks small ----- */
@media (max-width:480px){
  .hero{padding-left:16px;padding-right:16px}
  .pill{
    font-size:11.5px;padding:5px 12px;
    max-width:100%;white-space:normal;text-align:left;line-height:1.35;
  }
  .hero-title{font-size:clamp(32px,8.6vw,42px);letter-spacing:-.03em;line-height:1.02}
  .hero-sub{font-size:16px;margin-bottom:24px}
  .hero-cta{gap:10px;margin-bottom:24px;width:100%}
  .hero-cta .btn{flex:1 1 100%;justify-content:center}
  .hero-meta{gap:10px 16px}
  .hero-meta li{font-size:12.5px}
}

/* ----- KPI ----- */
@media (max-width:480px){
  .kpi{margin:18px 12px 0}
  .kpi-label{font-size:11.5px}
}

/* ----- Ticker readability ----- */
@media (max-width:480px){
  .ticker{padding:36px 0 18px}
  .ticker-intro{font-size:11px;margin-bottom:16px}
  .ticker-item{font-size:14px;gap:8px}
  .ti-logo{width:20px;height:20px}
  .ticker-row{gap:24px;padding:0 12px}
}

/* ----- Contact form: prevent value/email overflow ----- */
.contact-info-row{flex-wrap:wrap}
.contact-info-row > div{min-width:0;flex:1 1 0}
.contact-info-row strong{display:block;max-width:100%;overflow-wrap:anywhere}
@media (max-width:480px){
  .contact-info-row{padding:12px 14px;gap:12px}
  .contact-info-row strong{font-size:14.5px}
  .contact-form{padding:20px;border-radius:20px}
  .field input,.field textarea{padding-left:16px;padding-right:16px}
  .field select{padding-right:38px}
  .field label{left:16px}
  /* Web3Forms honeypot is absolutely positioned — keep it off-screen safely */
  .contact-form input[name="botcheck"]{left:-9999px !important;top:-9999px !important}
}

/* ----- Privacy & CTA cards on small screens ----- */
@media (max-width:480px){
  .privacy-card{padding:32px 20px}
  .privacy-card::before,.privacy-card::after{width:320px;height:320px}
  .cta-card{padding:36px 18px}
  .cta-actions{width:100%}
  .store-btn{flex:1 1 100%;justify-content:center;padding:12px 18px}
  .store-btn-text strong{font-size:15px}
  .store-btn-text small{font-size:10.5px}
}

/* ----- Footer overflow & wrap fixes ----- */
.footer-cols a{overflow-wrap:anywhere}
@media (max-width:480px){
  .footer-cols{gap:14px 18px}
  .footer-base{font-size:12px;line-height:1.5}
}

/* ----- Disable hover-lift transforms on touch devices (avoid sticky :hover) ----- */
@media (hover:none){
  .app-card:hover,.btn-primary:hover,.btn-ghost:hover,
  .store-btn:hover,.show-tag:hover,
  .contact-info-row:hover,.privacy-item:hover{
    transform:none;
  }
}

/* ----- Galaxy Fold / 320px ultra-narrow ----- */
@media (max-width:360px){
  .brand-name{font-size:17px}
  .logo-mark svg,.logo-mark img{width:30px;height:30px}
  .pill{font-size:11px;padding:4px 10px}
  .hero-title{font-size:clamp(28px,9vw,36px)}
  .nav-actions > .lang-switch .lang-btn{padding:5px 8px;font-size:10.5px}
  .phone-2{display:none}
  .phone-1{transform:none;margin:0 auto}
}

