/* ============================================================
   Lechería — landing site · Kondoo-style · brand colors
   ============================================================ */
:root{
  --bg:#070b18; --bg-elev:#0c1426; --surface:#101a31; --surface-2:#162340; --surface-3:#1d2c4d;
  --ink:#eef2fb; --ink-soft:#c2cce0; --ink-muted:#8593b0; --ink-faint:#5a6788;
  --line:#1d2742; --line-strong:#28365a;
  --blue:#2E6BF5; --blue2:#1247C8; --gold:#2E9DCD; --gold2:#5BC4E8; --teal:#0ABFAB;
  --coral:#FF5757; --amber:#F5A623; --green:#2BD46F;
  --blue-soft:rgba(46,107,245,.14); --gold-soft:rgba(46,157,205,.14);
  --r-sm:9px; --r-md:13px; --r-lg:18px; --r-xl:24px; --r-full:999px;
  --glow:0 0 60px rgba(46,157,205,.25); --glow-blue:0 0 46px rgba(46,107,245,.4);
  --shadow:0 18px 48px rgba(0,0,0,.5); --shadow-card:0 1px 0 rgba(255,255,255,.03),0 12px 32px rgba(0,0,0,.4);
  --font:'Inter',system-ui,-apple-system,sans-serif; --display:'Manrope',var(--font); --mono:'JetBrains Mono',ui-monospace,monospace;
  --nav-bg:rgba(7,11,24,.72); --body-glow-a:rgba(46,157,205,.10); --body-glow-b:rgba(46,107,245,.10);
}
/* ---------- Light theme ---------- */
html.light{
  --bg:#eef2f9; --bg-elev:#ffffff; --surface:#ffffff; --surface-2:#f3f6fc; --surface-3:#e8eef8;
  --ink:#0f1d38; --ink-soft:#33415d; --ink-muted:#5a6884; --ink-faint:#8492ab;
  --line:#e4e9f3; --line-strong:#d2dcec;
  --gold:#1f80a8; --gold2:#1f9bce;
  --blue-soft:rgba(46,107,245,.10); --gold-soft:rgba(46,157,205,.10);
  --glow:0 0 60px rgba(46,157,205,.14); --glow-blue:0 0 30px rgba(46,107,245,.22);
  --shadow:0 18px 48px rgba(23,42,82,.12); --shadow-card:0 1px 0 rgba(255,255,255,.7),0 12px 30px rgba(23,42,82,.08);
  --nav-bg:rgba(255,255,255,.80); --body-glow-a:rgba(46,157,205,.12); --body-glow-b:rgba(46,107,245,.08);
}
html.light .city-logo{mix-blend-mode:normal;}
html.light .nav-cta{color:#fff!important;}
*{margin:0;padding:0;box-sizing:border-box;}
/* ---------- Theme toggle button ---------- */
.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;background:var(--surface);border:1px solid var(--line-strong);color:var(--ink-soft);cursor:pointer;transition:.15s;flex:none;}
.theme-toggle:hover{color:var(--ink);border-color:var(--gold);transform:translateY(-1px);}
@media(max-width:780px){ .theme-toggle{margin-left:8px;} }
html{scroll-behavior:smooth;}
body{
  font-family:var(--font);color:var(--ink);letter-spacing:-.01em;line-height:1.6;
  background:
    radial-gradient(900px 600px at 85% -5%, var(--body-glow-a), transparent 60%),
    radial-gradient(800px 560px at 5% 8%, var(--body-glow-b), transparent 55%),
    var(--bg);
  transition:background-color .25s, color .25s;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none;}
.wrap{max-width:1120px;margin:0 auto;padding:0 24px;}
.eyebrow{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.16em;color:var(--gold2);}
.mono{font-family:var(--mono);}

