:root{
  --ink:#2d3f5d;
  --ink-soft:#6c7f9d;
  --dock-h:112px;
}
*{box-sizing:border-box}
html{
  scroll-behavior:smooth;
  scroll-snap-type:y proximity;
  overscroll-behavior-y:contain;
}
@view-transition{navigation:auto}
::view-transition-group(root){animation-duration:.18s;animation-timing-function:cubic-bezier(.2,.7,.2,1)}
::view-transition-new(root){animation-name:vtFromBottom}
::view-transition-old(root){animation-name:vtToTop}
@keyframes vtFromBottom{from{transform:translateY(28px);opacity:0}to{transform:translateY(0);opacity:1}}
@keyframes vtToTop{from{transform:translateY(0);opacity:1}to{transform:translateY(-28px);opacity:0}}
body{
  margin:0;
  min-height:100svh;
  font-family:Inter,system-ui,sans-serif;
  color:var(--ink);
  background:linear-gradient(180deg,#f4f9ff 0%,#e2edff 30%,#d2e2ff 60%,#c4d6ff 100%);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:geometricPrecision;
}
body::after{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:4;
  background:
    radial-gradient(circle at 20% 12%, rgba(255,255,255,.28) 0%, transparent 22%),
    radial-gradient(circle at 80% 22%, rgba(160,200,255,.15) 0%, transparent 28%),
    radial-gradient(circle at 50% 60%, rgba(200,225,255,.12) 0%, transparent 40%);
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:4;
  background:
    radial-gradient(circle at 16% 8%, rgba(255,255,255,.86), transparent 18%),
    radial-gradient(circle at 82% 18%, rgba(189,218,255,.72), transparent 24%),
    radial-gradient(circle at 50% 58%, rgba(255,255,255,.38), transparent 35%);
}
#particleCanvas{
  position:fixed;
  inset:0;
  z-index:1;
  pointer-events:none;
  opacity:.58;
  transition:opacity .25s ease;
}
@media(prefers-reduced-motion:reduce){
  #particleCanvas{opacity:0}
}
.vignette{
  position:fixed;
  inset:0;
  z-index:2;
  pointer-events:none;
  background:radial-gradient(ellipse at center, transparent 40%, rgba(10,20,44,.18) 100%);
}
.ambient{position:fixed;border-radius:50%;filter:blur(12px);pointer-events:none;opacity:.72;z-index:3}
.ambient-a{width:34vw;height:34vw;left:-8vw;top:20vh;background:radial-gradient(circle,rgba(255,255,255,.9),rgba(255,255,255,0))}
.ambient-b{width:44vw;height:44vw;right:-12vw;top:12vh;background:radial-gradient(circle,rgba(180,213,255,.72),rgba(180,213,255,0))}
.ambient-c{width:58vw;height:58vw;left:22vw;bottom:-26vw;background:radial-gradient(circle,rgba(206,227,255,.8),rgba(206,227,255,0))}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
button{font:inherit}
.logo-float{
  position:fixed;
  top:calc(14px + env(safe-area-inset-top));
  left:calc(14px + env(safe-area-inset-left));
  z-index:70;
  display:flex;
  align-items:center;
  justify-content:center;
  width:80px;
  height:80px;
  border-radius:50%;
  background:linear-gradient(180deg,rgba(255,255,255,.3),rgba(255,255,255,.16));
  backdrop-filter:blur(14px) saturate(145%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.72),0 18px 40px rgba(72,110,178,.12);
  transition:transform .24s ease, box-shadow .24s ease, filter .24s ease;
}
.logo-float:hover,.logo-float:active{transform:translateY(-2px) scale(1.04);box-shadow:inset 0 1px 0 rgba(255,255,255,.8),0 22px 44px rgba(72,110,178,.16)}
.logo-float img{width:62px;height:62px;filter:drop-shadow(0 12px 20px rgba(65,105,172,.18));animation:logoFloat 3s ease-in-out infinite}
.logo-float::after{
  content:"";
  position:absolute;
  inset:-6px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.18),transparent 70%);
  filter:blur(8px);
  z-index:-1;
  animation:logoGlow 2.4s ease-in-out infinite;
}
@keyframes logoGlow{0%,100%{opacity:.5}50%{opacity:.9}}
@keyframes logoFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
.top-cta{
  position:fixed;
  top:calc(18px + env(safe-area-inset-top));
  right:calc(16px + env(safe-area-inset-right));
  z-index:72;
  width:min(340px,50vw);
  min-width:190px;
  opacity:0;
  transform:translateY(-16px) scale(.98);
  pointer-events:none;
  transition:opacity .18s ease, transform .18s ease, filter .24s ease;
}
.top-cta.show{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.top-cta:hover,.top-cta:active{filter:saturate(1.06)}
.top-cta-bg{width:100%;height:auto;filter:drop-shadow(0 18px 30px rgba(70,110,178,.16))}
.tagline-badge{
  position:fixed;
  top:calc(90px + env(safe-area-inset-top));
  left:50%;
  transform:translateX(-50%);
  z-index:71;
  margin:0;
  padding:9px 26px;
  border-radius:999px;
  background:linear-gradient(180deg,rgba(255,255,255,.28),rgba(255,255,255,.08));
  backdrop-filter:blur(14px) saturate(170%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.72),0 12px 32px rgba(72,110,178,.1),0 0 0 1px rgba(255,255,255,.12);
  color:#3d5f8a;
  font-family:Inter,system-ui,sans-serif;
  font-size:clamp(12px,1.4vw,15px);
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  white-space:nowrap;
  pointer-events:none;
  animation:taglineFadeIn .16s ease .4s both;
}
.tagline-badge::after{
  content:"";
  position:absolute;
  inset:-4px;
  border-radius:999px;
  background:radial-gradient(circle at 50% 50%, rgba(100,160,255,.12), transparent 70%);
  filter:blur(6px);
  z-index:-1;
}
@keyframes taglineFadeIn{
  from{opacity:0;transform:translateX(-50%) translateY(-10px) scale(.94)}
  to{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}
}
@media(max-width:900px){
  .tagline-badge{
    top:calc(80px + env(safe-area-inset-top));
    padding:6px 16px;
    font-size:10px;
    letter-spacing:.08em;
  }
}
.scene-counter{
  position:fixed;
  right:calc(24px + env(safe-area-inset-right));
  top:50%;
  transform:translateY(-50%);
  z-index:65;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:2px;
  pointer-events:none;
  opacity:.22;
  font-family:Inter,system-ui,sans-serif;
  font-size:13px;
  font-weight:900;
  letter-spacing:.06em;
  color:#2e405f;
  line-height:1;
}
.sc-sep{
  font-size:9px;
  opacity:.5;
}
@media(max-width:900px){
  .scene-counter{display:none}
}
.paw-pulse{
  position:fixed;
  bottom:calc(160px + env(safe-area-inset-bottom));
  right:calc(20px + env(safe-area-inset-right));
  z-index:50;
  pointer-events:none;
  width:48px;
  height:48px;
  opacity:.32;
}
.paw-pulse::before,
.paw-pulse::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:50%;
  border:2px solid rgba(100,155,255,.4);
  animation:pawPulse 2s ease-out infinite;
}
.paw-pulse::after{
  animation-delay:1.25s;
}
@keyframes pawPulse{
  0%{transform:scale(.6);opacity:.6}
  100%{transform:scale(2.8);opacity:0}
}
.top-cta span{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  font-weight:900;
  font-size:clamp(12px,1.2vw,16px);
  letter-spacing:-.03em;
}
.experience{position:relative;z-index:5}
.scene{
  position:relative;
  min-height:100svh;
  scroll-snap-align:start;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:86px 20px calc(var(--dock-h) + 28px);
  overflow:hidden;
}
.scene::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:0;
  background:
    radial-gradient(circle at 50% 48%, rgba(255,255,255,.2), transparent 36%),
    radial-gradient(circle at 20% 70%, rgba(160,200,255,.08), transparent 30%);
}
.character-wrap{
  border:0;
  background:transparent;
  padding:0;
  position:relative;
  z-index:6;
  width:min(88vw,480px,48svh);
  aspect-ratio:1/1.28;
  margin:0 auto 16px;
  filter:drop-shadow(0 26px 40px rgba(43,70,116,.16));
  cursor:pointer;
  -webkit-tap-highlight-color:transparent;
  perspective:1200px;
  opacity:0;
  transition:opacity .01s;
}
.scene.active .character-wrap{
  animation:koraEnter .55s cubic-bezier(.34,1.56,.64,1) forwards;
  animation-delay:.05s;
}
.kora-tilt{
  position:absolute;
  inset:0;
  transform-style:preserve-3d;
  will-change:transform;
  transition:transform .08s ease-out;
}
.kora-shadow{
  position:absolute;
  bottom:-8%;
  left:12%;
  width:76%;
  height:10%;
  border-radius:50%;
  background:rgba(43,70,116,.18);
  filter:blur(8px);
  pointer-events:none;
  z-index:-1;
  transform-origin:center;
}
.paw-ring{
  position:absolute;
  bottom:8%;
  right:6%;
  width:18%;
  aspect-ratio:1;
  pointer-events:none;
  z-index:2;
}
.paw-ring::before,
.paw-ring::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:50%;
  border:1.5px solid rgba(140,195,255,.5);
  animation:pawRingPulse 1.8s ease-out infinite;
}
.paw-ring::after{animation-delay:.9s}
@keyframes pawRingPulse{
  0%{transform:scale(.5);opacity:.6}
  100%{transform:scale(2.8);opacity:0}
}
/* V3100 ultra polish: alignment, smooth scroll safety, CTA timing, mascot pose consistency */
html{
  scroll-snap-type:y proximity;
  scroll-padding-top:0;
}
.logo-float{
  background:transparent !important;
  box-shadow:none !important;
  backdrop-filter:none !important;
  width:82px;
  height:82px;
}
.logo-float img{
  width:74px;
  height:74px;
  filter:drop-shadow(0 16px 26px rgba(64,103,172,.22));
}
.top-cta{
  top:calc(24px + env(safe-area-inset-top));
  right:calc(18px + env(safe-area-inset-right));
  width:min(318px,46vw);
}
.top-cta span{
  padding:0 24px;
}
.scene{
  padding-bottom:calc(var(--dock-h) + 88px);
}
.character-wrap{
  width:min(88vw,480px,44svh);
}
.kora{
  object-fit:contain;
}
.arrow-cta{
  z-index:95;
  margin-top:10px;
}
.arrow-cta img{
  width:108px;
  height:108px;
}
.dock{
  z-index:76;
}
.float-icon{
  z-index:1;
}
.character-wrap{
  z-index:8;
}
.copy-wrap{
  z-index:20;
}
.router{
  z-index:96;
}
.scene-line{
  text-shadow:0 2px 18px rgba(255,255,255,.72), 0 0 1px rgba(255,255,255,.8);
}
@media(max-width:900px){
  .logo-float{
    width:74px;
    height:74px;
  }
  .logo-float img{
    width:64px;
    height:64px;
  }
  .top-cta{
    top:calc(27px + env(safe-area-inset-top));
    right:calc(14px + env(safe-area-inset-right));
    width:188px;
    min-width:188px;
  }
  .top-cta span{
    font-size:11.5px;
    padding:0 18px;
  }
  .scene{
    padding-top:78px;
    padding-bottom:calc(var(--dock-h) + 82px);
  }
  .character-wrap{
    width:min(90vw,430px,43svh);
  }
  .arrow-cta{
    margin-top:18px;
    width:104px;
    height:104px;
  }
  .arrow-cta img{
    width:96px;
    height:96px;
  }
}
@media(max-height:760px) and (max-width:900px){
  .scene{
    padding-top:72px;
    padding-bottom:132px;
    justify-content:center;
  }
  .character-wrap{
    width:min(84vw,370px,38svh);
    margin-bottom:8px;
  }
  .scene-line{
    font-size:clamp(1.28rem,5.6vw,1.78rem);
    max-width:300px;
  }
  .scene-kicker{
    font-size:clamp(11px,2.2vw,13px);
    max-width:80%;
  }
  .arrow-cta{
    width:86px;
    height:86px;
    margin-top:10px;
  }
  .arrow-cta img{
    width:78px;
    height:78px;
  }
  .float-icon{
    width:78px;
    opacity:.62;
  }
  .dock{
    padding:8px 10px;
  }
  .dock-item{
    width:60px;
    height:60px;
  }
  .dock-item img{
    width:56px;
    height:56px;
  }
}
@media(max-height:670px) and (max-width:900px){
  html{
    scroll-snap-type:none;
  }
  .scene{
    min-height:100svh;
    padding-top:68px;
    padding-bottom:118px;
  }
  .character-wrap{
    width:min(78vw,330px,34svh);
  }
  .copy-wrap{
    gap:5px;
  }
  .scene-line{
    font-size:clamp(1.08rem,4.6vw,1.38rem);
    max-width:320px;
  }
  .arrow-cta{
    width:76px;
    height:76px;
    margin-top:8px;
  }
  .arrow-cta img{
    width:70px;
    height:70px;
  }
}
/* V3200 final home polish: wetter iPhone glass + smoother snap */
html{
  scroll-snap-type:y proximity;
  overscroll-behavior-y:none;
}
body{
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
.dock{
  background:
    linear-gradient(180deg, rgba(255,255,255,.34), rgba(255,255,255,.08)) !important;
  backdrop-filter: blur(16px) saturate(185%) brightness(1.08) !important;
  -webkit-backdrop-filter: blur(16px) saturate(185%) brightness(1.08) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.82),
    inset 0 -1px 0 rgba(255,255,255,.18),
    0 26px 54px rgba(72,110,178,.13) !important;
}
.dock::before{
  content:"";
  position:absolute;
  inset:1px 1px auto 1px;
  height:46%;
  border-radius:999px;
  background:linear-gradient(180deg,rgba(255,255,255,.42),rgba(255,255,255,0));
  pointer-events:none;
}
.dock::after{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:999px;
  background:radial-gradient(circle at 50% 0%, rgba(160,200,255,.08), transparent 70%);
  filter:blur(4px);
  z-index:-1;
  pointer-events:none;
}
.router{
  background:
    linear-gradient(180deg, rgba(255,255,255,.38), rgba(255,255,255,.10)) !important;
  backdrop-filter: blur(12px) saturate(185%) brightness(1.06) !important;
  -webkit-backdrop-filter: blur(12px) saturate(185%) brightness(1.06) !important;
}
.scene-line{
  letter-spacing:-.07em;
}
.top-cta{
  will-change:opacity, transform;
}
@media(max-width:900px){
  .dock{
    width:calc(100% - 26px);
  }
}
/* V3300 final wet-glass dock polish */
.dock{
  background:
    linear-gradient(180deg, rgba(255,255,255,.26), rgba(255,255,255,.055)) !important;
  backdrop-filter: blur(12px) saturate(205%) brightness(1.08) !important;
  -webkit-backdrop-filter: blur(12px) saturate(205%) brightness(1.08) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.86),
    inset 0 -1px 0 rgba(255,255,255,.12),
    0 28px 58px rgba(72,110,178,.12) !important;
}
.dock::before{
  opacity:.78;
}
@media(max-width:900px){
  html{scroll-snap-type:y proximity}
}
@media(max-height:690px) and (max-width:900px){
  html{scroll-snap-type:none}
}
/* V3400: ultra-transparent wet iPhone glass dock */
.dock{
  background:
    linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,.018)) !important;
  backdrop-filter: blur(22px) saturate(235%) brightness(1.14) !important;
  -webkit-backdrop-filter: blur(22px) saturate(235%) brightness(1.14) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.74),
    inset 0 -1px 0 rgba(255,255,255,.07),
    0 30px 62px rgba(72,110,178,.095) !important;
}
.dock::before{
  opacity:.54 !important;
  background:linear-gradient(180deg, rgba(255,255,255,.30), rgba(255,255,255,0)) !important;
}
@media(max-width:900px){
  html{scroll-snap-type:y proximity}
}
@media(max-height:690px) and (max-width:900px){
  html{scroll-snap-type:none}
}
/* V5100 secret Kora navigation, opened by the phone dock icon */
.secret-nav{
  position:fixed;
  inset:0;
  z-index:180;
  display:grid;
  place-items:end center;
  padding:18px 14px calc(18px + env(safe-area-inset-bottom));
  pointer-events:none;
  opacity:0;
  transition:opacity .28s ease;
}
.secret-nav.open{
  pointer-events:auto;
  opacity:1;
}
.secret-backdrop{
  position:absolute;
  inset:0;
  background:rgba(214,229,255,.26);
  backdrop-filter:blur(12px) saturate(150%);
  -webkit-backdrop-filter:blur(12px) saturate(150%);
}
.secret-panel{
  position:relative;
  width:min(560px,100%);
  border-radius:36px;
  padding:18px;
  background:linear-gradient(180deg,rgba(255,255,255,.18),rgba(255,255,255,.04));
  backdrop-filter:blur(14px) saturate(245%) brightness(1.16);
  -webkit-backdrop-filter:blur(14px) saturate(245%) brightness(1.16);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.78), inset 0 -1px 0 rgba(255,255,255,.05), 0 34px 82px rgba(72,110,178,.18);
  transform:translateY(20px) scale(.98);
  transition:transform .32s cubic-bezier(.2,.7,.2,1);
}
.secret-nav.open .secret-panel{
  transform:translateY(0) scale(1);
}
.secret-head{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:14px;
}
.secret-head img{
  width:64px;
  height:64px;
}
.secret-head p{
  margin:0 0 2px;
  color:#7086a6;
  font-size:11px;
  font-weight:900;
  letter-spacing:.24em;
  text-transform:uppercase;
}
.secret-head h2{
  margin:0;
  color:#2e405f;
  font-size:2rem;
  line-height:.9;
  font-weight:900;
  letter-spacing:-.07em;
}
.secret-close{
  margin-left:auto;
  width:42px;
  height:42px;
  border:0;
  border-radius:50%;
  background:rgba(255,255,255,.34);
  color:#2e405f;
  font-size:28px;
  line-height:1;
  font-weight:800;
  cursor:pointer;
}
.secret-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
.secret-grid a{
  display:flex;
  align-items:center;
  gap:10px;
  min-height:82px;
  padding:10px 12px;
  border-radius:28px;
  background:rgba(255,255,255,.22);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.66);
  color:#2e405f;
  font-size:15px;
  font-weight:900;
  letter-spacing:-.04em;
  transition:transform .22s ease, filter .22s ease;
}
.secret-grid a:hover,
.secret-grid a:active{
  transform:translateY(-3px);
  filter:saturate(1.06);
}
.secret-grid img{
  width:58px;
  height:58px;
  object-fit:contain;
}
.secret-whatsapp{
  position:relative;
  display:block;
  width:min(340px,100%);
  margin:14px auto 0;
}
.secret-whatsapp img{
  width:100%;
}
.secret-whatsapp span{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  color:white;
  font-size:15px;
  font-weight:900;
  letter-spacing:-.04em;
}
.secret-nav-trigger{
  border:0;
  background:transparent;
  padding:0;
}
@media(max-width:420px){
  .secret-grid{grid-template-columns:1fr}
  .secret-panel{border-radius:30px}
}
/* =============================================================
   V6000 � STEVE-JOBS-GRADE FINAL POLISH (home)
   Brutal mobile-first refinement. Holographic monumental hero,
   premium glass dock, kinetic micro-details, surgical spacing,
   pixel-perfect down to iPhone SE. Layered AFTER all V3000-V5200
   so every override here is final.
   ============================================================= */
