/* =============================================================
   XOX Studio · Graphic Design Microsite
   Shared tokens + patterns from xox-main-v7
   ============================================================= */

:root{
  --black:#080808;--bg:#030303;--dark:#0f0f0f;--surface:#141414;--surface-2:#1b1b1b;
  --line:rgba(244,239,231,.075);--line-2:rgba(244,239,231,.13);
  --white:#F4EFE7;--off:#FAF7F0;--muted:#A6A19A;--muted-2:#C7C2BA;
  --red:#C1121F;--red-2:#FF1024;--red-deep:#8A0D16;--glow:rgba(193,18,31,.28);
  --col:430px;--float:74px;--nav-h:60px;
  --ease:cubic-bezier(.16,1,.3,1);
  --font-body:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  --font-display:'Inter Tight','Inter',-apple-system,BlinkMacSystemFont,sans-serif;
}

/* Reset */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
*:focus-visible{outline:2px solid var(--red-2);outline-offset:3px}
html{scroll-behavior:smooth;scroll-padding-top:calc(var(--nav-h)+12px);-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--white);font-family:var(--font-body);font-size:15px;font-weight:400;line-height:1.65;letter-spacing:-.003em;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;padding-bottom:calc(var(--float)+18px+env(safe-area-inset-bottom));text-rendering:optimizeLegibility}
body.scroll-lock{overflow:hidden;position:fixed;width:100%;left:0;right:0}
a{color:inherit;text-decoration:none;-webkit-tap-highlight-color:rgba(193,18,31,.18)}
button,input,textarea{font:inherit}
img{max-width:100%;display:block}
::selection{background:var(--red);color:var(--white)}

/* Layout */
.site{max-width:var(--col);margin:0 auto;background:var(--black);min-height:100vh;position:relative;overflow:hidden;box-shadow:0 0 80px rgba(0,0,0,.6)}

/* Nav */
.site-nav{position:fixed;top:0;left:50%;transform:translateX(-50%);width:100%;max-width:var(--col);height:var(--nav-h);z-index:70;display:flex;align-items:center;justify-content:space-between;padding:0 18px;background:rgba(8,8,8,.94);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--line)}
.logo{display:flex;align-items:center;gap:10px;line-height:1}
.logo-mark{width:28px;height:28px;flex-shrink:0}
.logo-mark circle:nth-child(2){transform-origin:16px 16px;animation:logoDotOrbit 4.5s linear infinite}
@keyframes logoDotOrbit{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.logo-text{font-family:var(--font-display);font-size:13px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--white)}
.nav-right{display:flex;align-items:center;gap:8px}
.lang-toggle{display:flex;border:1px solid var(--line);overflow:hidden}
.lang-btn{background:transparent;border:0;color:var(--muted);padding:8px 10px;font-size:10px;font-weight:600;letter-spacing:.1em;cursor:pointer;min-height:34px;min-width:34px}
.lang-btn.active{background:rgba(244,239,231,.06);color:var(--white)}
.lang-divider{width:1px;background:var(--line);height:13px;align-self:center}
.menu-btn{width:34px;height:29px;border:1px solid var(--line);background:transparent;display:flex;flex-direction:column;gap:4px;align-items:center;justify-content:center;cursor:pointer}
.menu-btn span{width:14px;height:1.5px;background:var(--white);display:block;transition:.25s var(--ease)}
.menu-btn span:nth-child(2){width:10px}
.menu-btn[aria-expanded="true"] span:nth-child(1){transform:translateY(5.5px) rotate(45deg);background:var(--red)}
.menu-btn[aria-expanded="true"] span:nth-child(2){opacity:0;transform:translateX(-8px)}
.menu-btn[aria-expanded="true"] span:nth-child(3){transform:translateY(-5.5px) rotate(-45deg);background:var(--red)}
.nav-pulse{position:absolute;bottom:0;left:50%;transform:translateX(-50%);height:1px;background:var(--red);animation:navPulse 4s ease-in-out infinite;box-shadow:0 0 6px rgba(255,16,36,.4)}
@keyframes navPulse{0%,100%{width:30%;opacity:.4}50%{width:80%;opacity:1;box-shadow:0 0 12px rgba(255,16,36,.7)}}

