:root{
  --azul:#0F5298;
  --azul-escuro:#0B3D73;
  --laranja:#E8701A;
  --laranja-2:#F19116;
  --verde:#3A8E43;
  --crema:#FCFAF7;
  --areia:#F4EFEA;
  --noite:#0B1220;

  --texto: rgba(11,18,32,.86);
  --texto-fraco: rgba(11,18,32,.64);
  --borda: rgba(11,18,32,.12);
  --radius: 26px;

  --shadow-soft: 0 16px 40px rgba(11,18,32,.10);
  --shadow-glow: 0 12px 32px rgba(232,112,26,.22);
  --shadow-azul: 0 12px 32px rgba(15,82,152,.18);

  --font-sans: "Plus Jakarta Sans", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --font-serif: "Lora", ui-serif, Georgia, serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: var(--font-sans);
  background: var(--crema);
  color: var(--texto);
  line-height: 1.5;
}
img{max-width:100%;height:auto}
a{color:inherit}

.container{max-width:1120px;margin:0 auto;padding:0 16px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip:focus{position:fixed;top:12px;left:12px;z-index:999;background:var(--crema);padding:10px 14px;border-radius:16px;box-shadow:var(--shadow-soft)}

.font-serif{font-family: var(--font-serif)}
.t-azul{color:var(--azul)}
.t-laranja{color:var(--laranja)}
.t-verde{color:var(--verde)}

/* Reading progress */
#readProgress{
  position: fixed;
  top: 0;
  left: 0;
  height: 3px;
  width: 0%;
  z-index: 1000;
  background: linear-gradient(90deg, var(--laranja), var(--laranja-2));
  transition: width 90ms linear;
}

/* Header */
.header{
  position:sticky;top:0;z-index:50;
  background: color-mix(in srgb, var(--crema) 78%, white 22%);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--borda);
}
.header.is-shadow{box-shadow: var(--shadow-soft)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:66px;gap:16px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand img{width:42px;height:42px;border-radius:14px;background:white;border:1px solid var(--borda)}
.brand strong{display:block;font-size:14px;letter-spacing:.2px}
.brand span{display:block;font-size:12px;color:var(--texto-fraco)}

.nav{display:none;gap:18px;align-items:center}
.nav a{font-size:14px;text-decoration:none;color:var(--texto-fraco);font-weight:700}
.nav a:hover{color:var(--azul)}

.header-actions{display:flex;align-items:center;gap:10px}
.btn{
  border:1px solid var(--borda);
  background:rgba(255,255,255,.55);
  color:var(--noite);
  padding:10px 14px;
  border-radius: 18px;
  font-weight:800;
  text-decoration:none;
  display:inline-flex;align-items:center;justify-content:center;
  gap:8px;
  cursor:pointer;
}
.btn:hover{background:rgba(255,255,255,.75)}
.btn-primary{background:var(--laranja);border-color:transparent;color:white;box-shadow:var(--shadow-glow)}
.btn-primary:hover{filter:brightness(.98)}
.btn-azul{background:var(--azul);border-color:transparent;color:white;box-shadow:var(--shadow-azul)}
.btn-lg{padding:12px 16px;border-radius:20px}

.icon-btn{
  width:44px;height:44px;border-radius:18px;
  border:1px solid var(--borda);
  background:rgba(255,255,255,.45);
}
.icon-btn:hover{background:rgba(255,255,255,.7)}

.mobile-menu{
  display:none;
  border-top:1px solid var(--borda);
  background: color-mix(in srgb, var(--crema) 78%, white 22%);
}
.mobile-menu a{display:block;padding:12px 16px;text-decoration:none;color:var(--texto-fraco);font-weight:800}
.mobile-menu a:hover{color:var(--azul)}
.mobile-menu .menu-cta{padding:10px 16px 16px}

/* Hero */
.hero{
  position:relative;
  overflow:hidden;
  padding: 44px 0 26px;
}
.hero::before{
  content:"";
  position:absolute;inset:-40px -40px auto -40px;height:360px;
  background:
    radial-gradient(closest-side at 16% 20%, rgba(241,145,22,.22), transparent 62%),
    radial-gradient(closest-side at 70% 10%, rgba(15,82,152,.18), transparent 56%),
    radial-gradient(closest-side at 80% 70%, rgba(58,142,67,.16), transparent 55%);
  pointer-events:none;
  filter: blur(2px);
}
.hero-grid{display:grid;grid-template-columns:1fr;gap:22px;position:relative}
.badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid var(--borda);
  background: rgba(255,255,255,.55);
  font-size:12px;
  font-weight:900;
  color: rgba(11,18,32,.70);
}
.badge-stars{color: var(--laranja-2); letter-spacing: 2px}
.pill{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.6);
  border:1px solid var(--borda);
  border-radius:999px;
  padding:8px 12px;
  font-size:12px;font-weight:900;color:rgba(11,18,32,.72);
}
.pill i{width:9px;height:9px;border-radius:50%;background:var(--laranja);display:inline-block}
.hero-title{
  margin:12px 0 0;
  font-size: 40px;
  line-height: 1.06;
  color: var(--noite);
  letter-spacing: -0.8px;
  font-family: var(--font-serif);
}
.hero p{margin:12px 0 0;color:var(--texto-fraco);max-width:62ch}
.hero-ctas{display:flex;flex-direction:column;gap:10px;margin-top:18px}
.hero-cards{display:grid;grid-template-columns:1fr;gap:12px;margin-top:18px}
.mini{
  background:rgba(255,255,255,.55);
  border:1px solid var(--borda);
  border-radius: var(--radius);
  padding:14px 16px;
}
.mini b{display:block;color:var(--noite)}
.mini small{display:block;color:var(--texto-fraco);margin-top:2px;font-weight:650}

