:root {
  --navy:       #0a1628;
  --navy-mid:   #0e1f3d;
  --navy-light: #162845;
  --blue:       #1a56c4;
  --blue-bright:#2563eb;
  --teal:       #0d9488;
  --gold:       #d97706;
  --cream:      #f5f0e8;
  --white:      #ffffff;
  --muted:      rgba(255,255,255,0.55);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}

/* grain overlay */
body::after{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:9998;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='512' height='512' filter='url(%23n)' opacity='0.045'/%3E%3C/svg%3E");
  opacity:.45;mix-blend-mode:overlay;
}

body{
  font-family:'Raleway',sans-serif;
  background:var(--navy);
  color:var(--white);
  overflow-x:hidden;
}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 3rem;height:68px;
  background:rgba(10,22,40,.97);
  border-bottom:1px solid rgba(255,255,255,0.07);
}
nav::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--blue) 0%,var(--teal) 40%,var(--gold) 70%,var(--blue) 100%);
}
.nav-logo-img{width:38px;height:38px;object-fit:contain}
.nav-logo{
  display:flex;align-items:center;gap:.75rem;
  font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:700;
  letter-spacing:-.02em;color:var(--white);text-decoration:none;
}
.nav-links{display:flex;align-items:center;gap:0;list-style:none}
.nav-links a{
  color:rgba(255,255,255,.5);text-decoration:none;
  font-size:.65rem;font-weight:600;letter-spacing:.13em;text-transform:uppercase;
  padding:.45rem 1rem;border-left:1px solid rgba(255,255,255,.06);
  transition:color .15s,background .15s;display:block;
}
.nav-links a:hover{color:var(--white);background:rgba(255,255,255,.04)}
.nav-cta{
  background:var(--blue-bright)!important;
  color:var(--white)!important;
  border-left:none!important;margin-left:.75rem;border-radius:3px;
}
.nav-cta:hover{background:#1d4ed8!important}

/* ── HERO ── */
.hero{
  min-height:100vh;position:relative;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;overflow:hidden;padding-top:68px;
}

/* Foto estática de Recife */
.hero-photo{
  position:absolute;inset:0;
  background:url('../images/hero-recife-noite.jpg') center/cover no-repeat;
}

/* Camadas de overlay */
.hero-photo::before{
  content:'';position:absolute;inset:0;
  background:rgba(10,22,40,.55);
}
.hero-photo::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(10,22,40,.3) 0%,rgba(10,22,40,.1) 35%,rgba(10,22,40,.75) 100%);
}

/* Faixa azulejo topo */
.hero-azulejo-top{
  position:absolute;top:0;left:0;right:0;height:8px;z-index:2;
  background:repeating-linear-gradient(90deg,var(--blue) 0,var(--blue) 55px,rgba(255,255,255,.06) 55px,rgba(255,255,255,.06) 60px);
  opacity:.5;
}
.hero-azulejo-bottom{
  position:absolute;bottom:0;left:0;right:0;height:8px;z-index:2;
  background:repeating-linear-gradient(90deg,var(--teal) 0,var(--teal) 35px,rgba(255,255,255,.06) 35px,rgba(255,255,255,.06) 40px);
  opacity:.5;
}