/* Drawer */
.drawer{position:fixed;top:var(--nav-h);left:50%;transform:translateX(-50%);z-index:69;width:100%;max-width:var(--col);background:rgba(8,8,8,.985);border-bottom:1px solid var(--line);backdrop-filter:blur(22px);max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.drawer.open{max-height:420px}
.drawer ul{list-style:none;padding:14px 24px 22px}
.drawer a{display:block;color:var(--off);border-bottom:1px solid var(--line);padding:16px 0;font-family:var(--font-display);font-size:17px;font-weight:500;letter-spacing:-.005em;transition:color .2s}
.drawer li:last-child a{border-bottom:0}
.drawer a[aria-current="page"]{color:var(--red)}
@media(hover:hover){.drawer a:hover{color:var(--red)}}

/* Float CTA */
.float-cta{position:fixed;left:50%;bottom:0;transform:translateX(-50%);z-index:68;width:100%;max-width:var(--col);display:flex;align-items:center;justify-content:space-between;gap:12px;background:rgba(8,8,8,.93);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--red);padding:12px 18px;padding-bottom:calc(12px+env(safe-area-inset-bottom));animation:floatBreath 5s ease-in-out 1s infinite}
.float-cta span{color:var(--off);font-size:10px;line-height:1.35;text-transform:uppercase;letter-spacing:.14em;font-weight:600;display:inline-flex;align-items:center;flex:1}
.float-cta span::before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--red);box-shadow:0 0 8px rgba(255,16,36,.6);margin-right:9px;flex-shrink:0;animation:ctaDot 2.6s ease-in-out infinite}
@keyframes ctaDot{0%,100%{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}
@keyframes floatBreath{0%,100%{box-shadow:0 -1px 0 0 rgba(193,18,31,.45)}50%{box-shadow:0 -1px 0 0 rgba(255,16,36,.85),0 -8px 24px -8px rgba(193,18,31,.45)}}

/* Buttons */
.btn,.btn-ghost{min-height:48px;display:inline-flex;align-items:center;justify-content:center;gap:8px;text-align:center;text-decoration:none;cursor:pointer;padding:14px 24px;font-family:var(--font-body);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;border-radius:8px;transition:.25s var(--ease);touch-action:manipulation}
.btn{background:var(--red);border:1px solid var(--red);color:var(--white);box-shadow:0 6px 18px -6px rgba(193,18,31,.45);animation:btnPulse 4s ease-in-out 2s infinite}
.btn-ghost{background:transparent;border:1px solid rgba(244,239,231,.18);color:var(--white)}
.btn-full{width:100%}
@keyframes btnPulse{0%,100%{box-shadow:0 6px 18px -6px rgba(193,18,31,.45)}50%{box-shadow:0 6px 28px -4px rgba(255,16,36,.65)}}
@media(hover:hover){.btn:hover{background:var(--red-2);border-color:var(--red-2);box-shadow:0 0 28px var(--glow);transform:translateY(-2px)}.btn-ghost:hover{border-color:rgba(244,239,231,.45);background:rgba(244,239,231,.04);transform:translateY(-2px)}}
.btn:active,.btn-ghost:active{transform:scale(.98)}

/* Shared section */
.section{padding:72px 24px;border-top:1px solid var(--line);position:relative}
.label{display:inline-flex;align-items:center;gap:10px;color:var(--red);font-family:var(--font-body);font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;margin-bottom:18px}
.label::before{content:"";width:22px;height:1px;background:var(--red);animation:labelBar 2.6s ease-in-out infinite;box-shadow:0 0 6px rgba(255,16,36,.5)}
@keyframes labelBar{0%,100%{width:18px;opacity:.7}50%{width:36px;opacity:1;box-shadow:0 0 14px rgba(255,16,36,.85)}}
.headline{font-family:var(--font-display);font-size:clamp(38px,9.5vw,52px);line-height:.98;letter-spacing:-.035em;font-weight:600;margin-bottom:20px;color:var(--white)}
.headline em{font-style:normal;color:var(--red);font-weight:600;animation:emPulse 4s ease-in-out infinite}
@keyframes emPulse{0%,100%{color:var(--red);text-shadow:none}50%{color:var(--red-2);text-shadow:0 0 14px rgba(255,16,36,.35)}}
.headline-sm{font-family:var(--font-display);font-size:clamp(26px,6vw,34px);line-height:1.02;letter-spacing:-.03em;font-weight:600;margin-bottom:16px}
.headline-sm em{font-style:normal;color:var(--red);animation:emPulse 4s ease-in-out infinite}
.lead{color:var(--off);font-size:15px;line-height:1.7;letter-spacing:-.003em;max-width:34em}
.text{color:var(--muted-2);font-size:14px;line-height:1.65}

/* Page header (inner pages) */
.page-header{padding:calc(var(--nav-h)+48px) 24px 56px;border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.page-header::before{content:"";position:absolute;inset:-30% -50%;background:radial-gradient(ellipse 50% 40% at center 40%,rgba(193,18,31,.25),transparent 55%);pointer-events:none;animation:pgGlow 6s ease-in-out infinite}
@keyframes pgGlow{0%,100%{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}
.page-header .label,.page-header .headline,.page-header .lead{position:relative;z-index:1}

/* Hero */
#hero{min-height:100svh;display:flex;align-items:center;justify-content:center;text-align:center;padding:110px 24px 170px;position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
#hero::before{content:"";position:absolute;inset:-30% -50%;background:radial-gradient(ellipse 55% 45% at center 35%,rgba(193,18,31,.42),transparent 55%),radial-gradient(ellipse 40% 30% at 50% 60%,rgba(255,16,36,.24),transparent 60%),radial-gradient(ellipse 30% 30% at 35% 45%,rgba(193,18,31,.18),transparent 50%),linear-gradient(180deg,transparent 0%,rgba(0,0,0,.42) 100%);pointer-events:none;animation:heroGlowAlive 5.5s ease-in-out infinite;will-change:opacity,transform}
#hero::after{content:"";position:absolute;inset:-20% -30%;background:radial-gradient(ellipse 45% 35% at 60% 40%,rgba(255,16,36,.15),transparent 55%),radial-gradient(ellipse 30% 45% at 40% 65%,rgba(193,18,31,.12),transparent 50%);pointer-events:none;animation:heroGlow2 8s ease-in-out infinite;will-change:opacity,transform;z-index:0}
@keyframes heroGlowAlive{0%{opacity:.55;transform:scale(1) translate3d(-1%,0,0)}20%{opacity:1;transform:scale(1.08) translate3d(2.5%,-2%,0)}45%{opacity:.65;transform:scale(.96) translate3d(-2.5%,1.5%,0)}65%{opacity:1;transform:scale(1.1) translate3d(2%,-1%,0)}85%{opacity:.55;transform:scale(1.02) translate3d(-1%,2%,0)}100%{opacity:.55;transform:scale(1) translate3d(-1%,0,0)}}
@keyframes heroGlow2{0%{opacity:.4;transform:scale(1) translate3d(1%,1%,0)}33%{opacity:.85;transform:scale(1.06) translate3d(-2%,-1%,0)}66%{opacity:.5;transform:scale(.97) translate3d(1.5%,2%,0)}100%{opacity:.4;transform:scale(1) translate3d(1%,1%,0)}}
.hero-inner{position:relative;z-index:2;max-width:680px;width:100%;text-align:center}
.hero-logo{width:clamp(300px,82vw,560px);margin:0 auto 24px;position:relative;opacity:0;animation:heroLogoReveal 1.4s var(--ease) .2s forwards}
.hero-x-img{width:100%;height:auto;display:block;position:relative;z-index:1;filter:drop-shadow(0 0 8px rgba(193,18,31,.15));animation:xImgBreath 6s ease-in-out 1.6s infinite}
@keyframes xImgBreath{0%,100%{filter:drop-shadow(0 0 8px rgba(193,18,31,.15))}50%{filter:drop-shadow(0 0 30px rgba(255,16,36,.4))}}
.hero-o-svg{position:absolute;z-index:2;top:46.8%;left:50%;transform:translate(-50%,-50%);width:29%;height:auto;overflow:visible}
.svg-o-ring{fill:none;stroke:var(--white);stroke-width:28;opacity:0;stroke-dasharray:565;stroke-dashoffset:565;animation:ringDraw 1.6s var(--ease) .6s forwards,ringGlow 5s ease-in-out 2.4s infinite}
@keyframes ringDraw{0%{stroke-dashoffset:565;opacity:0}8%{opacity:1}100%{stroke-dashoffset:0;opacity:1}}
@keyframes ringGlow{0%,100%{filter:drop-shadow(0 0 4px rgba(193,18,31,.15))}50%{filter:drop-shadow(0 0 22px rgba(255,16,36,.4))}}
.svg-eye-orbit{transform-origin:120px 120px;opacity:0;animation:eyeIn .6s var(--ease) 2s forwards,eyeOrbit 10s linear 2.6s infinite}
@keyframes eyeIn{to{opacity:1}}@keyframes eyeOrbit{from{transform:rotate(0)}to{transform:rotate(360deg)}}
.svg-eye{fill:var(--red);opacity:0;animation:eyePop .7s var(--ease) 2s forwards,eyePulse 2.4s ease-in-out 2.7s infinite}
@keyframes eyePop{0%{opacity:0;r:0}50%{opacity:1;r:16;filter:drop-shadow(0 0 28px rgba(255,16,36,.95))}100%{opacity:1;r:12;filter:drop-shadow(0 0 10px rgba(255,16,36,.7))}}
@keyframes eyePulse{0%,100%{r:12;filter:drop-shadow(0 0 10px rgba(255,16,36,.6))}50%{r:14;filter:drop-shadow(0 0 24px rgba(255,16,36,.9))}}
.svg-eye-trail{fill:rgba(255,16,36,.12);filter:blur(4px);opacity:0;animation:eyeIn .6s var(--ease) 2.2s forwards}
.hero-logo::before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:110%;height:110%;border-radius:50%;background:radial-gradient(circle,rgba(193,18,31,.22) 0%,rgba(255,16,36,.08) 40%,transparent 70%);filter:blur(30px);animation:logoHalo 6s ease-in-out infinite;pointer-events:none;z-index:0}
.hero-logo::after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.7);width:120%;height:120%;border-radius:50%;border:1px solid rgba(193,18,31,.25);opacity:0;animation:logoPulseRing 4s ease-out 2s infinite;pointer-events:none;z-index:1}
@keyframes heroLogoReveal{0%{opacity:0;transform:scale(.85) translateY(20px);filter:blur(12px)}40%{opacity:.7;filter:blur(3px)}100%{opacity:1;transform:scale(1) translateY(0);filter:blur(0)}}
@keyframes logoHalo{0%,100%{opacity:.6;transform:translate(-50%,-50%) scale(1);filter:blur(30px)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.12);filter:blur(40px)}}
@keyframes logoPulseRing{0%{transform:translate(-50%,-50%) scale(.7);opacity:.5;border-color:rgba(193,18,31,.35)}50%{opacity:.15}100%{transform:translate(-50%,-50%) scale(1.4);opacity:0;border-color:rgba(255,16,36,0)}}
.hero-tagline{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:14px;opacity:0;animation:heroReveal .85s var(--ease) .65s forwards}
.hero-tag-text{font-family:var(--font-display);font-size:clamp(11px,2.5vw,13px);font-weight:700;letter-spacing:.32em;text-transform:uppercase;color:var(--muted-2);white-space:nowrap}
.hero-tag-line{display:block;width:clamp(30px,8vw,60px);height:1px;background:linear-gradient(90deg,transparent,var(--red),transparent);animation:tagPulse 3.5s ease-in-out infinite}
@keyframes tagPulse{0%,100%{width:clamp(24px,6vw,50px);opacity:.5}50%{width:clamp(40px,10vw,80px);opacity:1;box-shadow:0 0 12px rgba(255,16,36,.5)}}
.hero-phrase{font-family:var(--font-display);font-size:clamp(10px,2.6vw,14px);font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--off);margin-bottom:34px;opacity:0;animation:heroReveal .85s var(--ease) .82s forwards}
.hero-actions{display:flex;flex-direction:column;gap:10px;margin:10px auto 0;max-width:310px;opacity:0;animation:heroActionsReveal 1s var(--ease) 1.1s forwards}
@keyframes heroActionsReveal{from{opacity:0;transform:translateY(20px);filter:blur(6px)}to{opacity:1;transform:translateY(0);filter:blur(0)}}

