:root{
  --red:#c0392b;--red2:#96281b;
  --dark:#111111;--dark2:#1c1c1c;
  --s0:#ffffff;   /* section white */
  --s1:#f5f5f5;   /* section light gray */
  --s2:#eeeeee;   /* section medium gray */
  --card:#ffffff; /* card background */
  --txt:#1a1a1a;--txtm:#4a4a4a;--txts:#888;
  --bd:rgba(0,0,0,.07);--bdm:rgba(0,0,0,.11);
  --nh:68px;--r:8px;
  --fd:'Playfair Display',serif;--fb:'DM Sans',sans-serif;
  --sh:0 2px 20px rgba(0,0,0,.06);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--fb);color:var(--txt);background:var(--s1);-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}

.wrap{width:100%;max-width:1180px;margin:0 auto;padding:0 32px}
.section{padding:86px 0}
.bg-w{background:var(--s0)}
.bg-g{background:var(--s1)}
.bg-g2{background:var(--s2)}
.bg-dk{background:var(--dark)}

/* TYPOGRAPHY */
.title{font-family:var(--fd);font-size:clamp(1.8rem,3.2vw,2.6rem);font-weight:500;line-height:1.15;color:var(--txt)}
.title em{color:var(--red);font-style:italic}
.title.light{color:#fff}
.eyebrow{display:block;font-size:.64rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--txts);margin-bottom:9px}
.eyebrow-red{display:block;font-size:.64rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--red);margin-bottom:9px}
.subtitle{font-size:.9rem;color:var(--txtm);font-weight:300;margin-top:10px;line-height:1.7}
.body-txt{font-size:.92rem;line-height:1.82;color:var(--txtm);font-weight:300;margin-bottom:10px}
.body-txt strong{color:var(--txt);font-weight:600}
.sec-hdr{margin-bottom:48px}
.sec-hdr.center{text-align:center}
.pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:22px}
.pill{display:inline-block;padding:5px 15px;border:1.5px solid var(--red);border-radius:100px;font-size:.72rem;font-weight:500;color:var(--red)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 28px;font-family:var(--fb);font-size:.78rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;border-radius:var(--r);transition:.22s;border:none;cursor:pointer}
.btn-red{background:var(--red);color:#fff;transition:background .2s,transform .18s,box-shadow .2s}
.btn-ghost{background:transparent;color:var(--txt);border:1.5px solid var(--bdm)}
.btn-ghost:hover{border-color:var(--red);color:var(--red);background:rgba(192,57,43,.04)}
.btn-outline-dk{background:transparent;color:var(--txt);border:1.5px solid var(--bdm);font-size:.74rem}
.btn-outline-dk:hover{border-color:var(--red);color:var(--red)}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:999;height:var(--nh);background:rgba(255,255,255,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--bd);transition:background .3s,border-color .3s,box-shadow .3s}
.nav.scrolled{background:rgba(255,255,255,.97);backdrop-filter:blur(12px);border-color:var(--bd);box-shadow:var(--sh)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:var(--nh);padding:0 32px;max-width:1400px;margin:0 auto}
.nav-logo img{height:80px;width:auto;object-fit:contain}
.nav-links{display:flex;align-items:center;gap:22px;list-style:none}
.nav-links a{font-size:.68rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--txtm);transition:.2s;position:relative}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-4px;width:0;height:1.5px;background:var(--red);transition:.3s}
.nav-links a:hover{color:var(--red)}
.nav-links a:hover::after{width:100%}
.nav.scrolled .nav-links a{color:var(--txtm);}
.nav.scrolled .nav-links a:hover{color:var(--red);}
.nav-cta{padding:7px 17px;border:1.5px solid var(--red);border-radius:var(--r);color:var(--red)!important}
.nav-cta::after{display:none!important}
.nav-cta:hover{background:var(--red);color:#fff!important}
.nav-burger{display:none;flex-direction:column;gap:5px;padding:6px}
.nav-burger span{display:block;width:22px;height:1.5px;background:var(--txt);transition:.25s}

.nav-burger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-burger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.nav-mob{position:absolute;top:var(--nh);left:0;right:0;background:var(--s0);backdrop-filter:blur(14px);border-bottom:1px solid var(--bd);max-height:0;overflow:hidden;transition:max-height .35s ease;display:flex;flex-direction:column;box-shadow:var(--sh)}
.nav-mob.open{max-height:520px}
.mob-link{display:block;padding:13px 24px;font-size:.78rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--txtm);border-bottom:1px solid var(--bd);transition:color .2s}
.mob-link:hover{color:var(--red)}

