/* =========================================================
   VARIÁVEIS
========================================================= */
:root{
  --bordo:#4A1D2A;
  --espresso:#2B1F1A;
  --off:#FAF9F7;

  --line: rgba(43,31,26,.14);
  --glass: rgba(255,255,255,.08);
  --shadow: 0 20px 60px rgba(0,0,0,.20);

  --radius: 18px;
  --container: 1120px;

  --serif: "Canela", ui-serif, Georgia, "Times New Roman", serif;
  --sans: "Inter", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

/* =========================================================
   RESET + CORREÇÃO DE OVERFLOW
========================================================= */
*{margin:0;padding:0;box-sizing:border-box;}

html,body{
  width:100%;
  max-width:100%;
  overflow-x:hidden;
}

body{
  background: var(--off);
  font-family: var(--sans);
  color: var(--espresso);
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
}

img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}

.container{
  width:min(var(--container), 100%);
  margin:0 auto;
  padding:0 24px;
}

/* =========================================================
   TOPBAR
========================================================= */
.topbar{
  position:fixed;
  inset:0 0 auto 0;
  height:78px;
  z-index:50;
  background:transparent;
  transition: background .35s ease, backdrop-filter .35s ease;
}

.topbar.scrolled{
  background: rgba(250,249,247,.72);
  backdrop-filter: blur(14px);
  border-bottom:1px solid var(--line);
}

.topbar-inner{
  height:78px;
  display:flex;
  align-items:center;
  justify-content:space-between;
}

.brand{
  display:flex;
  flex-direction:column;
}

.brand-mark{
  font-family: var(--serif);
  font-size:14px;
  letter-spacing:.22em;
}

.brand-sub{
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  opacity:.7;
}

.nav{
  display:flex;
  gap:18px;
  font-size:13px;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.nav a{opacity:.78;}
.nav a:hover{opacity:1;}

.nav-cta{
  padding:12px 14px;
  border:1px solid var(--line);
  border-radius:999px;
}

/* =========================================================
   HERO (DESKTOP)
========================================================= */
.hero{
  min-height:100vh;
  color:#fff;
  background:
    radial-gradient(1200px 600px at 20% 20%, rgba(74,29,42,.55), transparent 60%),
    linear-gradient(rgba(0,0,0,.45), rgba(0,0,0,.45)),
    url("https://images.unsplash.com/photo-1600607687920-4e2a09cf159d?auto=format&fit=crop&w=1800&q=80")
    center/cover;
  display:flex;
  align-items:center;
  padding-top:78px;
}

.hero-grid{
  display:grid;
  grid-template-columns: 1.25fr .75fr;
  gap:48px;
  padding:72px 0;
  align-items:end;
}

.eyebrow{
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  opacity:.85;
  margin-bottom:18px;
}

.hero h1{
  font-family: var(--serif);
  font-size: clamp(44px, 5vw, 64px);
  font-weight:400;
  line-height:1.02;
  margin-bottom:18px;
}

.lead{
  font-size:16px;
  line-height:1.7;
  max-width:42ch;
}

.hero-actions{
  display:flex;
  gap:12px;
  margin-top:26px;
}

.btn{
  display:inline-flex;
  justify-content:center;
  align-items:center;
  padding:14px 18px;
  border-radius:999px;
  font-size:13px;
  letter-spacing:.12em;
  text-transform:uppercase;
  border:1px solid transparent;
}

.btn-primary{
  background:#fff;
  color:#1a1412;
}

.btn-ghost{
  background:transparent;
  border-color: rgba(255,255,255,.28);
  color:#fff;
}

.hero-meta{
  display:flex;
  gap:18px;
  margin-top:28px;
  padding-top:20px;
  border-top:1px solid rgba(255,255,255,.18);
  flex-wrap:wrap;
}

.meta-item{min-width:0;}

.meta-label{
  font-size:11px;
  letter-spacing:.16em;
  text-transform:uppercase;
  opacity:.7;
}

.meta-value{font-size:14px;}

/* HERO CARD */
.hero-card{
  background: var(--glass);
  border:1px solid rgba(255,255,255,.18);
  border-radius: var(--radius);
  padding:22px;
  box-shadow: var(--shadow);
}

.hero-card-title{
  font-family: var(--serif);
  font-size:20px;
  margin-bottom:10px;
}

/* =========================================================
   SECTIONS
========================================================= */
.section{padding:88px 0;}

/* MANIFESTO */
.manifesto-text{
  font-family: var(--serif);
  font-size:28px;
  line-height:1.25;
  max-width:28ch;
}

.manifesto-grid{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:26px;
}

.pill{
  border:1px solid var(--line);
  border-radius:999px;
  padding:10px 14px;
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
}

/* =========================================================
   GALERIA
========================================================= */
.gallery-grid{
  display:grid;
  grid-template-columns: 2fr 1fr;
  grid-template-rows: 320px 320px;
  gap:16px;
}

.gallery-grid figure{
  overflow:hidden;
  border-radius: var(--radius);
  border:1px solid var(--line);
}

.gallery-grid img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.g1{grid-row:span 2;}

/* =========================================================
   AUTOR (PROJETISTA)
========================================================= */
.author-grid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:56px;
  align-items:center;
}