/* ---------- Nav ---------- */
.nav{position:sticky;top:0;z-index:50;background:var(--nav-bg);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);}
.nav-in{display:flex;align-items:center;gap:22px;height:64px;max-width:1120px;margin:0 auto;padding:0 24px;}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--display);font-weight:800;font-size:18px;letter-spacing:-.03em;}
.brand strong{color:var(--gold2);}
.brand-dot{width:11px;height:11px;border-radius:50%;background:linear-gradient(135deg,var(--gold2),var(--teal));box-shadow:0 0 16px var(--gold);}
.city-logo{mix-blend-mode:screen;display:block;}
.brand .city-logo{width:36px;height:auto;}
footer .brand .city-logo{width:26px;}
.nav-links{display:flex;gap:6px;margin-left:auto;align-items:center;}
.nav-links a{font-family:var(--display);font-weight:600;font-size:14px;color:var(--ink-muted);padding:8px 13px;border-radius:9px;transition:.15s;}
.nav-links a:hover{color:var(--ink);background:var(--surface);}
.nav-links a.active{color:var(--ink);}
.nav-cta{font-family:var(--display);font-weight:700;font-size:14px;padding:10px 17px;border-radius:var(--r-md);background:linear-gradient(135deg,var(--blue),var(--blue2));color:#fff!important;box-shadow:var(--glow-blue);transition:.15s;}
.nav-cta:hover{transform:translateY(-1px);background:linear-gradient(135deg,var(--blue),var(--blue2));}
.nav-toggle{display:none;}
@media(max-width:780px){
  .nav-links{display:none;}
  .nav-links.open{display:flex;position:absolute;top:64px;left:0;right:0;flex-direction:column;background:var(--bg-elev);border-bottom:1px solid var(--line);padding:12px;gap:2px;}
  .nav-toggle{display:flex;margin-left:auto;background:var(--surface);border:1px solid var(--line);color:var(--ink);width:40px;height:40px;border-radius:10px;align-items:center;justify-content:center;cursor:pointer;font-size:18px;}
}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:700;font-size:15px;padding:14px 24px;border-radius:var(--r-md);cursor:pointer;border:none;transition:.15s;}
.btn-primary{background:linear-gradient(135deg,var(--blue),var(--blue2));color:#fff;box-shadow:var(--glow-blue);}
.btn-primary:hover{transform:translateY(-2px);}
.btn-ghost{background:var(--surface);color:var(--ink);border:1px solid var(--line-strong);}
.btn-ghost:hover{border-color:var(--gold);}

/* ---------- Sections ---------- */
section{padding:72px 0;}
.sec-head{max-width:680px;}
.sec-head .eyebrow{display:block;margin-bottom:12px;}
h1{font-family:var(--display);font-weight:800;letter-spacing:-.035em;line-height:1.04;font-size:clamp(34px,6vw,60px);}
h2{font-family:var(--display);font-weight:800;letter-spacing:-.03em;line-height:1.08;font-size:clamp(26px,4vw,40px);}
h3{font-family:var(--display);font-weight:700;letter-spacing:-.02em;font-size:20px;}
.lead{color:var(--ink-soft);font-size:clamp(16px,2vw,19px);margin-top:18px;}
.muted{color:var(--ink-muted);}

/* ---------- Hero ---------- */
.hero{padding:84px 0 64px;position:relative;}
.hero .badge{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);background:var(--surface);border:1px solid var(--line-strong);padding:7px 13px;border-radius:var(--r-full);margin-bottom:24px;}
.hero .badge .dot{width:7px;height:7px;border-radius:50%;background:var(--teal);box-shadow:0 0 10px var(--teal);}
.hero h1{max-width:14ch;}
.hero h1 .grad{background:linear-gradient(120deg,var(--gold2),var(--teal));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.hero .lead{max-width:54ch;}
.hero-cta{display:flex;gap:13px;margin-top:34px;flex-wrap:wrap;}
.hero-stats{display:flex;gap:34px;margin-top:48px;flex-wrap:wrap;}
.hero-stats .hs .n{font-family:var(--mono);font-weight:700;font-size:28px;letter-spacing:-.02em;}
.hero-stats .hs .l{font-size:12.5px;color:var(--ink-muted);margin-top:2px;}
.hero-stats .hs .n.grad{background:linear-gradient(120deg,var(--gold2),var(--teal));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}

/* ---------- Cards ---------- */
.grid{display:grid;gap:18px;}
.g3{grid-template-columns:repeat(3,1fr);}
.g2{grid-template-columns:repeat(2,1fr);}
.g4{grid-template-columns:repeat(4,1fr);}
@media(max-width:900px){.g3,.g4{grid-template-columns:repeat(2,1fr);}}
@media(max-width:620px){.g2,.g3,.g4{grid-template-columns:1fr;}}
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;box-shadow:var(--shadow-card);transition:.16s;}
.card:hover{border-color:var(--line-strong);transform:translateY(-3px);}
.card .ic{width:44px;height:44px;border-radius:12px;background:var(--gold-soft);color:var(--gold2);display:flex;align-items:center;justify-content:center;margin-bottom:16px;}
.card.blue .ic{background:var(--blue-soft);color:#7aa3ff;}
.card.teal .ic{background:rgba(10,191,171,.14);color:#3fe0cf;}
.card.coral .ic{background:rgba(255,87,87,.14);color:#ff8f8f;}
.card h3{margin-bottom:8px;}
.card p{color:var(--ink-muted);font-size:14px;}

/* split feature */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;}
@media(max-width:840px){.split{grid-template-columns:1fr;gap:30px;}}
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-xl);padding:28px;box-shadow:var(--shadow-card);}

