/* ============================================================
   ALAN MANSUR — Premium Political Website
   Tech: HTML · CSS · JS · GSAP · Swiper · Lenis
   ============================================================ */

/* ---------- TOKENS ---------- */
:root{
  --violet:#8a00ff;
  --violet-2:#7608ed;
  --violet-deep:#5d05bf;
  --violet-light:#a85cff;
  --magenta:#b03cff;
  --cyan:#00c6ff;
  --cyan-2:#04abf0;
  --hero-cyan:#05b0ed;
  --blue:#0e7fd8;
  --blue-deep:#0a4ea0;
  --navy:#062a52;
  --lav-1:#f3ecfc;
  --lav-2:#e7d7f8;
  --lav-3:#dcc6f4;
  --ink:#1f1140;
  --ink-soft:#4b3a6b;
  --white:#ffffff;

  --maxw:1280px;
  --gutter:clamp(20px,5vw,80px);
  --radius:22px;
  --radius-lg:30px;

  --font-display:"Sora",system-ui,sans-serif;
  --font-body:"Manrope",system-ui,sans-serif;

  --ease:cubic-bezier(.22,1,.36,1);
  --ease-soft:cubic-bezier(.4,0,.2,1);

  --shadow-soft:0 18px 40px -18px rgba(40,8,90,.45);
  --shadow-card:0 30px 60px -25px rgba(30,5,70,.55);
}

/* ---------- RESET ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--violet-deep);
  color:var(--white);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font-family:inherit;border:0;background:none;cursor:pointer;color:inherit}
section{position:relative}
em{font-style:normal}

/* Lenis */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-stopped{overflow:hidden}

::selection{background:var(--cyan);color:var(--ink)}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
}

.eyebrow{
  display:inline-block;font-family:var(--font-display);font-weight:700;
  letter-spacing:.28em;text-transform:uppercase;font-size:clamp(11px,1vw,13px);
  color:var(--cyan);
}

/* ============================================================
   PRELOADER
   ============================================================ */
.preloader{
  position:fixed;inset:0;z-index:9999;display:grid;place-items:center;
  background:linear-gradient(160deg,#7a14d8,#5d05bf);
  transition:opacity .7s var(--ease),visibility .7s;
}
.preloader.is-done{opacity:0;visibility:hidden}
.preloader__inner{display:flex;flex-direction:column;align-items:center;gap:26px}
.preloader__logo{width:150px;filter:drop-shadow(0 8px 20px rgba(0,0,0,.3));animation:pulse 1.6s var(--ease-soft) infinite}
.preloader__bar{width:160px;height:3px;border-radius:99px;background:rgba(255,255,255,.2);overflow:hidden}
.preloader__bar span{display:block;height:100%;width:40%;border-radius:99px;background:var(--cyan);
  animation:loadbar 1.2s var(--ease-soft) infinite}
@keyframes loadbar{0%{transform:translateX(-120%)}100%{transform:translateX(360%)}}
@keyframes pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(.94);opacity:.7}}

/* ============================================================
   HEADER
   ============================================================ */
.header{
  position:fixed;top:0;left:0;width:100%;z-index:900;
  transition:background .45s var(--ease),backdrop-filter .45s,box-shadow .45s,transform .5s var(--ease);
}
.header.is-scrolled{
  background:rgba(48,8,110,.55);
  backdrop-filter:blur(16px) saturate(140%);
  -webkit-backdrop-filter:blur(16px) saturate(140%);
  box-shadow:0 1px 0 rgba(255,255,255,.06),0 12px 30px -20px rgba(0,0,0,.6);
}
.header.is-hidden{transform:translateY(-100%)}
.header__inner{
  position:relative;max-width:none;margin:0 auto;padding:clamp(14px,1.6vw,22px) clamp(20px,3vw,52px);
  display:flex;align-items:center;justify-content:space-between;gap:30px;
}
/* only the nav buttons are centered; logo stays pinned to the left */
.nav{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:max-content}
.nav__list{flex-wrap:nowrap;white-space:nowrap}
.header__logo img{width:clamp(120px,9vw,160px);transition:transform .4s var(--ease),filter .4s}
.header__logo:hover img{transform:scale(1.05);filter:drop-shadow(0 6px 16px rgba(0,200,255,.4))}

