:root {
  --yellow: #FFD600;
  --yellow-dk: #E6C000;
  --dark: #111111;
  --mid: #444444;
  --muted: #888888;
  --border: #E8E8E8;
  --bg: #F7F6F2;
  --white: #FFFFFF;
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: "Plus Jakarta Sans", sans-serif; background: var(--white); color: var(--dark); -webkit-font-smoothing: antialiased; overflow-x: hidden; }

/* ── NAV ── */
nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; background: rgba(255,255,255,.97); backdrop-filter: blur(8px); border-bottom: 2.5px solid var(--yellow); height: 64px; display: flex; align-items: center; justify-content: space-between; padding: 0 2.5rem; }
.nav-logo { text-decoration: none; display: flex; align-items: center; }
.nav-logo img { height: 56px; width: auto; }
.nav-links { display: flex; align-items: center; gap: 2rem; list-style: none; }
.nav-links a { font-size: .875rem; font-weight: 600; color: var(--mid); text-decoration: none; transition: color .15s; }
.nav-links a:hover { color: var(--dark); }
.nav-cta { background: var(--yellow); color: var(--dark); font-size: .875rem; font-weight: 800; padding: .55rem 1.3rem; border-radius: 8px; text-decoration: none; transition: background .15s, transform .15s; }
.nav-cta:hover { background: var(--yellow-dk); transform: translateY(-1px); }
.hamburger { display: none; flex-direction: column; gap: 5px; cursor: pointer; background: none; border: none; padding: 4px; }
.hamburger span { display: block; width: 22px; height: 2px; background: var(--dark); border-radius: 2px; }

/* ── HERO ── */
.hero-wrap { max-width: 1140px; margin: 0 auto; }
.hero { padding: 104px 2.5rem 80px; display: grid; grid-template-columns: 1fr 420px; gap: 4rem; align-items: center; min-height: 95vh; }
.hero-eyebrow { display: inline-flex; align-items: center; gap: 8px; background: var(--yellow); border-radius: 100px; padding: .35rem 1rem; font-size: .78rem; font-weight: 800; color: var(--dark); margin-bottom: 1.5rem; letter-spacing: .02em; }
.hero h1 { font-size: 3.2rem; font-weight: 800; line-height: 1.15; letter-spacing: -.035em; margin-bottom: 1.2rem; }
.hero h1 em { font-style: normal; background: var(--yellow); padding: 0 6px; border-radius: 4px; }
.hero-desc { font-size: 1rem; line-height: 1.75; color: var(--mid); font-weight: 500; margin-bottom: 2rem; max-width: 420px; }
.hero-btns { display: flex; gap: .75rem; flex-wrap: wrap; }
.hero-stats { display: flex; gap: 2.5rem; margin-top: 3rem; padding-top: 2rem; border-top: 1px solid var(--border); }
.hero-stat strong { display: block; font-size: 1.7rem; font-weight: 800; letter-spacing: -.03em; }
.hero-stat span { font-size: .75rem; color: var(--muted); font-weight: 600; text-transform: uppercase; letter-spacing: .05em; }
.hero-card { background: var(--bg); border: 1.5px solid var(--border); border-radius: 20px; overflow: hidden; }
.hero-card-img { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; }
.hero-card-body { padding: 1.2rem 1.4rem; }
.hero-card-chips { display: flex; flex-wrap: wrap; gap: .4rem; }
.chip-sm { background: var(--white); border: 1px solid var(--border); border-radius: 6px; padding: .3rem .7rem; font-size: .75rem; font-weight: 700; color: var(--mid); }

/* ── NUMBERS STRIP ── */
.numbers-strip { background: var(--yellow); padding: 2.5rem; }
.numbers-inner { max-width: 1140px; margin: 0 auto; display: grid; grid-template-columns: repeat(4,1fr); gap: 1rem; text-align: center; }
.num-item strong { display: block; font-size: 2.4rem; font-weight: 800; letter-spacing: -.04em; color: var(--dark); }
.num-item span { font-size: .75rem; font-weight: 700; color: rgba(0,0,0,.55); text-transform: uppercase; letter-spacing: .06em; }

/* ── SHARED ── */
.wrap { max-width: 1140px; margin: 0 auto; padding: 0 2.5rem; }
section { padding: 6rem 0; }
.sec-white { background: var(--white); }
.sec-compact { padding: 5rem 0; }
.sec-label { font-size: .72rem; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); margin-bottom: .65rem; }
.sec-title { font-size: 1.8rem; font-weight: 800; letter-spacing: -.03em; line-height: 1.2; }
.sec-title-mb { margin-bottom: .75rem; }
.sec-sub { font-size: .95rem; color: var(--mid); font-weight: 500; line-height: 1.7; max-width: 440px; }
.sec-sub-right { margin: 0; }
.sec-center-header { text-align: center; margin-bottom: 3rem; }

