/* =========================================================
   JORGE LERA — Periodista deportivo y locutor publicitario
   Brand: black · boxing red · gold · bone white
   Type: Anton (impact) · Oswald (condensed) · Inter (body)
   ========================================================= */
:root{
  --black:#0a0a0c;
  --black-2:#111114;
  --coal:#16161a;
  --red:#e2231a;
  --red-deep:#a3120c;
  --gold:#cda349;
  --gold-light:#e7cf8f;
  --bone:#f4f1ea;
  --grey:#9a9aa5;
  --muted:#8c8c97;
  --line:rgba(255,255,255,.10);
  --line-gold:rgba(205,163,73,.4);

  --display:"Anton", Impact, sans-serif;
  --cond:"Oswald", system-ui, sans-serif;
  --body:"Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;

  --container:1280px;
  --gutter:clamp(20px,5vw,80px);
  --section:clamp(72px,11vw,168px);
  --ease:cubic-bezier(.16,1,.3,1);
  --header-h:102px;
}
*,*::before,*::after{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; }
body{
  margin:0; background:var(--black); color:var(--bone);
  font-family:var(--body); font-size:16px; line-height:1.65; overflow-x:hidden;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; image-orientation:from-image; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4{ margin:0; font-family:var(--display); font-weight:400; line-height:.92; text-transform:uppercase; }
p{ margin:0 0 1em; }
::selection{ background:var(--red); color:#fff; }
#smooth-wrapper,#smooth-content{ will-change:transform; }
/* ambient color layer sits behind all content */
.bgfx{ position:fixed; inset:0; z-index:0; pointer-events:none; background-color:var(--black); }
#smooth-wrapper{ position:relative; z-index:1; }

/* expanding fullscreen panel (pin + clip grow) */
.expand{ position:relative; height:100vh; overflow:hidden; display:grid; place-items:center; }
.expand__media{ position:relative; width:100%; height:100%; overflow:hidden; will-change:clip-path; }
.expand__media img{ width:100%; height:100%; object-fit:cover; will-change:transform; }
.expand__media::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(8,8,10,.25),rgba(8,8,10,.7)); }
.expand__title{ position:absolute; inset:0; z-index:2; display:grid; place-items:center; text-align:center; padding:1rem; }
.expand__title h2{ font-size:clamp(2.6rem,9vw,8rem); line-height:.88; text-shadow:0 14px 60px rgba(0,0,0,.7); }
.expand__title .red{ color:var(--red); }
.expand__title .k{ display:block; font-family:var(--cond); font-weight:300; letter-spacing:.4em; text-transform:uppercase;
  font-size:clamp(.7rem,1.6vw,1rem); color:var(--gold); margin-top:1rem; }

