/* ===================================================================
   Arena Club 56 — Site Institucional
   Cores oficiais: vermelho #E1222F · navy #1B3A6B · cyan #3FB0E5 · branco
=================================================================== */
:root{
  --red:#E1222F;
  --red-dark:#B5121D;
  --navy:#1B3A6B;
  --navy-deep:#12274A;
  --cyan:#3FB0E5;
  --sky:#DCF1FB;
  --sky-deep:#9FD8F2;
  --sand:#FBF7F0;
  --ink:#16233A;
  --muted:#5C6B82;
  --white:#fff;
  --wa:#25D366;
  --radius:18px;
  --radius-lg:26px;
  --shadow:0 12px 32px rgba(27,58,107,.13);
  --shadow-lg:0 28px 64px rgba(18,39,74,.24);
  --max:1180px;
  --ease:cubic-bezier(.22,1,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);background:var(--white);line-height:1.6;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:'Baloo 2',cursive;line-height:1.1;font-weight:700;text-wrap:balance}
p{text-wrap:pretty}
.container{width:100%;max-width:var(--max);margin:0 auto;padding:0 22px}

.eyebrow{display:inline-block;font-weight:700;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--red);margin-bottom:.6rem}
.section-title{font-size:clamp(1.8rem,4vw,2.8rem);color:var(--navy)}
.head-center{text-align:center;max-width:720px;margin:0 auto 3.2rem}
.head-center.light .section-title,.head-center.light .head-sub{color:#fff}
.head-sub{color:var(--muted);font-size:1.05rem;margin-top:.7rem}
.section{padding:88px 0;position:relative}
.note{margin-top:1.7rem;text-align:center;color:var(--muted);font-size:.96rem}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;justify-content:center;font-weight:700;font-family:'Baloo 2',cursive;font-size:1.02rem;padding:.85rem 1.8rem;border-radius:999px;cursor:pointer;border:2px solid transparent;transition:transform .2s var(--ease),box-shadow .2s var(--ease),background .2s var(--ease);position:relative;overflow:hidden}
.btn:hover{transform:translateY(-3px)}
.btn-primary{background:var(--red);color:#fff;box-shadow:0 10px 24px rgba(225,34,47,.36)}
.btn-primary:hover{background:var(--red-dark);box-shadow:0 14px 30px rgba(225,34,47,.45)}
.btn-primary::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);transform:skewX(-20deg)}
.btn-primary:hover::after{animation:shine .8s ease}
@keyframes shine{to{left:140%}}
.btn-ghost{background:transparent;border-color:var(--navy);color:var(--navy)}
.btn-ghost:hover{background:var(--navy);color:#fff}
.hero .btn-ghost,.dayuse .btn-ghost{color:#fff;border-color:rgba(255,255,255,.55)}
.hero .btn-ghost:hover,.dayuse .btn-ghost:hover{background:#fff;color:var(--navy)}
.btn-wa{display:inline-flex;align-items:center;gap:.45rem;background:var(--wa);color:#fff;font-weight:700;padding:.55rem 1.1rem;border-radius:999px;font-size:.92rem;transition:transform .2s var(--ease),background .2s var(--ease)}
.btn-wa:hover{transform:translateY(-2px);background:#1eb955}
.ico-wa{width:18px;height:18px;fill:currentColor}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:80;background:rgba(255,255,255,.9);backdrop-filter:blur(12px);border-bottom:1px solid rgba(27,58,107,.08)}
.nav-wrap{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:.6rem}
.brand-logo{height:48px;width:auto;transition:transform .3s var(--ease)}
.brand:hover .brand-logo{transform:rotate(-6deg) scale(1.05)}
.brand-name{font-family:'Baloo 2',cursive;font-weight:800;font-size:1.32rem;color:var(--navy)}
.brand-name strong{color:var(--red)}
.brand-name i{color:var(--cyan);font-style:normal;margin-left:2px}
.main-nav{display:flex;align-items:center;gap:1.7rem}
.main-nav a{font-weight:600;color:var(--navy);font-size:.96rem;position:relative}
.main-nav a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:-6px;height:2px;width:0;background:var(--red);transition:width .22s var(--ease)}
.main-nav a:not(.nav-cta):hover::after{width:100%}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.nav-toggle span{width:26px;height:3px;background:var(--navy);border-radius:3px;transition:.25s}
.nav-toggle.open span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:92vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:url('../img/arena.jpg') center/cover no-repeat;transform:scale(1.08)}
@keyframes kenburns{from{transform:scale(1.08) translate(0,0)}to{transform:scale(1.16) translate(-2%,-2%)}}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(115deg,rgba(18,39,74,.93) 0%,rgba(27,58,107,.8) 42%,rgba(63,176,229,.4) 100%)}
.hero-grid{position:relative;z-index:3;display:grid;grid-template-columns:1.25fr .75fr;align-items:center;gap:2rem;padding:80px 22px 130px}
.hero-tag{display:inline-block;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.3);padding:.45rem 1.1rem;border-radius:999px;font-weight:600;font-size:.88rem;margin-bottom:1.4rem;backdrop-filter:blur(4px)}
.hero-title{font-size:clamp(2.1rem,5.2vw,3.9rem);font-weight:800}
.ink-underline{color:var(--sky-deep);position:relative}
.hero-sub{font-size:clamp(1rem,2vw,1.22rem);margin:1.4rem 0 2rem;max-width:600px;color:rgba(255,255,255,.92)}
.hero-actions{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:2.6rem}
.hero-badges{display:flex;flex-wrap:wrap;gap:1.6rem}
.hbadge{display:flex;flex-direction:column;gap:.12rem;padding:.6rem 1rem;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:14px}
.hbadge strong{font-family:'Baloo 2',cursive;font-size:1.3rem}
.hbadge span{font-size:.84rem;color:rgba(255,255,255,.8)}