/* SR-only utility for accessible labels we add via JS */
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
/* Body gradient: richer floor ? ceiling, sits cleanly under aurora */
body{
  background:
    radial-gradient(120% 80% at 50% -10%, #f7fbff 0%, #e9f2ff 32%, #d6e3ff 62%, #c1d3ff 100%) !important;
}
/* Logo: glassless and crisp, tighter shadow on mobile */
.logo-float{
  background:transparent !important;
  box-shadow:none !important;
  backdrop-filter:none !important;
}
.logo-float::after{ display:none; }
.logo-float img{
  filter:drop-shadow(0 14px 22px rgba(60,100,170,.22)) drop-shadow(0 2px 4px rgba(60,100,170,.12));
}
/* Tagline pill: feels like a halo, never blocks the logo */
.tagline-badge{
  pointer-events:none;
  background:linear-gradient(180deg,rgba(255,255,255,.42),rgba(255,255,255,.16)) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.85), 0 12px 30px rgba(72,110,178,.12) !important;
}
/* Top CTA: solid premium drop shadow, NEVER touches the logo on mobile */
.top-cta{
  filter:drop-shadow(0 12px 24px rgba(70,110,178,.22));
}
.top-cta:hover{ filter:drop-shadow(0 16px 30px rgba(127,209,255,.35)) drop-shadow(0 4px 10px rgba(184,156,255,.30)) saturate(1.12); }
/* Scene line: monumental + chromatic � already overridden in holo.css */
.scene-line{
  letter-spacing:-.075em !important;
  font-size:clamp(1.65rem,3.2vw,2.5rem);
}
.scene-kicker{
  font-size:clamp(11.5px,1.5vw,14px) !important;
  letter-spacing:.12em !important;
  text-transform:uppercase;
  color:#5a76a0 !important;
  font-weight:900;
}
/* Mascot float-icons polish */
.float-icon{
  filter:drop-shadow(0 18px 28px rgba(70,108,172,.10)) drop-shadow(0 0 14px rgba(160,210,255,.14));
}
/* Arrow CTA � gentler bounce, more click-worthy on mobile */
.arrow-cta img{
  filter:drop-shadow(0 14px 26px rgba(72,110,178,.20)) drop-shadow(0 0 18px rgba(127,209,255,.24));
}
/* Dock: feels like real glass, with chromatic conic rim from holo.css */
.dock{
  isolation:isolate;
  border-radius:999px;
}
.dock-item img{
  filter:drop-shadow(0 14px 18px rgba(72,110,178,.14)) drop-shadow(0 0 10px rgba(160,210,255,.20));
}
/* Scene counter: less obtrusive, more 'mission control' */
.scene-counter{
  opacity:.34;
  font-feature-settings:"tnum" 1, "ss01" 1;
}
/* MOBILE-FIRST FINAL TUNE � every viewport from iPhone SE upward */
@media(max-width:900px){
  .logo-float{ width:64px; height:64px; }
  .logo-float img{ width:54px; height:54px; }
  .top-cta{ width:170px; min-width:170px; top:calc(20px + env(safe-area-inset-top)); }
  .top-cta span{ font-size:11px; padding:0 14px; }
  .tagline-badge{
    top:calc(74px + env(safe-area-inset-top));
    padding:5px 14px;
    font-size:9.5px;
  }
  .scene-line{ font-size:clamp(1.32rem,5.4vw,1.95rem); max-width:88vw; }
  .scene-kicker{ max-width:84%; }
}
@media(max-width:430px){
  .logo-float{ width:58px; height:58px; }
  .logo-float img{ width:50px; height:50px; }
  .top-cta{ width:152px; min-width:152px; }
  .top-cta span{ font-size:10.5px; padding:0 12px; }
  .tagline-badge{ font-size:9px; padding:4px 12px; }
  .dock-item{ width:58px; height:58px; }
  .dock-item img{ width:54px; height:54px; }
  .scene{ padding-bottom:calc(var(--dock-h) + 76px); }
}
/* Very short screens (landscape phones, small laptops) */
@media(max-height:640px){
  .tagline-badge{ display:none; }
  .scene{ padding-top:64px; padding-bottom:104px; }
  .character-wrap{ width:min(72vw,300px,32svh); margin-bottom:6px; }
  .scene-line{ font-size:clamp(1.05rem,4.4vw,1.34rem); }
  .arrow-cta{ width:72px; height:72px; }
  .arrow-cta img{ width:66px; height:66px; }
}
/* Touch-only: no hover transforms that linger */
@media(hover:none){
  .dock-item:hover,
  .dock-item:active{ transform:none; filter:none; }
  .top-cta:hover{ filter:drop-shadow(0 12px 24px rgba(70,110,178,.22)); }
}
/* Router (mobile-first) � feels like an Apple sheet */
.router{
  border-radius:38px;
  background:linear-gradient(180deg, rgba(255,255,255,.40), rgba(255,255,255,.10)) !important;
  backdrop-filter:blur(22px) saturate(220%) brightness(1.10) !important;
  -webkit-backdrop-filter:blur(22px) saturate(220%) brightness(1.10) !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.85), 0 40px 90px rgba(72,110,178,.22) !important;
}
.router-option{
  letter-spacing:-.045em;
  border:1px solid rgba(255,255,255,.55);
}
.router-option:hover, .router-option.active{
  box-shadow:0 14px 28px rgba(39,114,238,.28), inset 0 1px 0 rgba(255,255,255,.6);
}
/* Secret nav grid items: chromatic edge */
.secret-grid a{
  border:1px solid rgba(255,255,255,.42);
  transition:transform .14s ease, filter .14s ease, box-shadow .14s ease, border-color .22s ease;
}
.secret-grid a:hover{
  border-color:rgba(127,209,255,.6);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.8), 0 18px 38px rgba(127,209,255,.22);
}
/* =============================================================
   V6100 � Marquee positioning + final hero shine
   ============================================================= */