/* texture overlays applied to body via fixed layers */
.fx-grain,.fx-vignette{ position:fixed; inset:0; pointer-events:none; z-index:600; }
.fx-grain{ opacity:.05; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
.fx-vignette{ box-shadow:inset 0 0 220px 70px rgba(0,0,0,.65); z-index:590; }

/* ---------- layout ---------- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block:var(--section); position:relative; }
.center{ text-align:center; }
.mt-s{ margin-top:1rem }.mt-m{ margin-top:2rem }.mt-l{ margin-top:3.5rem }
.lead{ font-size:clamp(1.05rem,1.6vw,1.3rem); color:#c9c9d2; }

.eyebrow{ font-family:var(--cond); font-weight:500; letter-spacing:.42em; text-transform:uppercase;
  font-size:.72rem; color:var(--gold); display:inline-flex; align-items:center; gap:1em; }
.eyebrow::before{ content:""; width:40px; height:2px; background:var(--red); }
.eyebrow.no-line::before{ display:none; }

.section-title{ font-size:clamp(2.3rem,6vw,5rem); letter-spacing:.01em; margin-top:.5rem; }
.section-title .red{ color:var(--red); }
.section-title .out{ color:transparent; -webkit-text-stroke:2px var(--bone); }
.kicker{ font-family:var(--cond); font-weight:300; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }

/* ---------- buttons ---------- */
.btn{ --bg:var(--red); --fg:#fff; position:relative; display:inline-flex; align-items:center; gap:.7em;
  font-family:var(--cond); font-weight:600; letter-spacing:.16em; text-transform:uppercase; font-size:.82rem;
  color:var(--fg); background:var(--bg); padding:1.05em 2.1em; border-radius:2px; overflow:hidden; isolation:isolate;
  transition:transform .5s var(--ease), box-shadow .5s var(--ease), color .4s var(--ease); }
.btn::after{ content:""; position:absolute; inset:0; z-index:-1; transform:translateY(101%);
  background:var(--gold); transition:transform .55s var(--ease); }
.btn:hover{ color:var(--black); transform:translateY(-3px); box-shadow:0 18px 40px -16px rgba(226,35,26,.6); }
.btn:hover::after{ transform:translateY(0); }
.btn--gold{ --bg:var(--gold); --fg:var(--black); }
.btn--gold::after{ background:var(--red); }
.btn--gold:hover{ color:#fff; }
.btn--ghost{ --bg:transparent; --fg:var(--bone); border:1px solid var(--line-gold); }
.btn--ghost::after{ background:var(--gold); }
.btn--ghost:hover{ color:var(--black); border-color:var(--gold); }

.link-arrow{ font-family:var(--cond); font-weight:500; letter-spacing:.12em; text-transform:uppercase; font-size:.82rem;
  color:var(--gold); display:inline-flex; align-items:center; gap:.6em; position:relative; }
.link-arrow::after{ content:""; position:absolute; left:0; bottom:-4px; width:100%; height:1px; background:currentColor;
  transform:scaleX(0); transform-origin:right; transition:transform .5s var(--ease); }
.link-arrow:hover::after{ transform:scaleX(1); transform-origin:left; }
.link-arrow span{ transition:transform .4s var(--ease); }
.link-arrow:hover span{ transform:translateX(5px); }

/* =========================================================
   PRELOADER
   ========================================================= */
.preloader{ position:fixed; inset:0; z-index:9000; display:grid; place-items:center; background:var(--black); }
.preloader__logo{ width:clamp(150px,26vw,230px); }
.preloader__count{ font-family:var(--display); font-size:clamp(4rem,16vw,11rem); color:transparent;
  -webkit-text-stroke:2px var(--red); position:absolute; bottom:6vh; right:6vw; line-height:.8; }
.preloader__bar{ position:absolute; left:0; bottom:0; height:3px; width:100%; transform:scaleX(0); transform-origin:left;
  background:linear-gradient(90deg,var(--red),var(--gold)); }

/* page transition */
.transition{ position:fixed; inset:0; z-index:8000; display:flex; pointer-events:none; }
.transition__col{ flex:1; background:var(--red); transform:scaleY(0); transform-origin:bottom; }
.transition__logo{ position:absolute; top:50%; left:50%; width:min(340px,62vw); height:auto; z-index:1; opacity:0;
  filter:drop-shadow(0 10px 30px rgba(0,0,0,.5)); }

/* =========================================================
   CUSTOM CURSOR
   ========================================================= */
.cursor-dot, .cursor-ring{ position:fixed; top:0; left:0; z-index:9999; pointer-events:none; border-radius:50%; }
.cursor-dot{ width:7px; height:7px; margin:-3.5px 0 0 -3.5px; background:var(--gold); }
.cursor-ring{ width:40px; height:40px; margin:-20px 0 0 -20px; border:1px solid rgba(245,197,66,.55);
  transition:width .3s var(--ease), height .3s var(--ease), margin .3s var(--ease), border-color .3s, background .3s; }
.cursor-ring.is-hover{ width:64px; height:64px; margin:-32px 0 0 -32px; border-color:var(--red); background:rgba(226,35,26,.08); }
body.has-cursor, body.has-cursor a, body.has-cursor button, body.has-cursor input,
body.has-cursor textarea, body.has-cursor select, body.has-cursor [data-magnetic]{ cursor:none; }
@media (hover:none),(pointer:coarse){ .cursor-dot, .cursor-ring{ display:none; } }

/* =========================================================
   INTRO (home, once per session)
   ========================================================= */
.intro{ position:fixed; inset:0; z-index:9500; overflow:hidden; }
.intro__curtain{ position:absolute; inset:0; z-index:1; display:flex; }
.intro__curtain i{ flex:1; background:var(--black); }
.intro__spot{ position:absolute; left:50%; top:38%; z-index:2; width:120vmax; height:120vmax;
  transform:translate(-50%,-50%) scale(0); pointer-events:none; mix-blend-mode:screen;
  background:radial-gradient(closest-side, rgba(205,163,73,.22), rgba(205,163,73,.05) 42%, transparent 70%); }
.intro__onair{ position:absolute; left:24px; top:20px; z-index:4; font-family:var(--cond); font-weight:600;
  letter-spacing:.28em; text-transform:uppercase; font-size:.74rem; color:#fff; display:flex; align-items:center; gap:.6em; opacity:0; }
.intro__onair .oa-dot{ width:11px; height:11px; border-radius:50%; background:var(--red); box-shadow:0 0 12px var(--red); }
.intro__skip{ position:absolute; right:22px; top:18px; z-index:4; font-family:var(--cond); letter-spacing:.22em;
  text-transform:uppercase; font-size:.7rem; color:#8a8e9b; padding:.5em .8em; opacity:0; }
.intro__skip:hover{ color:var(--gold); }
.intro__count{ position:absolute; right:5vw; bottom:5vh; z-index:3; font-family:var(--display); line-height:.8;
  font-size:clamp(6rem,26vw,22rem); color:transparent; -webkit-text-stroke:2px var(--red); opacity:0; }
.intro__stage{ position:absolute; inset:0; z-index:3; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1.4rem; }
.intro__logo{ width:clamp(220px,40vw,460px); height:auto; opacity:0; }
.intro__eq{ display:flex; align-items:center; gap:5px; height:64px; }
.intro__eq i{ width:6px; height:30%; border-radius:3px; background:linear-gradient(var(--gold-light),var(--gold)); transform-origin:center; }
.intro__tag{ font-family:var(--cond); font-weight:300; letter-spacing:.4em; text-transform:uppercase;
  font-size:clamp(.8rem,2.4vw,1.3rem); color:#d7d7de; min-height:1.4em; }
.intro__sparks{ position:absolute; inset:0; z-index:4; pointer-events:none; }

/* =========================================================
   HEADER / NAV (with dropdown)
   ========================================================= */
.site-header{ position:fixed; top:0; left:0; width:100%; z-index:1000; height:var(--header-h);
  display:flex; align-items:center; transition:height .5s var(--ease), background .5s var(--ease), backdrop-filter .5s; }
.site-header.scrolled{ height:78px; background:rgba(10,10,12,.72); backdrop-filter:blur(14px) saturate(140%);
  box-shadow:0 1px 0 var(--line); }
.nav{ width:min(100%,1460px); max-width:1460px; margin-inline:auto; padding-inline:var(--gutter);
  display:flex; align-items:center; justify-content:space-between; gap:clamp(1rem,2vw,2rem); box-sizing:border-box; }
.brand{ display:flex; align-items:center; }
.brand__logo{ height:64px; width:auto; transition:height .45s var(--ease); }
.scrolled .brand__logo{ height:52px; }
@media (max-width:560px){ .brand__logo{ height:46px; } }

.nav__links{ display:flex; align-items:center; gap:clamp(1.2rem,2.6vw,2.6rem); }
.nav__item{ position:relative; }
.nav__link{ font-family:var(--cond); font-weight:500; letter-spacing:.14em; text-transform:uppercase; font-size:.82rem;
  color:var(--bone); padding:.5em 0; display:inline-flex; align-items:center; gap:.4em; opacity:.85; transition:opacity .3s; }
.nav__link .caret{ width:.7em; height:.7em; transition:transform .4s var(--ease); }
.nav__link::after{ content:""; position:absolute; left:0; bottom:0; width:100%; height:2px; background:var(--red);
  transform:scaleX(0); transform-origin:right; transition:transform .45s var(--ease); }
.nav__link:hover, .nav__link.active{ opacity:1; }
.nav__link:hover::after, .nav__link.active::after{ transform:scaleX(1); transform-origin:left; }

/* dropdown */
.dropdown{ position:absolute; top:100%; left:50%; transform:translateX(-50%) translateY(10px);
  min-width:280px; background:rgba(15,15,18,.97); backdrop-filter:blur(14px); border:1px solid var(--line);
  border-top:2px solid var(--red); border-radius:0 0 6px 6px; padding:.6rem; opacity:0; visibility:hidden;
  transition:opacity .35s var(--ease), transform .35s var(--ease), visibility .35s; box-shadow:0 30px 60px -20px rgba(0,0,0,.7); }
.nav__item:hover .dropdown{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.nav__item:hover .caret{ transform:rotate(180deg); }
.dropdown a{ display:flex; align-items:center; gap:.9rem; padding:.85rem 1rem; border-radius:4px;
  font-family:var(--cond); letter-spacing:.06em; font-size:.92rem; transition:background .3s, color .3s; }
.dropdown a .n{ font-family:var(--display); font-size:.85rem; color:var(--red); width:1.4em; }
.dropdown a:hover{ background:rgba(226,35,26,.12); color:var(--gold-light); }

.nav__cta{ font-size:.74rem; padding:.78em 1.5em; }
.burger{ display:none; width:42px; height:42px; position:relative; z-index:1200; }
.burger span{ position:absolute; left:9px; right:9px; height:2px; background:var(--bone); transition:transform .4s var(--ease), opacity .3s; }
.burger span:nth-child(1){ top:15px } .burger span:nth-child(2){ top:21px } .burger span:nth-child(3){ top:27px }
.menu-open .burger span:nth-child(1){ transform:translateY(6px) rotate(45deg) }
.menu-open .burger span:nth-child(2){ opacity:0 }
.menu-open .burger span:nth-child(3){ transform:translateY(-6px) rotate(-45deg) }

/* mobile menu */
.mobile{ position:fixed; inset:0; z-index:1100; background:var(--black-2); padding:var(--gutter);
  display:flex; flex-direction:column; justify-content:center; gap:.2rem;
  clip-path:circle(0% at calc(100% - 40px) 42px); transition:clip-path .7s var(--ease); }
.menu-open .mobile{ clip-path:circle(150% at calc(100% - 40px) 42px); }
.mobile a{ font-family:var(--display); font-size:clamp(1.8rem,8vw,3rem); padding:.12em 0; color:var(--bone); }
.mobile a .n{ font-family:var(--cond); font-size:.8rem; color:var(--red); margin-right:.7em; }
.mobile .sub a{ font-size:clamp(1.1rem,5vw,1.5rem); color:var(--gold); padding-left:1.2em; }

/* =========================================================
   HERO
   ========================================================= */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end; overflow:hidden;
  padding-bottom:clamp(48px,8vh,100px); }
.hero__bg{ position:absolute; inset:0; z-index:0; overflow:hidden; }
.hero__bg img{ position:absolute; top:-16%; left:0; width:100%; height:132%; object-fit:cover; object-position:center 30%; will-change:transform; }
.hero__bg::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(180deg,rgba(10,10,12,.55) 0%,rgba(10,10,12,.35) 35%,rgba(10,10,12,.96) 100%); }
.hero__bg::before{ content:""; position:absolute; inset:0; z-index:1; mix-blend-mode:multiply;
  background:linear-gradient(90deg,rgba(163,18,12,.25),transparent 60%); }
.hero__content{ position:relative; z-index:2; width:100%; }
.hero__eyebrow{ color:var(--gold-light); }
.hero__title{ font-size:clamp(3rem,11vw,9.5rem); line-height:.86; letter-spacing:.005em; }
.hero__title .red{ color:var(--red); }
.hero__title .out{ color:transparent; -webkit-text-stroke:clamp(1px,.25vw,2.5px) var(--bone); }
.hero__sub{ max-width:54ch; margin-top:1.4rem; font-size:clamp(1rem,1.5vw,1.22rem); color:#d4d4dc; }
.hero__actions{ display:flex; flex-wrap:wrap; gap:1rem; margin-top:2.2rem; }
.hero__scroll{ position:absolute; right:var(--gutter); bottom:clamp(40px,7vh,80px); z-index:2; writing-mode:vertical-rl;
  font-family:var(--cond); letter-spacing:.3em; text-transform:uppercase; font-size:.66rem; color:#aaa;
  display:flex; align-items:center; gap:1rem; }
.hero__scroll i{ width:1px; height:60px; background:linear-gradient(var(--gold),transparent); }
.hero .sparks{ position:absolute; inset:0; z-index:2; pointer-events:none; }
.spark{ position:absolute; top:0; left:0; width:6px; height:6px; border-radius:50%; will-change:transform; }

/* ticker strip */
.ticker{ background:var(--red); color:#fff; overflow:hidden; padding:.85rem 0; border-block:2px solid var(--black); }
.ticker__row{ display:flex; gap:2.4rem; width:max-content; white-space:nowrap; font-family:var(--display);
  font-size:clamp(1.1rem,2.6vw,1.8rem); text-transform:uppercase; }
.ticker__row .dot{ color:var(--black); }

/* =========================================================
   STATS
   ========================================================= */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); border:1px solid var(--line); }
.stat{ padding:clamp(24px,3.4vw,46px); border-right:1px solid var(--line); }
.stat:last-child{ border-right:none; }
.stat b{ font-family:var(--display); font-size:clamp(2.6rem,5.4vw,4rem); color:var(--gold-light); line-height:1; display:block; }
.stat span{ font-family:var(--cond); letter-spacing:.12em; text-transform:uppercase; font-size:.74rem; color:var(--muted); margin-top:.4rem; display:block; }

/* =========================================================
   SPLIT (bio / about) + media
   ========================================================= */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,6vw,5.5rem); align-items:center; }
.split--rev .split__media{ order:2; }
.split__media{ position:relative; }
.split__media .frame{ position:relative; overflow:hidden; border-radius:4px; }
.split__media img{ width:100%; aspect-ratio:4/5; object-fit:cover; will-change:transform; }
.split__media .frame::after{ content:""; position:absolute; inset:0; box-shadow:inset 0 0 0 1px var(--line-gold); }
.split__media .tag{ position:absolute; bottom:-20px; left:-20px; background:var(--red); color:#fff;
  padding:1.1rem 1.4rem; box-shadow:0 26px 50px -24px rgba(0,0,0,.7); }
.split__media .tag b{ font-family:var(--display); font-size:2.2rem; display:block; line-height:1; }
.split__media .tag span{ font-family:var(--cond); letter-spacing:.14em; text-transform:uppercase; font-size:.66rem; }
.split__media.media--red .tag{ background:var(--gold); color:var(--black); }
.feature-list{ margin-top:1.6rem; display:grid; gap:1rem; }
.feature-list li{ display:flex; gap:1rem; align-items:flex-start; }
.feature-list .fi{ flex:0 0 auto; width:42px; height:42px; border-radius:50%; display:grid; place-items:center;
  background:rgba(226,35,26,.14); color:var(--red); }
.feature-list b{ font-family:var(--cond); font-weight:600; letter-spacing:.04em; text-transform:uppercase; font-size:.95rem; }
.feature-list p{ margin:.15rem 0 0; font-size:.92rem; color:var(--muted); }

/* =========================================================
   SERVICES (voiceover)
   ========================================================= */
.svc-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:1.2rem; }
.svc-card{ position:relative; background:var(--coal); border:1px solid var(--line); padding:clamp(1.6rem,2.6vw,2.3rem);
  overflow:hidden; transition:transform .5s var(--ease), border-color .5s; }
.svc-card::before{ content:""; position:absolute; left:0; top:0; width:100%; height:3px; background:var(--red);
  transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease); }
