/* =========================================================================
   PRAGMMA × CCBF — Sistema visual compartilhado
   Herda a identidade do Centro Comercial Beija-Flor
   Verde #566049 · Branco #F4F2EC · Bege #B69876 · Mr Eaves Mod OT
   ========================================================================= */

@font-face{font-family:'Mr Eaves Mod OT';font-weight:300;font-display:swap;
  src:local('Mr Eaves Mod OT Light'),url('fonts/MrEavesModOT-Light.otf') format('opentype');}
@font-face{font-family:'Mr Eaves Mod OT';font-weight:400;font-display:swap;
  src:local('Mr Eaves Mod OT Reg'),url('fonts/MrEavesModOT-Reg.otf') format('opentype');}
@font-face{font-family:'Mr Eaves Mod OT';font-weight:500;font-display:swap;
  src:local('Mr Eaves Mod OT Book'),url('fonts/MrEavesModOT-Book.otf') format('opentype');}
@font-face{font-family:'Mr Eaves Mod OT';font-weight:700;font-display:swap;
  src:local('Mr Eaves Mod OT Bold'),url('fonts/MrEavesModOT-Bold.otf') format('opentype');}

:root{
  --verde:#566049; --verde-deep:#3f4836; --verde-ink:#2a3024;
  --branco:#F4F2EC; --branco-pure:#fbfaf6;
  --bege:#B69876; --bege-soft:#cbb398; --bege-pale:#e7dccd;
  --line:rgba(86,96,73,.16);
  --font:'Mr Eaves Mod OT','Jost','Century Gothic',system-ui,-apple-system,'Segoe UI',sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
  --shadow:0 30px 80px -34px rgba(42,48,36,.45);
  --shadow-soft:0 18px 44px -24px rgba(42,48,36,.3);
  --maxw:1080px;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--font); font-weight:300; line-height:1.6;
  background:var(--branco); color:var(--verde-ink);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img,svg{display:block;max-width:100%;}
a{color:var(--verde);text-decoration:none;}

/* ---------- Tipografia ---------- */
.eyebrow{font-weight:400;letter-spacing:.4em;text-transform:uppercase;
  font-size:clamp(.6rem,1vw,.74rem);color:var(--bege);}
h1,h2,h3,h4{font-weight:400;color:var(--verde);line-height:1.05;letter-spacing:-.01em;}
h1{font-size:clamp(2.6rem,6vw,4.6rem);}
h2{font-size:clamp(2rem,4.4vw,3.2rem);}
h3{font-size:clamp(1.3rem,2.4vw,1.7rem);}
h4{font-size:clamp(1.05rem,1.7vw,1.22rem);}
p{font-size:clamp(1rem,1.3vw,1.12rem);color:var(--verde-ink);}
strong,b{font-weight:500;color:var(--verde-deep);}
.lead{font-size:clamp(1.12rem,1.7vw,1.35rem);color:var(--verde-deep);font-weight:300;}
.muted{color:var(--verde);opacity:.72;}
.accent{color:var(--bege);}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,48px);}
section{padding:clamp(48px,8vw,104px) 0;}
.section-tag{display:flex;align-items:center;gap:14px;margin-bottom:18px;}
.section-tag::before{content:"";width:34px;height:1px;background:var(--bege);}
.grid{display:grid;gap:clamp(18px,2.4vw,28px);}
.g2{grid-template-columns:repeat(2,1fr);}
.g3{grid-template-columns:repeat(3,1fr);}
.g4{grid-template-columns:repeat(4,1fr);}
@media(max-width:860px){.g2,.g3,.g4{grid-template-columns:1fr;}}

/* ---------- Topbar ---------- */
.topbar{position:sticky;top:0;z-index:50;background:rgba(244,242,236,.86);
  backdrop-filter:blur(12px);border-bottom:1px solid var(--line);}
.topbar__in{max-width:var(--maxw);margin:0 auto;padding:14px clamp(20px,5vw,48px);
  display:flex;align-items:center;justify-content:space-between;gap:20px;}
.topbar img{height:34px;width:auto;}
.topbar__nav{display:flex;gap:22px;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;}
.topbar__nav a{color:var(--verde);opacity:.75;transition:opacity .2s;}
.topbar__nav a:hover{opacity:1;}
@media(max-width:720px){.topbar__nav{display:none;}}

/* ---------- Hero ---------- */
.hero{background:var(--verde);color:var(--branco);position:relative;overflow:hidden;}
.hero::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(120% 90% at 80% 10%,rgba(182,152,118,.22),transparent 60%);}
.hero .wrap{position:relative;z-index:1;}
.hero h1,.hero h2{color:var(--branco);}
.hero .eyebrow{color:var(--bege-soft);}
.hero p{color:rgba(244,242,236,.82);}
.hero__logo{height:40px;margin-bottom:34px;}