.selos{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:16px}
.selo{
  border: 1.5px solid rgba(15,82,152,0.20);
  background: rgba(255,255,255,.55);
  border-radius: 18px;
  padding: 12px;
  text-align:center;
}
.selo-num{font-family: var(--font-serif);font-weight:800;font-size:22px}
.selo-label{font-size:12px;color:rgba(11,18,32,.58);font-weight:750;margin-top:2px}

.searchbox{
  background: rgba(252,250,247,.70);
  border:1px solid var(--borda);
  border-radius: calc(var(--radius) + 6px);
  padding:14px;
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(16px);
}
.searchrow{display:flex;flex-direction:column;gap:10px}
.field{display:grid;gap:6px}
.field label{font-weight:850;font-size:12px;color:rgba(11,18,32,.76)}
.input, .select{
  width:100%;
  border-radius: 16px;
  border: 1px solid var(--borda);
  background: rgba(255,255,255,.82);
  padding: 12px 12px;
  outline:none;
  font-size:14px;
}
.input:focus, .select:focus{border-color: color-mix(in srgb, var(--azul) 65%, white); box-shadow: 0 0 0 4px rgba(15,82,152,.16)}

.filters{
  display:grid;
  grid-template-columns: 1fr;
  gap:10px;
  margin-top:12px;
}
.filters-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
}
.muted{color:var(--texto-fraco)}
.helper{font-size:12px;color:rgba(11,18,32,.56);margin-top:10px}

/* Section */
section{padding: 34px 0}
.section-title{display:flex;align-items:flex-end;justify-content:space-between;gap:14px}
.section-title h2{margin:0;font-size:28px;color:var(--noite);letter-spacing:-.4px;font-family: var(--font-serif)}
.section-title p{margin:6px 0 0;color:var(--texto-fraco)}
.divider{border-top:1px solid var(--borda)}