.svc-card:hover{ transform:translateY(-8px); border-color:var(--line-gold); }
.svc-card:hover::before{ transform:scaleX(1); }
.svc-card .ico{ width:46px; height:46px; color:var(--gold); margin-bottom:1rem; }
.svc-card h3{ font-family:var(--cond); font-weight:600; text-transform:uppercase; letter-spacing:.04em; font-size:1.3rem; }
.svc-card p{ margin:.6rem 0 0; font-size:.92rem; color:var(--muted); }
.svc-card .num{ position:absolute; top:1.1rem; right:1.3rem; font-family:var(--display); font-size:2rem; color:rgba(255,255,255,.07); }

/* quote band / cta */
.band{ position:relative; overflow:hidden; }
.band__bg{ position:absolute; inset:0; z-index:0; overflow:hidden; }
.band__bg img{ position:absolute; top:-16%; left:0; width:100%; height:132%; object-fit:cover; filter:grayscale(.3) contrast(1.08); will-change:transform; }
.band__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(120deg,rgba(10,10,12,.92),rgba(163,18,12,.7)); }
.band__inner{ position:relative; z-index:1; text-align:center; padding-block:clamp(70px,11vw,150px); }
.band h2{ font-size:clamp(2.2rem,6vw,5rem); max-width:18ch; margin-inline:auto; }
.band p{ color:#e6d9d9; max-width:56ch; margin:1.2rem auto 2rem; }
.bigquote{ font-family:var(--display); text-transform:uppercase; font-size:clamp(2rem,6vw,5rem); line-height:.95;
  max-width:20ch; }
.bigquote .red{ color:var(--red); } .bigquote .out{ color:transparent; -webkit-text-stroke:2px var(--bone); }

/* =========================================================
   PAGE HERO (inner)
   ========================================================= */
.page-hero{ position:relative; min-height:60svh; display:flex; align-items:flex-end; overflow:hidden;
  padding-block:clamp(120px,16vh,200px) clamp(44px,7vh,76px); }
.page-hero__bg{ position:absolute; inset:0; z-index:0; overflow:hidden; }
.page-hero__bg img{ position:absolute; top:-16%; left:0; width:100%; height:132%; object-fit:cover; will-change:transform; }
.page-hero__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(10,10,12,.5),rgba(10,10,12,.95)); }
.page-hero__c{ position:relative; z-index:1; }
.page-hero h1{ font-size:clamp(2.8rem,9vw,7rem); letter-spacing:.01em; }
.page-hero h1 .red{ color:var(--red); }
.breadcrumb{ font-family:var(--cond); letter-spacing:.2em; text-transform:uppercase; font-size:.72rem; color:#aaa; margin-bottom:1rem; }
.breadcrumb a:hover{ color:var(--gold); } .breadcrumb .sep{ color:var(--red); margin-inline:.6em; }

/* =========================================================
   AUDIO DEMO PLAYER (locuciones)
   ========================================================= */
.player{ background:var(--coal); border:1px solid var(--line); border-radius:8px; padding:clamp(1.4rem,3vw,2.4rem);
  display:flex; flex-direction:column; gap:1.2rem; }
.player__top{ display:flex; align-items:center; gap:1.2rem; }
.player__btn{ flex:0 0 auto; width:68px; height:68px; border-radius:50%; background:var(--red); color:#fff;
  display:grid; place-items:center; transition:transform .4s var(--ease), background .4s; position:relative; }
.player__btn:hover{ transform:scale(1.06); background:var(--gold); color:var(--black); }
.player__btn svg{ width:26px; height:26px; }
.player__meta b{ font-family:var(--cond); font-weight:600; text-transform:uppercase; letter-spacing:.06em; font-size:1.15rem; display:block; }
.player__meta span{ font-size:.82rem; color:var(--muted); }
.player__wave{ display:flex; align-items:center; gap:3px; height:64px; cursor:pointer; }
.player__wave i{ flex:1; background:rgba(255,255,255,.16); border-radius:2px; height:30%; transform-origin:center;
  transition:background .2s; }
.player__wave i.on{ background:var(--gold); }
.player__time{ display:flex; justify-content:space-between; font-family:var(--cond); letter-spacing:.1em; font-size:.78rem; color:var(--muted); }

.reels{ display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:1rem; }
.reel{ background:var(--coal); border:1px solid var(--line); padding:1.4rem; transition:border-color .4s, transform .4s var(--ease); }
.reel:hover{ border-color:var(--line-gold); transform:translateY(-5px); }
.reel .tagx{ font-family:var(--cond); letter-spacing:.16em; text-transform:uppercase; font-size:.66rem; color:var(--red); }
.reel h4{ font-family:var(--cond); font-weight:600; text-transform:uppercase; font-size:1.1rem; margin:.4rem 0; }
.reel p{ font-size:.86rem; color:var(--muted); margin:0; }

/* =========================================================
   BOOKS
   ========================================================= */
.book{ display:grid; grid-template-columns:.8fr 1.2fr; gap:clamp(1.6rem,4vw,3.4rem); align-items:center; }
.book--rev .book__cover{ order:2; }
.book__cover{ position:relative; aspect-ratio:3/4.4; border-radius:4px; overflow:hidden;
  background:linear-gradient(160deg,var(--coal),var(--black-2)); border:1px solid var(--line-gold);
  display:flex; flex-direction:column; justify-content:space-between; padding:1.8rem; box-shadow:0 40px 70px -30px rgba(0,0,0,.8); }
.book__cover::before{ content:""; position:absolute; left:0; top:0; width:12px; height:100%; background:linear-gradient(var(--red),var(--red-deep)); }
.book__cover .bk-top{ font-family:var(--cond); letter-spacing:.2em; text-transform:uppercase; font-size:.6rem; color:var(--gold); }
.book__cover .bk-title{ font-family:var(--display); text-transform:uppercase; font-size:clamp(1.4rem,2.4vw,2rem); line-height:.95; color:var(--bone); }
.book__cover .bk-title .red{ color:var(--red); }
.book__cover .bk-author{ font-family:var(--cond); letter-spacing:.16em; text-transform:uppercase; font-size:.74rem; color:var(--muted); }
.book__meta{ display:flex; gap:1.6rem; margin:1rem 0 1.4rem; }
.book__meta div b{ font-family:var(--cond); text-transform:uppercase; letter-spacing:.1em; font-size:.7rem; color:var(--gold); display:block; }
.book__meta div span{ font-size:.95rem; }
.buy{ display:flex; flex-wrap:wrap; gap:.7rem; margin-top:1.2rem; }
.buy a{ font-family:var(--cond); letter-spacing:.1em; text-transform:uppercase; font-size:.74rem; padding:.7em 1.2em;
  border:1px solid var(--line-gold); border-radius:2px; transition:background .35s, color .35s; }
.buy a:hover{ background:var(--gold); color:var(--black); }

/* =========================================================
   ARTICLES / NEWS cards
   ========================================================= */
.cards{ display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:1.4rem; }
.post{ background:var(--coal); border:1px solid var(--line); overflow:hidden; display:flex; flex-direction:column;
  transition:transform .5s var(--ease), border-color .5s; }
.post:hover{ transform:translateY(-8px); border-color:var(--line-gold); }
.post__media{ overflow:hidden; aspect-ratio:16/10; }
.post__media img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease); }
.post:hover .post__media img{ transform:scale(1.07); }
.post__body{ padding:1.5rem; display:flex; flex-direction:column; flex:1; }
.post__tag{ font-family:var(--cond); letter-spacing:.16em; text-transform:uppercase; font-size:.66rem; color:var(--red); }
.post__title{ font-family:var(--cond); font-weight:600; text-transform:uppercase; font-size:1.3rem; line-height:1.05; margin:.5rem 0 .6rem; }
.post__excerpt{ font-size:.9rem; color:var(--muted); flex:1; }
.post__meta{ margin-top:1rem; font-family:var(--cond); letter-spacing:.08em; font-size:.74rem; color:var(--muted); display:flex; gap:.8rem; }
.post__meta .dot{ color:var(--red); }