/* ── BUTTONS ── */
.btn-primary { background: var(--yellow); color: var(--dark); font-weight: 800; font-size: .92rem; padding: .8rem 1.6rem; border-radius: 8px; text-decoration: none; display: inline-flex; align-items: center; gap: 7px; transition: background .15s, transform .15s; }
.btn-primary:hover { background: var(--yellow-dk); transform: translateY(-1px); }
.btn-outline { background: transparent; color: var(--dark); font-weight: 600; font-size: .92rem; padding: .8rem 1.6rem; border-radius: 8px; border: 1.5px solid var(--border); text-decoration: none; display: inline-flex; align-items: center; gap: 7px; transition: border-color .15s, transform .15s; }
.btn-outline:hover { border-color: var(--dark); transform: translateY(-1px); }
.btn-sm { font-size: .78rem; padding: .45rem .9rem; }
.btn-wpp { background: #25D366; color: #fff; font-weight: 800; font-size: .95rem; padding: .9rem 2rem; border-radius: 8px; text-decoration: none; display: inline-flex; align-items: center; gap: 8px; transition: opacity .15s, transform .15s; }
.btn-wpp:hover { opacity: .88; transform: translateY(-1px); }
.btn-ig { background: rgba(255,255,255,.1); color: rgba(255,255,255,.85); font-weight: 600; font-size: .95rem; padding: .9rem 2rem; border-radius: 8px; text-decoration: none; display: inline-flex; align-items: center; gap: 8px; border: 1px solid rgba(255,255,255,.15); transition: background .15s, transform .15s; }
.btn-ig:hover { background: rgba(255,255,255,.18); transform: translateY(-1px); }

/* ── COMO FUNCIONA ── */
.steps-grid { display: grid; grid-template-columns: 1fr auto 1fr auto 1fr; gap: 1rem; align-items: start; }
.step-card { background: var(--bg); border-radius: 16px; padding: 2rem 1.5rem; text-align: center; }
.step-num { width: 32px; height: 32px; background: var(--yellow); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: .8rem; font-weight: 800; margin: 0 auto 1rem; }
.step-icon { font-size: 2rem; margin-bottom: .75rem; }
.step-card h3 { font-size: 1rem; font-weight: 800; margin-bottom: .4rem; }
.step-card p { font-size: .83rem; color: var(--mid); font-weight: 500; line-height: 1.6; }
.step-arrow { font-size: 1.5rem; color: var(--border); align-self: center; padding-top: 1rem; }

/* ── SERVIÇOS ── */
#servicos { background: var(--bg); }
.serv-top { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 2.5rem; flex-wrap: wrap; gap: 1.5rem; padding: 0 1.2rem;}
.serv-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 1px; background: var(--border); border: 1.5px solid var(--border); border-radius: 16px; overflow: hidden; }
.serv-card { background: var(--white); padding: 1.75rem 1.5rem; transition: background .2s; }
.serv-card:hover { background: #FFFEF0; }
.serv-icon { width: 46px; height: 46px; background: var(--yellow); border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 1.3rem; margin-bottom: 1rem; }
.serv-card h3 { font-size: 1rem; font-weight: 800; margin-bottom: .4rem; }
.serv-card p { font-size: .83rem; color: var(--mid); font-weight: 500; line-height: 1.6; }

/* ── TIPOS DE EVENTO ── */
.eventos-top { padding: 0 1.2rem; }
.eventos-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1rem; margin-top: 2.5rem; }
.evento-card { border: 1.5px solid var(--border); border-radius: 16px; padding: 1.75rem; display: flex; flex-direction: column; gap: .5rem; }
.evento-card.evento-destaque { border-color: var(--yellow); border-width: 2px; background: #FFFEF5; }
.evento-icon { font-size: 1.8rem; }
.evento-card h3 { font-size: 1rem; font-weight: 800; }
.evento-card p { font-size: .83rem; color: var(--mid); font-weight: 500; line-height: 1.6; flex: 1; }

/* ── PACOTES ── */
#pacotes { background: var(--bg); }
.pkg-top { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 2.5rem; flex-wrap: wrap; gap: 1.5rem; padding: 0 1.2rem;}
.pkg-table { border: 1.5px solid var(--border); border-radius: 16px; overflow: hidden; background: var(--white); }
.pkg-row { display: grid; grid-template-columns: 1.8fr 2.5fr 1.8fr 1fr; gap: 2rem; align-items: center; border-bottom: 1px solid var(--border); padding: 1rem 1.5rem; }
.pkg-row:last-child { border-bottom: none; }
.pkg-row-header { background: var(--bg); font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); padding: .75rem 1.5rem; }
.pkg-row-featured { background: #FFFEF5; }
.pkg-col-name { display: flex; align-items: center; gap: .6rem; flex-wrap: wrap; }
.pkg-col-name strong { font-size: .9rem; font-weight: 800; }
.pkg-col-desc { font-size: .82rem; color: var(--mid); font-weight: 500; line-height: 1.5; }
.pkg-col-detail { font-size: .8rem; color: var(--muted); font-weight: 500; }
.pkg-col-cta { display: flex; justify-content: flex-end; white-space: nowrap; }
.pkg-num { width: 24px; height: 24px; min-width: 24px; background: var(--bg); border: 1.5px solid var(--border); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: .72rem; font-weight: 800; color: var(--mid); }
.pkg-num-yellow { background: var(--yellow); border-color: var(--yellow); color: var(--dark); }
.pkg-badge { background: var(--yellow); border-radius: 6px; padding: .2rem .6rem; font-size: .68rem; font-weight: 800; color: var(--dark); }
.pkg-note { font-size: .8rem; color: var(--muted); margin-top: 1rem; padding: 0 1.2rem;}

/* ── DIFERENCIAIS ── */
.dif-top { padding: 0 1.2rem;}
.dif-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; margin-top: 2.5rem; }
.dif-item { display: flex; flex-direction: column; gap: .4rem; padding: 1.5rem; background: var(--bg); border-radius: 12px; }
.dif-icon { font-size: 1.5rem; }
.dif-item strong { font-size: .95rem; font-weight: 800; }
.dif-item p { font-size: .83rem; color: var(--mid); font-weight: 500; line-height: 1.55; }