/* Ícones flutuantes */
.hero-float{position:absolute;pointer-events:none;z-index:2}
.hf-1{top:12%;left:5%;animation:float 9s ease-in-out infinite}
.hf-2{top:16%;right:6%;animation:float 7s ease-in-out infinite;animation-delay:-3s}
.hf-3{bottom:18%;left:7%;animation:float 10s ease-in-out infinite;animation-delay:-5s}
.hf-4{bottom:22%;right:5%;animation:float 8s ease-in-out infinite;animation-delay:-1.5s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

.hero-content{position:relative;z-index:3;padding:2rem;max-width:800px}

.hero-eyebrow{
  display:inline-flex;align-items:center;gap:.7rem;
  font-size:.6rem;letter-spacing:.35em;text-transform:uppercase;
  color:var(--gold);margin-bottom:1.75rem;
  border:1px solid rgba(217,119,6,.28);padding:.4rem 1.4rem;
}
.hero-eyebrow::before,.hero-eyebrow::after{content:'—';opacity:.38}

.hero-logo-mark{margin-bottom:1.25rem;animation:fadeUp .9s .05s both}

.hero-title{
  font-family:'Playfair Display',serif;
  font-size:clamp(3.5rem,9vw,6.5rem);
  font-weight:900;line-height:.92;letter-spacing:-.03em;
  color:var(--white);margin-bottom:1.2rem;
  animation:fadeUp .9s .15s both;
}

.hero-sub{
  font-size:clamp(1rem,2.2vw,1.25rem);letter-spacing:.04em;
  color:rgba(255,255,255,.88);margin-bottom:2.5rem;
  line-height:1.7;font-family:'Raleway',sans-serif;font-weight:400;
  animation:fadeUp .9s .3s both;
}
.hero-sub strong{
  color:#3b82f6;font-weight:700;letter-spacing:.06em;
}

.hero-ctas{
  display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;
  animation:fadeUp .9s .45s both;
}

.btn-primary{
  background:var(--blue-bright);color:var(--white);
  padding:.85rem 2.2rem;border:none;
  font-family:'Raleway',sans-serif;font-size:.72rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
  cursor:pointer;text-decoration:none;display:inline-block;
  transition:all .15s;border-radius:3px;
  clip-path:polygon(0 0,calc(100% - 10px) 0,100% 10px,100% 100%,10px 100%,0 calc(100% - 10px));
}
.btn-primary:hover{background:#1d4ed8;transform:translateY(-2px)}

.btn-outline{
  background:transparent;color:var(--white);
  padding:.85rem 2.2rem;
  border:1.5px solid rgba(255,255,255,.25);
  font-family:'Raleway',sans-serif;font-size:.72rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;
  cursor:pointer;text-decoration:none;display:inline-block;
  transition:all .15s;border-radius:3px;
}
.btn-outline:hover{border-color:var(--teal);color:#5eead4}

.scroll-hint{
  position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.4rem;
  opacity:.35;z-index:3;animation:bounce 2.5s ease-in-out infinite;
}
.scroll-hint span{font-size:.55rem;letter-spacing:.28em;text-transform:uppercase;color:var(--white)}
.scroll-arrow{width:16px;height:16px;border-right:1px solid var(--white);border-bottom:1px solid var(--white);transform:rotate(45deg)}

@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes bounce{
  0%,100%{transform:translateX(-50%) translateY(0)}
  50%{transform:translateX(-50%) translateY(8px)}
}

/* ── TICKER ── */
.ticker{
  background:var(--blue);padding:.6rem 0;
  overflow:hidden;white-space:nowrap;
  border-top:2px solid rgba(255,255,255,.1);
  border-bottom:2px solid rgba(255,255,255,.1);
  position:relative;z-index:2;
}
.ticker-inner{display:inline-flex;gap:2.5rem;animation:ticker 22s linear infinite}
.ticker-item{
  font-family:'Playfair Display',serif;font-size:.95rem;
  color:rgba(255,255,255,.85);letter-spacing:.08em;
}
.ticker-dot{color:var(--gold)}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── TEXTURAS POR SEÇÃO ── */
.tex-dots{position:relative;background:var(--navy-mid)}
.tex-dots::before{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:radial-gradient(circle,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:22px 22px;
}
.tex-dots>*{position:relative;z-index:1}

.tex-grid{position:relative;background:var(--navy)}
.tex-grid::before{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:40px 40px;
}
.tex-grid>*{position:relative;z-index:1}

.tex-lines{position:relative;background:var(--navy-mid)}
.tex-lines::before{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:repeating-linear-gradient(135deg,transparent,transparent 18px,rgba(255,255,255,.022) 18px,rgba(255,255,255,.022) 19px);
}
.tex-lines>*{position:relative;z-index:1}

.tex-sobre{
  position:relative;
  background:var(--blue);overflow:hidden;
}
.tex-sobre::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    repeating-linear-gradient(0deg,rgba(255,255,255,.025) 0,rgba(255,255,255,.025) 1px,transparent 1px,transparent 40px),
    repeating-linear-gradient(90deg,rgba(255,255,255,.025) 0,rgba(255,255,255,.025) 1px,transparent 1px,transparent 40px);
}

/* ── AZULEJO DIVIDER ── */
.azulejo-divider{
  height:6px;
  background:repeating-linear-gradient(90deg,var(--blue) 0,var(--blue) 28px,var(--navy) 28px,var(--navy) 34px);
  opacity:.5;
}
.azulejo-divider.teal{
  background:repeating-linear-gradient(90deg,var(--teal) 0,var(--teal) 20px,var(--navy) 20px,var(--navy) 26px);
  opacity:.45;
}

/* ── SEÇÃO GENÉRICA ── */
section{padding:6rem 3rem}
.s-label{font-size:.58rem;letter-spacing:.38em;text-transform:uppercase;color:var(--teal);margin-bottom:.6rem;display:block}
.s-title{font-family:'Playfair Display',serif;font-size:clamp(2rem,5.5vw,4rem);line-height:.95;color:var(--white);margin-bottom:1.5rem}
.s-body{font-size:.82rem;color:var(--muted);line-height:1.9;max-width:520px}

/* ── CULTURAL STRIP ── */
.cultural-strip{
  background:#0d1829;
  border-bottom:1px solid rgba(255,255,255,.04);
  padding:2.5rem;display:flex;align-items:center;justify-content:center;
  gap:3.5rem;flex-wrap:wrap;
}
.cultural-item{display:flex;flex-direction:column;align-items:center;gap:.6rem;opacity:.38;transition:opacity .2s;cursor:default}
.cultural-item:hover{opacity:1}
.cultural-item span{font-size:.55rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.5)}

/* ── EXPERIÊNCIAS ── */
.exp-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3rem;flex-wrap:wrap;gap:1rem}
.exp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:rgba(255,255,255,.03)}