.feature{ display:grid; grid-template-columns:1.1fr .9fr; border:1px solid var(--line-gold); overflow:hidden; margin-bottom:2.4rem; }
.feature__media{ overflow:hidden; min-height:320px; }
.feature__media img{ width:100%; height:100%; object-fit:cover; }
.feature__body{ padding:clamp(1.8rem,4vw,3.2rem); display:flex; flex-direction:column; justify-content:center; background:var(--coal); }
.feature__body h2{ font-family:var(--cond); font-weight:700; text-transform:uppercase; font-size:clamp(1.6rem,3vw,2.4rem); margin:.5rem 0 1rem; }

/* =========================================================
   CONTACT
   ========================================================= */
.contact-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4.5rem); align-items:start; }
.info-row{ display:flex; gap:1.1rem; align-items:flex-start; padding:1.2rem 0; border-bottom:1px solid var(--line); }
.info-row .ic{ flex:0 0 auto; width:46px; height:46px; border-radius:50%; background:rgba(226,35,26,.14); color:var(--red); display:grid; place-items:center; }
.info-row b{ font-family:var(--cond); letter-spacing:.14em; text-transform:uppercase; font-size:.7rem; color:var(--gold); }
.info-row a,.info-row p{ margin:.2rem 0 0; font-size:1.05rem; }
.socials{ display:flex; gap:.7rem; margin-top:1.6rem; }
.socials a{ width:46px; height:46px; border:1px solid var(--line); border-radius:50%; display:grid; place-items:center;
  transition:background .4s, color .4s, transform .4s; }