/* ── SOBRE ── */
#sobre { background: var(--bg); }
.sobre-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; }
.sobre-img-wrap { position: relative; }
.sobre-img { width: 100%; aspect-ratio: 3/4; object-fit: cover; object-position: top center; border-radius: 20px; display: block; }
.sobre-float { position: absolute; bottom: 1.5rem; left: -1.5rem; background: var(--yellow); border-radius: 12px; padding: .75rem 1.1rem; font-size: .8rem; font-weight: 800; box-shadow: 0 6px 20px rgba(0,0,0,.12); }
.sobre-float2 { position: absolute; top: 1.5rem; right: -1.5rem; background: var(--dark); color: var(--white); border-radius: 12px; padding: .75rem 1.1rem; font-size: .8rem; font-weight: 800; box-shadow: 0 6px 20px rgba(0,0,0,.18); }
.check-list { list-style: none; margin: 1.5rem 0 2rem; display: flex; flex-direction: column; gap: .7rem; }
.check-list li { display: flex; align-items: center; gap: .65rem; font-size: .9rem; font-weight: 500; color: var(--mid); }
.check-list li::before { content: ""; width: 18px; height: 18px; min-width: 18px; background: var(--yellow) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='9' height='9' viewBox='0 0 9 9'%3E%3Cpath d='M1.5 4.5l2 2L7.5 2' stroke='%230F0F0F' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") no-repeat center; border-radius: 50%; }

/* ── ATIVIDADES ── */
.ativ-header { display: flex; justify-content: space-between; align-items: flex-end; flex-wrap: wrap; gap: 1.5rem; margin-bottom: .5rem; padding: 0 1.2rem; }
.ativ-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: .75rem; margin-top: 2.5rem; }
.ativ-card { background: var(--bg); border-radius: 12px; padding: 1.2rem; }
.ativ-card.yellow { background: var(--yellow); }
.ativ-label { font-size: .65rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); margin-bottom: .75rem; }
.ativ-card.yellow .ativ-label { color: rgba(0,0,0,.45); }
.ativ-item { font-size: .83rem; font-weight: 500; color: var(--mid); padding: .3rem 0; border-bottom: 1px solid rgba(0,0,0,.06); }
.ativ-card.yellow .ativ-item { color: var(--dark); border-bottom-color: rgba(0,0,0,.1); font-weight: 600; }
.ativ-item:last-child { border-bottom: none; }
.ativ-tags { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 1.5rem; }
.ativ-tag { background: var(--bg); border-radius: 6px; padding: .3rem .75rem; font-size: .75rem; font-weight: 600; color: var(--mid); }