/* Cards */
.grid{display:grid;gap:14px}
.grid-3{grid-template-columns:1fr}
.card{
  border:1px solid var(--borda);
  background: rgba(255,255,255,.60);
  border-radius: var(--radius);
  overflow:hidden;
  box-shadow: 0 10px 24px rgba(11,18,32,.08);
}
.card:hover{box-shadow: 0 24px 60px rgba(11,18,32,.14)}
.thumb{aspect-ratio: 16/10; background: var(--areia); display:block; object-fit:cover}
.card-body{padding:14px 16px}
.tag{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:900;border-radius:999px;padding:6px 10px;background:rgba(15,82,152,.10);color:var(--azul)}
.tag.orange{background:rgba(232,112,26,.12);color:var(--laranja)}
.tag.green{background:rgba(58,142,67,.12);color:var(--verde)}
.card h3{margin:10px 0 0;font-size:18px;color:var(--noite);font-family: var(--font-serif)}
.meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.chip{font-size:12px;font-weight:850;color:rgba(11,18,32,.70);background:rgba(11,18,32,.06);border:1px solid rgba(11,18,32,.10);border-radius:999px;padding:6px 10px}
.price{margin-top:10px;font-weight:1000;color:var(--noite)}
.card-actions{margin-top:12px;display:flex;gap:10px}
.btn-sm{padding:10px 12px;border-radius:16px;font-size:13px}
.btn-outline{background:transparent}

/* About / steps */
.steps{display:grid;gap:12px}
.step{
  background: rgba(255,255,255,.55);
  border:1px solid var(--borda);
  border-radius: var(--radius);
  padding:16px;
  box-shadow: 0 10px 24px rgba(11,18,32,.06);
}
.step b{display:flex;align-items:center;gap:10px;color:var(--noite)}
.num{width:34px;height:34px;border-radius:14px;background:var(--laranja);color:white;display:inline-flex;align-items:center;justify-content:center;font-weight:1000}
.step p{margin:10px 0 0;color:var(--texto-fraco)}