.hero-mascot{position:relative;display:flex;justify-content:center;align-items:center}
.float-mascot{width:min(100%,360px);filter:drop-shadow(0 22px 30px rgba(0,0,0,.4));animation:floaty 7s ease-in-out infinite;position:relative;z-index:2}
@keyframes floaty{0%,100%{transform:translateY(0) rotate(-1.5deg)}50%{transform:translateY(-22px) rotate(1.5deg)}}
.mascot-ring{position:absolute;width:330px;height:330px;border-radius:50%;background:radial-gradient(circle,rgba(63,176,229,.45),transparent 65%);filter:blur(6px);animation:pulsering 5s ease-in-out infinite}
@keyframes pulsering{0%,100%{transform:scale(1);opacity:.8}50%{transform:scale(1.12);opacity:1}}

.hero-bubbles{position:absolute;inset:0;z-index:1;overflow:hidden}
.hero-bubbles span{position:absolute;bottom:-40px;border-radius:50%;background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.6),rgba(255,255,255,.08));animation:rise linear infinite}
.hero-bubbles span:nth-child(1){left:8%;width:14px;height:14px;animation-duration:9s}
.hero-bubbles span:nth-child(2){left:20%;width:22px;height:22px;animation-duration:12s;animation-delay:2s}
.hero-bubbles span:nth-child(3){left:33%;width:10px;height:10px;animation-duration:8s;animation-delay:1s}
.hero-bubbles span:nth-child(4){left:48%;width:18px;height:18px;animation-duration:11s;animation-delay:3s}
.hero-bubbles span:nth-child(5){left:62%;width:12px;height:12px;animation-duration:10s;animation-delay:1.5s}
.hero-bubbles span:nth-child(6){left:75%;width:26px;height:26px;animation-duration:13s;animation-delay:.5s}
.hero-bubbles span:nth-child(7){left:86%;width:9px;height:9px;animation-duration:7.5s;animation-delay:2.5s}
.hero-bubbles span:nth-child(8){left:94%;width:16px;height:16px;animation-duration:12.5s;animation-delay:1.2s}
@keyframes rise{0%{transform:translateY(0);opacity:0}10%{opacity:.9}100%{transform:translateY(-105vh);opacity:0}}