/* ── COBERTURA ── */
#cobertura { background: var(--bg); }
.cobertura-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center; }
.cobertura-tags { display: flex; flex-wrap: wrap; gap: .5rem; margin-top: 1.25rem; }
.cobertura-tags span { background: var(--white); border: 1px solid var(--border); border-radius: 6px; padding: .35rem .85rem; font-size: .8rem; font-weight: 600; color: var(--mid); }
.cobertura-note { font-size: .82rem; color: var(--muted); margin-top: 1rem; }
.cobertura-box { background: var(--white); border-radius: 20px; padding: 2.5rem; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 1rem; border: 1.5px solid var(--border); }
.cobertura-icon { font-size: 2.5rem; }
.cobertura-box strong { font-size: 1rem; font-weight: 800; }
.cobertura-box p { font-size: .85rem; color: var(--mid); font-weight: 500; line-height: 1.6; }

/* ── GALERIA ── */
#fotos { background: var(--white); }
.fotos-header { display: flex; justify-content: space-between; align-items: flex-end; flex-wrap: wrap; gap: 1rem; margin-bottom: 1.5rem; padding: 0 1.2rem;}
.fotos-grid { display: grid; grid-template-columns: repeat(4,1fr); grid-auto-rows: 220px; gap: .75rem; }
.fi { border-radius: 12px; overflow: hidden; }
.fi img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s; }
.fi:hover img { transform: scale(1.05); }
.fi-tall { grid-row: span 2; }
.fi-wide { grid-column: span 2; }
.fi-tall-wide { grid-column: span 2; grid-row: span 2; }

/* ── FAQ ── */
#faq { background: var(--bg); }
.faq-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: start; }
.faq-btn { margin-top: 1.5rem; }
.faq-list { display: flex; flex-direction: column; gap: .5rem; }
.faq-item { border: 1px solid var(--border); border-radius: 12px; overflow: hidden; background: var(--white); }
.faq-q { width: 100%; background: var(--white); border: none; padding: 1rem 1.25rem; text-align: left; font-family: "Plus Jakarta Sans", sans-serif; font-size: .9rem; font-weight: 700; color: var(--dark); cursor: pointer; display: flex; justify-content: space-between; align-items: center; gap: 1rem; transition: background .15s; }
.faq-q:hover { background: var(--bg); }
.faq-q.open { background: var(--bg); }
.faq-q span { font-size: 1.2rem; font-weight: 400; flex-shrink: 0; transition: transform .2s; }
.faq-q.open span { transform: rotate(45deg); }
.faq-a { display: none; padding: 1rem 1.25rem 1rem; font-size: .85rem; color: var(--mid); font-weight: 500; line-height: 1.65; }
.faq-a.open { display: block; }