/* HERO */
.hero{position:relative;min-height:100vh;background:var(--s1);overflow:hidden;display:flex;align-items:center;border-bottom:1px solid var(--bd)}
.hero-arc{position:absolute;right:-8%;top:50%;transform:translateY(-50%);width:52vw;height:52vw;max-width:720px;max-height:720px;border-radius:50%;border:1px solid rgba(192,57,43,.12);background:radial-gradient(circle,rgba(192,57,43,.03) 0%,transparent 70%);pointer-events:none}
.hero-arc::before{content:'';position:absolute;inset:12%;border-radius:50%;border:1px solid rgba(192,57,43,.07)}
.hero .wrap{position:relative;z-index:1;padding-top:calc(var(--nh) + 72px);padding-bottom:68px}
.hero-tagline{font-size:.65rem;font-weight:600;letter-spacing:.28em;text-transform:uppercase;color:var(--txts);margin-bottom:16px}
.hero-title{font-family:var(--fd);font-size:clamp(2.6rem,6vw,4.8rem);font-weight:400;line-height:1.06;color:var(--txt);margin-bottom:22px;max-width:560px}
.hero-title em{color:var(--red);font-style:italic}
.hero-desc{font-size:.92rem;font-weight:300;color:var(--txtm);max-width:420px;line-height:1.8;margin-bottom:34px}
.hero-stats{display:flex;align-items:center;flex-wrap:wrap;padding-top:34px;border-top:1px solid var(--bdm);margin-top:46px;max-width:560px}
.hstat{display:flex;flex-direction:column;gap:4px;padding:8px 0;flex:1 1 120px}
.hnum{font-family:var(--fd);font-size:2rem;font-weight:500;color:var(--red);line-height:1}
.hlbl{font-size:.67rem;color:var(--txts);font-weight:300;letter-spacing:.04em;line-height:1.4}
.hdiv{width:1px;height:32px;background:var(--bdm);margin:0 14px;align-self:center;flex-shrink:0}

/* SOBRE */
.sobre-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:72px;align-items:center}
.sobre-visual{position:relative;padding:22px 22px 22px 22px}
.sobre-main-img{position:relative;border-radius:16px;overflow:hidden;aspect-ratio:4/5;box-shadow:0 24px 64px rgba(0,0,0,.15),0 4px 16px rgba(0,0,0,.08)}
.sobre-main-img img{width:100%;height:100%;object-fit:cover}
.sobre-badge{position:absolute;bottom:-14px;right:-14px;background:var(--red);color:#fff;padding:18px 24px;border-radius:var(--r);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;box-shadow:0 6px 22px rgba(192,57,43,.35);text-align:center;min-width:90px}
.b-num{font-family:var(--fd);font-size:2rem;font-weight:500;line-height:1;display:block;text-align:center;width:100%}
.b-txt{font-size:.58rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;text-align:center;opacity:.9;display:block;width:100%}
.sobre-txt{padding-left:4px}

/* SERVICOS */
.sv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--bdm);border:1px solid var(--bdm);border-radius:var(--r);overflow:hidden}
.sv-card{background:var(--card);padding:34px 26px;transition:background .22s}
.sv-card:hover{background:var(--s1)}
.sv-ico{width:38px;height:38px;color:#bbb;margin-bottom:16px;transition:color .22s}
.sv-card:hover .sv-ico{color:var(--red)}
.sv-card h3{font-family:var(--fd);font-size:1.08rem;font-weight:500;color:var(--txt);margin-bottom:9px}
.sv-card p{font-size:.82rem;line-height:1.72;color:var(--txtm);font-weight:300}
.sv-cta{text-align:center;margin-top:36px}

/* PRODUTOS */
.ptabs{display:flex;border-bottom:1px solid var(--bd);margin-bottom:36px;flex-wrap:wrap}
.ptab{padding:11px 26px;font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--txts);border-bottom:2px solid transparent;margin-bottom:-1px;transition:.2s;background:none;border-top:none;border-left:none;border-right:none;cursor:pointer}
.ptab:hover{color:var(--txt)}
.ptab.active{color:var(--red);border-bottom-color:var(--red)}
.tab-panel{display:none}
.tab-panel.active{display:block}
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.prod-card{background:var(--card);border:1px solid var(--bd);border-radius:var(--r);overflow:hidden;transition:box-shadow .26s,transform .26s;display:block;color:inherit}
.prod-card:hover{box-shadow:0 12px 34px rgba(0,0,0,.1);transform:translateY(-4px)}
.prod-img{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--s2)}
.prod-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.prod-card:hover .prod-img img{transform:scale(1.04)}
.ptag{position:absolute;top:10px;left:10px;background:var(--red);color:#fff;font-size:.61rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:3px 10px;border-radius:100px}
.prod-info{padding:16px 18px 20px}
.prod-info h4{font-family:var(--fd);font-size:1.05rem;font-weight:500;margin-bottom:6px;color:var(--txt)}
.prod-info p{font-size:.81rem;line-height:1.65;color:var(--txtm);font-weight:300;margin-bottom:10px}
.prod-cta{font-size:.7rem;font-weight:600;color:var(--red);letter-spacing:.06em;text-transform:uppercase}

/* Lentes grid 2x3 */
.lentes-grid{grid-template-columns:repeat(3,1fr)}
.lente-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:32px 22px;gap:0}
.lente-card .prod-info{padding:0;width:100%}
.lente-card .prod-info h4{margin-top:0;margin-bottom:8px}
.lente-ico{width:72px;height:72px;margin:0 auto 18px;display:flex;align-items:center;justify-content:center}
.lente-ico svg{width:60px;height:60px}