/* Testimonials / FAQ / CTA */
.stars{color: var(--laranja-2); letter-spacing: 2px; font-weight: 900}
.testimonial{padding:18px}
.testimonial blockquote{margin:10px 0 0;color:rgba(11,18,32,.74);font-size:14px;line-height:1.6;font-style:italic}
.testimonial figcaption{display:flex;align-items:center;gap:10px;margin-top:14px;font-weight:900;color:var(--noite)}
.avatar{
  width:36px;height:36px;border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;
  font-weight:1000;
  background: rgba(15,82,152,.12);
}
.avatar.t-laranja{background: rgba(232,112,26,.12)}
.avatar.t-verde{background: rgba(58,142,67,.12)}
.cta-band{
  margin-top: 16px;
  border-radius: var(--radius);
  background: var(--azul);
  color: white;
  padding: 18px;
  display:flex;
  gap: 14px;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  box-shadow: var(--shadow-azul);
}
.cta-title{font-weight:900;font-size:20px}
.cta-sub{opacity:.78;margin-top:4px}
.faq{display:grid;gap:10px}
.faq-item{
  border:1px solid var(--borda);
  background: rgba(255,255,255,.60);
  border-radius: 18px;
  padding: 12px 14px;
  box-shadow: 0 10px 24px rgba(11,18,32,.06);
}
.faq-item summary{cursor:pointer;font-weight:900;color:var(--noite);list-style:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item p{margin:10px 0 0;color:rgba(11,18,32,.70);font-size:14px}

/* Modal */
.dialog-backdrop{
  position:fixed;inset:0;background:rgba(11,18,32,.58);
  display:none;align-items:flex-end;justify-content:center;
  z-index:1000;
  padding: 14px;
}
.dialog{
  width: min(980px, 100%);
  background: var(--crema);
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 24px;
  box-shadow: 0 30px 80px rgba(0,0,0,.35);
  overflow:hidden;
  max-height: 92vh;
  display:grid;
  grid-template-rows:auto 1fr;
}
.dialog-head{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:14px 16px;border-bottom:1px solid var(--borda);
  background: color-mix(in srgb, var(--crema) 84%, white 16%);
}
.dialog-head strong{color:var(--noite)}
.dialog-body{overflow:auto}
.dialog-content{padding:16px}
.gallery{display:grid;gap:10px}
.gallery-main{border-radius:18px;overflow:hidden;border:1px solid var(--borda);background:white}
.gallery-main img{width:100%;height:auto;display:block;aspect-ratio:16/10;object-fit:cover}
.thumbs{display:flex;gap:8px;flex-wrap:wrap}
.thumbs button{
  padding:0;border:1px solid var(--borda);background:white;border-radius:14px;
  overflow:hidden;cursor:pointer;
  width:78px;height:52px;
}
.thumbs img{width:100%;height:100%;object-fit:cover;display:block}
.dialog-grid{display:grid;gap:14px}
.kvs{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.kv{background:rgba(255,255,255,.65);border:1px solid var(--borda);border-radius:18px;padding:12px}
.kv small{display:block;color:rgba(11,18,32,.52);font-weight:850;font-size:11px}
.kv b{display:block;color:var(--noite);margin-top:4px}
.video-wrap{border:1px solid var(--borda);border-radius:18px;overflow:hidden;background:rgba(255,255,255,.65)}
.video-wrap iframe,.video-wrap video{width:100%;aspect-ratio:16/9;display:block;border:0;background:black}

/* Footer */
.footer{
  background: var(--noite);
  color: rgba(255,255,255,.90);
  padding: 32px 0;
}
.footer-grid{display:grid;gap:18px}
.footer p{margin:10px 0 0;color:rgba(255,255,255,.68)}
.footer a{color:rgba(255,255,255,.86);text-decoration:none}
.footer a:hover{color:white}
.fineprint{margin-top:18px;padding-top:14px;border-top:1px solid rgba(255,255,255,.12);display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;color:rgba(255,255,255,.55);font-size:12px}

/* Floating WhatsApp */
.wa-float{
  position:fixed;right:16px;bottom:16px;z-index:900;
  width:56px;height:56px;border-radius:999px;
  background:#25D366;display:flex;align-items:center;justify-content:center;
  box-shadow: 0 10px 26px rgba(37,211,102,.35);
  border: 1px solid rgba(255,255,255,.22);
}
.wa-float svg{width:26px;height:26px;fill:white}
.wa-float:focus{outline:3px solid rgba(37,211,102,.35);outline-offset:4px}

/* To top */
.to-top{
  position:fixed;
  right:16px;
  bottom:86px;
  z-index:900;
  width:44px;
  height:44px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.22);
  background: rgba(11,18,32,.84);
  color: white;
  box-shadow: var(--shadow-soft);
  opacity: 0;
  pointer-events: none;
  transition: opacity 220ms ease;
}
.to-top.visible{opacity:1;pointer-events:auto}

/* Reveal */
.reveal{opacity:0;transform: translateY(16px);transition: opacity 700ms ease, transform 700ms ease}
.reveal.is-visible{opacity:1;transform: translateY(0)}

@media (min-width: 900px){
  .nav{display:flex}
  .hero-grid{grid-template-columns: 1.2fr .8fr;gap:26px;align-items:start}
  .hero-title{font-size:56px}
  .hero-ctas{flex-direction:row;align-items:center}
  .hero-cards{grid-template-columns:repeat(3,1fr)}
  .searchrow{flex-direction:row;align-items:end}
  .searchrow .field{flex:1}
  .grid-3{grid-template-columns:repeat(3, 1fr)}
  .steps{grid-template-columns:repeat(3,1fr)}
  .dialog-backdrop{align-items:center}
  .dialog-content{padding:18px}
  .dialog-grid{grid-template-columns: 1.1fr .9fr}
  .footer-grid{grid-template-columns: 1.2fr .8fr .8fr}
}

/* Zoom Overlay */
.zoom-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.9);
  z-index: 2000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  cursor: zoom-out;
}

.zoom-overlay[aria-hidden="false"] {
  display: flex;
}

.zoom-overlay img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  border-radius: 8px;
  box-shadow: 0 0 30px rgba(0, 0, 0, 0.5);
  cursor: default;
}

.zoom-close {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: none;
  background: rgba(255, 255, 255, 0.2);
  color: white;
  font-size: 32px;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s;
}

.zoom-close:hover {
  background: rgba(255, 255, 255, 0.4);
}

.gallery-main img {
  cursor: zoom-in;
  transition: opacity 0.2s;
}

.gallery-main img:hover {
  opacity: 0.9;
}