/* ── CONTATO ── */
#contato { background: var(--bg); }
.cta-box { background: var(--dark); border-radius: 24px; padding: 4.5rem; text-align: center; }
.cta-eyebrow { display: inline-block; background: var(--yellow); border-radius: 100px; padding: .3rem .9rem; font-size: .72rem; font-weight: 800; color: var(--dark); margin-bottom: 1rem; letter-spacing: .05em; text-transform: uppercase; }
.cta-title { font-size: 2.4rem; font-weight: 800; letter-spacing: -.04em; color: var(--white); margin-bottom: .75rem; line-height: 1.15; }
.cta-sub { font-size: 1rem; color: rgba(255,255,255,.55); font-weight: 500; line-height: 1.7; max-width: 420px; margin: 0 auto 2.5rem; }
.cta-btns { display: flex; gap: .75rem; justify-content: center; flex-wrap: wrap; margin-bottom: 2.5rem; }
.cta-divider { border: none; border-top: 1px solid rgba(255,255,255,.1); margin: 0 0 2rem; }
.cta-info { display: flex; justify-content: center; flex-wrap: wrap; }
.cta-info-item { display: flex; align-items: center; gap: .5rem; padding: .65rem 1.75rem; border-right: 1px solid rgba(255,255,255,.1); }
.cta-info-item:last-child { border-right: none; }
.cta-info-item span, .cta-info-item a { font-size: .87rem; color: rgba(255,255,255,.65); font-weight: 500; text-decoration: none; }
.cta-info-item a:hover { color: #fff; }

/* ── FOOTER ── */
footer { border-top: 2.5px solid var(--yellow); padding: 1.5rem 2.5rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; background: var(--white); }
.footer-logo img { height: 48px; width: auto; }
.footer-copy { font-size: .78rem; color: var(--muted); }
.footer-links { display: flex; gap: 1.5rem; }
.footer-links a { font-size: .78rem; color: var(--muted); text-decoration: none; font-weight: 600; }
.footer-links a:hover { color: var(--dark); }

/* ── FLOAT WPP ── */
.wpp-float { position: fixed; bottom: 1.5rem; right: 1.5rem; z-index: 999; width: 54px; height: 54px; background: #25D366; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; text-decoration: none; box-shadow: 0 4px 20px rgba(37,211,102,.4); transition: transform .2s, box-shadow .2s; }
.wpp-float:hover { transform: translateY(-2px) scale(1.08); box-shadow: 0 8px 28px rgba(37,211,102,.5); }

/* ── RESPONSIVE 960px ── */
@media (max-width: 960px) {
  nav { padding: 0 1.5rem; }
  .nav-links { display: none; position: fixed; top: 64px; left: 0; right: 0; background: var(--white); flex-direction: column; padding: 1.5rem; gap: 1rem; border-bottom: 2px solid var(--yellow); z-index: 99; box-shadow: 0 8px 24px rgba(0,0,0,.08); }
  .nav-links.open { display: flex; }
  .hamburger { display: flex; }
  .hero { grid-template-columns: 1fr; padding: 90px 1.5rem 56px; min-height: auto; gap: 2rem; }
  .hero h1 { font-size: 2.3rem; }
  .hero-desc { max-width: 100%; }
  .hero-card { display: none; }
  .numbers-strip { padding: 2rem 1.5rem; }
  .numbers-inner { grid-template-columns: repeat(2,1fr); gap: 1.5rem; }
  .wrap { padding: 0 1.5rem; }
  section { padding: 4rem 0; }
  .steps-grid { grid-template-columns: 1fr; }
  .step-arrow { display: none; }
  .serv-top { flex-direction: column; align-items: flex-start; }
  .serv-grid { grid-template-columns: 1fr 1fr; }
  .eventos-grid { grid-template-columns: 1fr; }
  .pkg-top { flex-direction: column; align-items: flex-start; }
  .pkg-row { grid-template-columns: 1fr; gap: .4rem; }
  .pkg-row-header { display: none; }
  .pkg-col-cta { justify-content: flex-start; margin-top: .25rem; }
  .dif-grid { grid-template-columns: 1fr 1fr; }
  .sobre-grid { grid-template-columns: 1fr; gap: 2rem; }
  .sobre-img { aspect-ratio: 4/3; }
  .sobre-float, .sobre-float2 { display: none; }
  .ativ-header { flex-direction: column; align-items: flex-start; }
  .ativ-grid { grid-template-columns: 1fr 1fr; }
  .cobertura-grid { grid-template-columns: 1fr; gap: 2rem; }
  .fotos-header { flex-direction: column; align-items: flex-start; gap: .75rem; }
  .fotos-grid { grid-template-columns: 1fr 1fr; grid-auto-rows: 160px; }
  .fi-tall-wide, .fi-wide { grid-column: span 2; }
  .fi-tall { grid-row: span 1; }
  .faq-grid { grid-template-columns: 1fr; gap: 2rem; }
  .cta-box { padding: 2.5rem 1.75rem; }
  .cta-title { font-size: 1.8rem; }
  .cta-info { flex-direction: column; }
  .cta-info-item { border-right: none; border-bottom: 1px solid rgba(255,255,255,.1); justify-content: center; }
  .cta-info-item:last-child { border-bottom: none; }
  footer { padding: 1.4rem 1.5rem; flex-direction: column; align-items: flex-start; gap: .75rem; }
}

/* ── RESPONSIVE 580px ── */
@media (max-width: 580px) {
  .hero h1 { font-size: 2rem; }
  .hero-stats { gap: 1.5rem; }
  .hero-stat strong { font-size: 1.2rem; }
  .hero-stat span { font-size: 0.65rem; }
  .numbers-inner { grid-template-columns: repeat(2,1fr); }
  .num-item strong { font-size: 1.5rem; }
  .serv-grid { grid-template-columns: 1fr; }
  .dif-grid { grid-template-columns: 1fr; }
  .ativ-grid { grid-template-columns: 1fr 1fr; }
  .fotos-grid { grid-auto-rows: 120px; }
  .cta-box { padding: 2rem 1.25rem; }
  .cta-title { font-size: 1.6rem; }
  .cta-btns { flex-direction: column; }
  .btn-wpp, .btn-ig { justify-content: center; width: 100%; }
}
