/* =========================================================
   ENJOY WORK COWORKING — Black & White editorial
   ========================================================= */
:root{
  --black:#0a0a0a;
  --black-2:#0f0f0f;
  --surface:#151515;
  --surface-2:#1c1c1c;
  --white:#f4f3f0;
  --white-dim:#c9c7c2;
  --muted:#878580;
  --line:rgba(244,243,240,.13);
  --line-2:rgba(244,243,240,.24);

  --serif:"Cormorant Garamond", Georgia, "Times New Roman", serif;
  --ui:"Syne", system-ui, sans-serif;
  --body:"Inter", system-ui, -apple-system, sans-serif;

  --wrap:1220px;
  --radius:4px;
  --radius-lg:8px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  font-family:var(--body);
  background:var(--black);
  color:var(--white);
  line-height:1.65;
  font-size:clamp(1rem,.96rem + .15vw,1.06rem);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg,iframe{ display:block; max-width:100%; }
img{ height:auto; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }
::selection{ background:var(--white); color:var(--black); }
:focus-visible{ outline:2px solid var(--white); outline-offset:3px; }

.skip-link{ position:fixed; top:-100px; left:1rem; z-index:300; background:var(--white); color:var(--black); padding:.7rem 1.1rem; border-radius:4px; font-weight:600; transition:top .25s; }
.skip-link:focus{ top:1rem; }

.wrap{ width:min(var(--wrap),92vw); margin-inline:auto; }
.section{ padding:clamp(4.5rem,9vw,8rem) 0; position:relative; }
section[id]{ scroll-margin-top:118px; }

.grain{ position:fixed; inset:0; z-index:200; pointer-events:none; opacity:.4; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E"); }

/* ---------- typography helpers ---------- */
.kicker{ font-family:var(--ui); text-transform:uppercase; letter-spacing:.26em; font-size:.7rem; font-weight:600; color:var(--muted); margin-bottom:1.2rem; display:flex; align-items:center; gap:.7rem; }
.kicker::before{ content:""; width:26px; height:1px; background:var(--white-dim); }
.section-head--center .kicker{ justify-content:center; }

h1,h2,h3{ font-family:var(--serif); font-weight:500; line-height:1.04; letter-spacing:-.01em; }
h2{ font-size:clamp(2.1rem,1.3rem + 3.2vw,3.8rem); }
.lead{ color:var(--white-dim); font-size:clamp(1.05rem,1rem + .4vw,1.2rem); max-width:54ch; }
.lead + .lead{ margin-top:1.1rem; }

.section-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:2.5rem; margin-bottom:clamp(2.2rem,4vw,3.4rem); flex-wrap:wrap; }
.section-head--center{ flex-direction:column; align-items:center; text-align:center; }
.section-head h2{ max-width:16ch; }
.section-head__aside{ color:var(--muted); max-width:42ch; }
.section-head--center .section-head__aside{ max-width:48ch; }

/* ---------- buttons ---------- */
.btn{ font-family:var(--ui); font-weight:600; font-size:.88rem; letter-spacing:.01em; padding:.85rem 1.5rem; border-radius:100px; display:inline-flex; align-items:center; justify-content:center; gap:.5rem; border:1px solid transparent; cursor:pointer; transition:transform .3s var(--ease), background .3s, color .3s, border-color .3s; white-space:nowrap; }
.btn--lg{ padding:1.05rem 2rem; font-size:.95rem; }
.btn--block{ width:100%; }
.btn--solid{ background:var(--white); color:var(--black); }
.btn--solid:hover{ transform:translateY(-2px); background:#fff; }
.btn--outline{ border-color:var(--line-2); color:var(--white); }
.btn--outline:hover{ border-color:var(--white); background:var(--white); color:var(--black); transform:translateY(-2px); }
.btn--ghost{ border-color:rgba(244,243,240,.3); color:var(--white); background:rgba(244,243,240,.06); backdrop-filter:blur(8px); }
.btn--ghost:hover{ background:var(--white); color:var(--black); border-color:var(--white); transform:translateY(-2px); }

/* "Conheça a Enjoy Business" cross-link */
.biz{ font-family:var(--ui); font-weight:600; font-size:.74rem; letter-spacing:.04em; text-transform:uppercase; display:inline-flex; align-items:center; gap:.45rem; color:var(--white); padding:.4rem .85rem; border:1px solid var(--line-2); border-radius:100px; transition:.3s; }
.biz:hover{ background:var(--white); color:var(--black); border-color:var(--white); }
.biz svg{ transition:transform .3s var(--ease); }
.biz:hover svg{ transform:translate(2px,-2px); }

/* =========================================================
   HEADER
   ========================================================= */
.hd{ position:fixed; inset:0 0 auto 0; z-index:120; transition:transform .4s var(--ease); }
.hd--compact{ transform:translateY(-42px); }
.hd__util{ background:var(--black); border-bottom:1px solid var(--line); height:42px; }
.hd__util-in{ display:flex; align-items:center; justify-content:space-between; height:42px; gap:1rem; }
.hd__phone{ font-family:var(--ui); font-size:.74rem; letter-spacing:.04em; color:var(--muted); transition:color .25s; }
.hd__phone:hover{ color:var(--white); }

.hd__main{ background:rgba(10,10,10,.72); backdrop-filter:blur(16px) saturate(140%); border-bottom:1px solid var(--line); transition:background .4s; }
.hd__main-in{ display:flex; align-items:center; gap:1.4rem; height:68px; }

.brand__type{ display:flex; flex-direction:column; line-height:1; }
.brand__type strong{ font-family:var(--serif); font-weight:600; font-size:1.5rem; letter-spacing:0; }
.brand__type small{ font-family:var(--ui); text-transform:uppercase; letter-spacing:.36em; font-size:.54rem; color:var(--muted); margin-top:.3rem; }

.nav{ display:flex; gap:1.6rem; margin-left:auto; }
.nav a{ font-family:var(--ui); font-size:.84rem; font-weight:600; color:var(--white-dim); position:relative; padding:.3rem 0; transition:color .25s; }
.nav a::after{ content:""; position:absolute; left:0; bottom:-2px; width:0; height:1px; background:var(--white); transition:width .3s var(--ease); }
.nav a:hover{ color:var(--white); }
.nav a:hover::after{ width:100%; }
.hd__cta{ flex:none; }

.burger{ display:none; width:44px; height:44px; background:none; border:1px solid var(--line); border-radius:8px; cursor:pointer; position:relative; margin-left:auto; }
.burger span{ position:absolute; left:11px; width:22px; height:1.6px; background:var(--white); transition:transform .3s var(--ease), opacity .2s; }
.burger span:nth-child(1){ top:17px; } .burger span:nth-child(2){ bottom:17px; }
.burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(5px) rotate(45deg); }
.burger[aria-expanded="true"] span:nth-child(2){ transform:translateY(-5px) rotate(-45deg); }

.drawer{ position:fixed; inset:110px 0 auto 0; z-index:115; background:rgba(10,10,10,.97); backdrop-filter:blur(20px); border-bottom:1px solid var(--line); padding:1.4rem 6vw 2rem; display:grid; gap:1rem; transform:translateY(-130%); transition:transform .45s var(--ease); }
.drawer.is-open{ transform:translateY(0); }
.drawer nav{ display:grid; gap:.2rem; }
.drawer nav a{ font-family:var(--serif); font-size:1.5rem; padding:.55rem 0; border-bottom:1px solid var(--line); }
.biz--drawer{ justify-content:center; border:none; color:var(--muted); }

/* =========================================================
   HERO
   ========================================================= */
.hero{ position:relative; min-height:100svh; display:grid; place-items:center; overflow:hidden; padding:120px 0 84px; text-align:center; }
.hero__bg{ position:absolute; inset:0; z-index:0;
  background-image:linear-gradient(var(--line) 1px, transparent 1px), linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size:74px 74px; opacity:.7;
  -webkit-mask-image:radial-gradient(78% 72% at 50% 44%, #000, transparent 80%);
  mask-image:radial-gradient(78% 72% at 50% 44%, #000, transparent 80%); }
.hero__bg::after{ content:""; position:absolute; inset:0; background:radial-gradient(50% 46% at 50% 42%, rgba(244,243,240,.05), transparent 70%); }
.hero__frame{ position:relative; z-index:2; width:min(1080px,92vw); border:1px solid var(--line-2); border-radius:8px; padding:clamp(3rem,7vw,6rem) clamp(1.6rem,5vw,4.5rem); }
.hero__labels{ position:absolute; top:1.1rem; left:1.4rem; right:1.4rem; display:flex; justify-content:space-between; gap:1rem; font-family:var(--ui); font-size:.62rem; font-weight:600; text-transform:uppercase; letter-spacing:.18em; color:var(--muted); }
.hero__labels--b{ top:auto; bottom:1.1rem; }
.hero__inner{ position:relative; z-index:2; display:flex; flex-direction:column; align-items:center; }

.eyebrow{ font-family:var(--ui); text-transform:uppercase; letter-spacing:.24em; font-size:.76rem; font-weight:600; color:var(--white-dim); }
.hero__title{ font-family:var(--serif); font-weight:500; font-size:clamp(2.9rem,1rem + 8vw,6.8rem); line-height:.98; letter-spacing:-.02em; margin:1.5rem 0; }
.hero__sub{ color:var(--white-dim); max-width:52ch; font-size:clamp(1.05rem,1rem + .45vw,1.26rem); }
.hero__actions{ display:flex; gap:1rem; flex-wrap:wrap; justify-content:center; margin-top:2.3rem; }
.hero__proof{ display:flex; align-items:center; justify-content:center; gap:.5rem; margin-top:2.4rem; font-family:var(--ui); font-size:.9rem; color:var(--white-dim); flex-wrap:wrap; }
.hero__proof strong{ color:var(--white); }
.hero__proof .sep{ color:var(--muted); margin:0 .3rem; }
.stars{ color:var(--white); letter-spacing:.1em; }

.hero__scroll{ position:absolute; left:50%; bottom:1.6rem; transform:translateX(-50%); z-index:2; }
.hero__scroll span{ display:block; width:1px; height:54px; background:linear-gradient(var(--white),transparent); position:relative; overflow:hidden; }
.hero__scroll span::after{ content:""; position:absolute; inset:0; background:var(--white); animation:scrollline 2s var(--ease) infinite; }
@keyframes scrollline{ 0%{ transform:translateY(-100%);} 100%{ transform:translateY(100%);} }

/* =========================================================
   SOBRE
   ========================================================= */
.about__grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
.about__text h2{ margin:.2rem 0 1.6rem; max-width:16ch; }
.signature{ font-family:var(--serif); font-style:italic; font-size:clamp(1.3rem,1rem + 1.4vw,1.9rem); color:var(--white); margin-top:1.6rem; }
.about__panel{ border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(1.6rem,3vw,2.4rem); background:var(--surface); }
.about__panel-label{ font-family:var(--ui); font-size:.72rem; font-weight:600; text-transform:uppercase; letter-spacing:.16em; color:var(--muted); margin-bottom:1.4rem; display:flex; align-items:center; gap:.7rem; }
.about__panel-label::before{ content:""; width:24px; height:1px; background:var(--white-dim); }
.about__stats{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.about__stats li{ background:var(--black); padding:1.7rem 1.4rem; display:flex; flex-direction:column; }
.about__stats strong{ font-family:var(--serif); font-size:clamp(2.4rem,1.6rem + 1.6vw,3.2rem); line-height:1; }
.about__stats span{ font-family:var(--ui); font-size:.72rem; text-transform:uppercase; letter-spacing:.08em; color:var(--muted); margin-top:.5rem; }

/* =========================================================
   GALERIA / O ESPAÇO
   ========================================================= */
.gallery__grid{ display:grid; grid-template-columns:repeat(3,1fr); grid-auto-rows:208px; grid-auto-flow:dense; gap:14px; }
.gallery__item{ position:relative; overflow:hidden; border-radius:var(--radius-lg); border:1px solid var(--line); }
.gallery__item--tall{ grid-row:span 2; }
.gallery__item img{ width:100%; height:100%; object-fit:cover; filter:grayscale(1) contrast(1.05); transition:transform .9s var(--ease-out), filter .4s; }
.gallery__item:hover img{ transform:scale(1.05); }
.gallery__item figcaption{ position:absolute; left:0; right:0; bottom:0; padding:1.8rem 1.1rem .9rem; background:linear-gradient(transparent, rgba(6,6,6,.9)); font-family:var(--ui); font-size:.74rem; font-weight:600; text-transform:uppercase; letter-spacing:.1em; color:var(--white); }

/* =========================================================
   BENEFÍCIOS
   ========================================================= */
.benefits__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; }
.bcard{ padding:2.4rem 2rem; border:1px solid var(--line); border-radius:var(--radius-lg); background:var(--surface); transition:transform .4s var(--ease), border-color .35s, background .35s; }
.bcard:hover{ transform:translateY(-5px); border-color:var(--line-2); background:var(--surface-2); }
.bcard__ic{ display:grid; place-items:center; width:52px; height:52px; border:1px solid var(--line-2); border-radius:50%; color:var(--white); margin-bottom:1.5rem; }
.bcard__ic svg{ width:26px; height:26px; }
.bcard h3{ font-size:1.6rem; margin-bottom:.7rem; }
.bcard p{ color:var(--muted); }

/* =========================================================
   SERVIÇOS (tabs + carousel)
   ========================================================= */
.tabs{ display:flex; gap:.3rem; justify-content:center; flex-wrap:wrap; border:1px solid var(--line); border-radius:100px; padding:.4rem; width:fit-content; max-width:100%; margin:0 auto clamp(2.2rem,4vw,3.2rem); }
.tab{ font-family:var(--ui); font-weight:600; font-size:.86rem; padding:.7rem 1.25rem; border-radius:100px; background:none; border:none; color:var(--muted); cursor:pointer; transition:.3s; white-space:nowrap; }
.tab:hover{ color:var(--white); }
.tab.is-active{ background:var(--white); color:var(--black); }

.panel[hidden]{ display:none; }
.panel{ animation:fadeUp .5s var(--ease-out); }
@keyframes fadeUp{ from{ opacity:0; transform:translateY(14px);} to{ opacity:1; transform:none;} }
.panel__intro{ text-align:center; color:var(--white-dim); max-width:60ch; margin:0 auto 2.2rem; font-size:1.08rem; }

.carousel{ position:relative; }
.carousel__track{ display:flex; gap:1.2rem; overflow-x:auto; scroll-snap-type:x mandatory; padding:.3rem .3rem 1rem; scrollbar-width:none; -ms-overflow-style:none; }
.carousel__track::-webkit-scrollbar{ display:none; }
.carousel__nav{ display:flex; gap:.6rem; justify-content:center; margin-top:1.4rem; }
.carousel__btn{ width:48px; height:48px; border-radius:50%; border:1px solid var(--line-2); background:none; color:var(--white); font-size:1.4rem; line-height:1; cursor:pointer; transition:.3s; display:grid; place-items:center; }
.carousel__btn:hover{ background:var(--white); color:var(--black); border-color:var(--white); }
.carousel__btn:disabled{ opacity:.3; cursor:default; }
.carousel__btn:disabled:hover{ background:none; color:var(--white); border-color:var(--line-2); }

.plan{ scroll-snap-align:start; flex:0 0 clamp(290px, 30%, 350px); display:flex; flex-direction:column; padding:2.1rem 1.8rem; border:1px solid var(--line); border-radius:var(--radius-lg); background:var(--surface); position:relative; transition:border-color .35s, transform .4s var(--ease); }
.plan:hover{ border-color:var(--line-2); transform:translateY(-4px); }
.plan__head{ display:flex; flex-direction:column; gap:.25rem; margin-bottom:1.1rem; }
.plan__name{ font-family:var(--serif); font-size:1.55rem; font-weight:600; line-height:1.1; }
.plan__use{ font-family:var(--ui); font-size:.72rem; text-transform:uppercase; letter-spacing:.08em; color:var(--muted); }
.plan__price{ font-family:var(--serif); font-size:2.7rem; font-weight:600; line-height:1; letter-spacing:-.01em; }
.plan__price small{ font-family:var(--ui); font-size:.8rem; font-weight:600; color:var(--muted); letter-spacing:.02em; }
.plan__old{ font-family:var(--ui); font-size:.82rem; color:var(--muted); text-decoration:line-through; margin-top:.25rem; }
.plan__tiers{ font-family:var(--ui); font-size:.78rem; color:var(--white-dim); margin-top:.5rem; }
.plan__items{ display:grid; gap:.7rem; margin:1.4rem 0 1.8rem; flex:1; }
.plan__items li{ display:flex; gap:.6rem; font-size:.92rem; color:var(--white-dim); line-height:1.45; }
.plan__items li::before{ content:""; flex:none; width:15px; height:15px; margin-top:.28rem;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='15' height='15' viewBox='0 0 24 24' fill='none' stroke='%23f4f3f0' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:center; }
.plan__flag{ position:absolute; top:-12px; left:1.8rem; font-family:var(--ui); font-weight:700; font-size:.66rem; text-transform:uppercase; letter-spacing:.1em; background:var(--white); color:var(--black); padding:.3rem .8rem; border-radius:100px; }

/* featured plan: inverted (white) for B&W pop */
.plan--feature{ background:var(--white); color:var(--black); border-color:var(--white); }
.plan--feature .plan__use{ color:#5a5853; }
.plan--feature .plan__items li{ color:#2a2a28; }
.plan--feature .plan__items li::before{ background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='15' height='15' viewBox='0 0 24 24' fill='none' stroke='%230a0a0a' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E"); }
.plan--feature .plan__flag{ background:var(--black); color:var(--white); }
.plan--feature .btn--solid{ background:var(--black); color:var(--white); }
.plan--feature .btn--solid:hover{ background:#000; }

/* =========================================================
   VANTAGENS
   ========================================================= */
.adv{ background:var(--black-2); border-block:1px solid var(--line); }
.adv__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; }
.adv__card{ padding:2.2rem 1.9rem; border:1px solid var(--line); border-radius:var(--radius-lg); background:var(--surface); }
.adv__num{ font-family:var(--serif); font-style:italic; font-size:1.4rem; color:var(--muted); }
.adv__card h3{ font-size:1.5rem; margin:1rem 0 .7rem; }
.adv__card p{ color:var(--muted); }

/* =========================================================
   QUOTE BAND (typographic)
   ========================================================= */
.quoteband{ border-block:1px solid var(--line); background:var(--black-2); padding:clamp(4rem,8vw,7rem) 0; text-align:center; }
.quoteband__mark{ font-family:var(--serif); font-size:5rem; line-height:.4; color:var(--line-2); }
.quoteband__q{ font-family:var(--serif); font-style:italic; font-weight:500; font-size:clamp(1.8rem,1rem + 3.4vw,3.4rem); line-height:1.22; max-width:24ch; margin:1.2rem auto 0; }
.quoteband__src{ font-family:var(--ui); font-size:.72rem; text-transform:uppercase; letter-spacing:.2em; color:var(--muted); margin-top:1.8rem; }

/* =========================================================
   PROVA SOCIAL
   ========================================================= */
.proof{ border-bottom:1px solid var(--line); }
.proof__in{ display:flex; align-items:center; justify-content:center; gap:clamp(1.5rem,5vw,4rem); padding:clamp(2.2rem,4vw,3.2rem) 0; flex-wrap:wrap; }
.proof__item{ display:flex; flex-direction:column; align-items:center; gap:.2rem; text-align:center; }
.proof__item .stars{ font-size:.9rem; margin-bottom:.2rem; }
.proof__item strong{ font-family:var(--serif); font-size:clamp(2rem,1.4rem + 2vw,3rem); line-height:1; }
.proof__item span{ font-family:var(--ui); font-size:.74rem; text-transform:uppercase; letter-spacing:.1em; color:var(--muted); }
.proof__divider{ width:1px; height:46px; background:var(--line-2); }

/* =========================================================
   CONTATO + FORM
   ========================================================= */
.contact__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4.5rem); align-items:start; }
.contact__info h2{ margin:.2rem 0 1.3rem; max-width:14ch; }
.contact__list{ display:grid; gap:1.3rem; margin:2rem 0; }
.contact__list li{ display:flex; gap:1rem; align-items:flex-start; }
.contact__ic{ flex:none; width:44px; height:44px; display:grid; place-items:center; border:1px solid var(--line-2); border-radius:50%; color:var(--white); }
.contact__ic svg{ width:22px; height:22px; }
.contact__list div{ display:flex; flex-direction:column; gap:.25rem; color:var(--white-dim); }
.contact__list strong{ font-family:var(--ui); font-weight:600; font-size:.72rem; text-transform:uppercase; letter-spacing:.1em; color:var(--muted); }
.contact__list a:hover{ color:var(--white); text-decoration:underline; }
.contact__actions{ display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:1.4rem; }
.map-link{ font-family:var(--ui); font-weight:600; font-size:.88rem; color:var(--white); border-bottom:1px solid var(--line-2); padding-bottom:2px; transition:.25s; }
.map-link:hover{ border-color:var(--white); }

.cform{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(1.8rem,3vw,2.6rem); display:grid; gap:1rem; }
.cform h3{ font-size:1.8rem; }
.cform__sub{ color:var(--muted); margin-top:-.6rem; font-size:.95rem; }
.cform label{ display:grid; gap:.45rem; font-family:var(--ui); font-size:.76rem; font-weight:600; text-transform:uppercase; letter-spacing:.06em; color:var(--muted); }
.cform input,.cform select{ font-family:var(--body); font-size:1rem; color:var(--white); background:var(--black); border:1px solid var(--line-2); border-radius:var(--radius); padding:.85rem .9rem; transition:border-color .25s; text-transform:none; letter-spacing:0; }
.cform input::placeholder{ color:#5e5c58; }
.cform input:focus,.cform select:focus{ outline:none; border-color:var(--white); }
.cform select{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23878580' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right .9rem center; }
.cform button{ margin-top:.4rem; }
.cform__note{ font-size:.8rem; color:var(--muted); text-align:center; }

.contact__map{ margin-top:clamp(2.5rem,5vw,4rem); height:clamp(320px,40vw,460px); border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; }
.contact__map iframe{ width:100%; height:100%; border:0; filter:grayscale(1) invert(.92) contrast(.92); }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{ background:var(--black-2); border-top:1px solid var(--line); padding-top:clamp(3rem,6vw,5rem); }
.footer__grid{ display:grid; grid-template-columns:2fr 1fr 1.4fr 1.2fr; gap:2rem; padding-bottom:3rem; }
.footer__brand p{ color:var(--muted); margin-top:1.1rem; font-family:var(--serif); font-style:italic; font-size:1.15rem; }
.footer__col h4{ font-family:var(--ui); font-size:.72rem; text-transform:uppercase; letter-spacing:.16em; color:var(--muted); margin-bottom:1.1rem; font-weight:600; }
.footer__col{ display:flex; flex-direction:column; gap:.7rem; }
.footer__col a,.footer__col span{ color:var(--white-dim); font-size:.92rem; transition:color .25s; }
.footer__col a:hover{ color:var(--white); }
.biz--footer{ border:none; padding:0; text-transform:none; letter-spacing:0; font-size:.92rem; }
.biz--footer:hover{ background:none; color:var(--white); }
.footer__bottom{ display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; padding:1.6rem 0; border-top:1px solid var(--line); color:var(--muted); font-size:.84rem; }

/* =========================================================
   REVEAL
   ========================================================= */
/* reveal só esconde quando o JS está ativo (.js); sem JS, conteúdo aparece normal */
.js .reveal{ opacity:0; transform:translateY(24px); transition:opacity .8s var(--ease-out), transform .8s var(--ease-out); }
.js .reveal.is-in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  .reveal,.js .reveal{ opacity:1 !important; transform:none !important; transition:none; }
  .hero__scroll span::after,.panel{ animation:none; }
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1000px){
  .nav{ display:none; }
  .hd__cta{ display:none; }
  .burger{ display:block; }
  .benefits__grid,.adv__grid{ grid-template-columns:1fr; max-width:520px; margin-inline:auto; }
  .about__grid{ grid-template-columns:1fr; }
  .about__panel{ max-width:520px; }
  .contact__grid{ grid-template-columns:1fr; }
  .footer__grid{ grid-template-columns:1fr 1fr; }
  .plan{ flex-basis:78%; }
  .gallery__grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:600px){
  .hd__phone{ display:none; }
  .hd__util-in{ justify-content:flex-start; }
  .hero{ min-height:auto; padding:128px 0 70px; }
  .hero__labels{ display:none; }
  .footer__grid{ grid-template-columns:1fr; }
  .proof__divider{ display:none; }
  .plan{ flex-basis:86%; }
  .gallery__grid{ grid-template-columns:1fr; grid-auto-rows:auto; }
  .gallery__item{ aspect-ratio:4/3; }
  .gallery__item--tall{ grid-row:auto; aspect-ratio:3/4; }
}