.hero-waves{position:absolute;left:0;right:0;bottom:-1px;z-index:2;line-height:0}
.hero-waves .wv{position:absolute;left:0;bottom:0;width:200%;height:110px}
.hero-waves .wv path{fill:#fff}
.wv1{opacity:.55;animation:wave 9s linear infinite}
.wv2{animation:wave 13s linear infinite reverse}
@keyframes wave{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- Sobre ---------- */
.sobre{background:#fff}
.sobre-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:3.6rem;align-items:center}
.sobre-text p{color:var(--muted);margin-bottom:1rem}
.sobre-list{list-style:none;margin-top:1.5rem;display:grid;gap:.8rem}
.sobre-list li{font-weight:600;color:var(--navy);display:flex;align-items:center;gap:.7rem}
.dot{width:11px;height:11px;border-radius:50%;flex-shrink:0}
.dot-blue{background:var(--cyan)}.dot-red{background:var(--red)}
.sobre-media{position:relative}
.sobre-photo{width:100%;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);aspect-ratio:4/3;object-fit:cover;position:relative;z-index:2}
.media-blob{position:absolute;width:78%;height:78%;right:-22px;bottom:-22px;background:var(--sky);border-radius:30% 70% 70% 30%/30% 30% 70% 70%;z-index:1;animation:morph 12s ease-in-out infinite}
@keyframes morph{0%,100%{border-radius:30% 70% 70% 30%/30% 30% 70% 70%}50%{border-radius:60% 40% 30% 70%/60% 30% 70% 40%}}
.media-chip{position:absolute;bottom:18px;left:18px;z-index:3;background:#fff;color:var(--navy);font-weight:700;padding:.5rem 1rem;border-radius:999px;box-shadow:var(--shadow);font-size:.9rem}

/* ---------- Estrutura ---------- */
.estrutura{background:var(--sand)}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.card{background:#fff;border-radius:var(--radius);padding:2.1rem 1.8rem;box-shadow:var(--shadow);border:1px solid rgba(27,58,107,.05);transition:transform .25s var(--ease),box-shadow .25s var(--ease);position:relative;overflow:hidden}
.card::before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,var(--red),var(--cyan));transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg)}
.card:hover::before{transform:scaleX(1)}
.card-ico{width:62px;height:62px;display:grid;place-items:center;border-radius:16px;background:linear-gradient(135deg,var(--sky),#fff);margin-bottom:1.2rem;transition:transform .25s var(--ease)}
.card:hover .card-ico{transform:rotate(-8deg) scale(1.06)}
.card-ico svg{width:32px;height:32px;fill:none;stroke:var(--navy);stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.card:hover .card-ico svg{stroke:var(--red)}
.card h3{color:var(--navy);font-size:1.3rem;margin-bottom:.5rem}
.card p{color:var(--muted);font-size:.95rem}

/* ---------- Day Use ---------- */
.dayuse{background:linear-gradient(165deg,var(--navy),var(--navy-deep));color:#fff;overflow:hidden}
.dayuse-deco{position:absolute;top:-120px;right:-120px;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(63,176,229,.25),transparent 70%)}
.ticket-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.8rem;max-width:840px;margin:0 auto}
.ticket{background:#fff;color:var(--navy);border-radius:var(--radius-lg);padding:0 0 1.8rem;position:relative;box-shadow:var(--shadow-lg);transition:transform .25s var(--ease)}
.ticket:hover{transform:translateY(-6px)}
.ticket-head{padding:1.8rem 2rem 1.4rem;text-align:center}
.ticket-kicker{display:block;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;font-weight:700;color:var(--muted)}
.ticket-head h3{font-size:1.7rem;color:var(--navy);margin-top:.2rem}
.ticket.featured{background:linear-gradient(160deg,#fff,#fff7f7);transform:translateY(-10px);outline:3px solid var(--red);outline-offset:-3px}
.ticket.featured:hover{transform:translateY(-16px)}
.ribbon{position:absolute;top:18px;right:-34px;background:var(--red);color:#fff;font-weight:700;font-size:.74rem;letter-spacing:.04em;padding:.35rem 2.6rem;transform:rotate(45deg);box-shadow:0 4px 10px rgba(0,0,0,.2)}
.ticket-notch{position:relative;height:0;border-top:2px dashed rgba(27,58,107,.2);margin:0 1.6rem}
.ticket-notch::before,.ticket-notch::after{content:"";position:absolute;top:-13px;width:26px;height:26px;border-radius:50%;background:var(--navy-deep)}
.ticket-notch::before{left:-29px}
.ticket-notch::after{right:-29px}
.ticket.featured .ticket-notch::before,.ticket.featured .ticket-notch::after{background:var(--navy-deep)}
.ticket-rows{list-style:none;display:grid;gap:1rem;padding:1.5rem 2rem 0}
.ticket-rows li{display:flex;justify-content:space-between;align-items:center;gap:1rem;font-weight:600}
.ticket-rows strong{font-family:'Baloo 2',cursive;font-size:1.7rem;color:var(--red);white-space:nowrap}

.price-extra{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;max-width:900px;margin:2.6rem auto 0}
.extra-item{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.13);border-radius:16px;padding:1.1rem;text-align:center;display:flex;flex-direction:column;gap:.35rem;transition:transform .2s var(--ease)}
.extra-item:hover{transform:translateY(-4px)}
.extra-item b{font-family:'Baloo 2',cursive;font-size:1.05rem}
.extra-item span{font-size:.85rem;color:rgba(255,255,255,.78)}
.extra-item.free{border-color:rgba(37,211,102,.5);background:rgba(37,211,102,.12)}
.dayuse .note{color:rgba(255,255,255,.75)}
.cta-band{margin-top:3rem;background:var(--red);border-radius:var(--radius-lg);padding:2rem 2.4rem;display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 90% 10%,rgba(255,255,255,.18),transparent 50%)}
.cta-band p{font-family:'Baloo 2',cursive;font-size:1.4rem;font-weight:700;position:relative}
.cta-band .btn-primary{background:#fff;color:var(--red);position:relative}
.cta-band .btn-primary:hover{background:var(--navy);color:#fff}

/* ---------- Mascotes ---------- */
.mascotes{background:var(--sand)}
.masc-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.masc-card{border-radius:var(--radius-lg);padding:2.2rem;display:flex;align-items:center;gap:1.4rem;box-shadow:var(--shadow);overflow:hidden;position:relative;color:#fff;min-height:230px;transition:transform .3s var(--ease)}
.masc-card::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 20%,rgba(255,255,255,.18),transparent 45%)}
.masc-card:hover{transform:translateY(-6px)}
.masc-blue{background:linear-gradient(135deg,var(--cyan),var(--navy))}
.masc-red{background:linear-gradient(135deg,var(--red),var(--red-dark))}
.masc-art{flex-shrink:0;width:150px;display:grid;place-items:center}
.masc-art img{width:150px;filter:drop-shadow(0 14px 20px rgba(0,0,0,.35));animation:floaty 6s ease-in-out infinite}
.masc-red .masc-art img{animation-delay:-3s}
.masc-info{position:relative;z-index:2}
.masc-info h3{font-size:1.8rem}
.masc-role{display:inline-block;font-weight:700;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;background:rgba(255,255,255,.2);padding:.25rem .75rem;border-radius:999px;margin:.4rem 0 .7rem}
.masc-info p{font-size:.97rem;color:rgba(255,255,255,.94)}

/* ---------- Regras ---------- */
.regras{background:#fff}
.rules-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.rule-col{border-radius:var(--radius);padding:1.9rem;border:2px solid;transition:transform .25s var(--ease)}
.rule-col:hover{transform:translateY(-5px)}
.rule-col h3{font-size:1.3rem;margin-bottom:1.1rem;display:flex;align-items:center;gap:.5rem}
.rule-col h3::before{font-size:1.1rem}
.rule-col ul{list-style:none;display:grid;gap:.65rem}
.rule-col li{padding-left:1.5rem;position:relative;color:var(--muted)}
.rule-col li::before{position:absolute;left:0;top:0;font-weight:800}
.rule-col.yes{border-color:rgba(37,211,102,.45);background:rgba(37,211,102,.06)}
.rule-col.yes h3{color:#149b4a}
.rule-col.yes h3::before{content:"✅"}
.rule-col.yes li::before{content:"✓";color:#149b4a}
.rule-col.no{border-color:rgba(225,34,47,.4);background:rgba(225,34,47,.05)}
.rule-col.no h3{color:var(--red)}
.rule-col.no h3::before{content:"⛔"}
.rule-col.no li::before{content:"✕";color:var(--red)}
.rule-col.info{border-color:rgba(63,176,229,.45);background:rgba(63,176,229,.08)}
.rule-col.info h3{color:var(--cyan)}
.rule-col.info h3::before{content:"🏊"}
.rule-col.info li::before{content:"›";color:var(--cyan)}

/* ---------- Contato ---------- */
.contato{background:var(--sand);overflow:hidden}
.contato-peek{position:absolute;right:-30px;bottom:-20px;width:230px;opacity:.14;pointer-events:none;z-index:0}
.contato-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;position:relative;z-index:1}
.info-row{display:flex;gap:1rem;margin:1.4rem 0;align-items:flex-start}
.info-ico{width:48px;height:48px;flex-shrink:0;display:grid;place-items:center;font-size:1.3rem;background:#fff;border-radius:14px;box-shadow:var(--shadow)}
.info-row b{display:block;font-family:'Baloo 2',cursive;color:var(--navy);font-size:1.12rem}
.info-row span{color:var(--muted);font-size:.96rem}
.info-row small{color:var(--muted);opacity:.85}
.info-row a{color:var(--red);font-weight:700}
.contato-actions{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.7rem}
.map-widget{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);border:6px solid #fff;background:var(--sky);min-height:380px;position:relative}
.map-widget iframe{display:block;width:100%;height:380px;filter:saturate(1.05)}
.map-card{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:.6rem;background:linear-gradient(160deg,var(--navy),var(--cyan));color:#fff;border-radius:var(--radius-lg);padding:3.6rem 2rem;min-height:340px;box-shadow:var(--shadow-lg);transition:transform .25s var(--ease)}
.map-card:hover{transform:translateY(-5px)}
.map-pin{font-size:3rem;animation:bob 2.4s ease-in-out infinite}
.map-card strong{font-family:'Baloo 2',cursive;font-size:1.5rem}
.map-card span{color:rgba(255,255,255,.86);max-width:240px}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy-deep);color:rgba(255,255,255,.82)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1.3fr;gap:2.5rem;padding:62px 22px 42px}
.foot-logo{height:62px;margin-bottom:1rem}
.foot-brand p{font-size:.95rem;max-width:310px;margin-bottom:1.2rem}
.foot-social{display:flex;gap:1rem}
.foot-social a{font-weight:600;color:var(--sky-deep)}
.foot-social a:hover{color:#fff}
.foot-col h4{color:#fff;font-size:1.05rem;margin-bottom:1rem}
.foot-col a{display:block;margin-bottom:.5rem;font-size:.95rem;color:rgba(255,255,255,.8)}
.foot-col a:hover{color:#fff}
.foot-legal{font-size:.92rem;line-height:1.85}
.foot-legal small{font-size:.82rem;color:rgba(255,255,255,.55)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1)}
.footer-bottom .container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem;padding:18px 22px;font-size:.84rem;color:rgba(255,255,255,.6)}

/* ---------- Floating WhatsApp ---------- */
.fab-wa{position:fixed;right:20px;bottom:20px;z-index:90;width:58px;height:58px;border-radius:50%;background:var(--wa);display:grid;place-items:center;box-shadow:0 10px 26px rgba(37,211,102,.5);animation:pulse 2.6s infinite}
.fab-wa svg{width:30px;height:30px;fill:#fff}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 16px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}

/* ---------- Reveal ---------- */
.js .reveal{opacity:0;transform:translateY(30px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.js .reveal.in{opacity:1;transform:none}
.js .stagger>*{opacity:0;transform:translateY(26px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.js .stagger.in>*{opacity:1;transform:none}
.js .stagger.in>*:nth-child(2){transition-delay:.08s}
.js .stagger.in>*:nth-child(3){transition-delay:.16s}
.js .stagger.in>*:nth-child(4){transition-delay:.24s}
.js .stagger.in>*:nth-child(5){transition-delay:.32s}
.js .stagger.in>*:nth-child(6){transition-delay:.4s}

/* ===================================================================
   Responsive
=================================================================== */
@media(max-width:920px){
  .hero-grid{grid-template-columns:1fr;text-align:center}
  .hero-content{order:2}
  .hero-mascot{order:1;margin-bottom:1rem}
  .float-mascot{width:230px}
  .mascot-ring{width:230px;height:230px}
  .hero-actions,.hero-badges{justify-content:center}
  .hbadge{align-items:center}
  .sobre-grid,.contato-grid{grid-template-columns:1fr;gap:2.4rem}
  .cards,.rules-grid{grid-template-columns:1fr 1fr}
  .price-extra{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .masc-grid{grid-template-columns:1fr}
}
@media(max-width:760px){
  .section{padding:62px 0}
  .nav-toggle{display:flex}
  .main-nav{position:fixed;inset:74px 0 auto 0;background:#fff;flex-direction:column;align-items:flex-start;gap:0;padding:1rem 22px 1.6rem;box-shadow:var(--shadow);transform:translateY(-135%);transition:transform .32s var(--ease);border-bottom:1px solid rgba(0,0,0,.06)}
  .main-nav.open{transform:none}
  .main-nav a{width:100%;padding:.85rem 0;border-bottom:1px solid rgba(0,0,0,.05)}
  .nav-cta{margin-top:.6rem;width:fit-content}
  .ticket-grid{grid-template-columns:1fr;gap:2.2rem}
  .ticket.featured{transform:none}
  .cards,.rules-grid,.price-extra{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .masc-card{flex-direction:column;text-align:center}
  .cta-band{flex-direction:column;text-align:center}
  .hero{min-height:auto}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal,.stagger>*{opacity:1;transform:none}
}


/* ---------- Polish: focus + title accent ---------- */
a:focus-visible,.btn:focus-visible,.btn-wa:focus-visible,.fab-wa:focus-visible,.nav-toggle:focus-visible,.ticket:focus-visible,.map-widget iframe:focus-visible{outline:3px solid var(--cyan);outline-offset:3px;border-radius:10px}
.head-center .section-title{display:inline-block}
.head-center .section-title::after,.sobre-text .section-title::after,.contato-info .section-title::after{content:"";display:block;width:58px;height:4px;border-radius:4px;margin:16px auto 0;background:linear-gradient(90deg,var(--red),var(--cyan))}
.sobre-text .section-title::after,.contato-info .section-title::after{margin-left:0}
.head-center.light .section-title::after{background:linear-gradient(90deg,var(--cyan),#fff)}


/* ---------- Polish#2: unified icons + scroll-spy ---------- */
.info-ico svg{width:24px;height:24px;fill:none;stroke:var(--navy);stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.main-nav a.active:not(.nav-cta){color:var(--red)}
.main-nav a.active:not(.nav-cta)::after{width:100%}