.socials a:hover{ background:var(--red); color:#fff; transform:translateY(-3px); border-color:var(--red); }
.form{ background:var(--coal); border:1px solid var(--line); border-radius:8px; padding:clamp(1.6rem,3vw,2.6rem); }
.field{ margin-bottom:1.3rem; }
.field label{ font-family:var(--cond); letter-spacing:.12em; text-transform:uppercase; font-size:.7rem; color:var(--muted); display:block; margin-bottom:.5rem; }
.field input,.field select,.field textarea{ width:100%; font-family:var(--body); font-size:.98rem; color:var(--bone);
  background:var(--black-2); border:1px solid var(--line); border-radius:4px; padding:.9em 1em; transition:border-color .3s, box-shadow .3s; }
.field textarea{ min-height:140px; resize:vertical; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(205,163,73,.18); }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; }
.consent{ display:flex; gap:.7rem; align-items:flex-start; font-size:.82rem; color:var(--muted); }
.consent input{ margin-top:.25rem; accent-color:var(--red); }
.form-success{ display:none; padding:1.1rem 1.2rem; background:rgba(205,163,73,.12); border:1px solid var(--line-gold); border-radius:6px; color:var(--gold-light); }
.form-success.show{ display:block; }

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{ width:100%; max-width:none; background:var(--black-2); border-top:1px solid var(--line); padding-top:clamp(60px,8vw,100px); }
.site-footer > .container{ width:min(100%,1460px); max-width:1460px; margin-inline:auto; padding-inline:var(--gutter); box-sizing:border-box; }
.footer-top{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1.2fr; gap:clamp(1.6rem,3vw,3rem); padding-bottom:clamp(40px,6vw,70px); border-bottom:1px solid var(--line); }
.footer-brand img{ width:160px; margin-bottom:1rem; }
.footer-brand p{ font-size:.9rem; color:var(--muted); max-width:34ch; }
.footer-col h4{ font-family:var(--cond); letter-spacing:.16em; text-transform:uppercase; font-size:.74rem; color:var(--gold); margin-bottom:1.1rem; }
.footer-col a{ display:block; font-size:.92rem; color:var(--muted); padding:.3em 0; transition:color .3s; }
.footer-col a:hover{ color:var(--gold-light); }
.footer-bottom{ display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; padding-block:1.8rem; font-size:.78rem; color:var(--muted); }