/* Hero kicker */
.hero-kicker{color:var(--off);font-family:var(--font-body);font-size:11px;text-transform:uppercase;letter-spacing:.28em;font-weight:600;margin-bottom:20px;opacity:0;animation:heroReveal .85s var(--ease) .08s forwards;display:inline-flex;align-items:center;gap:10px}
.hero-kicker::before{content:"";width:22px;height:1px;background:var(--red);animation:kickerLine 3s ease-in-out infinite;box-shadow:0 0 8px rgba(255,16,36,.5)}
.hero-kicker::after{content:"";width:6px;height:6px;border-radius:50%;background:var(--red);box-shadow:0 0 10px rgba(255,16,36,.7);animation:dotBreath 1.8s ease-in-out infinite}
@keyframes kickerLine{0%,100%{width:18px;opacity:.7}50%{width:38px;opacity:1;box-shadow:0 0 14px rgba(255,16,36,.85)}}
@keyframes dotBreath{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.35);box-shadow:0 0 18px rgba(255,16,36,.95)}}

/* Hero notice */
.hero-notice{font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:28px;opacity:0;animation:heroReveal .85s var(--ease) .92s forwards}

/* Float ghost btn */
.float-ghost{min-height:auto!important;padding:10px 14px!important;font-size:9px!important;border-radius:6px!important}
@keyframes heroReveal{from{opacity:0;transform:translateY(14px);filter:blur(5px)}to{opacity:1;transform:translateY(0);filter:blur(0)}}