.exp-card{position:relative;overflow:hidden;aspect-ratio:3/4;cursor:pointer;background:var(--navy-light)}
.exp-card-img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease,filter .5s ease;filter:brightness(.45) saturate(.8)}
.exp-card:hover .exp-card-img{transform:scale(1.06);filter:brightness(.28) saturate(1)}
.exp-card-bar{position:absolute;top:0;left:0;width:4px;height:100%;transition:width .3s}
.exp-card:hover .exp-card-bar{width:6px}
.exp-num{position:absolute;top:1rem;right:.8rem;font-family:'Playfair Display',serif;font-size:5rem;line-height:1;color:rgba(255,255,255,.04);z-index:0;pointer-events:none}
.exp-card-bg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:5rem}
.exp-card-info{
  position:absolute;bottom:0;left:0;right:0;padding:1.5rem;
  background:linear-gradient(transparent,rgba(0,0,0,.93));
  transform:translateY(28px);transition:transform .3s;z-index:1;
}
.exp-card:hover .exp-card-info{transform:translateY(0)}
.exp-cat{font-size:.55rem;color:var(--teal);letter-spacing:.25em;text-transform:uppercase;margin-bottom:.3rem;display:block}
.exp-name{font-family:'Playfair Display',serif;font-size:1.45rem;color:var(--white);line-height:1;margin-bottom:.35rem}
.exp-desc{font-size:.72rem;color:rgba(255,255,255,.65);opacity:0;transform:translateY(8px);transition:opacity .3s .1s,transform .3s .1s;line-height:1.75}
.exp-card:hover .exp-desc{opacity:1;transform:translateY(0)}