.holo-marquee{
  position:fixed;
  left:0; right:0;
  bottom:calc(var(--dock-h) + 12px + env(safe-area-inset-bottom));
  z-index:60;
  pointer-events:none;
  margin:0;
  padding:6px 0;
  opacity:0;
  animation:marqueeFadeIn .35s ease .6s forwards;
}
@keyframes marqueeFadeIn{ to{ opacity:.9; } }
.holo-marquee-track{ font-size:12px; }
@media(max-width:900px){
  .holo-marquee{ bottom:calc(var(--dock-h) + 4px + env(safe-area-inset-bottom)); }
  .holo-marquee-track{ font-size:10.5px; gap:22px; }
}
@media(max-height:690px){
  .holo-marquee{ display:none; }
}
/* =============================================================
   V7000 � HOME PRODUCTION POLISH
   Shimmer hologr??fico aplicado solo al scene-line (era en holo.css).
   ============================================================= */
.scene-line{
  background:linear-gradient(120deg,
    #243854 0%,
    #1f4f9a 30%,
    #344763 55%,
    #1f4f9a 80%,
    #243854 100%);
  background-size:220% 220%;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent !important;
  -webkit-text-fill-color:transparent;
  animation:sceneShimmer 6s ease-in-out infinite;
  text-shadow:0 2px 24px rgba(255,255,255,.55) !important;
  will-change:background-position;
}
@keyframes sceneShimmer{ 0%,100%{ background-position:0% 50%; } 50%{ background-position:100% 50%; } }
@media(max-width:430px){
  .scene-line{ animation:none; background-position:0% 50%; }
}
.paw-ring::after{animation-delay:.9s}
.character-wrap::after{
  content:"";
  position:absolute;
  inset:-16%;
  border-radius:50%;
  background:radial-gradient(circle,rgba(140,190,255,.2),rgba(140,190,255,0) 70%);
  pointer-events:none;
  animation:assistPulse 2.4s ease-in-out infinite;
  z-index:-1;
}
@keyframes assistPulse{
  0%,100%{opacity:.4;transform:scale(1)}
  50%{opacity:.7;transform:scale(1.1)}
}
@keyframes koraFloat{
  0%,100%{transform:translateY(0) rotate(0deg)}
  20%{transform:translateY(-4px) rotate(.4deg)}
  40%{transform:translateY(-10px) rotate(0deg)}
  60%{transform:translateY(-13px) rotate(-.3deg)}
  80%{transform:translateY(-6px) rotate(.2deg)}
}
@keyframes koraShadow{
  0%,100%{opacity:.5;transform:scale(1)}
  20%{opacity:.4;transform:scale(.94)}
  40%{opacity:.25;transform:scale(.84)}
  60%{opacity:.2;transform:scale(.78)}
  80%{opacity:.35;transform:scale(.9)}
}
@keyframes poseMorph{
  0%{filter:blur(0)}
  35%{filter:blur(6px)}
  50%{filter:blur(8px)}
  65%{filter:blur(6px)}
  100%{filter:blur(0)}
}
@keyframes koraEnter{
  0%{transform:translateY(70px) scale(.88);opacity:0}
  55%{transform:translateY(-10px) scale(1.03);opacity:1}
  75%{transform:translateY(5px) scale(.985)}
  88%{transform:translateY(-2px) scale(1.005)}
  100%{transform:translateY(0) scale(1);opacity:1}
}
.kora{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:contain;
  opacity:0;
  transform:translateY(12px) scale(.985);
  transition:opacity .22s cubic-bezier(.2,.7,.2,1), transform .22s cubic-bezier(.2,.7,.2,1);
  will-change:opacity,transform;
}
.kora.visible{opacity:1;transform:translateY(0) scale(1)}
.scene.active .kora.visible{animation:koraFloat 3.2s ease-in-out infinite}
.kora.morph{animation:poseMorph .22s ease .05s 1!important;z-index:5}
.scene.active .character-wrap .kora-shadow{animation:koraShadow 3.2s ease-in-out infinite}
.copy-wrap{
  position:relative;
  z-index:13;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
  padding:0 12px;
  opacity:0;
  transform:translateY(28px);
  transition:opacity .22s cubic-bezier(.15,.7,.2,1), transform .22s cubic-bezier(.15,.7,.2,1);
}
.scene.active .copy-wrap{opacity:1;transform:translateY(0);transition-delay:.22s}
.scene.active .scene-kicker{opacity:1;transform:translateY(0);transition:opacity .22s ease,transform .22s ease;transition-delay:.12s}
.scene.active .scene-line{opacity:1;transform:translateY(0);transition:opacity .22s ease,transform .22s ease;transition-delay:.28s}
.scene-kicker{
  opacity:0;
  transform:translateY(16px);
  margin:0 0 6px;
  color:#5b779b;
  font-size:clamp(13px,1.4vw,16px);
  font-weight:900;
  letter-spacing:-.03em;
  text-wrap:balance;
  max-width:min(86vw,540px);
  line-height:1.2;
}
.scene-line{
  opacity:0;
  transform:translateY(16px);
  margin:0;
  text-align:center;
  text-wrap:balance;
  max-width:min(86vw,640px);
  font-size:clamp(1.52rem,3vw,2.35rem);
  line-height:1.06;
  font-weight:900;
  letter-spacing:-.065em;
  color:#344763;
  text-shadow:0 2px 18px rgba(255,255,255,.66);
}
.arrow-cta{
  position:relative;
  z-index:14;
  margin-top:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  width:120px;
  height:120px;
  border:0;
  background:transparent;
  padding:0;
  cursor:pointer;
  opacity:0;
  transform:translateY(18px) scale(.92);
  transition:opacity .22s cubic-bezier(.15,.7,.2,1), transform .22s cubic-bezier(.15,.7,.2,1), filter .25s ease;
  -webkit-tap-highlight-color:transparent;
}
.scene.active .arrow-cta{opacity:1;transform:translateY(0) scale(1);transition-delay:.18s}
.arrow-cta:hover,.arrow-cta:active{filter:saturate(1.08)}
.arrow-cta img{width:112px;height:112px;filter:drop-shadow(0 18px 30px rgba(72,110,178,.18));animation:arrowPulse 1.22s ease-in-out infinite}
@keyframes arrowPulse{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.float-icon{
  position:absolute;
  z-index:2;
  pointer-events:none;
  opacity:.74;
  width:clamp(92px,10vw,138px);
  filter:drop-shadow(0 18px 28px rgba(70,108,172,.1));
  animation:floaty 5.2s ease-in-out infinite;
  transform:scale(.7) rotate(var(--r,0deg));
  opacity:0;
  transition:opacity .22s ease, transform .22s cubic-bezier(.15,.7,.2,1);
}
.scene.active .float-icon{
  opacity:.74;
  transform:scale(1) rotate(var(--r,0deg));
}
.scene.active .fi-left{transition-delay:.08s}
.scene.active .fi-right{transition-delay:.14s}
.scene.active .fi-bottom{transition-delay:.2s}
@keyframes floaty{0%,100%{transform:translateY(0) rotate(var(--r,0deg))}50%{transform:translateY(-12px) rotate(calc(var(--r,0deg) + 2deg))}}
.fi-left{left:7%;top:28%;--r:-5deg}
.fi-right{right:7%;top:42%;--r:7deg;animation-duration:5s}
.fi-bottom{right:22%;bottom:20%;--r:-4deg;animation-duration:5.5s}
.dock{
  position:fixed;
  left:50%;
  bottom:calc(16px + env(safe-area-inset-bottom));
  transform:translateX(-50%) translateY(20px);
  z-index:80;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  width:min(640px,calc(100% - 28px));
  padding:14px 18px;
  border-radius:999px;
  background:linear-gradient(180deg,rgba(255,255,255,.24),rgba(255,255,255,.14));
  backdrop-filter:blur(14px) saturate(140%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.68),0 22px 46px rgba(72,110,178,.11);
  opacity:0;
  animation:dockEnter .22s cubic-bezier(.15,.7,.2,1) .6s both;
}
@keyframes dockEnter{
  to{opacity:1;transform:translateX(-50%) translateY(0)}
}
.dock.hidden{transform:translateX(-50%) translateY(120%);opacity:0;animation:none}
.dock-item{
  display:flex;
  align-items:center;
  justify-content:center;
  width:82px;
  height:82px;
  border:0;
  background:transparent;
  padding:0;
  border-radius:50%;
  cursor:pointer;
  font:inherit;
  color:inherit;
  transition:transform .22s ease, filter .22s ease;
  -webkit-tap-highlight-color:transparent;
}
.dock-item img{width:78px;height:78px;filter:drop-shadow(0 16px 22px rgba(72,110,178,.12))}
.dock-item:hover,.dock-item:active{transform:translateY(-4px) scale(1.04);filter:saturate(1.08)}
.dock-wa{transform:translateY(-1px) scale(1.03)}
.router{
  position:fixed;
  left:50%;
  bottom:calc(124px + env(safe-area-inset-bottom));
  transform:translateX(-50%) translateY(24px) scale(.985);
  z-index:90;
  width:min(560px,calc(100% - 28px));
  padding:18px;
  border-radius:38px;
  background:linear-gradient(180deg,rgba(255,255,255,.36),rgba(255,255,255,.18));
  backdrop-filter:blur(16px) saturate(150%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.74),0 34px 70px rgba(72,110,178,.18);
  opacity:0;
  pointer-events:none;
  transition:opacity .14s ease, transform .14s ease;
}
.router.open{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0) scale(1)}
.router-close{
  position:absolute;
  top:14px;
  right:14px;
  z-index:3;
  width:42px;
  height:42px;
  border-radius:999px;
  border:0;
  background:rgba(255,255,255,.34);
  color:#243854;
  font-size:28px;
  line-height:1;
  font-weight:700;
  cursor:pointer;
}
.router-card{position:relative;width:100%;margin:8px 0 18px}
.router-card img{width:100%;height:auto;filter:drop-shadow(0 18px 24px rgba(30,44,82,.22))}
.router-copy{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:clamp(22px,5vw,46px);
}
.router-copy span{
  color:#9fbaff;
  font-size:clamp(12px,2vw,18px);
  font-weight:900;
  letter-spacing:.22em;
}
.router-copy strong{
  margin-top:10px;
  max-width:360px;
  color:white;
  font-size:clamp(1.45rem,5.4vw,2.4rem);
  line-height:1.02;
  font-weight:900;
  letter-spacing:-.06em;
}
.router-options{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  margin:0 6px 18px;
}
.router-option{
  min-height:62px;
  border:0;
  border-radius:999px;
  cursor:pointer;
  color:#273a58;
  background:linear-gradient(180deg,rgba(255,255,255,.48),rgba(255,255,255,.25));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.72),0 16px 28px rgba(72,110,178,.08);
  font-size:clamp(15px,3.4vw,20px);
  font-weight:900;
  letter-spacing:-.04em;
  transition:transform .2s ease, background .2s ease, color .2s ease;
}
.router-option:hover,.router-option:active,.router-option.active{
  transform:translateY(-2px);
  color:#fff;
  background:linear-gradient(180deg,#4f94ff,#2772ee);
}
.router-primary{
  position:relative;
  display:block;
  width:min(360px,82%);
  margin:0 auto 4px;
  transition:transform .24s ease, filter .24s ease;
}
.router-primary:hover,.router-primary:active{transform:translateY(-2px) scale(1.01);filter:saturate(1.05)}
.router-primary img{width:100%;height:auto;filter:drop-shadow(0 18px 30px rgba(70,110,178,.16))}
.router-primary span{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  color:white;
  font-size:clamp(14px,3.4vw,19px);
  font-weight:900;
  letter-spacing:-.04em;
}
@media (max-width:900px){
  .logo-float{width:72px;height:72px;top:calc(14px + env(safe-area-inset-top));left:calc(14px + env(safe-area-inset-left))}
  .logo-float img{width:56px;height:56px}
  .top-cta{top:calc(14px + env(safe-area-inset-top));right:calc(14px + env(safe-area-inset-right));width:190px;min-width:190px}
  .top-cta span{font-size:12px}
  .scene{padding:82px 16px calc(var(--dock-h) + 26px)}
  .character-wrap{width:min(90vw,430px,45svh);margin-bottom:10px}
  .scene-kicker{font-size:clamp(11px,2.2vw,13px);max-width:80%}
  .scene-line{font-size:clamp(1.28rem,5.4vw,1.95rem);max-width:380px}
  .float-icon{width:96px;opacity:.72}
  .fi-left{left:6%;top:23%}
  .fi-right{right:6%;top:42%}
  .fi-bottom{right:18%;bottom:18%}
  .arrow-cta{width:108px;height:108px;margin-top:12px}
  .arrow-cta img{width:98px;height:98px}
  .dock{gap:12px;padding:10px 12px;bottom:calc(14px + env(safe-area-inset-bottom));justify-content:space-between}
  .dock-item{width:72px;height:72px}
  .dock-item img{width:68px;height:68px}
  .router{bottom:calc(108px + env(safe-area-inset-bottom));padding:14px;border-radius:34px}
  .router-card{margin-top:8px}
  .router-options{gap:10px;margin:0 4px 14px}
  .router-option{min-height:58px}
}
@media (max-width:430px){
  .dock-item{width:68px;height:68px}
  .dock-item img{width:64px;height:64px}
  .scene-kicker{max-width:90%;font-size:clamp(10px,2.6vw,12px)}
  .scene-line{max-width:300px}
  .router-copy{padding:26px 28px}
}
@media (max-height:760px) and (max-width:900px){
  .scene{padding-top:74px;padding-bottom:118px}
  .character-wrap{width:min(84vw,380px,39svh)}
  .scene-line{font-size:clamp(1.32rem,5.8vw,1.82rem)}
  .arrow-cta{width:92px;height:92px}
  .arrow-cta img{width:84px;height:84px}
  .dock-item{width:62px;height:62px}
  .dock-item img{width:58px;height:58px}
  .router{bottom:94px}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
  ::view-transition-group(root),
  ::view-transition-new(root),
  ::view-transition-old(root){animation:none!important}
}