/* Scroll Reveal */
.reveal{opacity:0;transform:translateY(28px);filter:blur(6px);transition:opacity .8s var(--ease),transform .8s var(--ease),filter .8s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0);filter:blur(0)}
.reveal-d1{transition-delay:.1s}.reveal-d2{transition-delay:.2s}.reveal-d3{transition-delay:.3s}.reveal-d4{transition-delay:.4s}

/* Visual Breaks */
.visual-break{position:relative;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.visual-break img{width:100%;height:280px;object-fit:cover;display:block;filter:brightness(.85) contrast(1.05);transition:filter .6s var(--ease)}
.visual-break::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,8,8,.25) 0%,transparent 30%,transparent 70%,rgba(8,8,8,.35) 100%);pointer-events:none}

/* Marquee */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--surface);overflow:hidden;white-space:nowrap;padding:14px 0}
.marquee-track{display:inline-flex;animation:marquee 28s linear infinite}
.marquee-item{display:inline-flex;align-items:center;gap:22px;padding:0 24px;color:var(--off);font-family:var(--font-body);font-size:11px;font-weight:600;letter-spacing:.2em;text-transform:uppercase}
.marquee-item i{width:5px;height:5px;border-radius:50%;background:var(--red);box-shadow:0 0 8px rgba(255,16,36,.5)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);margin-top:32px}
.stat{background:var(--surface);padding:24px 16px;text-align:center}
.stat-num{font-family:var(--font-display);font-size:32px;font-weight:700;letter-spacing:-.02em;line-height:1;margin-bottom:6px}
.stat-num span{color:var(--red)}
.stat-label{font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}