/* ---------- Cards ---------- */
.card{background:var(--branco-pure);border:1px solid var(--line);border-radius:18px;
  padding:clamp(22px,3vw,34px);box-shadow:var(--shadow-soft);}
.card h3,.card h4{margin-bottom:10px;}
.card--green{background:var(--verde);color:var(--branco);border-color:transparent;}
.card--green h3,.card--green h4{color:var(--branco);}
.card--green p,.card--green li{color:rgba(244,242,236,.85);}
.card--outline{background:transparent;box-shadow:none;}
.kicker{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--bege);font-weight:500;}

/* ---------- Stat ---------- */
.stat__num{font-size:clamp(2.6rem,6vw,4rem);font-weight:300;color:var(--verde);line-height:1;}
.hero .stat__num{color:var(--branco);}
.stat__lbl{font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--bege);margin-top:8px;}

/* ---------- Pills / chips ---------- */
.pill{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:999px;
  border:1px solid var(--line);font-size:.82rem;color:var(--verde);background:var(--branco-pure);}
.pill--hot{background:#7a3a2a;color:#fbe9df;border-color:transparent;}
.pill--warm{background:var(--bege);color:#3a2c1c;border-color:transparent;}
.pill--cold{background:#dfe4e6;color:#5b6b6f;border-color:transparent;}

/* ---------- Lists ---------- */
.ticklist{list-style:none;display:flex;flex-direction:column;gap:12px;}
.ticklist li{position:relative;padding-left:30px;font-size:1.02rem;}
.ticklist li::before{content:"";position:absolute;left:0;top:.45em;width:14px;height:8px;
  border-left:2px solid var(--bege);border-bottom:2px solid var(--bege);transform:rotate(-45deg);}
.card--green .ticklist li::before{border-color:var(--bege-soft);}

/* ---------- Tables ---------- */
table{width:100%;border-collapse:collapse;font-size:.98rem;}
th,td{text-align:left;padding:14px 16px;border-bottom:1px solid var(--line);}
th{font-weight:500;color:var(--verde);font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;}
td.center,th.center{text-align:center;}
tr:hover td{background:rgba(182,152,118,.05);}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 26px;border-radius:999px;
  font-size:.92rem;letter-spacing:.04em;transition:transform .2s var(--ease),box-shadow .2s;}
.btn--solid{background:var(--bege);color:#2a2013;font-weight:500;}
.btn--solid:hover{transform:translateY(-2px);box-shadow:0 12px 28px -12px rgba(182,152,118,.7);}
.btn--ghost{border:1px solid rgba(244,242,236,.5);color:var(--branco);}

/* ---------- Footer ---------- */
.foot{background:var(--verde-ink);color:rgba(244,242,236,.7);padding:40px 0;}
.foot .wrap{display:flex;flex-wrap:wrap;gap:18px;justify-content:space-between;align-items:center;}
.foot img{height:30px;}
.foot small{font-size:.8rem;letter-spacing:.08em;}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
.reveal.in{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;}}

/* ---------- Scroll-snap (apresentação ao vivo, uma seção por vez) ---------- */
html:has(body.snap){scroll-snap-type:y mandatory;}
body.snap > section{
  scroll-snap-align:start; scroll-snap-stop:always;
  min-height:100vh; display:flex; flex-direction:column; justify-content:center;
}
body.snap .hero__logo{height:38px;margin-bottom:26px;}
@media(max-width:760px){
  html:has(body.snap){scroll-snap-type:y proximity;}
  body.snap > section{min-height:auto;}
}

/* ---------- Lightbox / ampliar cartão ---------- */
[data-expand]{cursor:zoom-in;position:relative;}
[data-expand]::after{content:"⤢ ampliar";position:absolute;top:14px;right:16px;
  font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--bege);opacity:.65;}
.card--green[data-expand]::after{color:var(--bege-soft);}
.lightbox{position:fixed;inset:0;z-index:200;display:none;place-items:center;padding:24px;
  background:rgba(42,48,36,.86);backdrop-filter:blur(6px);}
.lightbox.open{display:grid;}
.lightbox__card{width:min(580px,94vw);max-height:90vh;overflow:auto;}
.lightbox__close{position:fixed;top:18px;right:24px;width:46px;height:46px;border-radius:50%;
  background:rgba(244,242,236,.16);color:var(--branco);font-size:1.7rem;line-height:1;cursor:pointer;z-index:201;}
.lightbox__clone{margin:0!important;transform:none!important;width:100%!important;cursor:default;}
.lightbox__clone::after{display:none;}