/* problem→solution */
.ps{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
@media(max-width:840px){.ps{grid-template-columns:1fr;}}
.ps .col{padding:28px;border-radius:var(--r-xl);border:1px solid var(--line);}
.ps .col.prob{background:linear-gradient(160deg,rgba(255,87,87,.06),transparent);}
.ps .col.sol{background:linear-gradient(160deg,rgba(43,212,111,.07),transparent);border-color:rgba(43,212,111,.25);}
.ps .col h3{margin-bottom:16px;display:flex;align-items:center;gap:9px;}
.ps .li{display:flex;gap:11px;padding:9px 0;font-size:14.5px;color:var(--ink-soft);border-top:1px solid var(--line);}
.ps .li:first-of-type{border-top:none;}
.ps .li .b{flex:none;margin-top:1px;}

/* stat band */
.band{background:linear-gradient(135deg,var(--blue2),var(--gold));border-radius:var(--r-xl);padding:40px;box-shadow:var(--glow);position:relative;overflow:hidden;}
.band::after{content:'';position:absolute;right:-60px;top:-60px;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(91,196,232,.6),transparent 70%);opacity:.4;}
.band .grid{position:relative;}
.band .n{font-family:var(--mono);font-weight:700;font-size:34px;color:#fff;letter-spacing:-.02em;}
.band .l{color:rgba(255,255,255,.85);font-size:13.5px;margin-top:4px;}
.band-items{position:relative;gap:14px;}
.band-item{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:var(--r-lg);padding:18px;}
.band-ic{width:40px;height:40px;border-radius:11px;background:rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:14px;}
.band-t{font-family:var(--display);font-weight:700;font-size:15.5px;color:#fff;letter-spacing:-.01em;line-height:1.15;}
.band-s{font-size:12.5px;color:rgba(255,255,255,.82);margin-top:5px;}

/* Live app screens (iframes) in the 'three experiences' cards */
.exp-bezel{width:212px;background:#000;border-radius:30px;padding:6px;box-shadow:0 16px 40px rgba(0,0,0,.5);}
.exp-clip{width:200px;height:418px;border-radius:24px;overflow:hidden;position:relative;background:#0b1326;}
.exp-clip iframe{position:absolute;top:0;left:0;width:390px;height:815px;border:0;transform:scale(.5128);transform-origin:top left;}
.exp-win2{width:100%;border-radius:13px;overflow:hidden;border:1px solid var(--line-strong);box-shadow:0 16px 40px rgba(0,0,0,.5);background:#0b1326;}
.exp-win2 .wb{display:flex;gap:5px;padding:9px 12px;background:var(--surface-2);border-bottom:1px solid var(--line);}
.exp-win2 .wb span{width:8px;height:8px;border-radius:50%;background:var(--line-strong);}
.exp-win2 iframe{width:100%;height:398px;border:0;display:block;}
.exp-win-full iframe{height:580px;}
.wb-url{margin-left:12px;font-family:var(--mono);font-size:11px;color:var(--ink-muted);background:var(--bg-elev);border:1px solid var(--line);border-radius:7px;padding:3px 12px;}
/* App mockups in the 'three experiences' cards */
.exp-shot{display:flex;justify-content:center;align-items:center;margin-bottom:20px;}
.exp-phone{width:172px;aspect-ratio:10/19;background:#000;border-radius:24px;padding:6px;box-shadow:0 16px 40px rgba(0,0,0,.55);}
.exp-screen{width:100%;height:100%;border-radius:19px;overflow:hidden;background:#0b1326;padding:12px;display:flex;flex-direction:column;gap:8px;}
.exp-eyebrow{font-family:var(--mono);font-size:8px;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-muted);}
.exp-tile{height:30px;border-radius:9px;background:var(--surface);border:1px solid var(--line);}
.exp-win{width:100%;max-width:300px;border-radius:13px;overflow:hidden;border:1px solid var(--line-strong);background:#0b1326;box-shadow:0 16px 40px rgba(0,0,0,.55);}
.exp-winbar{display:flex;gap:5px;padding:9px 12px;background:var(--surface-2);border-bottom:1px solid var(--line);}
.exp-winbar span{width:8px;height:8px;border-radius:50%;background:var(--line-strong);}
.exp-winbody{padding:13px;display:flex;flex-direction:column;gap:9px;}
.exp-bar{display:flex;align-items:flex-end;gap:6px;height:50px;}
.exp-bar i{flex:1;border-radius:4px 4px 0 0;background:linear-gradient(var(--gold2),var(--blue));display:block;}

/* steps (plan) */
.steps{display:flex;flex-direction:column;gap:0;}
.step{display:grid;grid-template-columns:64px 1fr;gap:22px;padding:24px 0;border-top:1px solid var(--line);}
.step:first-child{border-top:none;}
.step .num{font-family:var(--mono);font-weight:700;font-size:15px;width:48px;height:48px;border-radius:14px;background:var(--surface-2);border:1px solid var(--line-strong);color:var(--gold2);display:flex;align-items:center;justify-content:center;}
.step .ph{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-muted);}
.step h3{margin:5px 0 8px;}
.step p{color:var(--ink-muted);font-size:14.5px;}
.step .chips{display:flex;gap:7px;flex-wrap:wrap;margin-top:11px;}
.chip{font-family:var(--mono);font-size:11px;color:var(--ink-soft);background:var(--surface-2);border:1px solid var(--line);padding:4px 10px;border-radius:var(--r-full);}

/* integrations */
.integ-row{display:flex;align-items:center;gap:14px;padding:16px 0;border-top:1px solid var(--line);}
.integ-row:first-child{border-top:none;}
.integ-row .lg{width:48px;height:48px;border-radius:13px;background:var(--surface-2);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--gold2);flex:none;}
.integ-row .nm{font-family:var(--display);font-weight:700;font-size:15px;}
.integ-row .ds{font-size:13px;color:var(--ink-muted);}
.pill{font-family:var(--mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;font-weight:700;padding:5px 11px;border-radius:var(--r-full);}
.pill.amber{background:rgba(245,166,35,.16);color:#f7c46b;}
.pill.green{background:rgba(43,212,111,.15);color:#5be89a;}

/* CTA */
.cta-band{text-align:center;background:var(--surface);border:1px solid var(--line-strong);border-radius:var(--r-xl);padding:54px 32px;box-shadow:var(--glow);}
.cta-band h2{max-width:18ch;margin:0 auto;}
.cta-band .lead{max-width:46ch;margin-left:auto;margin-right:auto;}

/* footer */
footer{border-top:1px solid var(--line);padding:40px 0;color:var(--ink-muted);font-size:13px;}
.foot-in{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;align-items:center;}
footer a:hover{color:var(--ink);}
.powered{display:inline-flex;align-items:center;gap:13px;opacity:.6;transition:opacity .25s;}
.powered:hover{opacity:1;}
.pb-label{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.2em;color:var(--ink-muted);}
.pb-logo{height:26px;width:auto;display:block;}

/* phone mock in hero */
.hero-mock{display:flex;justify-content:center;}
.mini-phone{width:300px;height:610px;background:#000;border-radius:42px;padding:11px;box-shadow:var(--shadow),0 0 0 1.5px rgba(255,255,255,.07),var(--glow);flex:none;}
.mini-screen{width:100%;height:100%;border-radius:32px;overflow:hidden;background:var(--bg-elev);position:relative;}
.reveal{opacity:0;transform:translateY(16px);transition:.7s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}

/* ============================================================
   Animated hero (OURA-style) — drifting blobs, ripple rings, parallax
   ============================================================ */
.hero-x{position:relative;min-height:calc(100svh - 64px);display:flex;align-items:center;justify-content:center;overflow:hidden;text-align:center;background:var(--bg);}
.hero-blobs{position:absolute;inset:0;pointer-events:none;will-change:transform;transition:transform .6s ease-out;}
.blob{position:absolute;border-radius:50%;filter:blur(120px);opacity:.55;}
.blob.b1{left:10%;top:14%;width:44vw;height:44vw;background:rgba(46,157,205,.30);animation:blob1 22s ease-in-out infinite;}
.blob.b2{right:8%;top:26%;width:40vw;height:40vw;background:rgba(10,191,171,.24);animation:blob2 26s ease-in-out infinite;}
.blob.b3{bottom:4%;left:50%;width:36vw;height:36vw;background:rgba(46,107,245,.26);animation:blob3 30s ease-in-out infinite;}
@keyframes blob1{0%,100%{transform:translate(0,0) scale(1);}33%{transform:translate(60px,-40px) scale(1.15);}66%{transform:translate(-20px,30px) scale(.95);}}
@keyframes blob2{0%,100%{transform:translate(0,0) scale(1);}33%{transform:translate(-50px,35px) scale(.9);}66%{transform:translate(25px,-25px) scale(1.12);}}
@keyframes blob3{0%,100%{transform:translate(-50%,0) scale(1);}33%{transform:translate(calc(-50% + 30px),-20px) scale(1.1);}66%{transform:translate(calc(-50% - 30px),20px) scale(.92);}}
.hero-rings{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;}
.ring{position:absolute;width:min(78vh,90vw);height:min(78vh,90vw);border-radius:50%;border:1px solid rgba(91,196,232,.16);animation:ring 7s ease-out infinite;animation-delay:var(--d);opacity:0;}
@keyframes ring{0%{transform:scale(.35);opacity:0;}40%{opacity:.5;}100%{transform:scale(1.25);opacity:0;}}
.hero-vignette{position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse at center,transparent 32%,rgba(5,9,20,.78) 100%);}
.hero-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;padding:0 24px;will-change:transform;transition:transform .4s ease-out;}
.hero-eyebrow{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--ink-muted);}
.hero-logo{width:clamp(230px,42vw,380px);height:auto;mix-blend-mode:screen;margin:18px 0 4px;}
.hero-slogan{font-family:var(--display);font-weight:300;font-size:clamp(1.7rem,4.4vw,3rem);letter-spacing:.005em;color:var(--ink-soft);}
.hero-slogan b{font-weight:700;background:linear-gradient(120deg,var(--gold2),var(--teal));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.hero-subline{color:var(--ink-muted);font-size:clamp(14px,1.6vw,17px);margin-top:16px;max-width:48ch;line-height:1.6;}
.hero-ctas{display:flex;gap:13px;margin-top:32px;flex-wrap:wrap;justify-content:center;}
.hero-scroll{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--ink-muted);opacity:0;animation:hrise 1s ease 1.7s forwards;}
.scroll-line{width:1px;height:28px;background:rgba(255,255,255,.4);animation:scrolldot 1.8s ease-in-out infinite;}
@keyframes scrolldot{0%,100%{transform:translateY(0);opacity:.45;}50%{transform:translateY(7px);opacity:1;}}
.r1,.rlogo,.r2,.r3{opacity:0;}
.r1{animation:hrise 1s cubic-bezier(.22,1,.36,1) .3s forwards;}
.rlogo{animation:hlogo 1.4s cubic-bezier(.22,1,.36,1) .5s forwards;}
.r2{animation:hrise 1s cubic-bezier(.22,1,.36,1) 1s forwards;}
.r3{animation:hrise 1s cubic-bezier(.22,1,.36,1) 1.25s forwards;}
@keyframes hrise{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:none;}}
@keyframes hlogo{from{opacity:0;transform:scale(.86);filter:blur(14px);}to{opacity:1;transform:none;filter:blur(0);}}
@media(prefers-reduced-motion:reduce){.blob,.ring,.scroll-line{animation:none;}.r1,.rlogo,.r2,.r3,.hero-scroll{opacity:1;animation:none;}}

/* ============================================================
   v2 — language toggle · photography · richer motion
   ============================================================ */

/* ---------- Language toggle (text pill, sits with theme toggle) ---------- */
.lang-toggle{display:inline-flex;align-items:center;justify-content:center;height:38px;padding:0 13px;border-radius:10px;background:var(--surface);border:1px solid var(--line-strong);color:var(--ink-soft);cursor:pointer;font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.08em;transition:.15s;flex:none;}
.lang-toggle:hover{color:var(--ink);border-color:var(--gold);transform:translateY(-1px);}
@media(max-width:780px){.lang-toggle{margin-left:8px;}}

/* ---------- Scroll progress bar ---------- */
.scroll-prog{position:fixed;top:0;left:0;height:2px;width:0;z-index:60;background:linear-gradient(90deg,var(--gold2),var(--teal));box-shadow:0 0 12px var(--gold2);transition:width .08s linear;pointer-events:none;}

/* ---------- Reveal stagger delays ---------- */
.reveal.d1{transition-delay:.07s}.reveal.d2{transition-delay:.14s}.reveal.d3{transition-delay:.21s}
.reveal.d4{transition-delay:.28s}.reveal.d5{transition-delay:.35s}.reveal.d6{transition-delay:.42s}
.reveal-l{opacity:0;transform:translateX(-26px);transition:.75s cubic-bezier(.2,.7,.2,1);}
.reveal-r{opacity:0;transform:translateX(26px);transition:.75s cubic-bezier(.2,.7,.2,1);}
.reveal-s{opacity:0;transform:scale(.94);transition:.75s cubic-bezier(.2,.7,.2,1);}
.reveal-l.in,.reveal-r.in,.reveal-s.in{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){.reveal,.reveal-l,.reveal-r,.reveal-s{opacity:1!important;transform:none!important;transition:none;}}

/* ---------- Photography ---------- */
.photo{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-card);background:var(--surface);}
.photo img{display:block;width:100%;height:100%;object-fit:cover;}
.photo.zoom img{transition:transform 1.3s cubic-bezier(.2,.7,.2,1);}
.photo.zoom:hover img{transform:scale(1.07);}
.photo .cap{position:absolute;left:0;right:0;bottom:0;padding:16px 16px 13px;background:linear-gradient(transparent,rgba(4,8,18,.86));font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:#dfe7f5;}
.photo .cap b{color:var(--gold2);font-weight:700;}
.photo .tagpill{position:absolute;top:12px;left:12px;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:#fff;background:rgba(7,11,24,.55);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.22);padding:5px 11px;border-radius:var(--r-full);}
.photo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.photo-grid .photo{aspect-ratio:3/4;}
.photo-grid .photo.wide{grid-column:span 2;aspect-ratio:auto;}
@media(max-width:840px){.photo-grid{grid-template-columns:repeat(2,1fr);}.photo-grid .photo.wide{grid-column:span 2;}}

/* full-bleed image band */
.imgband{position:relative;border-radius:var(--r-xl);overflow:hidden;min-height:380px;display:flex;align-items:flex-end;box-shadow:var(--shadow);}
.imgband>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transform:scale(1.04);transition:transform 6s ease;}
.imgband:hover>img{transform:scale(1.12);}
.imgband .scrim{position:absolute;inset:0;background:linear-gradient(100deg,rgba(6,11,26,.94),rgba(6,11,26,.5) 52%,rgba(18,71,200,.34));}
.imgband .imgband-in{position:relative;padding:clamp(26px,4vw,46px);max-width:62ch;}
.imgband .imgband-in .eyebrow{color:var(--gold2);}
.imgband .imgband-in h2{color:#fff;margin-top:12px;}
.imgband .imgband-in p{color:rgba(255,255,255,.92);margin-top:14px;}
.imgband .imgband-in .btn{margin-top:24px;}

/* photo paired with a feature split */
.media{position:relative;border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);min-height:340px;}
.media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.3s cubic-bezier(.2,.7,.2,1);}
.media:hover img{transform:scale(1.06);}
.media .media-tag{position:absolute;bottom:16px;left:16px;right:16px;display:flex;justify-content:space-between;align-items:flex-end;gap:12px;}
.media .chiprow{display:flex;gap:7px;flex-wrap:wrap;}
.media .chiprow .chip{background:rgba(7,11,24,.6);backdrop-filter:blur(6px);border-color:rgba(255,255,255,.18);color:#eaf0fb;}

/* ---------- Hero photo backdrop ---------- */
.hero-photo{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden;}
.hero-photo img{width:100%;height:100%;object-fit:cover;opacity:.30;filter:saturate(1.15) contrast(1.02);animation:heroKen 26s ease-in-out infinite alternate;}
.hero-photo::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(7,11,24,.45),rgba(7,11,24,.82));}
html.light .hero-photo img{opacity:.22;}
@keyframes heroKen{0%{transform:scale(1.05) translate(0,0);}100%{transform:scale(1.16) translate(-1.5%,-2%);}}
@media(prefers-reduced-motion:reduce){.hero-photo img{animation:none;}}

/* ---------- Card shine + lift ---------- */
.card.lift{position:relative;overflow:hidden;}
.card.lift::before{content:'';position:absolute;top:0;left:-70%;width:45%;height:100%;background:linear-gradient(105deg,transparent,rgba(255,255,255,.10),transparent);transform:skewX(-18deg);transition:left .8s ease;pointer-events:none;}
.card.lift:hover::before{left:130%;}

/* gradient shimmer accent text */
.shimmer{background:linear-gradient(100deg,var(--gold2),var(--teal),var(--gold2));background-size:200% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:shim 5s linear infinite;}
@keyframes shim{to{background-position:200% center;}}
@media(prefers-reduced-motion:reduce){.shimmer{animation:none;}}

/* count-up numbers + numeric pop */
[data-count]{font-variant-numeric:tabular-nums;}

/* floating element */
@keyframes floaty{0%,100%{transform:translateY(0);}50%{transform:translateY(-12px);}}
.floaty{animation:floaty 6s ease-in-out infinite;}
@media(prefers-reduced-motion:reduce){.floaty{animation:none;}}

/* download badges (used on landing + app-site) */
.store-badge{display:inline-flex;align-items:center;gap:12px;background:#000;border:1px solid rgba(255,255,255,.14);color:#fff;padding:11px 20px;border-radius:14px;transition:.18s;}
.store-badge:hover{transform:translateY(-2px);border-color:var(--gold2);box-shadow:var(--glow);}
.store-badge svg{flex:none;}
.store-badge .sb-t{display:flex;flex-direction:column;line-height:1.1;text-align:left;}
.store-badge .sb-small{font-size:10.5px;color:#b9c4dc;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;}
.store-badge .sb-big{font-family:var(--display);font-weight:700;font-size:17px;}
html.light .store-badge{background:#0b1326;}

/* ============================================================
   v3 — static app screenshots (no live iframes) + mobile polish
   ============================================================ */

/* phone bezel now holds a static screenshot instead of an iframe */
.exp-clip img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block;}
/* desktop "browser window" now holds a static admin screenshot */
.exp-win2 img.shot{width:100%;height:auto;display:block;}

/* prevent any accidental horizontal scroll on phones */
html,body{overflow-x:hidden;}
img{max-width:100%;}

@media(max-width:780px){
  /* injected EN/ES pill drops into the mobile dropdown — give it room */
  .nav-links.open{padding:14px;gap:4px;}
  .nav-links.open .lang-toggle{align-self:flex-start;margin:6px 0 2px;}
}

@media(max-width:680px){
  section{padding:48px 0;}
  .wrap{padding:0 17px;}
  h1{font-size:clamp(30px,9vw,40px);}
  .imgband{min-height:290px;border-radius:var(--r-lg);}
  .imgband .imgband-in{padding:22px 18px;}
  .band{padding:26px 20px;border-radius:var(--r-lg);}
  .cta-band{padding:38px 20px;}
  .panel{padding:22px;}
  .ps .col{padding:22px;}
  /* full-width, easy-to-tap CTAs on phones */
  .hero-ctas{width:100%;}
  .hero-ctas .btn,.hero-cta .btn{flex:1 1 100%;justify-content:center;}
  .btn{padding:13px 20px;}
  /* media photo blocks shouldn't dwarf the screen */
  .media{min-height:200px;}
}

@media(max-width:680px){
  /* the OURA hero: tighten so the logo + slogan fit above the fold */
  .hero-x{min-height:calc(100svh - 56px);}
  .hero-logo{width:clamp(200px,60vw,300px);}
  .hero-subline{font-size:14px;}
}
