:root{
  --lime:#A8CB4A; --lime-600:#7FA02C; --lime-700:#6B8A22; --lime-50:#F4F8E7;
  --graphite:#1B2430; --ink:#0C141E; --silver:#8C9099;
  --muted:#56616F; --bg:#FFFFFF; --bg-soft:#F5F8FC; --bg-soft2:#EEF3F9;
  --line:#E6EAF1; --wa:#25D366; --wa-d:#1EBE5B;
  --shadow:0 1px 2px rgba(16,30,50,.04),0 8px 24px rgba(16,30,50,.06); --shadow-lg:0 2px 6px rgba(16,30,50,.05),0 18px 44px rgba(16,30,50,.10);
  --r:14px; --r-sm:10px; --r-lg:20px;
  --maxw:1200px; --ease:cubic-bezier(.4,0,.2,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;color:var(--graphite);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
h1,h2,h3,h4,.font-d{font-family:'Sora',system-ui,sans-serif;letter-spacing:-.02em}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.sr{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}
:focus-visible{outline:3px solid var(--lime-600);outline-offset:2px;border-radius:6px}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}

/* ---------- TOP BAR ---------- */
.topbar{background:var(--graphite);color:#DCE3EC;font-size:13.5px}
.topbar .wrap{display:flex;align-items:center;justify-content:center;gap:18px;height:40px;text-align:center}
.topbar b{color:var(--lime)}
.topbar .tb-x{display:inline-flex;align-items:center;gap:7px}
.topbar svg{width:16px;height:16px;stroke:var(--lime)}
@media (max-width:720px){.topbar .tb-hide{display:none}}

/* ---------- NAV ---------- */
header.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.82);backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);border-bottom:1px solid var(--line)}
.nav .wrap{display:flex;align-items:center;gap:18px;height:74px}
.brand{display:flex;align-items:center;gap:10px;flex:0 0 auto}
.brand img{height:38px;width:auto}
.nav-links{display:flex;align-items:center;gap:6px;margin-left:auto}
.nav-links a{padding:10px 14px;border-radius:10px;font-weight:600;font-size:15px;color:var(--graphite);transition:.2s var(--ease)}
.nav-links a:hover{background:var(--bg-soft);color:var(--lime-700)}
.nav-links a.active{color:var(--lime-700);background:var(--lime-50)}
.nav-cta{display:inline-flex;align-items:center;gap:9px;background:var(--wa);color:#06270F;font-weight:700;
  padding:11px 18px;border-radius:999px;font-size:15px;box-shadow:0 4px 12px rgba(37,211,102,.20);transition:.2s var(--ease);flex:0 0 auto}
.nav-cta:hover{background:var(--wa-d);transform:translateY(-1px)}
.nav-cta svg{width:19px;height:19px}
.burger{display:none;flex:0 0 auto;margin-left:auto;width:46px;height:46px;border:1px solid var(--line);border-radius:12px;
  background:#fff;cursor:pointer;align-items:center;justify-content:center}
.burger svg{width:24px;height:24px;stroke:var(--graphite)}
@media (max-width:980px){
  .nav-links{display:none}
  .nav-cta.desk{display:none}
  .burger{display:flex}
}
/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:60;background:rgba(12,20,30,.5);opacity:0;pointer-events:none;transition:.25s}
.drawer.open{opacity:1;pointer-events:auto}
.drawer-panel{position:absolute;top:0;right:0;height:100%;width:min(82vw,340px);background:#fff;box-shadow:var(--shadow-lg);
  transform:translateX(100%);transition:.28s var(--ease);display:flex;flex-direction:column;padding:22px}
.drawer.open .drawer-panel{transform:none}
.drawer-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.drawer-head img{height:34px}
.drawer-close{width:42px;height:42px;border:1px solid var(--line);border-radius:10px;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}
.drawer-close svg{width:22px;height:22px;stroke:var(--graphite)}
.drawer a.dl{padding:15px 12px;border-radius:12px;font-weight:600;font-size:17px;border-bottom:1px solid var(--line)}
.drawer a.dl:hover{background:var(--bg-soft)}
.drawer .nav-cta{margin-top:18px;justify-content:center;font-size:16px;padding:14px}