/* Services Grid */
.services-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;margin-top:32px;background:var(--line)}
.service-cell{background:var(--surface);padding:22px 18px;display:flex;flex-direction:column;gap:6px}
.service-num{color:var(--red);font-family:var(--font-display);font-size:12px;font-weight:700;letter-spacing:.1em}
.service-name{font-family:var(--font-display);font-size:18px;font-weight:600;letter-spacing:-.02em;line-height:1.1}
.service-desc{color:var(--muted);font-size:12px;line-height:1.6}

/* Service Detail Card (services page) */
.service-detail{padding:40px 0;border-bottom:1px solid var(--line)}
.service-detail:first-child{padding-top:0}
.service-detail:last-child{border-bottom:0}
.service-detail-num{color:var(--red);font-family:var(--font-display);font-size:24px;font-weight:700;margin-bottom:12px}
.service-detail h3{font-family:var(--font-display);font-size:clamp(24px,5vw,30px);font-weight:600;letter-spacing:-.025em;margin-bottom:12px}
.service-detail>p{color:var(--muted-2);font-size:14px;line-height:1.7;margin-bottom:20px}
.includes{margin-top:16px}
.includes-title{font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:12px}
.include-item{display:flex;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--line);color:var(--off);font-size:13px;line-height:1.55}
.include-item:last-child{border-bottom:0}
.include-item::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--red);flex-shrink:0;margin-top:6px}

