/* ==========================================================================
   Oliveira Advocacia em Direito à Saúde — Folha de estilo principal
   Cores #233C36 (verde) · #EBE2D0 (cream) · #78C151 (CTA) · #BC9D88 / #928682
   Tipografia: Fraunces (títulos) · Open Sans (corpo)
   ========================================================================== */
:root{
  --green:#233C36; --green-deep:#1B2E2A; --green-panel:#2C4A43;
  --bright:#78C151; --bright-deep:#5FA53C;
  --cream:#EBE2D0; --cream-soft:#F2EBDD; --paper:#FBF8F1;
  --taupe:#BC9D88; --taupe-soft:#D6C4B2; --gray:#928682;
  --ink:#22332E; --ink-soft:#4A5752; --white:#fff;
  --maxw:1180px; --r:18px;
  --shadow:0 22px 60px -28px rgba(27,46,42,.45);
  --shadow-sm:0 10px 30px -18px rgba(27,46,42,.5);
  --ease:cubic-bezier(.2,.7,.2,1);
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;font-family:"Open Sans",system-ui,sans-serif;color:var(--ink);background:var(--paper);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
h1,h2,h3,h4{font-family:"Fraunces",Georgia,serif;font-weight:600;line-height:1.1;margin:0;color:var(--green);letter-spacing:-.01em;text-wrap:balance;}
p{margin:0;text-wrap:pretty;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}
.eyebrow{font-weight:700;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--bright-deep);margin:0 0 18px;display:flex;align-items:center;gap:10px;}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--bright);border-radius:2px;}
.eyebrow.center{justify-content:center;}
.eyebrow.light{color:var(--bright);}
section{position:relative;}