/* back to top */
.totop{ position:fixed; right:22px; bottom:22px; z-index:1500; width:52px; height:52px; border-radius:50%;
  background:var(--red); color:#fff; display:grid; place-items:center; opacity:0; transform:translateY(20px) scale(.8);
  transition:opacity .4s var(--ease), transform .4s var(--ease); box-shadow:0 14px 30px -10px rgba(226,35,26,.6); }
.totop.show{ opacity:1; transform:translateY(0) scale(1); }
.totop:hover{ background:var(--gold); color:var(--black); }

/* reveals */
[data-reveal],[data-split-lines]{ will-change:transform,opacity; }

/* =========================================================
   SHOWCASE SECTIONS
   ========================================================= */
/* word-by-word highlight scrub */
.hl-block{ padding-block:clamp(80px,14vw,200px); }
[data-highlight]{ font-family:var(--display); text-transform:uppercase; line-height:1.02;
  font-size:clamp(2.1rem,6.4vw,6rem); max-width:18ch; }
[data-highlight] .hl-word{ display:inline-block; }
[data-highlight] .red{ color:var(--red); }
[data-highlight] .gold{ color:var(--gold); }

/* full-bleed parallax feature */
.pfeature{ position:relative; min-height:100svh; display:flex; align-items:center; overflow:hidden; }
.pfeature__bg{ position:absolute; inset:0; z-index:0; }
.pfeature__bg img{ position:absolute; top:-12%; left:0; width:100%; height:124%; object-fit:cover; }
.pfeature__bg::after{ content:""; position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(8,8,10,.94) 0%, rgba(8,8,10,.55) 45%, rgba(8,8,10,.15) 100%); }
.pfeature__card{ position:relative; z-index:1; max-width:600px; }