.author-text h2{
  font-family: var(--serif);
  font-size:36px;
}

.author-media{
  max-width:320px;
  position:relative;
}

.author-media img{
  width:100%;
  border-radius: var(--radius);
}

.author-caption{
  position:absolute;
  left:14px;
  bottom:14px;
  padding:12px 14px;
  border-radius:14px;
  background: rgba(250,249,247,.78);
  border:1px solid var(--line);
}

.cap-title{
  font-family: var(--serif);
  font-size:16px;
}

.cap-sub{
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  opacity:.75;
}

/* =========================================================
   CTA
========================================================= */
.cta{
  background:
    radial-gradient(900px 500px at 20% 20%, rgba(255,255,255,.08), transparent 65%),
    linear-gradient(135deg, var(--bordo), var(--espresso));
  color:#fff;
}

.cta-grid{
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap:40px;
}

/* =========================================================
   FOOTER — VERSÃO PREMIUM
========================================================= */
.footer{
  background: linear-gradient(180deg, #1f1512 0%, #241815 100%);
  color:#fff;
  padding: 56px 0 48px;
}

.footer-inner{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap: 24px;
}

.footer-brand{
  display:flex;
  flex-direction:column;
  gap: 8px;
}

.footer .brand-mark{
  font-family: var(--serif);
  font-size:15px;
  letter-spacing:.24em;
}

.footer-sub{
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  opacity:.7;
}

.footer-copy{
  font-size:12px;
  opacity:.7;
  text-align:right;
  max-width: 360px;
}

/* =========================================================
   CTA FORM — MINIMAL, AUTORAL
========================================================= */

.cta-form--minimal{
  display:flex;
  flex-direction:column;
  gap:18px;
  max-width:420px;
}

.cta-form--minimal label{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.cta-form--minimal span{
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  opacity:.75;
}

.cta-form--minimal input{
  background:transparent;
  border:none;
  border-bottom:1px solid rgba(255,255,255,.35);
  padding:14px 0;
  font-size:15px;
  color:#fff;
}

.cta-form--minimal input::placeholder{
  color: rgba(255,255,255,.45);
}

.cta-form--minimal input:focus{
  outline:none;
  border-bottom-color:#fff;
}

.cta-form--minimal .btn-light{
  margin-top:10px;
  background:#fff;
  color:var(--espresso);
  border:none;
  font-weight:500;
  letter-spacing:.14em;
}

.cta-form--minimal .form-mini{
  font-size:11px;
  opacity:.6;
  margin-top:4px;
}


/* =========================================================
   MOBILE — LUXO, LIMPO, FINAL
========================================================= */
@media (max-width: 980px){

  /* Topo */
  .nav{display:none;}
  .container{padding:0 18px;}

  /* HERO */
  .hero{
    min-height:auto;
    display:block;
    padding-top:78px;
    padding-bottom:36px;
  }

  .hero-grid{
    display:block;
    padding:48px 0 0;
  }

  .eyebrow{display:none;}
  .hero-meta{display:none;}
  .btn-ghost{display:none;}

  .hero h1{
    font-size:34px;
    line-height:1.06;
  }

  .lead{
    max-width:100%;
    margin-bottom:18px;
  }

  .hero-actions{
    flex-direction:column;
    gap:10px;
  }

  .btn{width:100%;}

  /* GALERIA */
  .gallery-grid{
    grid-template-columns:1fr;
    grid-template-rows:auto;
  }

  .g1{grid-row:auto;}
  .gallery-grid figure{height:280px;}

  /* AUTOR */
  .author-grid{
    grid-template-columns:1fr;
    gap:26px;
  }

  .author-media{max-width:100%;}

  .author-caption{
    position:static;
    margin-top:12px;
    background:none;
    border:none;
    padding:0;
  }

  /* CTA */
  .cta-grid{
    grid-template-columns:1fr;
    gap:24px;
  }

  .cta h2{font-size:32px;}

  /* FOOTER */
  .footer{
    padding:28px 0;
  }

  .footer-inner{
    flex-direction:column;
    align-items:center;
    text-align:center;
    gap:8px;
  }

  .footer-sub{display:none;}

  .footer-copy{
    font-size:11px;
    opacity:.7;
  }

  /* FOOTER MOBILE — ELEGANTE */
  .footer{
    padding: 40px 0 32px;
  }

  .footer-inner{
    flex-direction:column;
    align-items:center;
    text-align:center;
    gap: 14px;
  }

  .footer-copy{
    text-align:center;
    font-size:11px;
    max-width: 100%;
  }

  /* HERO — LIMPEZA VISUAL MOBILE */
  @media (max-width: 980px){

    /* Esconde o texto longo no topo */
    .lead{
      display:none;
    }

    /* Esconde o card decorativo no topo */
    .hero-card{
      display:none;
    }

}


}