/* UNIDADES */
.unidade{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:start;min-width:0}
.unidade-rev{direction:rtl}
.unidade-rev>*{direction:ltr}
.u-sep{height:1px;background:var(--bdm);margin:56px 0}
.u-gal{display:flex;flex-direction:column;gap:10px;width:100%;min-width:0}
.u-main-wrap{position:relative;border-radius:var(--r);overflow:hidden;width:100%;display:block;line-height:0}
.u-main-wrap img{display:block;width:100%;height:auto;transition:opacity .28s;vertical-align:bottom}
.u-lbl{position:absolute;bottom:10px;left:10px;z-index:3;background:rgba(0,0,0,.55);color:#fff;font-size:.61rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;padding:8px 18px;border-radius:4px}
.u-thumbs{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;align-items:start}




.u-badges{display:flex;gap:8px;margin-bottom:10px}
.ubadge{font-size:.6rem;font-weight:700;letter-spacing:.13em;text-transform:uppercase;padding:4px 12px;border:1px solid var(--bdm);border-radius:100px;color:var(--txts)}
.ubadge.red{border-color:rgba(192,57,43,.4);color:var(--red)}
.ubadge.grey{border-color:var(--bdm);color:var(--txts)}
.u-name{font-family:var(--fd);font-size:1.7rem;font-weight:500;color:var(--txt);margin-bottom:8px}
.u-addr{font-size:.83rem;color:var(--txts);margin-bottom:22px;font-weight:300;line-height:1.7}
.u-hrs{padding:13px 0;border-top:1px solid var(--bd);border-bottom:1px solid var(--bd);margin-bottom:20px}
.hr-row{display:flex;justify-content:space-between;font-size:.82rem;padding:4px 0}
.hr-row strong{color:var(--txt);font-weight:500}
.hr-row span{color:var(--txts);font-weight:300}
.u-actions{display:flex;gap:10px;flex-wrap:wrap}

/* AVALIACOES */
.av-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px} /* legacy */
.av-card{background:var(--card);border:1px solid var(--bd);border-radius:var(--r);padding:26px 22px;display:flex;flex-direction:column;gap:14px;box-shadow:var(--sh)}
.av-stars{color:var(--red);font-size:.95rem;letter-spacing:2px}
.av-card p{font-size:.84rem;line-height:1.75;color:var(--txtm);font-weight:300;flex:1}
.av-autor{display:flex;align-items:center;gap:11px}
.av-ini{width:36px;height:36px;background:var(--red);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;flex-shrink:0}
.av-autor strong{font-size:.86rem;font-weight:600;color:var(--txt);display:block}
.av-autor span{font-size:.74rem;color:var(--txts);font-weight:300}

/* FAQ */
.faq-list{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:10px}
.faq-item{background:var(--card);border:1px solid var(--bd);border-radius:var(--r);overflow:hidden}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;padding:18px 22px;font-size:.9rem;font-weight:500;color:var(--txt);text-align:left;cursor:pointer;transition:background .2s}
.faq-q:hover{background:var(--s1)}
.faq-arr{font-size:1.2rem;color:var(--red);transition:transform .25s;flex-shrink:0;margin-left:12px}
.faq-item.open .faq-arr{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .32s ease}
.faq-item.open .faq-a{max-height:300px}
.faq-a p{padding:0 22px 18px;font-size:.85rem;line-height:1.78;color:var(--txtm);font-weight:300;border-top:1px solid var(--bd);padding-top:14px}