/* pinned horizontal gallery */
.hsection{ position:relative; height:100svh; overflow:hidden; background:var(--black-2); }
.htrack{ display:flex; height:100%; align-items:center; gap:clamp(1rem,2.4vw,2rem);
  width:max-content; padding-inline:var(--gutter); will-change:transform; }
.hintro{ flex:0 0 auto; width:min(44vw,520px); padding-right:2rem; }
.hpanel{ position:relative; flex:0 0 auto; width:min(48vw,560px); height:72vh; overflow:hidden; border-radius:6px;
  border:1px solid var(--line); }
.hpanel img{ width:114%; height:100%; object-fit:cover; margin-left:-7%; will-change:transform; }
.hpanel::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 45%, rgba(8,8,10,.9)); }
.hpanel__cap{ position:absolute; left:1.5rem; bottom:1.3rem; z-index:2; }
.hpanel__cap b{ font-family:var(--display); text-transform:uppercase; font-size:1.7rem; display:block; }
.hpanel__cap span{ font-family:var(--cond); letter-spacing:.18em; text-transform:uppercase; font-size:.7rem; color:var(--gold); }
.hprogress{ position:absolute; left:var(--gutter); bottom:32px; z-index:3; font-family:var(--cond); letter-spacing:.3em;
  text-transform:uppercase; font-size:.66rem; color:var(--muted); }