/* ---------- VIEWS ---------- */
.view{display:none;animation:fade .35s ease}
.view.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ---------- HERO ---------- */
.hero{background:radial-gradient(1100px 460px at 82% -12%,var(--lime-50),transparent 62%),var(--bg);padding:72px 0 48px;position:relative;overflow:hidden}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;background:var(--lime-50);color:var(--lime-700);
  font-weight:600;font-size:12.5px;letter-spacing:.05em;padding:7px 13px;border-radius:999px;text-transform:uppercase}
.eyebrow svg{width:15px;height:15px;stroke:var(--lime-700)}
.hero h1{font-size:clamp(32px,4.6vw,52px);font-weight:800;line-height:1.06;margin:18px 0 16px}
.hero h1 .hl{color:var(--lime-700)}
.hero p.lead{font-size:18px;color:var(--muted);max-width:540px;margin-bottom:26px}
.hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:26px}
.btn{display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:16px;padding:14px 22px;border-radius:999px;cursor:pointer;border:none;transition:.2s var(--ease);font-family:inherit}
.btn-wa{background:var(--wa);color:#06270F;box-shadow:0 4px 14px rgba(37,211,102,.22)}
.btn-wa:hover{background:var(--wa-d);transform:translateY(-2px)}
.btn-ghost{background:#fff;color:var(--graphite);border:1.6px solid var(--line)}
.btn-ghost:hover{border-color:var(--lime);background:var(--lime-50)}
.btn svg{width:20px;height:20px}
.hero-mini{display:flex;gap:22px;flex-wrap:wrap}
.hero-mini .m{display:flex;align-items:center;gap:9px;font-size:14.5px;color:var(--graphite);font-weight:600}
.hero-mini .m svg{width:20px;height:20px;stroke:var(--lime-600)}

/* hero art */
.hero-art{position:relative;display:flex;justify-content:center}
.hero-art svg{width:100%;max-width:460px;filter:drop-shadow(0 18px 36px rgba(16,30,50,.12))}
@media (max-width:980px){
  .hero .wrap{grid-template-columns:1fr;gap:30px}
  .hero-art{order:-1}
  .hero-art svg{max-width:340px}
}

/* ---------- TRUST BAR ---------- */
.trust{background:var(--graphite);color:#E7ECF3}
.trust .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:26px 22px}
.trust .t{display:flex;align-items:center;gap:13px}
.trust .t .ic{width:46px;height:46px;border-radius:12px;background:rgba(168,203,74,.16);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.trust .t svg{width:24px;height:24px;stroke:var(--lime)}
.trust .t b{display:block;font-size:15px;font-family:'Sora';font-weight:700}
.trust .t span{font-size:13px;color:#AEB9C6}
@media (max-width:860px){.trust .wrap{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.trust .wrap{grid-template-columns:1fr}}

/* ---------- SECTIONS ---------- */
section.block{padding:72px 0}
section.block.soft{background:var(--bg-soft)}
.sec-head{text-align:center;max-width:680px;margin:0 auto 44px}
.sec-head .eyebrow{margin-bottom:14px}
.sec-head h2{font-size:clamp(26px,3.4vw,38px);font-weight:800;margin-bottom:12px}
.sec-head p{color:var(--muted);font-size:17px}

/* perfil cards */
.perfil-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.perfil{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:24px 18px;text-align:center;cursor:pointer;transition:.25s var(--ease)}
.perfil:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--lime)}
.perfil .pic{width:62px;height:62px;margin:0 auto 14px;border-radius:16px;background:var(--lime-50);display:flex;align-items:center;justify-content:center}
.perfil:hover .pic{background:var(--lime);}
.perfil .pic svg{width:30px;height:30px;stroke:var(--lime-700);transition:.2s}
.perfil:hover .pic svg{stroke:#1B2430}
.perfil b{font-family:'Sora';font-size:16px;display:block;margin-bottom:4px}
.perfil span{font-size:13px;color:var(--muted)}
@media (max-width:980px){.perfil-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:600px){.perfil-grid{grid-template-columns:repeat(2,1fr)}}

/* ---------- FILTER CHIPS ---------- */
.filters{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:34px}
.chip{border:1.6px solid var(--line);background:#fff;color:var(--graphite);font-weight:600;font-size:14.5px;
  padding:10px 18px;border-radius:999px;cursor:pointer;transition:.2s var(--ease);font-family:inherit;display:inline-flex;align-items:center;gap:8px}
.chip svg{width:17px;height:17px;stroke:currentColor}
.chip:hover{border-color:var(--lime)}
.chip.active{background:var(--graphite);color:#fff;border-color:var(--graphite)}
.chip.active svg{stroke:var(--lime)}

/* ---------- CARD GRID ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:980px){.cards{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.cards{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;
  transition:.25s var(--ease);position:relative}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:#D7E0EC}
.card-top{padding:22px 22px 0;display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.card.pop .card-top{padding-top:50px}
.card-ic{width:54px;height:54px;border-radius:13px;background:var(--lime-50);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.card-ic svg{width:28px;height:28px;stroke:var(--lime-700)}
.tag-cat{font-size:11.5px;font-weight:700;color:var(--silver);letter-spacing:.06em;text-transform:uppercase;text-align:right}
.badge-emit{display:inline-flex;align-items:center;gap:7px;margin:16px 22px 0;background:var(--graphite);color:#EAF0E2;
  font-size:11.5px;font-weight:600;padding:7px 12px;border-radius:999px;line-height:1.2}
.badge-emit svg{width:14px;height:14px;stroke:var(--lime);flex:0 0 auto}
.card h3{font-family:'Sora';font-size:20px;font-weight:800;margin:14px 22px 6px;line-height:1.2}
.card .desc{color:var(--muted);font-size:14px;margin:0 22px 14px}
.card .specs{display:flex;gap:8px;margin:0 22px 14px;flex-wrap:wrap}
.spec{display:inline-flex;align-items:center;gap:6px;background:var(--bg-soft);border:1px solid var(--line);
  border-radius:999px;padding:5px 11px;font-size:12.5px;font-weight:600;color:var(--graphite)}
.spec svg{width:14px;height:14px;stroke:var(--lime-600)}
.price-box{margin:0 22px 14px}
.price-old{font-size:14px;color:var(--silver);font-weight:600;margin-bottom:3px}
.price-old s{text-decoration:line-through}
.price-old span{font-size:11.5px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-right:4px}
.price-now{display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.price-now .ap{font-size:12.5px;color:var(--muted);font-weight:600}
.price-now .pv{font-family:'Sora';font-size:30px;font-weight:800;color:var(--graphite);line-height:1}
.off{display:inline-flex;align-items:center;background:var(--lime);color:#1B2430;font-family:'Sora';
  font-weight:800;font-size:13px;padding:5px 10px;border-radius:8px}
.pay-mini{display:flex;align-items:center;gap:6px;margin:0 22px 16px;flex-wrap:wrap}
.pay-mini .pl{font-size:11px;color:var(--silver);font-weight:600;margin-right:2px;text-transform:uppercase;letter-spacing:.04em}
.pay-mini svg{height:22px;width:auto;border-radius:4px}
.card-actions{margin-top:auto;padding:0 22px 22px;display:flex;gap:9px}
.card-actions .btn{flex:1;justify-content:center;padding:12px 10px;font-size:14.5px}
.card-actions .btn-min{flex:0 0 auto;background:#fff;border:1.6px solid var(--line);color:var(--graphite);padding:12px 14px}
.card-actions .btn-min:hover{border-color:var(--lime);background:var(--lime-50)}
.popular{position:absolute;top:0;left:0;background:var(--lime);color:#1B2430;font-size:11px;font-weight:800;
  padding:6px 14px 6px 16px;border-radius:0 0 12px 0;letter-spacing:.04em;box-shadow:0 2px 6px rgba(168,203,74,.25);z-index:2}
.empty{grid-column:1/-1;text-align:center;color:var(--muted);padding:40px}

/* ---------- PAYMENT SECTION ---------- */
.pay-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:30px}
.pay-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:24px 16px;text-align:center;transition:.25s var(--ease)}
.pay-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.pay-card .pm{height:40px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.pay-card .pm svg{height:38px;width:auto}
.pay-card b{font-family:'Sora';font-size:15px;display:block}
.pay-card span{font-size:12.5px;color:var(--muted)}
@media (max-width:860px){.pay-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:520px){.pay-grid{grid-template-columns:repeat(2,1fr)}}
.pay-note{display:flex;flex-wrap:wrap;gap:18px;justify-content:center;margin-top:6px}
.pay-note .pn{display:flex;align-items:center;gap:10px;background:var(--lime-50);border:1px solid #E4EECB;border-radius:14px;padding:14px 18px;font-size:14.5px;font-weight:600}
.pay-note .pn svg{width:22px;height:22px;stroke:var(--lime-700)}

/* ---------- CTA BAND ---------- */
.ctaband{background:linear-gradient(120deg,var(--ink),var(--graphite));color:#fff;border-radius:var(--r-lg);
  padding:46px;display:grid;grid-template-columns:1.4fr auto;gap:28px;align-items:center;box-shadow:var(--shadow-lg);position:relative;overflow:hidden}
.ctaband::after{content:"";position:absolute;right:-60px;top:-60px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(168,203,74,.18),transparent 70%)}
.ctaband h2{font-size:clamp(24px,3vw,34px);font-weight:800;margin-bottom:10px;position:relative}
.ctaband p{color:#AEB9C6;font-size:16px;position:relative}
.ctaband .cb-actions{display:flex;gap:12px;flex-wrap:wrap;position:relative}
@media (max-width:760px){.ctaband{grid-template-columns:1fr;padding:32px;text-align:center}.ctaband .cb-actions{justify-content:center}}

/* ---------- CONTACT ---------- */
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:40px}
.ccard{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px 24px;text-align:center;transition:.25s var(--ease);display:flex;flex-direction:column}
.ccard:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.ccard .ci{width:64px;height:64px;border-radius:16px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center}
.ccard.phone .ci{background:#E8F1FB}.ccard.phone .ci svg{stroke:#2E77BC}
.ccard.wa .ci{background:#E4F9EC}.ccard.wa .ci svg{stroke:var(--wa-d)}
.ccard.mail .ci{background:var(--lime-50)}.ccard.mail .ci svg{stroke:var(--lime-700)}
.ccard .ci svg{width:32px;height:32px}
.ccard h3{font-family:'Sora';font-size:19px;margin-bottom:6px}
.ccard .cval{font-size:17px;font-weight:700;color:var(--graphite);margin-bottom:4px}
.ccard .csub{font-size:13.5px;color:var(--muted);margin-bottom:18px}
.ccard .btn{margin-top:auto;justify-content:center}
.ccard.phone .btn{background:#2E77BC;color:#fff}.ccard.phone .btn:hover{background:#235e96}
.ccard.mail .btn{background:var(--graphite);color:#fff}.ccard.mail .btn:hover{background:#0C141E}
@media (max-width:820px){.contact-grid{grid-template-columns:1fr}}

.contact-extra{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}
@media (max-width:820px){.contact-extra{grid-template-columns:1fr}}
.composer{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:28px}
.composer h3{font-family:'Sora';font-size:20px;margin-bottom:6px}
.composer p.sub{color:var(--muted);font-size:14.5px;margin-bottom:18px}
.field{margin-bottom:14px}
.field label{display:block;font-size:13.5px;font-weight:600;margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:12px 14px;border:1.6px solid var(--line);border-radius:12px;
  font-family:inherit;font-size:15px;background:#fff;transition:.15s var(--ease)}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--lime);outline:none;box-shadow:0 0 0 3px rgba(168,203,74,.18)}
.field textarea{resize:vertical;min-height:84px}
.hours{background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--r);padding:28px}
.hours h3{font-family:'Sora';font-size:20px;margin-bottom:16px}
.hours .hr{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line)}
.hours .hr:last-child{border-bottom:none}
.hours .hr svg{width:22px;height:22px;stroke:var(--lime-600);flex:0 0 auto}
.hours .hr b{font-family:'Sora';font-size:14.5px}
.hours .hr span{font-size:13.5px;color:var(--muted);display:block}

/* ---------- AUTORIDADE / SELOS ---------- */
.authority{background:var(--bg)}
.auth-inner{display:grid;grid-template-columns:1.35fr .65fr;gap:44px;align-items:center}
.auth-text .eyebrow{margin-bottom:14px}
.auth-text h2{font-size:clamp(23px,3vw,32px);font-weight:800;margin-bottom:12px;line-height:1.15}
.auth-text p{color:var(--muted);font-size:16px;margin-bottom:24px;max-width:560px}
.auth-text b{color:var(--graphite);font-weight:700}
.seals{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.seal{background:#fff;border:1px solid var(--line);border-radius:14px;padding:0 20px;display:flex;align-items:center;
  justify-content:center;height:76px;box-shadow:var(--shadow);transition:.25s var(--ease)}
.seal:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.seal img{height:44px;width:auto}
.auth-img{display:flex;justify-content:center}
.auth-img figure{margin:0;text-align:center}
.auth-img img{width:100%;max-width:280px;border-radius:20px;box-shadow:var(--shadow-lg)}
.auth-img figcaption{font-size:13px;color:var(--muted);margin-top:12px;font-weight:600}
@media (max-width:860px){.auth-inner{grid-template-columns:1fr;gap:30px}.auth-img{order:-1}.auth-img img{max-width:230px}.seal{height:66px}.seal img{height:38px}}

/* selos no rodapé (chips claros) */
.foot-seals{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:18px}
.foot-seals .fs-lbl{font-size:12px;color:#7A8696;font-weight:600;width:100%;margin-bottom:2px}
.foot-seals .chip-seal{background:#fff;border-radius:10px;padding:7px 12px;display:flex;align-items:center;height:42px}
.foot-seals .chip-seal img{height:26px;width:auto}

/* ---------- CONSELHOS PROFISSIONAIS ---------- */
.council-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.council{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px 12px;text-align:center;transition:.25s var(--ease)}
.council:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--lime)}
.council .cic{width:54px;height:54px;border-radius:14px;background:var(--lime-50);display:flex;align-items:center;justify-content:center;margin:0 auto 12px;transition:.2s}
.council:hover .cic{background:var(--lime)}
.council .cic svg{width:28px;height:28px;stroke:var(--lime-700);transition:.2s}
.council:hover .cic svg{stroke:#1B2430}
.council b{font-family:'Sora';font-size:15px;display:block;margin-bottom:2px}
.council span{font-size:12px;color:var(--muted);font-weight:700;letter-spacing:.04em}
.council-note{text-align:center;color:var(--muted);font-size:14px;margin-top:24px}
@media(max-width:900px){.council-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.council-grid{grid-template-columns:repeat(2,1fr)}}

/* ---------- FOOTER ---------- */
footer{background:var(--ink);color:#AEB9C6;padding:52px 0 26px;margin-top:10px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:34px;padding-bottom:34px;border-bottom:1px solid rgba(255,255,255,.08)}
.foot-brand img{height:40px;margin-bottom:16px}
.foot-brand p{font-size:14px;max-width:300px}
.foot-col h4{color:#fff;font-family:'Sora';font-size:15px;margin-bottom:14px}
.foot-col a{display:block;font-size:14px;padding:6px 0;color:#AEB9C6;transition:.15s var(--ease)}
.foot-col a:hover{color:var(--lime)}
.foot-contact .fc{display:flex;align-items:center;gap:10px;padding:7px 0;font-size:14px}
.foot-contact .fc svg{width:18px;height:18px;stroke:var(--lime);flex:0 0 auto}
.legal{padding-top:22px;font-size:12.5px;color:#7A8696;line-height:1.7}
.legal .lg-row{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:14px}
@media (max-width:860px){.foot-grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.foot-grid{grid-template-columns:1fr}}

/* ---------- FLOATING WA ---------- */
.fab{position:fixed;right:20px;bottom:20px;z-index:40;display:flex;align-items:center;gap:10px;background:var(--wa);
  color:#06270F;font-weight:700;padding:14px 20px;border-radius:999px;box-shadow:0 6px 20px rgba(37,211,102,.28);
  transition:.2s var(--ease);font-size:15px}
.fab:hover{transform:translateY(-2px);background:var(--wa-d)}
.fab svg{width:24px;height:24px}
.fab .fab-txt{display:inline}
@media (max-width:520px){.fab .fab-txt{display:none}.fab{padding:16px;right:16px;bottom:16px}}

/* ---------- MODAL ---------- */
.modal{position:fixed;inset:0;z-index:70;background:rgba(12,20,30,.6);display:flex;align-items:center;justify-content:center;
  padding:20px;opacity:0;pointer-events:none;transition:.25s}
.modal.open{opacity:1;pointer-events:auto}
.modal-box{background:#fff;border-radius:var(--r-lg);max-width:560px;width:100%;max-height:90vh;overflow:auto;
  transform:translateY(20px) scale(.98);transition:.28s var(--ease);box-shadow:var(--shadow-lg)}
.modal.open .modal-box{transform:none}
.modal-hd{padding:26px 28px 0;display:flex;justify-content:space-between;align-items:flex-start;gap:14px}
.modal-ic{width:60px;height:60px;border-radius:15px;background:var(--lime-50);display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.modal-ic svg{width:32px;height:32px;stroke:var(--lime-700)}
.modal-x{width:42px;height:42px;border:1px solid var(--line);border-radius:12px;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.modal-x svg{width:22px;height:22px;stroke:var(--graphite)}
.modal-box .m-cat{font-size:12px;font-weight:700;color:var(--silver);text-transform:uppercase;letter-spacing:.05em;padding:18px 28px 0}
.modal-box h2{font-family:'Sora';font-size:26px;padding:4px 28px 0}
.modal-box .m-desc{color:var(--muted);padding:12px 28px 0;font-size:15.5px}
.m-badge{margin:18px 28px 0;display:inline-flex;align-items:center;gap:8px;background:var(--graphite);color:#EAF0E2;font-size:13px;font-weight:600;padding:9px 14px;border-radius:999px}
.m-badge svg{width:16px;height:16px;stroke:var(--lime)}
.m-specs{display:flex;gap:10px;padding:18px 28px 0;flex-wrap:wrap}
.m-price{padding:20px 28px 0;display:flex;flex-direction:column;align-items:flex-start;gap:4px}
.m-price .ap{color:var(--muted);font-weight:600}
.m-price .pv{font-family:'Sora';font-size:38px;font-weight:800}
.m-pay{padding:18px 28px 0}
.m-pay .lbl{font-size:12.5px;font-weight:700;color:var(--silver);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}
.m-pay .pm-list{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.m-pay .pm-list svg{height:26px;width:auto;border-radius:4px}
.m-foot{padding:22px 28px 28px;display:flex;gap:10px;flex-wrap:wrap}
.m-foot .btn{flex:1;justify-content:center;min-width:160px}
.m-legal{font-size:11.5px;color:var(--silver);padding:0 28px 24px;line-height:1.6}