/* ---------- Skip link / a11y ---------- */
.skip{position:absolute;left:-999px;top:0;background:var(--green);color:#fff;padding:10px 16px;border-radius:0 0 8px 0;z-index:200;}
.skip:focus{left:0;}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:11px;font-family:"Open Sans",sans-serif;font-weight:700;font-size:1.02rem;padding:16px 26px;border-radius:999px;border:0;cursor:pointer;background:var(--bright);color:var(--green-deep);box-shadow:0 14px 30px -12px rgba(95,165,60,.6);transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease);line-height:1.1;text-align:left;}
.btn:hover{transform:translateY(-3px);box-shadow:0 20px 38px -12px rgba(95,165,60,.7);background:#84cd5c;}
.btn:focus-visible{outline:3px solid var(--green);outline-offset:3px;}
.btn svg{flex:none;}
.btn .sub{display:block;font-weight:600;font-size:.74rem;opacity:.82;}
.btn.outline{background:transparent;color:var(--green);box-shadow:none;border:1.6px solid var(--green);}
.btn.outline:hover{background:var(--green);color:var(--cream);}
.btn.call{background:#fff;color:var(--green);border:1.6px solid rgba(35,60,54,.18);box-shadow:var(--shadow-sm);}
.btn.call:hover{background:var(--green);color:#fff;border-color:var(--green);}
.btn.ghost-light{background:rgba(255,255,255,.1);color:#fff;border:1.5px solid rgba(255,255,255,.4);box-shadow:none;}
.btn.ghost-light:hover{background:#fff;color:var(--green);}
.btn-row{display:flex;flex-wrap:wrap;gap:14px;align-items:center;}
.cta-note{font-size:.86rem;color:var(--ink-soft);margin-top:16px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.cta-note b{color:var(--green);font-weight:700;}
.bg-green .cta-note{color:rgba(235,226,208,.85);} .bg-green .cta-note b{color:#fff;}

/* ---------- Header ---------- */
header.site{position:sticky;top:0;z-index:60;background:rgba(251,248,241,.86);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:border-color .3s,box-shadow .3s;}
header.site.scrolled{border-color:rgba(35,60,54,.12);box-shadow:0 8px 30px -22px rgba(27,46,42,.6);}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px;gap:18px;}
.brand{display:flex;align-items:center;gap:12px;flex:none;}
.brand img{height:38px;width:auto;}
.brand .wm{display:flex;flex-direction:column;line-height:1;}
.brand .wm b{font-family:"Fraunces",serif;font-weight:600;font-size:1.12rem;color:var(--green);letter-spacing:-.01em;}
.brand .wm span{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gray);font-weight:600;margin-top:3px;}
.nav-links{display:flex;align-items:center;gap:20px;margin-left:auto;margin-right:4px;}
.nav-links a{font-size:.9rem;font-weight:600;color:var(--ink-soft);position:relative;padding:4px 0;white-space:nowrap;transition:color .2s;}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:-3px;height:2px;background:var(--bright);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease);}
.nav-links a:hover{color:var(--green);} .nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1);}
.nav-links a.active{color:var(--green);}
/* Dropdown "Atuação" */
.nav-drop{position:relative;display:flex;align-items:center;}
.drop-toggle{display:inline-flex;align-items:center;gap:5px;background:none;border:0;cursor:pointer;font-family:"Open Sans",sans-serif;font-size:.9rem;font-weight:600;color:var(--ink-soft);padding:4px 0;position:relative;transition:color .2s;}
.drop-toggle::after{content:"";position:absolute;left:0;right:18px;bottom:-3px;height:2px;background:var(--bright);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease);}
.nav-drop:hover .drop-toggle,.nav-drop:focus-within .drop-toggle,.drop-toggle.active{color:var(--green);}
.drop-toggle.active::after{transform:scaleX(1);}
.drop-toggle .chev{transition:transform .25s var(--ease);}
.nav-drop:hover .chev,.nav-drop:focus-within .chev{transform:rotate(180deg);}
.drop-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(10px);min-width:252px;background:#fff;border:1px solid rgba(35,60,54,.1);border-radius:14px;box-shadow:var(--shadow);padding:8px;margin-top:12px;opacity:0;visibility:hidden;transition:opacity .22s var(--ease),transform .22s var(--ease);z-index:80;}
.drop-menu::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px;}
.nav-drop:hover .drop-menu,.nav-drop:focus-within .drop-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.drop-menu a{display:flex;align-items:center;gap:10px;padding:11px 13px;border-radius:9px;font-size:.92rem;font-weight:600;color:var(--ink-soft);white-space:nowrap;transition:background .18s,color .18s;}
.drop-menu a::after{display:none;}
.drop-menu a:hover{background:var(--cream-soft);color:var(--green);}
.drop-menu a .di{color:var(--bright-deep);flex:none;}
.nav-cta{display:flex;align-items:center;gap:12px;flex:none;}
/* esconde o telefone solto antes do menu apertar */
@media(max-width:1160px){.nav-phone{display:none;}}
@media(max-width:1080px){.nav-links{gap:16px;}}
.nav-phone{display:flex;align-items:center;gap:8px;font-weight:700;color:var(--green);font-size:.95rem;white-space:nowrap;}
.nav-phone svg{color:var(--bright-deep);}
.nav-cta .btn{padding:11px 18px;font-size:.9rem;}
.nav-cta .btn.wa-mini{padding:9px 15px;font-size:.85rem;gap:7px;}
.nav-cta .btn.wa-mini svg{width:15px;height:15px;}
.menu-btn{display:none;background:none;border:1.5px solid rgba(35,60,54,.2);border-radius:10px;width:44px;height:44px;align-items:center;justify-content:center;cursor:pointer;color:var(--green);}
.mobile-menu{display:none;}

/* ---------- generic section ---------- */
.sec{padding:84px 0;}
.sec.tight{padding:60px 0;}
.sec-head{max-width:760px;}
.sec-head.center{margin:0 auto;text-align:center;}
.sec h2{font-size:clamp(1.8rem,3.2vw,2.55rem);}
.sec .sub{font-size:1.08rem;color:var(--ink-soft);margin-top:18px;}
.bg-cream{background:var(--cream-soft);}
.bg-green{background:var(--green);color:var(--cream);}
.bg-green h2,.bg-green h3,.bg-green h4{color:#fff;}
.bg-green .sub{color:rgba(235,226,208,.85);}
.bg-green .eyebrow{color:var(--bright);}
.lead{font-size:1.12rem;color:var(--ink-soft);}

/* ---------- Home hero ---------- */
.hero{padding:60px 0 76px;overflow:hidden;}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;}
.loc-pill{display:inline-flex;align-items:center;gap:8px;background:var(--cream);color:var(--green);font-weight:600;font-size:.82rem;padding:7px 15px;border-radius:999px;border:1px solid rgba(35,60,54,.1);margin-bottom:22px;}
.loc-pill svg{color:var(--bright-deep);}
.hero h1{font-size:clamp(2.1rem,4.2vw,3.25rem);font-weight:600;}
.hero h1 .hl{color:var(--bright-deep);font-style:italic;font-weight:500;}
.hero .lead{margin-top:22px;max-width:36em;}
.hero-actions{margin-top:28px;}
.hero-assure{display:flex;gap:22px;margin-top:24px;flex-wrap:wrap;}
.hero-assure .it{display:flex;align-items:center;gap:9px;font-size:.9rem;font-weight:600;color:var(--green);}
.hero-assure .it svg{color:var(--bright-deep);flex:none;}