/* Process Steps */
.steps{margin-top:32px;display:flex;flex-direction:column}
.step{display:flex;gap:18px;padding:22px 0;border-bottom:1px solid var(--line)}
.step:first-child{border-top:1px solid var(--line)}
.step-num{font-family:var(--font-display);font-size:28px;font-weight:700;color:var(--red);line-height:1;min-width:34px}
.step h3{font-family:var(--font-display);font-size:16px;font-weight:600;letter-spacing:-.01em;margin-bottom:4px}
.step p{color:var(--muted);font-size:13px;line-height:1.6}

/* FAQ */
.faq{margin-top:32px}
.faq-item{border-bottom:1px solid var(--line);padding:20px 0}
.faq-item:first-child{border-top:1px solid var(--line)}
.faq-q{font-family:var(--font-display);font-size:16px;font-weight:600;letter-spacing:-.01em;margin-bottom:8px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq-q::after{content:"+";color:var(--red);font-size:20px;font-weight:400;transition:.25s var(--ease);flex-shrink:0}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{color:var(--muted-2);font-size:13px;line-height:1.7;max-height:0;overflow:hidden;transition:max-height .35s var(--ease),padding .35s var(--ease)}
.faq-item.open .faq-a{max-height:300px;padding-top:4px}

/* Trust Grid */
.trust-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;margin-top:32px;background:var(--line)}
.trust-cell{background:var(--surface);padding:22px 18px;display:flex;flex-direction:column;gap:8px}
.trust-cell svg{width:24px;height:24px;stroke:var(--red);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.trust-cell h3{font-family:var(--font-display);font-size:15px;font-weight:600;letter-spacing:-.01em;line-height:1.2}
.trust-cell p{color:var(--muted);font-size:12px;line-height:1.55}

/* Info block (contacto) */
.info-block{padding:28px 0;border-bottom:1px solid var(--line)}
.info-block:first-child{padding-top:0}
.info-block:last-child{border-bottom:0}
.info-block h3{font-family:var(--font-display);font-size:18px;font-weight:600;letter-spacing:-.015em;margin-bottom:10px}
.info-block p{color:var(--muted-2);font-size:13px;line-height:1.7}
.info-block ul{list-style:none;margin-top:12px}
.info-block li{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--line);color:var(--off);font-size:13px;line-height:1.5}
.info-block li:last-child{border-bottom:0}
.info-block li::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--red);flex-shrink:0;margin-top:6px}