.nav__list{display:flex;align-items:center;gap:clamp(16px,2vw,34px)}
.nav__link{
  position:relative;font-family:var(--font-display);font-weight:600;font-size:clamp(12px,.92vw,14.5px);
  letter-spacing:.07em;text-transform:uppercase;color:rgba(255,255,255,.88);padding:6px 0;transition:color .3s;
}
.nav__link::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:100%;
  background:linear-gradient(90deg,var(--cyan),var(--violet-light));
  transform:scaleX(0);transform-origin:right;transition:transform .45s var(--ease);border-radius:2px;
}
.nav__link:hover{color:#fff}
.nav__link:hover::after,.nav__link.is-active::after{transform:scaleX(1);transform-origin:left}

.burger{display:none;width:46px;height:46px;border-radius:50%;position:relative;
  background:rgba(255,255,255,.1);backdrop-filter:blur(8px);transition:background .3s}
.burger span{position:absolute;left:50%;top:50%;width:20px;height:2px;background:#fff;border-radius:2px;
  transform:translate(-50%,-50%);transition:.4s var(--ease)}
.burger span:nth-child(1){transform:translate(-50%,-7px)}
.burger span:nth-child(3){transform:translate(-50%,5px)}
.burger.is-open span:nth-child(1){transform:translate(-50%,-50%) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0}
.burger.is-open span:nth-child(3){transform:translate(-50%,-50%) rotate(-45deg)}

/* MOBILE MENU */
.mobile-menu{
  position:fixed;inset:0;z-index:880;background:linear-gradient(165deg,#7a14d8,#4f06a8);
  display:flex;flex-direction:column;justify-content:center;gap:8px;padding:0 var(--gutter);
  clip-path:circle(0% at 100% 0);transition:clip-path .7s var(--ease);visibility:hidden;
}
.mobile-menu.is-open{clip-path:circle(150% at 100% 0);visibility:visible}
.mobile-menu__link{
  font-family:var(--font-display);font-weight:700;font-size:clamp(28px,7vw,46px);
  color:#fff;padding:8px 0;opacity:0;transform:translateY(20px);transition:.5s var(--ease);
}
.mobile-menu.is-open .mobile-menu__link{opacity:1;transform:none}
.mobile-menu.is-open .mobile-menu__link:nth-child(1){transition-delay:.1s}
.mobile-menu.is-open .mobile-menu__link:nth-child(2){transition-delay:.16s}
.mobile-menu.is-open .mobile-menu__link:nth-child(3){transition-delay:.22s}
.mobile-menu.is-open .mobile-menu__link:nth-child(4){transition-delay:.28s}
.mobile-menu.is-open .mobile-menu__link:nth-child(5){transition-delay:.34s}
.mobile-menu.is-open .mobile-menu__link:nth-child(6){transition-delay:.4s}
.mobile-menu.is-open .mobile-menu__link:nth-child(7){transition-delay:.46s}
.mobile-menu__link:active{color:var(--cyan)}
.mobile-menu__socials{display:flex;gap:24px;margin-top:34px}
.mobile-menu__socials a{font-family:var(--font-display);font-weight:600;color:rgba(255,255,255,.8);letter-spacing:.05em}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;overflow:hidden;
  background:
    url("../assets/hero-hero-bg.webp") center/cover no-repeat,
    linear-gradient(178deg,#9a30f2 0%,#8a20ea 38%,#7d18df 68%,#6f12d4 100%);
}
.hero__glow{position:absolute;border-radius:50%;filter:blur(90px);opacity:.5;z-index:0;pointer-events:none}
.hero__glow--1{width:520px;height:520px;background:#c869ff;top:-140px;left:-60px}
.hero__glow--2{width:520px;height:520px;background:var(--cyan);bottom:6%;right:-120px;opacity:.28}

/* The hero behaves like a faithful poster canvas (PSD = 1920 x 1154) */
.hero__canvas{
  position:relative;width:100%;aspect-ratio:1920/1152;margin-inline:auto;
  z-index:1;overflow:hidden;
}
/* watermark hidden — the hero BG asset already includes it */
.hero__watermark{display:none}
.hero__title{position:absolute;left:15.36%;top:13.7%;width:69.7%;margin:0;z-index:2}
.hero__title img{width:100%;filter:drop-shadow(0 16px 34px rgba(30,0,70,.35))}
/* single combined element: Alan + city + cyan mountains (matches the PSD export) */
.hero__figure{
  position:absolute;left:0;top:24.65%;width:100%;z-index:4;pointer-events:none;
  filter:drop-shadow(0 24px 42px rgba(20,0,60,.38));
}
/* Cyan band at the hero bottom carrying the EXACT same Quem Sou texture.
   background-attachment:fixed anchors the bg image to the viewport (not the
   element), so the texture continues seamlessly between hero and Quem Sou. */
.hero__base{
  position:absolute;left:0;bottom:-1px;width:100%;height:13%;z-index:5;pointer-events:none;
  background:
    url("../assets/quemsou-quem-sou-bg.webp") center center/cover no-repeat fixed,
    var(--hero-cyan);
}
.hero__scroll{
  position:absolute;bottom:22px;left:50%;transform:translateX(-50%);z-index:6;
  display:flex;flex-direction:column;align-items:center;gap:10px;
}
.hero__scroll-dot{width:24px;height:40px;border:2px solid rgba(255,255,255,.6);border-radius:99px;position:relative}
.hero__scroll-dot::after{content:"";position:absolute;top:7px;left:50%;width:4px;height:8px;border-radius:99px;
  background:#fff;transform:translateX(-50%);animation:scrolldot 1.6s var(--ease-soft) infinite}
@keyframes scrolldot{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}100%{opacity:0;transform:translate(-50%,14px)}}
.hero__scroll-label{font-family:var(--font-display);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.7)}

/* ============================================================
   QUEM SOU
   ============================================================ */
.quem{
  padding:clamp(70px,9vh,130px) 0 clamp(70px,10vh,140px);
  background:
    url("../assets/quemsou-quem-sou-bg.webp") center center/cover no-repeat fixed,
    var(--hero-cyan);
}
/* fixed attachment is unreliable / heavy on mobile — fall back to scroll */
@media (max-width:820px),(hover:none){
  .hero__base,.quem{background-attachment:scroll}
}
.quem__inner{
  max-width:1560px;margin:0 auto;padding:0 var(--gutter);
  display:grid;grid-template-columns:0.92fr 1.08fr;gap:clamp(24px,3vw,56px);align-items:center;
}

/* Left media composition — faithful PSD canvas (840 x 1040), elements placed by exact % */
.quem__media{position:relative;width:100%;aspect-ratio:840/1040}
.qd{position:absolute;pointer-events:none}
.qd--photo{left:9.52%;top:7.98%;width:83.8%;z-index:1;pointer-events:auto;
  transition:transform .6s var(--ease);will-change:transform;
  filter:drop-shadow(0 24px 40px rgba(4,40,80,.4))}
.qd--photo:hover{transform:translateY(-12px) scale(1.015)}
.qd--neto{left:4.29%;top:4.62%;width:21.7%;z-index:3}
.qd--pescador{left:2.98%;top:10.4%;width:28.6%;z-index:3}
.qd--cria{left:75.7%;top:0.87%;width:20.6%;z-index:3}
.qd--barra{left:69.0%;top:8.17%;width:28.3%;z-index:3}
.qd--arrow-top{left:21.9%;top:20.4%;width:8.0%;z-index:2;opacity:.92}
.qd--arrow-right{left:17.3%;top:22.0%;width:8.6%;z-index:2;opacity:.92}
.qd--arrow-left{left:82.0%;top:22.2%;width:11.5%;z-index:2;opacity:.92}
.qd--wave{left:71.5%;top:19.7%;width:13.5%;z-index:2;opacity:.9}
.qd--boat{left:1.9%;top:28.2%;width:12.5%;z-index:2}
.qd--grid{left:5.2%;top:82.0%;width:3.6%;z-index:2}
.qd--pai{left:3.9%;top:50.96%;width:6.8%;z-index:3}
.qd--marido{left:88.6%;top:45.4%;width:9.6%;z-index:3}
.qd--obras{left:60.95%;top:74.9%;width:34.6%;z-index:4;filter:drop-shadow(var(--shadow-soft))}
.qd--atos{left:61.8%;top:81.2%;width:34.2%;z-index:4;filter:drop-shadow(var(--shadow-soft))}

.quem__text{display:flex;flex-direction:column;align-items:flex-start;gap:clamp(12px,1.6vw,22px)}
.quem__prazer{width:clamp(190px,24vw,340px)}
.quem__name{width:100%;max-width:760px;margin-top:-4px}
.quem__bio{width:100%;max-width:740px;margin-top:10px}

/* ============================================================
   MEU TRABALHO (slider)
   ============================================================ */
.work{
  padding:clamp(80px,11vh,150px) 0;
  background:
    url("../assets/trabalho-meu-trabalho-bg.webp") center/cover no-repeat,
    linear-gradient(180deg,#f8f7fb 0%,#ece0f8 50%,#d2b2f4 100%);
}
.work__head{max-width:var(--maxw);margin:0 auto clamp(36px,4vw,56px);padding:0 var(--gutter);text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:18px}
.work__title{width:min(900px,90%)}
.work__desc{width:min(820px,92%)}
.work__slider{max-width:1440px;margin:0 auto;padding:0 calc(var(--gutter) + 30px);position:relative}
.work .swiper{padding:24px 0 52px;overflow:hidden}
.swiper-slide{height:auto;display:flex}
.work-card{
  width:100%;transition:transform .55s var(--ease);will-change:transform;
}
.work-card img{width:100%}
.work-card:hover{transform:translateY(-12px) scale(1.015)}
.work__arrow{
  position:absolute;top:50%;transform:translateY(-50%);z-index:10;
  width:clamp(48px,4vw,64px);height:clamp(48px,4vw,64px);border-radius:50%;
  background:var(--violet);display:grid;place-items:center;
  box-shadow:0 16px 30px -12px rgba(90,5,190,.7);transition:transform .35s var(--ease),background .35s;
}
.work__arrow img{width:42%}
.work__arrow:hover{transform:translateY(-50%) scale(1.12);background:var(--violet-light)}
.work__arrow--prev{left:calc(var(--gutter) - 18px)}
.work__arrow--next{right:calc(var(--gutter) - 18px)}
.work__arrow.swiper-button-disabled{opacity:.35;pointer-events:none}
.work__progress{max-width:240px;height:4px;margin:26px auto 0;background:rgba(122,20,216,.18);border-radius:99px;overflow:hidden}
.work__progress span{display:block;height:100%;width:33%;background:linear-gradient(90deg,var(--violet),var(--cyan));border-radius:99px;transition:.4s var(--ease)}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{
  overflow:hidden;padding:clamp(14px,1.6vw,22px) 0;
  position:relative;display:flex;
  background:url("../assets/marquee1-marquee-bg.webp") center/cover no-repeat,var(--violet);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12),inset 0 -1px 0 rgba(0,0,0,.12);
}
.marquee--alt{background:url("../assets/marquee2-marquee-bg.webp") center/cover no-repeat,linear-gradient(90deg,#7608ed,#9526f5)}
.marquee__track{display:flex;flex-shrink:0;will-change:transform}
.marquee__group{display:flex;align-items:center;flex-shrink:0}
.marquee__group img{height:clamp(26px,3vw,46px);width:auto;margin:0 clamp(20px,2.4vw,40px)}
.marquee__dot{width:clamp(8px,.9vw,12px);height:clamp(8px,.9vw,12px);border-radius:50%;background:#fff;flex-shrink:0;opacity:.9}

/* ============================================================
   VISÃO E VALORES
   ============================================================ */
.vision{
  padding:clamp(80px,12vh,160px) 0;
  background:
    url("../assets/visao-visao-valores-bg.webp") center/cover no-repeat,
    linear-gradient(180deg,#f3ecfc 0%,#ece0f8 100%);
}
.vision__inner{max-width:1500px;margin:0 auto;padding:0 var(--gutter);
  display:grid;grid-template-columns:0.92fr 1.08fr;gap:clamp(24px,3vw,56px);align-items:center}
.vision__text{display:flex;flex-direction:column;align-items:flex-start;gap:clamp(14px,1.9vw,26px)}
.vision__title{width:min(100%,660px)}
.vision__desc{width:min(100%,620px)}
.vision__highlight{width:min(100%,680px)}
.vision__support{width:min(100%,660px)}
/* polaroid cluster — exact PSD overlap, no frame/shadow/hover (assets are pre-framed) */
.vision__gallery{position:relative;width:100%;aspect-ratio:900/1000;max-width:620px;margin-inline:auto}
.vp{position:absolute}
.vp--2{left:40%;top:0;width:56%;z-index:2}
.vp--3{left:0;top:19%;width:58%;z-index:1}
.vp--1{left:30%;top:40%;width:56%;z-index:3}

/* shared polaroid frame (used by Trajetória) */
.polaroid{
  border-radius:6px;overflow:hidden;background:#fff;padding:0;
  box-shadow:0 30px 55px -22px rgba(40,8,90,.55);
  transition:transform .55s var(--ease),box-shadow .55s;will-change:transform;
}
.polaroid img{width:100%;border-radius:4px}

/* ============================================================
   TRAJETÓRIA (timeline)
   ============================================================ */
.timeline{
  padding:clamp(80px,12vh,160px) 0 clamp(90px,12vh,170px);
  background:
    url("../assets/trajetoria-trajetoria-bg.webp") center/cover no-repeat,
    linear-gradient(180deg,#9a3cf2 0%,#7d12e3 45%,#6a0fd2 100%);
}
/* faithful PSD canvas (1920 x 2233): polaroids stacked left, line+dots centre, year cards alternating */
.timeline__canvas{position:relative;width:calc(100% - 40px);max-width:1500px;margin:0 auto;aspect-ratio:1920/2233}
.tj{position:absolute}
.tj--line{left:66.6%;top:12.4%;width:1.35%;height:73%;z-index:1}
.tj--c2016{left:42.7%;top:11.9%;width:20.6%;z-index:2}
.tj--c2020{left:72.0%;top:27.3%;width:20.5%;z-index:2}
.tj--c2024{left:42.5%;top:43.1%;width:20.8%;z-index:2}
.tj--c2025{left:72.0%;top:58.8%;width:20.2%;z-index:2}
.tj--c2026{left:42.7%;top:76.9%;width:20.2%;z-index:2}
.tj--p1{left:7.8%;top:9.4%;width:23.2%;z-index:3}
.tj--p2{left:9.8%;top:27.2%;width:24.9%;z-index:5}
.tj--p3{left:5.7%;top:47.8%;width:23.6%;z-index:4}
.tj--p4{left:8.6%;top:66.5%;width:23.3%;z-index:6}

/* ============================================================
   PRÉ-CANDIDATO
   ============================================================ */
.candidate{
  padding:clamp(70px,10vh,130px) 0 0;overflow:visible;position:relative;
  background:
    url("../assets/precand-pre-candidato-bg.webp") center/cover no-repeat,
    linear-gradient(180deg,#f5eefc 0%,#efe4f9 100%);
}
.candidate__glow{position:absolute;width:680px;height:680px;border-radius:50%;
  right:-6%;top:46%;transform:translateY(-50%);filter:blur(20px);z-index:0;
  background:radial-gradient(circle, rgba(138,0,255,.22), transparent 62%)}
.candidate__inner{max-width:1520px;margin:0 auto;padding:0 var(--gutter);position:relative;z-index:2;
  display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(20px,3vw,56px);align-items:start}
.candidate__text{display:flex;flex-direction:column;align-items:flex-start;gap:clamp(14px,1.8vw,24px);
  padding-top:clamp(10px,3vh,48px);padding-bottom:clamp(160px,20vh,300px)}
.candidate__eyebrow{width:min(360px,78%)}
.candidate__title{width:min(560px,92%)}
.candidate__desc{width:min(540px,92%)}
.candidate__media{display:flex;justify-content:flex-end;align-items:flex-end;position:relative}
.candidate__photo{width:clamp(320px,42vw,560px);position:relative;
  margin-bottom:clamp(-180px,-9vw,-90px);filter:drop-shadow(0 30px 50px rgba(60,10,120,.35))}

/* ============================================================
   FIQUE POR DENTRO (news)
   ============================================================ */
.news{
  position:relative;z-index:2;
  margin-top:clamp(-150px,-7.5vw,-80px);
  padding:clamp(200px,18vh,300px) 0 clamp(70px,9vh,120px);
  background:
    linear-gradient(180deg,rgba(127,13,229,.35),rgba(181,116,252,.35)),
    url("../assets/fique-fique-por-dentro-bg.webp") center/cover no-repeat,
    linear-gradient(180deg,#7f0de5 0%,#9636f3 52%,#b574fc 100%);
}
.news__head{max-width:var(--maxw);margin:0 auto clamp(36px,4vw,56px);padding:0 var(--gutter);text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:16px}
.news__title{width:min(560px,80%)}
.news__desc{width:min(880px,94%)}
.news__grid{max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter);
  display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,1.6vw,26px)}
.reel{
  position:relative;border-radius:20px;overflow:hidden;
  background:linear-gradient(160deg,#3a1668,#6a17bd);
  min-height:480px;box-shadow:var(--shadow-card);transition:transform .5s var(--ease),box-shadow .5s;
  display:flex;align-items:stretch;
}
.reel:hover{transform:translateY(-10px);box-shadow:0 44px 70px -28px rgba(20,0,60,.7)}
.reel .instagram-media{margin:0!important;min-width:auto!important;width:100%!important;border:0!important;
  box-shadow:none!important;background:transparent!important;position:relative;z-index:2}
.reel iframe{background:#fff!important;border-radius:20px}
.reel__video{position:relative;z-index:2;width:100%;height:100%;object-fit:cover;border-radius:20px;display:block}
.reel__fallback{
  position:absolute;inset:0;z-index:1;display:flex;flex-direction:column;gap:16px;
  align-items:center;justify-content:center;text-align:center;padding:24px;
  font-family:var(--font-display);font-weight:600;font-size:15px;color:#fff;
  background:radial-gradient(circle at 50% 38%,rgba(255,255,255,.12),transparent 60%);
}
.reel__fallback::before{
  content:"";width:64px;height:64px;border-radius:50%;
  background:rgba(255,255,255,.16) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M8 5v14l11-7z'/%3E%3C/svg%3E") no-repeat center/26px;
  border:2px solid rgba(255,255,255,.35);transition:transform .4s var(--ease);
}
.reel:hover .reel__fallback::before{transform:scale(1.12)}

/* Play / Instagram badge over each reel (always visible so users know it's
   clickable; sits over the video and goes to Instagram on click). */
.reel::after{
  content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:72px;height:72px;border-radius:50%;z-index:5;pointer-events:none;
  background:rgba(255,255,255,.22) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M8 5v14l11-7z'/%3E%3C/svg%3E") no-repeat center/28px;
  border:2px solid rgba(255,255,255,.65);backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  box-shadow:0 12px 30px -10px rgba(0,0,0,.5);
  transition:transform .4s var(--ease),background-color .3s;
  animation:reelPulse 2.4s var(--ease-soft) infinite;
}
.reel:hover::after{transform:translate(-50%,-50%) scale(1.15);background-color:rgba(255,255,255,.32)}
.reel__badge{
  position:absolute;bottom:14px;right:14px;z-index:5;pointer-events:none;
  display:flex;align-items:center;gap:6px;
  padding:6px 11px;border-radius:99px;
  background:rgba(0,0,0,.55);backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  color:#fff;font-family:var(--font-display);font-weight:600;font-size:11px;
  letter-spacing:.04em;
}
.reel__badge::before{
  content:"";width:14px;height:14px;border-radius:4px;
  background:linear-gradient(45deg,#f58529,#dd2a7b 50%,#8134af 75%,#515bd4);
}
@keyframes reelPulse{
  0%,100%{box-shadow:0 0 0 0 rgba(255,255,255,.45),0 12px 30px -10px rgba(0,0,0,.5)}
  60%{box-shadow:0 0 0 18px rgba(255,255,255,0),0 12px 30px -10px rgba(0,0,0,.5)}
}
.news__cta{text-align:center;margin-top:clamp(40px,5vw,64px)}
.btn-veja{display:inline-block;transition:transform .4s var(--ease),filter .4s}
.btn-veja img{width:clamp(280px,30vw,460px)}
.btn-veja:hover{transform:translateY(-4px) scale(1.03);filter:drop-shadow(0 14px 26px rgba(0,160,255,.5))}
.news__socials{display:flex;justify-content:center;flex-wrap:wrap;gap:clamp(14px,1.6vw,26px);margin-top:clamp(34px,4vw,52px)}
.social-ic{transition:transform .4s var(--ease)}
.social-ic img{width:clamp(46px,4.4vw,62px);filter:drop-shadow(0 10px 18px rgba(0,0,0,.25))}
.social-ic:hover{transform:translateY(-8px) scale(1.12) rotate(-4deg)}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{
  background:var(--white);color:var(--ink);position:relative;
  padding:clamp(70px,9vh,120px) 0 0;
}
.footer::before{content:"";position:absolute;top:-1px;left:0;width:100%;height:60px;
  background:linear-gradient(180deg,#8a2bf2,transparent);opacity:.18}
.footer__inner{max-width:1700px;margin:0 auto;padding:0 clamp(20px,3vw,56px);
  display:flex;justify-content:space-between;align-items:flex-start;gap:clamp(30px,4vw,60px)}
.footer__brand{flex:0 1 520px}
.footer__cols{display:flex;gap:clamp(70px,7vw,180px);flex-shrink:0}
.footer__logo{width:clamp(150px,12vw,190px)}
.footer__desc{margin-top:20px;max-width:420px;color:var(--ink-soft);font-size:clamp(14px,1vw,16px)}
.footer__col-title{font-family:var(--font-display);font-weight:700;color:var(--cyan-2);
  text-transform:uppercase;letter-spacing:.1em;font-size:14px;margin-bottom:18px}
.footer__col ul{display:flex;flex-direction:column;gap:11px}
.footer__col a{color:var(--ink-soft);font-weight:500;font-size:clamp(14px,1vw,15.5px);
  position:relative;transition:color .3s,padding-left .3s}
.footer__col a::before{content:"";position:absolute;left:-14px;top:50%;width:6px;height:6px;border-radius:50%;
  background:var(--violet);transform:translateY(-50%) scale(0);transition:transform .3s var(--ease)}
.footer__col a:hover{color:var(--violet);padding-left:14px}
.footer__col a:hover::before{transform:translateY(-50%) scale(1)}
.footer__bottom{max-width:1700px;margin:clamp(50px,6vw,80px) auto 0;padding:26px clamp(20px,3vw,56px);
  border-top:1px solid rgba(31,17,64,.12);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  color:var(--ink-soft);font-size:14px}

/* ============================================================
   REVEAL (GSAP fallback initial states)
   ============================================================ */
[data-reveal]{opacity:0}
.no-js [data-reveal]{opacity:1}

/* ============================================================
   RESPONSIVE
   ============================================================ */
/* ============================================================
   NOTEBOOK
   ============================================================ */
@media (max-width:1280px){
  .news__grid{grid-template-columns:repeat(2,1fr);max-width:820px;margin-left:auto;margin-right:auto}
}

/* ============================================================
   TABLET (≤980)
   ============================================================ */
@media (max-width:980px){
  .nav{display:none}
  .burger{display:block}

  /* Quem Sou stack */
  .quem__inner{grid-template-columns:1fr;gap:clamp(40px,6vw,60px)}
  .quem__text{align-items:center;text-align:center;order:2}
  .quem__media{order:1;max-width:540px;margin:0 auto;width:100%}
  .quem__name{margin-top:0}

  /* Visão stack — text first, polaroids below */
  .vision__inner{grid-template-columns:1fr;gap:40px}
  .vision__text{align-items:center;text-align:center;order:1}
  .vision__gallery{order:2;max-width:440px;margin:0 auto;width:100%}

  /* Pré-candidato stack — photo prominent on top */
  .candidate__inner{grid-template-columns:1fr;gap:24px}
  .candidate__text{align-items:center;text-align:center;order:2;padding-top:0;padding-bottom:clamp(140px,18vh,220px)}
  .candidate__media{order:1;justify-content:center}
  .candidate__photo{margin-bottom:0}
  .candidate__title,.candidate__desc,.candidate__eyebrow{width:min(640px,96%)}

  /* Footer stack */
  .footer__inner{flex-direction:column;align-items:center;text-align:center;gap:40px}
  .footer__brand{flex:initial;max-width:520px}
  .footer__desc{margin-inline:auto}
  .footer__cols{justify-content:center;gap:clamp(48px,10vw,120px)}
}

/* ============================================================
   TIMELINE — vertical stack
   ============================================================ */
@media (max-width:820px){
  .timeline{padding:clamp(60px,9vh,120px) 0 clamp(70px,10vh,130px)}
  .timeline__canvas{
    aspect-ratio:auto;display:flex;flex-direction:column;align-items:center;
    gap:22px;max-width:440px;padding:0 16px;
  }
  .tj{position:static!important;width:100%!important;height:auto!important;max-width:360px}
  .tj--line{display:none}
  /* polaroids slightly larger, year cards full width within container */
  .tj--p1,.tj--p2,.tj--p3,.tj--p4{max-width:300px}
  .tj--p1 img,.tj--p2 img,.tj--p3 img,.tj--p4 img{filter:drop-shadow(0 18px 30px rgba(20,0,60,.35))}
  .tj--c2016,.tj--c2020,.tj--c2024,.tj--c2025,.tj--c2026{max-width:340px}
}

/* ============================================================
   GLOBAL MOBILE BACKGROUND POLISH (≤820)
   Garante que toda seção tenha BG cover, centralizado, sem áreas sem textura.
   ============================================================ */
@media (max-width:820px){
  .hero,.quem,.work,.vision,.timeline,.candidate,.news{
    background-size:cover;background-position:center center;background-repeat:no-repeat;
  }
  /* Hero base seamless cyan strip continues into Quem Sou */
  .hero__base{background-attachment:scroll;background-size:cover;background-position:center}
  /* Marquee thin strips — keep stretched */
  .marquee,.marquee--alt{background-size:cover;background-position:center}
}

/* ============================================================
   MOBILE / PHONES (≤760)
   ============================================================ */
@media (max-width:760px){
  /* Header tighter */
  .header__inner{padding:12px 18px}
  .header__logo img{width:clamp(110px,28vw,140px)}

  /* HERO — portrait composition matching PSD mockup:
     logo + title up top, photo centered with city silhouette around it,
     bold cyan band anchored at the bottom (≈24% of canvas height). */
  .hero__canvas{
    aspect-ratio:auto;min-height:100svh;overflow:hidden;
    display:flex;flex-direction:column;align-items:center;justify-content:flex-start;
    padding-top:11svh;
  }
  .hero__title{
    position:relative;top:auto;left:auto;width:96%;max-width:620px;
    margin:0 auto;z-index:3;flex:0 0 auto;
  }
  .hero__title img{width:100%;height:auto;display:block;filter:drop-shadow(0 14px 28px rgba(20,0,60,.35))}
  .hero__figure{
    position:relative;top:auto;left:auto;bottom:auto;transform:none;
    width:175%;max-width:none;height:auto;
    margin:auto auto 0;align-self:center;
    z-index:4;display:block;flex:0 0 auto;
    filter:drop-shadow(0 18px 30px rgba(20,0,60,.32));
  }
  /* Bigger cyan band — matches the proportion in the PSD mobile reference */
  .hero__base{height:24%;bottom:0}
  /* Hide scroll indicator on mobile — it overlaps the cyan band */
  .hero__scroll{display:none}

  /* QUEM SOU — clean composition, hide cropped edge labels */
  .quem{padding:60px 0 70px}
  .quem__inner{padding:0 18px}
  .quem__media{max-width:360px;padding:0;margin:0 auto}
  /* Hide labels that don't read well at this scale to keep the photo prominent */
  .qd--pai,.qd--marido,.qd--boat,.qd--arrow-left{display:none}
  .qd--cria,.qd--barra{transform:scale(.78);transform-origin:right top}
  .qd--neto,.qd--pescador{transform:scale(.78);transform-origin:left top}
  /* CTA badges (obras / atos) — scale down and keep aligned right-bottom */
  .qd--obras,.qd--atos{transform:scale(.92);transform-origin:right top}
  .quem__text{padding:0 22px;align-items:center;text-align:center}
  .quem__prazer{width:clamp(150px,40vw,220px)}
  .quem__name{width:96%;max-width:380px}
  .quem__bio{width:100%;max-width:420px;margin:0 auto}

  /* MEU TRABALHO */
  .work{padding:70px 0}
  .work__title{max-width:88vw}
  .work__desc{max-width:90vw}
  .work__slider{padding:0 56px}
  .work .swiper{padding:18px 0 32px}
  .work__arrow{width:44px;height:44px}
  .work__arrow--prev{left:8px}
  .work__arrow--next{right:8px}

  /* VISÃO */
  .vision{padding:64px 0 70px}
  .vision__gallery{max-width:340px}

  /* PRÉ-CANDIDATO — keep photo prominent, text below */
  .candidate{padding:60px 0 0}
  .candidate__inner{padding:0 22px}
  .candidate__photo{width:clamp(260px,72vw,360px);margin:0 auto;display:block}
  .candidate__media{justify-content:center}
  .candidate__text{padding:0 6px clamp(120px,16vh,200px);align-items:center;text-align:center}
  .candidate__title,.candidate__desc,.candidate__eyebrow{margin-inline:auto}
  .candidate__glow{width:380px;height:380px;right:-30%}

  /* FIQUE — 2x2 grid (better than 4x1 on mobile) */
  .news{padding:140px 0 70px;margin-top:clamp(-90px,-5vw,-50px)}
  .news__grid{grid-template-columns:repeat(2,1fr);max-width:480px;gap:14px;padding:0 14px}
  .reel{min-height:0;aspect-ratio:9/16}
  .reel::after{width:54px;height:54px;background-size:22px}
  .reel__badge{font-size:9px;padding:4px 8px}
  .reel__badge::before{width:11px;height:11px}
  .news__socials{gap:14px}
  .social-ic img{width:42px}

  /* FOOTER — already stacked at 980, refine spacing */
  .footer{padding:60px 0 0}
  .footer__cols{flex-wrap:wrap;gap:40px 60px;justify-content:center}
  .footer__col{min-width:120px;text-align:left}
  .footer__col-title{text-align:center}
  .footer__col ul{align-items:flex-start}
  .footer__bottom{flex-direction:column;text-align:center;gap:6px;margin-top:40px;padding:22px 18px}

  /* MARQUEE — tighter */
  .marquee__group img{height:22px;margin:0 14px}
  .marquee__dot{width:7px;height:7px}
}

/* ============================================================
   SMALL PHONES (≤420)
   ============================================================ */
@media (max-width:420px){
  .header__inner{padding:10px 14px}
  .hero__canvas{padding-top:10svh}
  .hero__title{width:96%;max-width:520px}
  .hero__figure{width:190%}
  .hero__base{height:25%}
  .qd--grid,.qd--arrow-top,.qd--arrow-right,.qd--wave{display:none}
  .work__slider{padding:0 48px}
  .work__arrow{width:40px;height:40px}
  .news__grid{grid-template-columns:1fr;max-width:340px}
  .reel{aspect-ratio:9/15}
  .vision__gallery{max-width:300px}
  .footer__cols{gap:30px 40px}
}