/* clip-path image reveal */
.clipwrap{ position:relative; overflow:hidden; border-radius:10px; aspect-ratio:16/9; will-change:clip-path; }
@media (max-width:700px){ .clipwrap{ aspect-ratio:4/5; } }
.clipwrap img{ width:100%; height:100%; object-fit:cover; }
.clipwrap::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(8,8,10,.3),rgba(8,8,10,.7)); }
.clipwrap .ctitle{ position:absolute; inset:0; z-index:2; display:grid; place-items:center; text-align:center; padding:1rem; }
.clipwrap .ctitle h2{ font-size:clamp(2.2rem,8vw,6.5rem); line-height:.9; text-shadow:0 12px 50px rgba(0,0,0,.7); }
.clipwrap .ctitle .red{ color:var(--red); }

/* sticky stacking cards */
.stack{ position:relative; }
.stack-card{ background:var(--coal); border:1px solid var(--line-gold); border-radius:12px;
  padding:clamp(1.8rem,4vw,3.6rem); margin-bottom:2.4rem; box-shadow:0 -20px 60px -30px rgba(0,0,0,.9);
  display:grid; grid-template-columns:auto 1fr auto; gap:clamp(1rem,3vw,2.6rem); align-items:center; }
.stack-card:last-child{ margin-bottom:0; }
.stack-card .sc-num{ font-family:var(--display); font-size:clamp(2.4rem,5vw,4rem); color:var(--red); line-height:1; }
.stack-card h3{ font-family:var(--cond); font-weight:700; text-transform:uppercase; font-size:clamp(1.4rem,3vw,2.2rem); }
.stack-card p{ margin:.5rem 0 0; color:var(--muted); font-size:.95rem; max-width:48ch; }
.stack-card .sc-ico{ width:56px; height:56px; color:var(--gold); }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1024px){
  .stats{ grid-template-columns:repeat(2,1fr); }
  .stat:nth-child(2){ border-right:none; }
  .footer-top{ grid-template-columns:1fr 1fr; }
  .feature{ grid-template-columns:1fr; }
}
/* showcase stacked fallback (mobile / reduced) */
.hsection--stacked{ height:auto; padding-block:clamp(60px,10vw,100px); }
.hsection--stacked .htrack{ flex-direction:column; width:100%; transform:none !important; }
.hsection--stacked .hintro{ width:100%; padding:0 0 1rem; }
.hsection--stacked .hpanel{ width:100%; height:54vh; }

@media (max-width:860px){
  :root{ --header-h:78px; }
  .nav__links, .nav__cta{ display:none; }
  .burger{ display:block; }
  .split,.contact-grid,.book,.book--rev .book__cover{ grid-template-columns:1fr; }
  .stack-card{ grid-template-columns:auto 1fr; }
  .stack-card .sc-ico{ display:none; }
  .pfeature__bg::after{ background:linear-gradient(180deg,rgba(8,8,10,.6),rgba(8,8,10,.92)); }
  .book--rev .book__cover{ order:0; }
  .split--rev .split__media{ order:0; }
  .split__media img{ aspect-ratio:4/3; }
}
@media (max-width:560px){
  .stats{ grid-template-columns:1fr; } .stat{ border-right:none; }
  .footer-top{ grid-template-columns:1fr; } .field-row{ grid-template-columns:1fr; }
  .hero__scroll{ display:none; }
}
/* =========================================================
   FACE-SAFE CROPPING — per photo, so the face stays in frame
   wherever the image is used (hero, panels, cards, clips).
   ========================================================= */
img[src*="hero-studio"]      { object-position: 32% 30% !important; }
img[src*="portrait-ufc"]     { object-position: center 16% !important; }
img[src*="radio-marca"]      { object-position: center 16% !important; }
img[src*="eurosport-portrait"]{ object-position: center 18% !important; }
img[src*="eurosport-set"]    { object-position: center 30% !important; }
img[src*="studio-2"]         { object-position: center 20% !important; }
img[src*="studio-interview"] { object-position: center 50% !important; }
img[src*="collage"]          { object-position: center 35% !important; }
img[src*="bookfair-1"]       { object-position: center 30% !important; }
img[src*="bookfair-2"]       { object-position: center 26% !important; }
img[src*="bookfair-3"]       { object-position: center 30% !important; }

@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; transition-duration:.01ms !important; }
}