/* Contact Row */
.contact-row{display:flex;align-items:center;justify-content:space-between;padding:18px 0;border-bottom:1px solid var(--line);transition:.2s}
.contact-row:first-child{border-top:1px solid var(--line)}
.contact-row small{font-size:9px;text-transform:uppercase;letter-spacing:.18em;font-weight:700;color:var(--red);min-width:60px}
.contact-row span{flex:1;font-size:13px;color:var(--off);font-weight:500}
.contact-row b{color:var(--muted);font-weight:400;font-size:16px}
@media(hover:hover){.contact-row:hover{background:var(--surface);padding-left:8px;padding-right:8px}}

/* Statement */
.statement{padding:80px 24px;border-top:1px solid var(--line);position:relative;overflow:hidden;text-align:center}
.statement::before{content:"";position:absolute;inset:-20%;background:radial-gradient(ellipse 50% 50% at 50% 50%,rgba(193,18,31,.12),transparent 60%);pointer-events:none;animation:stmtGlow 8s ease-in-out infinite}
@keyframes stmtGlow{0%,100%{opacity:.4;transform:scale(1)}50%{opacity:.9;transform:scale(1.1)}}
.stmt-inner{position:relative;z-index:1;max-width:600px;margin:0 auto}
.stmt-label{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:28px}
.stmt-line{display:block;width:clamp(24px,6vw,50px);height:1px;background:var(--red);animation:stmtLine 3.5s ease-in-out infinite}
@keyframes stmtLine{0%,100%{width:clamp(20px,5vw,40px);opacity:.5}50%{width:clamp(36px,8vw,70px);opacity:1;box-shadow:0 0 10px rgba(255,16,36,.5)}}
.stmt-eyebrow{font-size:10px;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--red);white-space:nowrap}
.stmt-text{font-family:var(--font-display);font-size:clamp(28px,6vw,42px);line-height:1.08;letter-spacing:-.03em;font-weight:600;margin-bottom:28px}
.stmt-text em{font-style:normal;color:var(--red);animation:emPulse 4s ease-in-out infinite}
.stmt-rule{width:50px;height:1px;background:var(--red);margin:0 auto 20px;border:none;animation:rulePulse 3.4s ease-in-out infinite}
@keyframes rulePulse{0%,100%{width:50px;opacity:1}50%{width:100px;opacity:.7;box-shadow:0 0 12px rgba(255,16,36,.5)}}
.stmt-sig{font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.stmt-sig b{color:var(--white);font-weight:700}

/* Footer */
footer{padding:50px 22px 36px;border-top:1px solid rgba(193,18,31,.4);position:relative;overflow:hidden;background:radial-gradient(ellipse 80% 60% at 50% 100%,rgba(193,18,31,.12),transparent 60%);text-align:center}
footer::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:140px;height:2px;background:linear-gradient(90deg,transparent,var(--red-2),transparent);box-shadow:0 0 14px rgba(255,16,36,.5);animation:fBar 3.5s ease-in-out infinite;z-index:2}
@keyframes fBar{0%,100%{width:100px;opacity:.7}50%{width:200px;opacity:1}}
.footer-inner{position:relative;z-index:1}
.footer-tagline{font-family:var(--font-display);font-size:clamp(28px,6vw,42px);line-height:1.02;letter-spacing:-.035em;font-weight:600;margin-bottom:16px}
.footer-tagline em{font-style:normal;color:var(--red);animation:emPulse 4s ease-in-out infinite}
.footer-text{color:var(--muted);font-size:clamp(6.5px,2.2vw,10px);font-weight:600;letter-spacing:.2em;text-transform:uppercase;line-height:1;white-space:nowrap;margin:0 auto 20px}
.footer-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:6px 18px;margin-bottom:20px}
.footer-nav a{font-weight:600;letter-spacing:.14em;text-transform:uppercase;font-size:10px;color:var(--muted-2);padding:4px 0;transition:color .25s}
@media(hover:hover){.footer-nav a:hover{color:var(--red)}}
.footer-rule{width:50px;height:1px;background:var(--red);margin:0 auto 20px;border:none;animation:rulePulse 3.4s ease-in-out infinite}
.footer-mark{display:flex;align-items:center;justify-content:center;gap:4px;margin-bottom:8px}
.fm-xox{font-family:var(--font-display);font-weight:800;font-size:14px;letter-spacing:.16em;color:var(--white)}
.fm-studio{font-family:var(--font-body);font-weight:600;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-style:normal}
.copy{color:rgba(244,239,231,.25);font-size:10px;letter-spacing:.06em}