/* CONTATO */
.ct-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.ct-grid-4{grid-template-columns:1.4fr 1fr 1fr}
.ct-card{display:flex;align-items:flex-start;gap:14px;padding:22px 18px;border-radius:var(--r);border:1px solid var(--bd);background:var(--card);transition:transform .22s,box-shadow .22s,border-color .22s}
.ct-card:hover{transform:translateY(-4px);box-shadow:0 10px 28px rgba(0,0,0,.08)}
.ct-ico{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ct-wpp .ct-ico{background:#e6faf0;color:#25D366}.ct-wpp:hover{border-color:#25D366}
.ct-ig .ct-ico{background:linear-gradient(135deg,#fdf4ea,#fce4f0);color:#E1306C}.ct-ig:hover{border-color:#E1306C}
.ct-fb .ct-ico{background:#eaf0fb;color:#1877F2}.ct-fb:hover{border-color:#1877F2}
.ct-txt h4{font-size:.88rem;font-weight:600;color:var(--txt);margin-bottom:4px}
.ct-txt p{font-size:.79rem;line-height:1.6;color:var(--txtm);font-weight:300;margin-bottom:8px}
.ct-txt span{font-size:.69rem;font-weight:700;letter-spacing:.07em;color:var(--red);text-transform:uppercase}
.ct-wpp-double{cursor:default}
.ct-wpp-btns{display:flex;flex-direction:column;gap:7px;margin-top:8px}
.ct-wpp-link{display:flex;align-items:center;gap:7px;font-size:.8rem;font-weight:500;color:var(--txt);padding:7px 11px;border-radius:var(--r);background:rgba(37,211,102,.07);border:1px solid rgba(37,211,102,.16);transition:.2s}
.ct-wpp-link:hover{background:rgba(37,211,102,.14);border-color:#25D366;color:#166534}
.ct-wpp-dot{width:7px;height:7px;border-radius:50%;background:#25D366;flex-shrink:0}

/* TRABALHE CONOSCO */
.trab-inner{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.trab-list{display:flex;flex-direction:column;gap:10px;margin-top:18px}
.trab-list li{font-size:.87rem;color:var(--txtm);font-weight:300;padding-left:18px;position:relative}
.trab-list li::before{content:'';position:absolute;left:0;top:.52em;width:6px;height:6px;border-radius:50%;background:var(--red)}
.trab-card{background:var(--card);border:1px solid var(--bd);border-top:3px solid var(--red);border-radius:var(--r);padding:28px 26px;box-shadow:var(--sh)}
.trab-card-header{display:flex;align-items:flex-start;gap:14px;margin-bottom:22px}
.trab-card-header h4{font-family:var(--fd);font-size:1.15rem;font-weight:500;margin-bottom:5px}
.trab-card-header p{font-size:.82rem;line-height:1.62;color:var(--txtm);font-weight:300}
.trab-units{display:flex;gap:10px;flex-wrap:wrap}
.trab-unit-btn{display:inline-flex;align-items:center;gap:8px;padding:9px 17px;border:1.5px solid var(--bdm);border-radius:100px;background:var(--s1);transition:border-color .2s,background .2s;cursor:pointer;text-decoration:none;font-size:.78rem;font-weight:600;color:var(--txt)}
.trab-unit-btn:hover{border-color:var(--red);color:var(--red)}
.trab-unit-num{width:20px;height:20px;background:var(--red);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:700;flex-shrink:0}

/* FOOTER */
.footer{background:var(--dark2);color:#fff;padding:60px 0 0}
.ft-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.06)}
.ft-logo{height:70px;width:auto;object-fit:contain;margin-bottom:13px}
.ft-brand p{font-size:.79rem;color:rgba(255,255,255,.3);font-weight:300;line-height:1.75;max-width:240px;margin-bottom:16px}
.ft-socials{display:flex;gap:9px;flex-wrap:wrap}
.ft-socials a{width:32px;height:32px;border:1px solid rgba(255,255,255,.1);border-radius:6px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.38);transition:.22s}
.ft-socials a:hover{border-color:var(--red);color:var(--red)}
.ft-col h5{font-size:.62rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--red);margin-bottom:14px}
.ft-col ul{display:flex;flex-direction:column;gap:9px}
.ft-col li,.ft-col a{font-size:.8rem;color:rgba(255,255,255,.36);font-weight:300;transition:color .22s}
.ft-col a:hover{color:var(--red)}
.ft-bot{display:flex;justify-content:space-between;align-items:center;padding:18px 0;font-size:.7rem;color:rgba(255,255,255,.16);font-weight:300}

/* FAB */
.fab-wrap{position:fixed;bottom:24px;left:24px;z-index:900;display:flex;flex-direction:column;align-items:flex-start;gap:10px}
.fab-opts{display:flex;flex-direction:column;gap:8px;pointer-events:none;opacity:0;transform:translateY(8px);transition:opacity .22s,transform .22s}
.fab-opts.open{pointer-events:auto;opacity:1;transform:translateY(0)}
.fab-opt{display:flex;align-items:center;gap:10px;background:#fff;border-radius:100px;padding:7px 14px 7px 7px;box-shadow:0 4px 16px rgba(0,0,0,.13);font-size:.76rem;font-weight:600;color:var(--txt);transition:transform .18s,box-shadow .18s;white-space:nowrap}
.fab-opt:hover{transform:translateX(3px);box-shadow:0 6px 20px rgba(0,0,0,.18)}
.fab-opt-ico{width:32px;height:32px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}
.fab-btn{width:56px;height:56px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 18px rgba(37,211,102,.4);transition:.22s;color:#fff;position:relative;cursor:pointer;border:none}
.fab-btn.open{background:var(--dark)}
.fab-ico-wpp,.fab-ico-x{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;transition:opacity .18s,transform .18s}
.fab-ico-x{opacity:0;transform:rotate(-90deg)}
.fab-btn.open .fab-ico-wpp{opacity:0;transform:rotate(90deg)}
.fab-btn.open .fab-ico-x{opacity:1;transform:rotate(0)}

/* ── 1100px ── */
@media(max-width:1100px){
  .av-grid{grid-template-columns:repeat(2,1fr)}
  .ft-top{grid-template-columns:1fr 1fr;gap:28px}
  .nav-links{gap:16px}
  .nav-links a{font-size:.65rem}
  .ct-grid-4{grid-template-columns:1.2fr 1fr 1fr}
}

/* ── 960px ── */
@media(max-width:960px){
  .sobre-grid{grid-template-columns:1fr;gap:44px}
  .sobre-txt{padding-left:0}
  .sobre-badge{bottom:-10px;right:0}
  .sv-grid{grid-template-columns:repeat(2,1fr)}
  .unidade{grid-template-columns:1fr;gap:28px}
  .unidade-rev{direction:ltr}
  .trab-inner{grid-template-columns:1fr;gap:36px}
  .lentes-grid{grid-template-columns:repeat(2,1fr)}
}

/* ── 768px ── */
@media(max-width:768px){
  .nav-links{display:none}
  .nav-burger{display:flex}
  .nav-inner{padding:0 16px}
  .wrap{padding:0 20px}
  .section{padding:60px 0}
  .sec-hdr{margin-bottom:32px}
  .hero .wrap{padding-top:calc(var(--nh) + 52px);padding-bottom:44px;padding-left:20px;padding-right:20px}
  .hero-title{font-size:clamp(2.2rem,9vw,3.4rem);max-width:100%}
  .hero-desc{font-size:.87rem;max-width:100%}
  .hero-stats{display:grid;grid-template-columns:1fr 1fr;gap:16px 0;padding-top:22px;max-width:100%}
  .hdiv{display:none}
  .hstat{flex:none;min-width:0;padding:0}
  .hnum{font-size:1.7rem}
  .prod-grid{grid-template-columns:1fr 1fr}
  .lentes-grid{grid-template-columns:1fr 1fr}
  .av-grid{grid-template-columns:1fr}
  .ct-grid,.ct-grid-4{grid-template-columns:1fr}
  .ft-top{grid-template-columns:1fr;gap:24px}
  .ft-bot{flex-direction:column;gap:5px;text-align:center}
  .u-actions{flex-direction:column}
  .u-actions .btn{justify-content:center}
}

/* ── 540px ── */
@media(max-width:540px){
  .wrap{padding:0 16px}
  .hero .wrap{padding-left:16px;padding-right:16px}
  .prod-grid{grid-template-columns:1fr}
  .lentes-grid{grid-template-columns:1fr}
  .hero-title{font-size:clamp(2rem,10vw,2.7rem)}
  .section{padding:48px 0}
  .sv-grid{grid-template-columns:1fr}
  .fab-wrap{bottom:16px;left:16px}
}

/* ── 380px ── */
@media(max-width:380px){
  .wrap{padding:0 12px}
  .hero .wrap{padding-left:12px;padding-right:12px}
  .hero-title{font-size:1.95rem}
  .title{font-size:1.6rem}
  .btn{padding:11px 18px;font-size:.74rem}
  .nav-logo img{height:32px}
}

/* Gray section card lift */
.bg-g .sv-card{box-shadow:var(--sh)}
.bg-g .av-card{box-shadow:0 1px 8px rgba(0,0,0,.05)}
.bg-g .faq-item{box-shadow:0 1px 6px rgba(0,0,0,.04)}
.bg-g .prod-card{box-shadow:var(--sh)}
.bg-g .trab-card{box-shadow:0 2px 12px rgba(0,0,0,.07)}
.bg-g .u-info .u-hrs{border-color:var(--bd)}

/* Nav: when scrolled on light bg, logo keeps its color */
.nav.scrolled .nav-logo img{filter:none}

/* Unidade bg-g: info text colors remain readable */
.bg-g .u-name{color:var(--txt)}
.bg-g .u-addr{color:var(--txts)}
.bg-g .hr-row strong{color:var(--txt)}
.bg-g .hr-row span{color:var(--txts)}
.bg-g .ubadge{border-color:var(--bdm);color:var(--txts)}
.bg-g .ubadge.red{border-color:rgba(192,57,43,.35);color:var(--red)}
.bg-g .ubadge.grey{border-color:var(--bdm);color:var(--txts)}
.bg-g .u-sep{background:var(--bdm)}

/* ── CAROUSEL AVALIACOES ─────────────────────────── */
.carousel-wrap{position:relative;width:100%;user-select:none}

.carousel-track{
  position:relative;
  overflow:hidden;
  width:100%;
  min-height:260px;
}

/* Cards inside carousel are positioned absolutely by JS */
.carousel-track .av-card{
  box-sizing:border-box;
  padding:26px 22px;
  /* JS sets position:absolute, width, transform */
}

/* Slide transition classes */
@keyframes slideOutLeft  { from{opacity:1;transform:translateX(0)} to{opacity:0;transform:translateX(-6%)} }
@keyframes slideOutRight { from{opacity:1;transform:translateX(0)} to{opacity:0;transform:translateX(6%)} }
@keyframes slideInRight  { from{opacity:0;transform:translateX(6%)} to{opacity:1;transform:translateX(0)} }
@keyframes slideInLeft   { from{opacity:0;transform:translateX(-6%)} to{opacity:1;transform:translateX(0)} }

.carousel-track.slide-out-left  { animation: slideOutLeft  .35s ease forwards }
.carousel-track.slide-out-right { animation: slideOutRight .35s ease forwards }
.carousel-track.slide-in-right  { animation: slideInRight  .35s ease forwards }
.carousel-track.slide-in-left   { animation: slideInLeft   .35s ease forwards }

/* Controls */
.carousel-controls{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  margin-top:28px;
}
.car-btn{
  width:40px;height:40px;
  border-radius:50%;
  border:1.5px solid var(--bdm);
  background:var(--card);
  color:var(--txt);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  transition:border-color .2s,background .2s,color .2s,opacity .2s;
  flex-shrink:0;
}
.car-btn:hover:not(:disabled){border-color:var(--red);color:var(--red);background:rgba(192,57,43,.04)}
.car-btn:disabled{cursor:default}
.car-dots{display:flex;gap:7px;align-items:center}
.car-dot{
  width:8px;height:8px;
  border-radius:50%;
  border:none;
  background:var(--bdm);
  cursor:pointer;
  transition:background .25s,transform .25s,width .25s;
  padding:0;
}
.car-dot.active{
  background:var(--red);
  width:22px;
  border-radius:100px;
}

/* ── COUNTER easing ──────────────────────────────── */
.hnum{
  display:inline-block;
  font-variant-numeric:tabular-nums;
  transition:color .3s;
}

/* ── HERO BUTTONS row ─────────────────────────────── */
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.btn-ghost-dk{
  background:transparent;
  color:var(--txt);
  border:1.5px solid var(--bdm);
  font-family:var(--fb);
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.07em;
  text-transform:uppercase;
  padding:13px 28px;
  border-radius:var(--r);
  display:inline-flex;align-items:center;justify-content:center;
  transition:.22s;cursor:pointer;
}
.btn-ghost-dk:hover{border-color:var(--red);color:var(--red);background:rgba(192,57,43,.04)}

/* ── DOMINGO FECHADO ─────────────────────────────── */
.hr-closed strong{color:var(--txts)!important}
.hr-closed span{color:#c0392b!important;font-weight:500}

/* ── MODAL SELEÇÃO DE UNIDADE ─────────────────────── */
.wpp-modal-overlay{
  position:fixed;inset:0;z-index:1100;
  background:rgba(0,0,0,.45);
  backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;
  padding:20px;
  opacity:0;visibility:hidden;
  transition:opacity .28s,visibility .28s;
}
.wpp-modal-overlay.open{opacity:1;visibility:visible}
.wpp-modal{
  background:#fff;
  border-radius:16px;
  padding:36px 32px;
  width:100%;max-width:440px;
  position:relative;
  transform:translateY(18px) scale(.97);
  transition:transform .3s cubic-bezier(.34,1.56,.64,1);
  box-shadow:0 24px 64px rgba(0,0,0,.16);
}
.wpp-modal-overlay.open .wpp-modal{transform:translateY(0) scale(1)}
.wpp-modal-close{
  position:absolute;top:14px;right:16px;
  width:30px;height:30px;border-radius:50%;
  background:var(--s2);border:none;cursor:pointer;
  font-size:1.1rem;color:var(--txts);
  display:flex;align-items:center;justify-content:center;
  transition:.2s;
}
.wpp-modal-close:hover{background:var(--bdm);color:var(--txt)}
.wpp-modal-eyebrow{font-size:.62rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:6px}
.wpp-modal-title{font-family:var(--fd);font-size:1.5rem;font-weight:500;color:var(--txt);margin-bottom:6px}
.wpp-modal-sub{font-size:.83rem;color:var(--txts);font-weight:300;margin-bottom:24px}
.wpp-modal-units{display:flex;flex-direction:column;gap:12px}
.wpp-unit-btn{
  display:flex;align-items:center;gap:14px;
  padding:16px 18px;
  border:1.5px solid var(--bd);
  border-radius:12px;
  background:var(--s1);
  color:var(--txt);
  text-decoration:none;
  transition:border-color .2s,background .2s,transform .18s,box-shadow .2s;
  cursor:pointer;
}
.wpp-unit-btn:hover{
  border-color:#25D366;
  background:#f0fff4;
  transform:translateY(-2px);
  box-shadow:0 6px 20px rgba(37,211,102,.15);
}
.wpp-unit-ico{
  width:44px;height:44px;border-radius:10px;
  background:#e6faf0;color:#25D366;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.wpp-unit-info{display:flex;flex-direction:column;gap:2px;flex:1}
.wpp-unit-info strong{font-size:.9rem;font-weight:600;color:var(--txt)}
.wpp-unit-info span{font-size:.79rem;color:var(--txts);font-weight:300}
.wpp-unit-addr{font-size:.73rem!important}
.wpp-arrow{color:var(--txts);flex-shrink:0;transition:transform .2s,color .2s}
.wpp-unit-btn:hover .wpp-arrow{transform:translateX(3px);color:#25D366}

/* ── EFEITOS DE HOVER / CLIQUE (item 9) ──────────────
   Aplicado nos pontos estratégicos: botões primários,
   cards de produto, cards de serviço, cards de avaliação,
   thumbs de unidade, tabs de produto                   */

/* Serviços cards — border pulse on hover */
.sv-card{transition:background .22s,box-shadow .22s,border-left .22s;border-left:3px solid transparent}
.sv-card:hover{
  background:var(--card)!important;
  box-shadow:0 8px 24px rgba(0,0,0,.08);
  border-left-color:var(--red);
}

/* FAQ items */
.faq-q{transition:background .2s,color .2s,padding-left .2s}
.faq-item.open .faq-q,.faq-q:hover{padding-left:26px;color:var(--red)}

/* Avaliações cards */
.av-card{transition:transform .26s,box-shadow .26s}
.av-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px rgba(0,0,0,.09)}

/* Gallery thumbs */


/* Product tabs */
.ptab{transition:color .2s,border-bottom-color .2s,transform .15s}
.ptab:hover{transform:translateY(-1px)}
.ptab.active{transform:translateY(0)}

/* FAB */

/* Contato cards */
.ct-card{transition:transform .22s,box-shadow .22s,border-color .22s}
.ct-card:hover{transform:translateY(-5px);box-shadow:0 12px 32px rgba(0,0,0,.1)}

/* Unidade action buttons */
.u-actions .btn{transition:transform .2s,box-shadow .2s,background .2s,border-color .2s,color .2s}
.u-actions 
/* Hero stats — subtle scale on appear */
@keyframes statPop{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.hstat{animation:statPop .5s ease both}
.hstat:nth-child(1){animation-delay:.1s}
.hstat:nth-child(3){animation-delay:.2s}
.hstat:nth-child(5){animation-delay:.3s}
.hstat:nth-child(7){animation-delay:.4s}

/* ── MOBILE hero-btns ─────────────────────────────── */
@media(max-width:540px){
  .hero-btns{flex-direction:column;width:100%}
  .hero-btns .btn,.hero-btns .btn-ghost-dk{width:100%;justify-content:center}
}

/* ── HERO-STATS: forçar linha única ─────────────────── */
.hero-stats{
  display:flex !important;
  flex-direction:row !important;
  flex-wrap:nowrap !important;
  grid-template-columns:unset !important;
  align-items:center;
  gap:0;
  padding-top:34px;
  border-top:1px solid var(--bdm);
  margin-top:46px;
  overflow:visible;
}
.hstat{
  flex:0 0 auto;
  min-width:0;
  padding:0 20px 0 0;
}
.hstat:first-child{padding-left:0}
.hdiv{
  display:block !important;
  width:1px;height:32px;
  background:var(--bdm);
  margin:0 20px;
  align-self:center;
  flex-shrink:0;
}
/* Override the grid breakpoint that was breaking stats into 2 cols */
@media(max-width:768px){
  .hero-stats{
    flex-wrap:wrap !important;
    gap:12px 0;
  }
  .hstat{flex:1 1 40%;padding:0}
  .hdiv{display:none !important}
}
@media(max-width:380px){
  .hstat{flex:1 1 100%}
}

/* ── LENTES GRID 2×2 ────────────────────────────────── */
.lentes-grid-4{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:18px;
  max-width:760px;
  margin:0 auto;
}
.lentes-grid-4 .lente-card{
  display:flex;flex-direction:column;
  align-items:center;text-align:center;
  padding:36px 28px;
  background:var(--card);
  border:1px solid var(--bd);
  border-radius:var(--r);
  cursor:pointer;
  transition:transform .26s,box-shadow .26s,border-color .26s;
}
.lentes-grid-4 .lente-card:hover{
  transform:translateY(-5px);
  box-shadow:0 14px 36px rgba(0,0,0,.1);
  border-color:rgba(192,57,43,.2);
}
.lentes-grid-4 .lente-card h4{
  font-family:var(--fd);font-size:1.05rem;
  font-weight:500;color:var(--txt);
  margin:0 0 8px;
}
.lentes-grid-4 .lente-card p{
  font-size:.82rem;line-height:1.65;
  color:var(--txtm);font-weight:300;
  margin-bottom:14px;flex:1;
}
@media(max-width:540px){
  .lentes-grid-4{grid-template-columns:1fr}
}

/* ── PROD-CARD como div clicável ────────────────────── */
.prod-card[role="button"]{cursor:pointer}

/* ══════════════════════════════════════════════════
   ANIMAÇÃO ESTILO SUELLEN
   ══════════════════════════════════════════════════

   BOTÕES VERMELHOS  → outline externo que pulsa
   FAB WHATSAPP      → halo verde que expande e some
   ══════════════════════════════════════════════════ */

/* ─────────────────────────────────────────────────
   BOTÕES VERMELHOS
   No hover: um outline/borda externa aparece ao
   redor do botão e pulsa suavemente, exatamente
   como o "Descubra Agora" da Suellen.
   ───────────────────────────────────────────────── */

/* Keyframe: outline que cresce e desaparece */
@keyframes btnOutlinePulse {
  0%   { box-shadow: 0 0 0 0px  rgba(192,57,43,.55); }
  60%  { box-shadow: 0 0 0 8px  rgba(192,57,43,.0);  }
  100% { box-shadow: 0 0 0 8px  rgba(192,57,43,.0);  }
}

.btn-red {
  position: relative;
  overflow: hidden;
  transition: background .2s, transform .18s;
  animation: btnOutlinePulse 1.6s ease-out infinite;
}

/* Hover: sobe levemente + outline pulsa em loop */
.btn-red:hover {
  background: var(--red2);
  transform: translateY(-2px);
}

/* Active: afunda — confirma o toque */
.btn-red:active {
  transform: translateY(1px) scale(.98);
  box-shadow: 0 2px 8px rgba(192,57,43,.25);
  transition-duration: .08s;
}

/* Ripple no clique (span injetado via JS) */
@keyframes rippleExpand {
  0%   { transform: scale(0); opacity: .45; }
  100% { transform: scale(3.8); opacity: 0;  }
}
.btn-red .ripple {
  position: absolute;
  border-radius: 50%;
  width: 80px; height: 80px;
  margin-top: -40px; margin-left: -40px;
  background: rgba(255,255,255,.4);
  animation: rippleExpand .52s ease-out forwards;
  pointer-events: none;
}

/* ─────────────────────────────────────────────────
   FAB WHATSAPP
   Halo verde suave que expande continuamente para
   fora — idêntico ao comportamento da Suellen.
   ───────────────────────────────────────────────── */

/* Dois halos com offset para efeito contínuo */

/* Hover: leve zoom */

/* FAB WhatsApp — halo via box-shadow (sempre centrado) */

  70%  { box-shadow: 0 0 0 8px  rgba(37,211,102,0), 0 4px 18px rgba(37,211,102,.4); }
  100% { box-shadow: 0 0 0 8px  rgba(37,211,102,0), 0 4px 18px rgba(37,211,102,.4); }
}

  70%      { box-shadow: 0 0 0 18px rgba(37,211,102,0), 0 4px 18px rgba(37,211,102,.4); }
  100%     { box-shadow: 0 0 0 18px rgba(37,211,102,0), 0 4px 18px rgba(37,211,102,.4); }
}

.fab-btn:hover {
  transform: scale(1.1);
  box-shadow: 0 6px 22px rgba(37,211,102,.5);
}
.fab-btn:active {
  transform: scale(.95);
  transition-duration: .08s;
}

/* ─────────────────────────────────────────────────
   VER UNIDADES (ghost)
   Borda vermelha cresce ao redor no hover
   ───────────────────────────────────────────────── */
.btn-ghost-dk {
  position: relative;
  transition: color .22s, border-color .22s, background .22s, transform .18s;
}
.btn-ghost-dk:hover {
  border-color: var(--red);
  color: var(--red);
  background: rgba(192,57,43,.04);
  transform: translateY(-2px);
}
.btn-ghost-dk:active {
  transform: translateY(0);
  transition-duration: .08s;
}

/* ══════════════════════════════════════════════════
   DETALHE DECORATIVO — imagem do Sobre
   Arco externo + gradiente suave no canto, igual
   ao estilo elegante do site da Suellen
   ══════════════════════════════════════════════════ */

/* Arco decorativo atrás da imagem — deslocado */
.sobre-visual::before {
  content: '';
  position: absolute;
  top: -18px;
  left: -18px;
  right: 28px;
  bottom: 28px;
  border-radius: 20px;
  border: 2px solid rgba(192,57,43,.18);
  z-index: 0;
  pointer-events: none;
}

/* Segundo arco — canto oposto */
.sobre-visual::after {
  content: '';
  position: absolute;
  top: 28px;
  left: 28px;
  right: -18px;
  bottom: -18px;
  border-radius: 20px;
  background: linear-gradient(135deg, transparent 40%, rgba(192,57,43,.07) 100%);
  border: 1.5px solid rgba(192,57,43,.09);
  z-index: 0;
  pointer-events: none;
}

/* Imagem fica acima dos arcos */
.sobre-main-img {
  position: relative;
  z-index: 1;
}

/* Gradient overlay sutil na imagem — toque premium */
.sobre-main-img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    transparent 55%,
    rgba(0,0,0,.18) 100%
  );
  pointer-events: none;
  z-index: 1;
}

/* FAB pulse ring — via .fab-wrap::before, nunca interfere no botão */
@keyframes fabPing {
  0%   { transform: scale(1);   opacity: .45; }
  80%  { transform: scale(1.28); opacity: 0;  }
  100% { transform: scale(1.28); opacity: 0;  }
}



/* Anel centralizado no botão via pseudo-elemento no wrap */
.fab-btn-wrap {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.fab-btn-wrap::before,
.fab-btn-wrap::after {
  content: '';
  position: absolute;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #25D366;
  animation: fabPing 2.4s ease-out infinite;
  pointer-events: none;
  z-index: -1;
}
.fab-btn-wrap::after {
  animation-delay: 1.2s;
}

/* Thumbnail wrapper */
/* Button inside wrapper — handles image */
/* Label below thumbnail */


/* ── THUMBNAILS UNIDADES ─────────────────── */
.u-thumbs{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}

.uth{
  position:relative;
  display:block;
  width:100%;
  border-radius:6px;
  overflow:hidden;
  border:2px solid transparent;
  box-sizing:border-box;
  padding:0;
  cursor:pointer;
  background:var(--s2);
  -webkit-appearance:none;
  transition:border-color .22s;
}
.uth.active{border-color:var(--red)}
.uth:hover{border-color:rgba(192,57,43,.4)}

.uth img{
  display:block;
  width:100%;
  height:auto;
  filter:brightness(.7);
  transition:filter .22s;
}
.uth.active img,
.uth:hover img{filter:brightness(1)}

.uth span{
  position:absolute;
  bottom:0;left:0;right:0;
  background:rgba(0,0,0,.52);
  color:#fff;
  font-size:.58rem;
  font-weight:700;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:4px;
  text-align:center;
  z-index:2;
}