/* ── SOBRE RECIFE ── */
.sobre-recife{background:var(--navy);padding:7rem 3rem}
.sr-inner{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center;
}
.sr-titulo{
  font-family:'Playfair Display',serif;
  font-size:clamp(2.4rem,5vw,4rem);
  line-height:.95;color:var(--white);margin-bottom:2rem;
}
.sr-corpo{
  font-size:.88rem;color:rgba(255,255,255,.6);
  line-height:2;margin-bottom:1.2rem;
}
.sr-destaque{
  display:flex;gap:1rem;align-items:flex-start;
  margin-top:2.5rem;padding:1.5rem;
  border-left:3px solid var(--teal);
  background:rgba(13,148,136,.06);
}
.sr-aspas{
  font-family:'Playfair Display',serif;
  font-size:4rem;line-height:.7;color:var(--teal);opacity:.6;flex-shrink:0;
}
.sr-destaque p{
  font-family:'Playfair Display',serif;font-style:italic;
  font-size:1rem;color:rgba(255,255,255,.75);line-height:1.6;
}
.sr-fotos{display:flex;flex-direction:column;gap:1rem}
.sr-foto-grande{position:relative;overflow:hidden;border-radius:2px;aspect-ratio:16/10}
.sr-foto-grande img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.sr-foto-grande:hover img{transform:scale(1.04)}
.sr-fotos-menores{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.sr-foto-pequena{position:relative;overflow:hidden;border-radius:2px;aspect-ratio:4/3}
.sr-foto-pequena img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.sr-foto-pequena:hover img{transform:scale(1.05)}
.sr-foto-label{
  position:absolute;bottom:0;left:0;right:0;
  padding:.5rem .8rem;
  background:linear-gradient(transparent,rgba(0,0,0,.75));
  font-family:'Raleway',sans-serif;font-size:.58rem;
  color:rgba(255,255,255,.8);letter-spacing:.1em;text-transform:uppercase;
}

/* ── EVENTOS ── */
.eventos-header{text-align:center;margin-bottom:2.5rem}
.eventos-header .s-body{margin:.5rem auto 0}
.plataformas{
  display:inline-flex;justify-content:center;margin-bottom:3rem;
  border:1px solid rgba(255,255,255,.1);
  position:relative;left:50%;transform:translateX(-50%);
}
.plat-btn{
  padding:.55rem 1.4rem;border:none;border-right:1px solid rgba(255,255,255,.1);
  background:transparent;color:rgba(255,255,255,.3);
  font-family:'Raleway',sans-serif;font-size:.62rem;
  letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:all .15s;font-weight:700;
}
.plat-btn:last-child{border-right:none}
.plat-btn.active,.plat-btn:hover{background:var(--blue-bright);color:var(--white)}
.eventos-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:rgba(255,255,255,.04);
  max-width:1100px;margin:0 auto;
}
.evento-card{
  background:var(--navy-mid);padding:1.75rem;
  display:flex;flex-direction:column;gap:.7rem;
  transition:background .2s;position:relative;overflow:hidden;
}
.evento-card::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:var(--blue-bright);transform:scaleY(0);transition:transform .3s;transform-origin:bottom;
}
.evento-card:hover{background:var(--navy-light)}
.evento-card:hover::before{transform:scaleY(1)}
.evento-data{font-size:.6rem;color:var(--gold);letter-spacing:.18em;font-weight:700;text-transform:uppercase}
.evento-nome{font-family:'Playfair Display',serif;font-size:1.35rem;color:var(--white);line-height:1.1}
.evento-local{font-size:.72rem;color:var(--muted);display:flex;align-items:center;gap:.4rem}
.evento-footer{display:flex;align-items:center;justify-content:space-between;margin-top:.5rem}
.evento-plat{font-size:.56rem;letter-spacing:.1em;text-transform:uppercase;padding:.2rem .55rem;font-weight:700}
.plat-sympla{background:rgba(26,86,196,.25);color:#93c5fd;border:1px solid rgba(26,86,196,.35)}
.plat-shotgun{background:rgba(13,148,136,.2);color:#5eead4;border:1px solid rgba(13,148,136,.3)}
.evento-preco{font-size:.75rem;color:var(--muted)}
.btn-ticket-ev{
  display:inline-block;margin-top:.5rem;padding:.5rem 1.1rem;
  background:var(--blue-bright);color:var(--white);
  font-family:'Raleway',sans-serif;font-size:.6rem;
  letter-spacing:.12em;text-transform:uppercase;text-decoration:none;
  transition:all .15s;font-weight:700;border-radius:2px;
  clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,8px 100%,0 calc(100% - 8px));
}
.btn-ticket-ev:hover{background:#1d4ed8}

/* ── CARROSSEL ── */
.carrossel-secao{
  background:url('../images/bg-carrossel.png') center/cover no-repeat;
  padding:5rem 3rem;display:flex;flex-direction:column;align-items:center;
}
.carr-topo{text-align:center;margin-bottom:2rem}
.carr-titulo{
  font-family:'Playfair Display',serif;
  font-size:clamp(2rem,4vw,3.2rem);
  color:var(--white);line-height:1;margin-top:.4rem;
}
.carr-wrapper{
  position:relative;width:100%;max-width:900px;
  overflow:hidden;
}
.carr-rodape{
  max-width:680px;text-align:center;margin-top:2.5rem;
  font-size:.85rem;color:rgba(255,255,255,.5);line-height:1.9;
}
.carr-track{
  display:flex;
  transition:transform .6s cubic-bezier(.4,0,.2,1);
}
.carr-slide{
  min-width:100%;position:relative;aspect-ratio:16/7;overflow:hidden;
}
.carr-slide img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s ease;
}
.carr-slide:hover img{transform:scale(1.03)}
.carr-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  width:52px;height:52px;border-radius:50%;border:1px solid rgba(255,255,255,.2);
  background:rgba(10,22,40,.7);color:var(--white);
  font-size:2rem;line-height:1;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .2s;backdrop-filter:blur(6px);z-index:10;
}
.carr-btn:hover{background:var(--teal);border-color:var(--teal)}
.carr-prev{left:1.2rem}
.carr-next{right:1.2rem}
.carr-dots{
  display:flex;justify-content:center;gap:.6rem;
  margin-top:1.5rem;
}
.carr-dot{
  width:28px;height:3px;border-radius:2px;
  background:rgba(255,255,255,.18);cursor:pointer;
  transition:all .3s;
}
.carr-dot.ativo{background:var(--teal);width:44px}