/* Nav page link inside sections */
.section-link{display:flex;align-items:center;justify-content:space-between;margin-top:28px;padding:16px 0;border-top:1px solid var(--line);font-family:var(--font-display);font-size:15px;font-weight:600;letter-spacing:-.01em;color:var(--off);transition:.2s}
.section-link::after{content:"→";color:var(--red);font-size:18px;transition:.15s var(--ease)}
@media(hover:hover){.section-link:hover{color:var(--red)}.section-link:hover::after{transform:translateX(4px)}}

/* ============ HOOK SECTIONS ============ */

/* Contrast List (The Problem) */
.contrast-list{margin-top:32px;display:flex;flex-direction:column}
.contrast-item{display:flex;align-items:flex-start;gap:14px;padding:16px 0;border-bottom:1px solid var(--line);font-size:14px;line-height:1.5;color:var(--off)}
.contrast-item:first-child{border-top:1px solid var(--line)}
.contrast-x{color:var(--red);font-size:16px;font-weight:700;flex-shrink:0;width:22px;text-align:center;animation:xPulse 3s ease-in-out infinite}
@keyframes xPulse{0%,100%{opacity:.6}50%{opacity:1;text-shadow:0 0 10px rgba(255,16,36,.4)}}

/* Difference Grid */
.diff-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;margin-top:32px;background:var(--line)}
.diff-card{background:var(--surface);padding:24px 18px;display:flex;flex-direction:column;gap:10px}
.diff-icon{width:36px;height:36px;border-radius:50%;background:rgba(193,18,31,.12);border:1px solid rgba(193,18,31,.25);display:grid;place-items:center;animation:iconBreath 4s ease-in-out infinite}
.diff-card:nth-child(2) .diff-icon{animation-delay:.5s}
.diff-card:nth-child(3) .diff-icon{animation-delay:1s}
.diff-card:nth-child(4) .diff-icon{animation-delay:1.5s}
@keyframes iconBreath{0%,100%{border-color:rgba(193,18,31,.2);box-shadow:none}50%{border-color:rgba(255,16,36,.5);box-shadow:0 0 16px rgba(193,18,31,.2)}}
.diff-icon svg{width:18px;height:18px;stroke:var(--red)}
.diff-card h3{font-family:var(--font-display);font-size:16px;font-weight:600;letter-spacing:-.01em;line-height:1.15}
.diff-card p{color:var(--muted);font-size:12px;line-height:1.6}

/* Availability Section */
.avail-section{padding:0 24px 0}
.avail-card{position:relative;background:var(--surface);border:1px solid rgba(193,18,31,.2);border-radius:12px;padding:40px 24px;text-align:center;overflow:hidden}
.avail-card::before{content:"";position:absolute;inset:-40%;background:radial-gradient(ellipse 50% 50% at 50% 30%,rgba(193,18,31,.15),transparent 60%);pointer-events:none;animation:availGlow 5s ease-in-out infinite}
@keyframes availGlow{0%,100%{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}
.avail-dot{width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 12px rgba(255,16,36,.7);margin:0 auto 16px;position:relative;z-index:1;animation:ctaDot 2.6s ease-in-out infinite}
.avail-eyebrow{font-size:10px;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--red);margin-bottom:16px;position:relative;z-index:1}
.avail-headline{font-family:var(--font-display);font-size:clamp(26px,6.5vw,36px);line-height:1.02;letter-spacing:-.03em;font-weight:600;color:var(--white);margin-bottom:16px;position:relative;z-index:1}
.avail-headline em{font-style:normal;color:var(--red);animation:emPulse 4s ease-in-out infinite}
.avail-text{color:var(--muted-2);font-size:13px;line-height:1.65;max-width:340px;margin:0 auto 24px;position:relative;z-index:1}
.avail-card .btn{position:relative;z-index:1}