/* arch photo */
.hero-media{position:relative;display:flex;justify-content:center;}
.arch{position:relative;width:100%;max-width:420px;aspect-ratio:4/5;border-radius:600px 600px 22px 22px;overflow:hidden;background:var(--green);box-shadow:var(--shadow);border:7px solid #fff;}
.arch img{width:100%;height:100%;object-fit:cover;object-position:center 18%;}
.arch::after{content:"";position:absolute;inset:0;border-radius:inherit;box-shadow:inset 0 0 0 1px rgba(35,60,54,.18);pointer-events:none;}
.hero-media .watermark{position:absolute;font-family:"Fraunces",serif;font-weight:600;font-size:13rem;color:var(--cream);z-index:-1;top:-6%;left:-22%;opacity:.7;user-select:none;pointer-events:none;}
.badge-float{position:absolute;bottom:24px;left:-26px;z-index:3;background:#fff;border-radius:16px;padding:13px 17px;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:13px;max-width:240px;border:1px solid rgba(35,60,54,.08);}
.badge-float .ic{width:42px;height:42px;border-radius:11px;background:var(--green);color:var(--bright);display:flex;align-items:center;justify-content:center;flex:none;}
.badge-float b{display:block;font-family:"Fraunces",serif;font-size:1.02rem;color:var(--green);line-height:1.1;}
.badge-float span{font-size:.78rem;color:var(--ink-soft);}

/* ---------- Inner page hero ---------- */
.page-hero{background:var(--green);color:var(--cream);padding:62px 0 66px;position:relative;overflow:hidden;}
.page-hero::after{content:"";position:absolute;right:-80px;top:-80px;width:340px;height:340px;border-radius:50%;border:60px solid rgba(120,193,81,.1);pointer-events:none;}
.page-hero .crumbs{font-size:.82rem;color:var(--taupe-soft);display:flex;gap:8px;align-items:center;margin-bottom:20px;font-weight:600;flex-wrap:wrap;}
.page-hero .crumbs a:hover{color:#fff;}
.page-hero .crumbs span{opacity:.5;}
.page-hero h1{color:#fff;font-size:clamp(2rem,4vw,3rem);max-width:16em;}
.page-hero .lead{color:rgba(235,226,208,.88);margin-top:20px;max-width:42em;font-size:1.12rem;}
.page-hero .btn-row{margin-top:30px;}

/* ---------- Prova social bar ---------- */
.social-bar{background:var(--cream);border-top:1px solid rgba(35,60,54,.08);border-bottom:1px solid rgba(35,60,54,.08);}
.social-bar .wrap{display:flex;align-items:center;justify-content:center;gap:14px 26px;padding-top:18px;padding-bottom:18px;flex-wrap:wrap;text-align:center;}
.social-bar .gscore{font-family:"Fraunces",serif;font-weight:700;font-size:1.6rem;color:var(--green);line-height:1;}
.social-bar .stars{display:inline-flex;gap:2px;}
.social-bar .stars svg{color:#F5B400;}
.social-bar .smeta{font-size:.92rem;color:var(--ink-soft);font-weight:600;}
.social-bar .divider{width:1px;height:30px;background:rgba(35,60,54,.16);}

/* ---------- Area cards ---------- */
.area-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:46px;}
.area-card{display:flex;flex-direction:column;background:#fff;border:1px solid rgba(35,60,54,.09);border-radius:var(--r);padding:32px 30px;box-shadow:var(--shadow-sm);transition:transform .25s var(--ease),border-color .25s;position:relative;overflow:hidden;}
.area-card:hover{transform:translateY(-4px);border-color:var(--taupe);}
.area-card .ic{width:54px;height:54px;border-radius:14px;background:var(--green);color:var(--bright);display:flex;align-items:center;justify-content:center;margin-bottom:22px;flex:none;}
.area-card h3{font-size:1.3rem;}
.area-card p{margin-top:12px;color:var(--ink-soft);font-size:1rem;flex:1;}
.area-card .more{margin-top:20px;display:inline-flex;align-items:center;gap:8px;font-weight:700;color:var(--bright-deep);font-size:.95rem;}
.area-card .more svg{transition:transform .25s var(--ease);}
.area-card:hover .more svg{transform:translateX(4px);}

/* ---------- Editorial ---------- */
.editorial{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.editorial .body p{margin-top:18px;color:var(--ink-soft);font-size:1.06rem;}
.editorial .body p:first-child{margin-top:0;}
.bg-green .editorial .body p{color:rgba(235,226,208,.9);}
.pullquote{background:var(--green);color:var(--cream);border-radius:var(--r);padding:40px 38px;box-shadow:var(--shadow);}
.pullquote .mark{font-family:"Fraunces",serif;font-size:5rem;line-height:.6;color:var(--bright);opacity:.55;}
.pullquote p{font-family:"Fraunces",serif;font-size:1.5rem;line-height:1.25;color:#fff;margin-top:6px;font-weight:500;}
.pullquote .who{margin-top:22px;font-size:.84rem;letter-spacing:.04em;color:var(--taupe-soft);font-weight:600;text-transform:uppercase;}

/* ---------- Frentes (numbered list cards) ---------- */
.frentes{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:46px;}
.frente{background:#fff;border:1px solid rgba(35,60,54,.09);border-radius:var(--r);padding:32px 30px;box-shadow:var(--shadow-sm);position:relative;}
.frente .num{font-family:"Fraunces",serif;font-size:2.6rem;font-weight:600;color:var(--taupe);line-height:1;opacity:.9;}
.frente h3{font-size:1.24rem;margin-top:10px;}
.frente p{margin-top:12px;color:var(--ink-soft);font-size:1rem;}
.frente ul{list-style:none;margin:16px 0 0;padding:0;display:flex;flex-direction:column;gap:9px;}
.frente li{display:flex;gap:10px;align-items:flex-start;font-size:.96rem;font-weight:500;color:var(--green);}
.frente li .d{flex:none;width:20px;height:20px;border-radius:50%;background:rgba(120,193,81,.16);color:var(--bright-deep);display:flex;align-items:center;justify-content:center;margin-top:2px;}

/* ---------- Two list cards ---------- */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:44px;}
.list-card{background:#fff;border-radius:var(--r);padding:34px 32px;border:1px solid rgba(35,60,54,.09);box-shadow:var(--shadow-sm);}
.list-card.alt{background:var(--green);color:var(--cream);}
.list-card h3{font-size:1.3rem;margin-bottom:6px;}
.list-card.alt h3{color:#fff;}
.list-card .tag{font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--bright-deep);}
.list-card.alt .tag{color:var(--bright);}
.list-card ul{list-style:none;margin:20px 0 0;padding:0;display:flex;flex-direction:column;gap:13px;}
.list-card li{display:flex;gap:12px;align-items:flex-start;font-size:1rem;font-weight:500;}
.list-card li .d{flex:none;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-top:2px;}
.list-card li .d.ok{background:rgba(120,193,81,.16);color:var(--bright-deep);}
.list-card.alt li .d.no{background:rgba(235,226,208,.16);color:var(--taupe-soft);}

/* ---------- callout box ---------- */
.callout{display:flex;gap:18px;align-items:flex-start;background:var(--cream);border:1px solid rgba(35,60,54,.1);border-left:4px solid var(--bright);border-radius:14px;padding:24px 26px;margin-top:32px;}
.callout .ic{flex:none;width:40px;height:40px;border-radius:10px;background:var(--green);color:var(--bright);display:flex;align-items:center;justify-content:center;}
.callout p{color:var(--ink-soft);font-size:1rem;}
.callout b{color:var(--green);}

/* link card (external) */
.link-card{display:flex;align-items:center;gap:20px;background:#fff;border:1px solid rgba(35,60,54,.1);border-radius:var(--r);padding:24px 28px;box-shadow:var(--shadow-sm);margin-top:30px;transition:transform .25s var(--ease),border-color .25s;}
.link-card:hover{transform:translateY(-3px);border-color:var(--taupe);}
.link-card .ic{flex:none;width:52px;height:52px;border-radius:13px;background:rgba(120,193,81,.16);color:var(--bright-deep);display:flex;align-items:center;justify-content:center;}
.link-card .tx b{display:block;font-family:"Fraunces",serif;font-size:1.2rem;color:var(--green);}
.link-card .tx span{font-size:.96rem;color:var(--ink-soft);}
.link-card .arw{margin-left:auto;color:var(--bright-deep);flex:none;}

/* ---------- About ---------- */
.about{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:center;}
.about-media{position:relative;}
.about-media .arch{max-width:380px;aspect-ratio:4/5;border:7px solid var(--cream);}
.about-media .arch img{object-position:center 12%;}
.about .body p{margin-top:18px;color:var(--ink-soft);font-size:1.05rem;}
.about .tagline{margin-top:30px;font-family:"Fraunces",serif;font-size:1.5rem;line-height:1.2;color:var(--green);padding-left:22px;border-left:3px solid var(--bright);font-weight:500;}
.signature{margin-top:26px;display:flex;align-items:center;gap:14px;}
.signature .nm{font-family:"Fraunces",serif;font-size:1.12rem;color:var(--green);font-weight:600;}
.signature .oab{font-size:.85rem;color:var(--gray);}

/* credentials list */
.creds{display:grid;grid-template-columns:1fr 1fr;gap:14px 26px;margin-top:30px;}
.cred{display:flex;gap:13px;align-items:flex-start;}
.cred .ck{flex:none;width:32px;height:32px;border-radius:9px;background:rgba(120,193,81,.18);color:var(--bright-deep);display:flex;align-items:center;justify-content:center;}
.cred p{font-size:.98rem;font-weight:600;color:var(--green);line-height:1.4;}
.bg-green .cred p{color:var(--cream);} .bg-green .cred .ck{background:rgba(120,193,81,.22);color:var(--bright);}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:48px;}
.step{position:relative;padding-top:8px;}
.step .num{font-family:"Fraunces",serif;font-size:3.2rem;font-weight:600;color:var(--taupe);line-height:1;opacity:.85;}
.step h3{font-size:1.16rem;margin-top:10px;}
.step p{margin-top:10px;color:var(--ink-soft);font-size:.96rem;}
.step::before{content:"";position:absolute;top:28px;left:62px;right:-11px;height:2px;background:linear-gradient(90deg,var(--taupe-soft),transparent);}
.step:last-child::before{display:none;}

/* ---------- Reviews ---------- */
.reviews-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:24px;margin-top:46px;}
.review-card{flex:1 1 320px;max-width:380px;background:#fff;border:1px solid rgba(35,60,54,.09);border-radius:var(--r);padding:28px 28px 24px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;position:relative;transition:transform .25s var(--ease);}
.review-card:hover{transform:translateY(-3px);}
.review-card .gicon{position:absolute;top:24px;right:26px;width:22px;height:22px;}
.rev-head{display:flex;align-items:center;gap:14px;}
.rev-avatar{width:52px;height:52px;border-radius:50%;object-fit:cover;flex:none;border:2px solid var(--cream);}
.rev-avatar.initials{background:var(--green);color:var(--bright);display:flex;align-items:center;justify-content:center;font-family:"Fraunces",serif;font-weight:600;font-size:1.2rem;}
.rev-id b{display:block;font-weight:700;color:var(--green);font-size:1rem;line-height:1.2;}
.rev-id small{font-size:.8rem;color:var(--gray);}
.rev-row{display:flex;align-items:center;gap:10px;margin-top:14px;}
.rev-row .when{font-size:.8rem;color:var(--gray);}
.rev-stars{display:inline-flex;gap:2px;} .rev-stars svg{color:#F5B400;}
.rev-text{margin-top:13px;color:var(--ink-soft);font-size:.99rem;line-height:1.6;}
.rev-tag{margin-top:18px;display:inline-flex;align-items:center;gap:7px;font-size:.76rem;font-weight:700;letter-spacing:.04em;color:var(--bright-deep);text-transform:uppercase;}
.grev-link{margin-top:40px;text-align:center;}
.grev-link a{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:var(--green);border-bottom:2px solid var(--bright);padding-bottom:3px;}
.grev-link a:hover{color:var(--bright-deep);}

/* ---------- FAQ ---------- */
.faq{max-width:840px;margin:44px auto 0;}
.qa{border-bottom:1px solid rgba(35,60,54,.14);}
.qa button{width:100%;background:none;border:0;cursor:pointer;text-align:left;display:flex;align-items:center;justify-content:space-between;gap:20px;padding:22px 4px;font-family:"Fraunces",serif;font-size:1.16rem;font-weight:600;color:var(--green);}
.qa .ico{flex:none;width:30px;height:30px;border-radius:50%;border:1.5px solid var(--taupe);color:var(--green);display:flex;align-items:center;justify-content:center;transition:transform .35s var(--ease),background .3s,color .3s,border-color .3s;font-size:1.2rem;line-height:1;}
.qa.on .ico{transform:rotate(45deg);background:var(--green);color:var(--bright);border-color:var(--green);}
.qa .ans{max-height:0;overflow:hidden;transition:max-height .4s var(--ease);}
.qa .ans-inner{padding:0 4px 22px;color:var(--ink-soft);font-size:1.01rem;max-width:62em;}
.qa .ans-inner ul{margin:10px 0 0;padding-left:20px;}
.qa .ans-inner li{margin-top:6px;}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
.contact-list{display:flex;flex-direction:column;gap:14px;margin-top:30px;}
.contact-item{display:flex;gap:16px;align-items:flex-start;background:#fff;border:1px solid rgba(35,60,54,.09);border-radius:14px;padding:20px 22px;box-shadow:var(--shadow-sm);}
.contact-item .ic{flex:none;width:46px;height:46px;border-radius:12px;background:var(--green);color:var(--bright);display:flex;align-items:center;justify-content:center;}
.contact-item .tx small{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gray);font-weight:700;}
.contact-item .tx b{display:block;font-size:1.08rem;color:var(--green);font-weight:700;margin-top:3px;}
.contact-item .tx span{font-size:.94rem;color:var(--ink-soft);}
.map-frame{border-radius:var(--r);overflow:hidden;border:1px solid rgba(35,60,54,.12);box-shadow:var(--shadow-sm);min-height:340px;background:var(--cream);}
.map-frame iframe{width:100%;height:100%;min-height:420px;border:0;display:block;}

/* fallback form */
.lead-form{background:#fff;border:1px solid rgba(35,60,54,.1);border-radius:var(--r);padding:30px 30px;box-shadow:var(--shadow-sm);}
.lead-form h3{font-size:1.3rem;}
.lead-form .field{margin-top:16px;}
.lead-form label{display:block;font-size:.84rem;font-weight:700;color:var(--green);margin-bottom:6px;}
.lead-form input{width:100%;padding:13px 15px;border:1.5px solid rgba(35,60,54,.16);border-radius:11px;font:inherit;font-size:1rem;background:var(--paper);color:var(--ink);}
.lead-form input:focus{outline:none;border-color:var(--bright-deep);background:#fff;}
.lead-form .btn{width:100%;justify-content:center;margin-top:20px;}
.lead-form .hint{font-size:.82rem;color:var(--gray);margin-top:14px;text-align:center;}

/* ---------- Qualification form (LPs) ---------- */
.qual-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:start;}
.qual-intro .sub{margin-top:16px;}
.qual-points{list-style:none;margin:26px 0 0;padding:0;display:flex;flex-direction:column;gap:13px;}
.qual-points li{display:flex;align-items:center;gap:12px;font-weight:600;color:var(--green);font-size:1.02rem;}
.qual-points .ck{flex:none;width:27px;height:27px;border-radius:50%;background:rgba(120,193,81,.18);color:var(--bright-deep);display:flex;align-items:center;justify-content:center;}
.qual-form{background:#fff;border:1px solid rgba(35,60,54,.1);border-radius:var(--r);padding:30px;box-shadow:var(--shadow);display:grid;grid-template-columns:1fr 1fr;gap:15px;}
.qual-form .fhead{grid-column:1/-1;margin-bottom:2px;}
.qual-form .fhead b{font-family:"Fraunces",serif;font-size:1.3rem;color:var(--green);font-weight:600;}
.qual-form .field{margin:0;}
.qual-form .field.full{grid-column:1/-1;}
.qual-form label{display:block;font-size:.8rem;font-weight:700;color:var(--green);margin-bottom:6px;}
.qual-form input,.qual-form select{width:100%;padding:12px 14px;border:1.5px solid rgba(35,60,54,.16);border-radius:11px;font:inherit;font-size:.98rem;background:var(--paper);color:var(--ink);}
.qual-form input:focus,.qual-form select:focus{outline:none;border-color:var(--bright-deep);background:#fff;}
.qual-form select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23233C36' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><path d='m6 9 6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 13px center;padding-right:38px;cursor:pointer;}
.qual-form .btn{grid-column:1/-1;justify-content:center;margin-top:6px;}
.qual-form .hint{grid-column:1/-1;font-size:.8rem;color:var(--gray);text-align:center;line-height:1.5;}
.qual-form .hint a{color:var(--bright-deep);font-weight:600;}
@media(max-width:980px){.qual-grid{grid-template-columns:1fr;gap:34px;}}
@media(max-width:560px){.qual-form{grid-template-columns:1fr;}}

/* ---------- Article / legal copy ---------- */
.article{max-width:820px;}
.article h2{font-size:1.5rem;margin-top:38px;}
.article h3{font-size:1.18rem;margin-top:28px;}
.article p{margin-top:14px;color:var(--ink-soft);}
.article ul{margin-top:14px;padding-left:22px;color:var(--ink-soft);}
.article li{margin-top:8px;}
.article a{color:var(--bright-deep);font-weight:600;border-bottom:1px solid currentColor;}
.article .updated{font-size:.86rem;color:var(--gray);margin-bottom:8px;}

/* ---------- Final CTA ---------- */
.final{background:var(--green);color:var(--cream);text-align:center;padding:92px 0;position:relative;overflow:hidden;}
.final .watermark{position:absolute;font-family:"Fraunces",serif;font-weight:600;font-size:22rem;color:rgba(235,226,208,.05);top:50%;left:50%;transform:translate(-50%,-50%);white-space:nowrap;pointer-events:none;}
.final h2{font-size:clamp(2rem,4vw,2.9rem);color:#fff;position:relative;}
.final .sub{max-width:46em;margin:20px auto 0;color:rgba(235,226,208,.88);font-size:1.1rem;position:relative;}
.final .btn-row{margin-top:32px;justify-content:center;position:relative;}

/* ---------- Footer ---------- */
footer.site{background:var(--green-deep);color:rgba(235,226,208,.8);padding:60px 0 30px;}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.1fr;gap:36px;}
.foot-brand img{height:40px;margin-bottom:16px;}
.foot-brand .fn{color:var(--cream);font-family:"Fraunces",serif;font-size:1.15rem;display:block;margin-bottom:8px;}
.foot-brand p{font-size:.94rem;line-height:1.6;max-width:30em;color:rgba(235,226,208,.7);}
.foot-col h4{font-family:"Open Sans",sans-serif;font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;color:var(--taupe);font-weight:700;margin-bottom:16px;}
.foot-col a,.foot-col p{display:flex;align-items:flex-start;gap:10px;font-size:.94rem;margin-bottom:12px;color:rgba(235,226,208,.82);line-height:1.5;}
.foot-col a:hover{color:#fff;}
.foot-col svg{color:var(--bright);flex:none;margin-top:3px;}
.foot-bottom{margin-top:44px;padding-top:22px;border-top:1px solid rgba(235,226,208,.14);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:.8rem;color:rgba(235,226,208,.55);line-height:1.6;}
.foot-bottom .disc{max-width:62em;}

/* ---------- Floating WA ---------- */
.wa-float{position:fixed;right:20px;bottom:20px;z-index:90;display:flex;align-items:center;gap:12px;background:var(--bright);color:var(--green-deep);padding:13px 19px 13px 15px;border-radius:999px;font-weight:700;box-shadow:0 16px 36px -12px rgba(40,70,40,.6);transition:transform .3s var(--ease),box-shadow .3s;}
.wa-float:hover{transform:translateY(-3px);box-shadow:0 22px 44px -12px rgba(40,70,40,.7);}
.wa-float .pulse{width:38px;height:38px;border-radius:50%;background:var(--green);color:var(--bright);display:flex;align-items:center;justify-content:center;flex:none;position:relative;}
.wa-float .pulse::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid var(--bright);animation:pulse 2.2s ease-out infinite;}
@keyframes pulse{0%{transform:scale(1);opacity:.8}100%{transform:scale(1.7);opacity:0}}
.wa-float .lbl{display:flex;flex-direction:column;line-height:1.15;}
.wa-float .lbl span{font-size:.72rem;font-weight:600;opacity:.78;}

/* ---------- Cookie banner ---------- */
.cookie{position:fixed;left:20px;right:20px;bottom:20px;z-index:120;max-width:540px;margin:0 auto;background:#fff;border:1px solid rgba(35,60,54,.14);border-radius:16px;box-shadow:0 24px 60px -20px rgba(27,46,42,.5);padding:22px 24px;transform:translateY(140%);transition:transform .5s var(--ease);}
.cookie.show{transform:translateY(0);}
.cookie h4{font-size:1.05rem;}
.cookie p{font-size:.9rem;color:var(--ink-soft);margin-top:8px;}
.cookie p a{color:var(--bright-deep);font-weight:600;text-decoration:underline;}
.cookie .acts{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap;}
.cookie .btn{padding:11px 20px;font-size:.92rem;}
.cookie .btn.mini{background:transparent;color:var(--green);box-shadow:none;border:1.5px solid rgba(35,60,54,.2);}
.cookie .btn.mini:hover{background:var(--cream);}

/* ---------- reveal ---------- */
[data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
[data-reveal].in{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){[data-reveal]{opacity:1!important;transform:none!important;transition:none!important;}.wa-float .pulse::after{animation:none;}}

/* ---------- Responsive ---------- */
@media(max-width:1024px){
  .hero-grid,.editorial,.about,.contact-grid{grid-template-columns:1fr;gap:42px;}
  .about-media{order:-1;}
  .about-media .arch,.arch{margin:0 auto;}
  .area-grid,.frentes{grid-template-columns:1fr;}
  .duo{grid-template-columns:1fr;}
  .steps{grid-template-columns:1fr 1fr;}
  .step::before{display:none;}
  .creds{grid-template-columns:1fr;}
  .nav-links,.nav-phone{display:none;}
  .menu-btn{display:flex;}
  .mobile-menu{display:block;position:fixed;inset:0;z-index:100;background:rgba(27,46,42,.5);opacity:0;pointer-events:none;transition:opacity .3s;}
  .mobile-menu.open{opacity:1;pointer-events:auto;}
  .mobile-menu .panel{position:absolute;top:0;right:0;width:min(82vw,340px);height:100%;background:var(--paper);box-shadow:-20px 0 60px -20px rgba(0,0,0,.4);padding:26px 24px;display:flex;flex-direction:column;gap:6px;transform:translateX(100%);transition:transform .35s var(--ease);}
  .mobile-menu.open .panel{transform:none;}
  .mobile-menu .mhead{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;}
  .mobile-menu a.ml{padding:14px 6px;font-weight:600;color:var(--green);border-bottom:1px solid rgba(35,60,54,.1);font-size:1.05rem;}
  .mobile-menu .ml-group{margin-top:14px;padding:4px 6px;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gray);font-weight:700;}
  .mobile-menu a.ml-sub{padding-left:18px;font-size:1rem;color:var(--ink-soft);}
  .mobile-menu .btn{margin-top:18px;justify-content:center;}
  .mobile-menu .close{background:none;border:0;font-size:1.6rem;color:var(--green);cursor:pointer;line-height:1;}
  .foot-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:620px){
  body{font-size:16px;}
  .wrap{padding:0 18px;}
  .sec{padding:56px 0;}
  .hero{padding:34px 0 50px;}
  .steps{grid-template-columns:1fr;}
  .badge-float{left:0;bottom:14px;}
  .hero-media .watermark{display:none;}
  .brand .wm span{display:none;}
  .nav-cta .btn .full{display:none;}
  .wa-float .lbl{display:none;}
  .pullquote p{font-size:1.25rem;}
  .foot-grid{grid-template-columns:1fr;gap:30px;}
  .social-bar .divider{display:none;}
}