/* ── LUGARES ── */
#lugares{
  background:url('../images/bg-lugares.png') center/cover no-repeat;
  overflow:hidden;
}
.lugares-inner{max-width:1100px;margin:0 auto}
.lugares-layout{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.lugares-list{display:flex;flex-direction:column}
.lugar-item{
  padding:1.4rem 1rem;margin-bottom:.5rem;
  display:flex;gap:1.2rem;align-items:flex-start;cursor:pointer;
  background:transparent;
  border-left:3px solid transparent;
  transition:padding-left .2s, background .2s, border-left-color .2s;
}
.lugar-item:hover{padding-left:1.4rem;border-left-color:rgba(37,99,235,.5);background:rgba(5,12,28,.75);backdrop-filter:blur(4px)}
.lugar-item.active-lugar{border-left-color:var(--teal);padding-left:1.4rem;background:rgba(5,12,28,.75);backdrop-filter:blur(4px)}
.lugar-item.active-lugar .lugar-num{color:var(--teal)}
.lugar-item.active-lugar h3{color:var(--white)}
.lugar-num{font-family:'Raleway',sans-serif;font-size:.62rem;color:rgba(255,255,255,.25);min-width:22px;margin-top:.2rem;transition:color .2s;font-weight:700}
.lugar-info h3{font-family:'Playfair Display',serif;font-size:1.18rem;color:rgba(255,255,255,.5);margin-bottom:.15rem;transition:color .2s}
.lugar-info p{font-size:.72rem;color:var(--muted);line-height:1.75}
.lugar-tag{display:inline-block;margin-top:.35rem;font-family:'Raleway',sans-serif;font-size:.52rem;padding:.15rem .45rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700}
.tag-cultura{background:rgba(13,148,136,.18);color:#5eead4;border:1px solid rgba(13,148,136,.22)}
.tag-praia{background:rgba(26,86,196,.22);color:#93c5fd;border:1px solid rgba(26,86,196,.28)}
.tag-gastronomia{background:rgba(217,119,6,.18);color:#fcd34d;border:1px solid rgba(217,119,6,.22)}
.tag-musica{background:rgba(255,255,255,.07);color:rgba(255,255,255,.6);border:1px solid rgba(255,255,255,.12)}

.lugares-visual{position:sticky;top:88px}
.lugar-foto-box{
  position:relative;aspect-ratio:4/5;background:var(--navy-light);overflow:hidden;
  border:1px solid rgba(255,255,255,.07);
  box-shadow:0 0 0 6px rgba(255,255,255,.02),24px 24px 60px rgba(0,0,0,.7);
}
.lugar-foto-box::before{
  content:'';position:absolute;top:0;left:0;bottom:0;width:6px;z-index:2;
  background:linear-gradient(180deg,var(--blue) 0%,var(--teal) 50%,var(--gold) 100%);
}
.lugar-foto-slide{position:absolute;inset:0;opacity:0;transition:opacity .5s ease;display:flex;flex-direction:column}
.lugar-foto-slide.active-slide{opacity:1}
.lugar-foto-slide img{width:100%;height:100%;object-fit:cover;filter:brightness(.72) saturate(.9);transition:transform .6s ease}
.lugar-foto-slide.active-slide img{transform:scale(1.03)}
.lugar-foto-caption{
  position:absolute;bottom:0;left:0;right:0;padding:1.25rem 1.5rem;
  background:linear-gradient(transparent,rgba(0,0,0,.92));
  display:flex;align-items:center;gap:1rem;z-index:1;
}
.lugar-foto-num{font-family:'Playfair Display',serif;font-size:2.2rem;color:var(--teal);line-height:1;min-width:32px}
.lugar-foto-caption div{flex:1;display:flex;flex-direction:column;gap:.1rem}
.lugar-foto-caption strong{font-family:'Playfair Display',serif;font-size:.83rem;color:var(--white)}
.lugar-foto-caption span{font-family:'Raleway',sans-serif;font-size:.56rem;color:var(--muted);letter-spacing:.1em}
.foto-maps-btn{font-family:'Raleway',sans-serif;font-size:.56rem;color:var(--teal);text-decoration:none;letter-spacing:.1em;white-space:nowrap;border:1px solid rgba(13,148,136,.3);padding:.3rem .6rem;transition:all .15s;font-weight:700}
.foto-maps-btn:hover{background:rgba(13,148,136,.1)}

/* Fallback se foto não carrega */
.lugar-foto-slide.foto-fallback{background:linear-gradient(135deg,var(--navy),var(--navy-light));align-items:center;justify-content:center}

/* ── SOBRE ── */
.sobre-inner{max-width:900px;margin:0 auto;position:relative;z-index:1}
#sobre .s-label{color:rgba(255,255,255,.5)}
.sobre-stats{display:grid;grid-template-columns:repeat(3,1fr);margin-top:3rem;border-top:1px solid rgba(255,255,255,.14)}
.stat{padding:2rem 1.5rem;border-right:1px solid rgba(255,255,255,.09)}
.stat:last-child{border-right:none}
.stat-num{font-family:'Playfair Display',serif;font-size:3.5rem;color:var(--gold);line-height:1;display:block}
.stat-label{font-size:.72rem;color:rgba(255,255,255,.52);margin-top:.25rem;font-weight:700}

/* ── FOOTER ── */
footer{
  background:#060e1c;padding:4rem 3rem 2rem;
  border-top:1px solid rgba(255,255,255,.04);
  position:relative;
}
footer::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,.015) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.015) 1px,transparent 1px);
  background-size:50px 50px;
}
footer>*{position:relative;z-index:1}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:3rem;margin-bottom:3rem;padding-bottom:3rem;border-bottom:1px solid rgba(255,255,255,.04)}
.footer-brand-name{font-family:'Playfair Display',serif;font-size:1.5rem;color:var(--white);letter-spacing:-.01em;margin-bottom:.75rem;display:block}
.footer-brand p{font-size:.73rem;color:rgba(255,255,255,.3);line-height:1.85;max-width:268px}
.footer-col h4{font-size:.6rem;color:var(--teal);letter-spacing:.28em;text-transform:uppercase;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid rgba(13,148,136,.15);font-weight:700}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.55rem}
.footer-col ul a{color:rgba(255,255,255,.32);text-decoration:none;font-size:.74rem;transition:color .2s}
.footer-col ul a:hover{color:var(--white)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.footer-copy{font-size:.56rem;color:rgba(255,255,255,.18);letter-spacing:.1em}

/* ── MISC ── */
a{color:inherit}
.view-all{
  font-size:.68rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--teal);text-decoration:none;
  border-bottom:1px solid rgba(13,148,136,.35);padding-bottom:2px;
  white-space:nowrap;transition:color .2s;
}
.view-all:hover{color:#5eead4}

/* ── HAMBURGER (oculto no desktop) ── */
.nav-hamburger{
  display:none;flex-direction:column;gap:5px;cursor:pointer;
  background:none;border:none;padding:.4rem;
}
.nav-hamburger span{
  display:block;width:24px;height:2px;
  background:var(--white);border-radius:2px;
  transition:transform .25s,opacity .25s;
}
.nav-hamburger.aberto span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-hamburger.aberto span:nth-child(2){opacity:0}
.nav-hamburger.aberto span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── RESPONSIVO — TABLET (≤ 900px) ── */
@media(max-width:900px){
  .sr-inner{grid-template-columns:1fr;gap:3rem}
  .sobre-recife{padding:5rem 2rem}
  .lugares-layout{grid-template-columns:1fr;gap:2.5rem}
  .lugares-visual{position:static}
  .lugar-foto-box{aspect-ratio:16/10}
  .footer-top{grid-template-columns:1fr 1fr;gap:2.5rem}
  .eventos-grid{grid-template-columns:repeat(2,1fr)}
  .sobre-stats{grid-template-columns:repeat(3,1fr)}
}

/* ── RESPONSIVO — MOBILE (≤ 700px) ── */
@media(max-width:700px){

  /* NAV */
  nav{padding:0 1.25rem}
  .nav-hamburger{display:flex}
  .nav-links{
    display:none;
    position:fixed;top:68px;left:0;right:0;
    background:rgba(8,18,34,.98);
    flex-direction:column;gap:0;
    border-bottom:2px solid rgba(255,255,255,.07);
    z-index:198;
    backdrop-filter:blur(8px);
  }
  .nav-links.aberto{display:flex}
  .nav-links li{border-left:none;border-bottom:1px solid rgba(255,255,255,.05)}
  .nav-links a{
    border-left:none;padding:1rem 1.5rem;
    font-size:.7rem;letter-spacing:.1em;
  }
  .nav-links li:last-child{padding:.75rem 1.25rem}
  .nav-cta{
    margin:0!important;border-radius:0!important;
    display:block!important;text-align:center;
    padding:1rem 1.5rem!important;
  }

  /* SEÇÕES — padding geral */
  section{padding:3.5rem 1.25rem}
  .sobre-recife{padding:4rem 1.25rem}
  #lugares{padding:4rem 1.25rem}

  /* HERO */
  .hero-content{padding:1rem 1.25rem;max-width:100%}
  .hf-1,.hf-2,.hf-3,.hf-4{display:none}
  .hero-sub{font-size:clamp(.88rem,3.5vw,1.1rem)}

  /* CULTURAL STRIP */
  .cultural-strip{gap:1.5rem 2rem;padding:2rem 1.25rem}

  /* SOBRE RECIFE */
  .sr-inner{grid-template-columns:1fr;gap:2.5rem}
  .sr-titulo{font-size:clamp(2rem,7vw,3rem)}

  /* EVENTOS */
  .eventos-grid{grid-template-columns:1fr}
  .plataformas{width:calc(100% - 2.5rem);flex-direction:column;left:0;transform:none;margin:0 auto 2.5rem}
  .plat-btn{
    border-right:none;
    border-bottom:1px solid rgba(255,255,255,.1);
    padding:.65rem 1rem;font-size:.65rem;
  }
  .plat-btn:last-child{border-bottom:none}

  /* CARROSSEL */
  .carrossel-secao{padding:3.5rem 1rem}
  .carr-rodape{font-size:.78rem;margin-top:1.75rem}
  .carr-btn{width:40px;height:40px;font-size:1.5rem}

  /* LUGARES */
  .lugares-layout{grid-template-columns:1fr;gap:1.5rem}
  .lugares-visual{position:static;order:-1}
  .lugar-foto-box{aspect-ratio:16/10}
  .lugar-item{padding:1rem .75rem}
  .lugar-item.active-lugar{padding-left:1rem}
  .lugar-item:hover{padding-left:1rem}

  /* SOBRE */
  .sobre-stats{
    grid-template-columns:1fr 1fr;
    border-top:1px solid rgba(255,255,255,.14);
  }
  .stat{padding:1.4rem 1rem}
  .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid rgba(255,255,255,.09)}
  .stat:nth-child(odd){border-right:1px solid rgba(255,255,255,.09)}
  .stat:nth-child(even){border-right:none}
  .stat:nth-child(3){grid-column:1/-1;border-right:none}
  .stat-num{font-size:2.8rem}

  /* FOOTER */
  footer{padding:3rem 1.25rem 1.75rem}
  .footer-top{grid-template-columns:1fr;gap:2rem;margin-bottom:2rem;padding-bottom:2rem}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:.4rem}
}

/* ── RESPONSIVO — PEQUENO (≤ 400px) ── */
@media(max-width:400px){
  .cultural-strip{gap:1.2rem 1.4rem}
  .sobre-stats{grid-template-columns:1fr}
  .stat{border-right:none!important;border-bottom:1px solid rgba(255,255,255,.09)!important}
  .stat:last-child{border-bottom:none!important}
  .carr-btn{width:34px;height:34px;font-size:1.2rem}
}
