:root{
  --ink:#1F2024; --black:#111214; --grey:#32373C; --g600:#6E7176; --g400:#A2A4A8;
  --line:#E6E6E4; --soft:#F4F4F2; --white:#FFFFFF;
  --disp:'Montserrat',-apple-system,'Segoe UI',sans-serif;
  --body:'Inter',-apple-system,'Segoe UI',sans-serif;
  --ease:cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;}
body{font-family:var(--body);font-weight:400;font-size:16px;line-height:1.65;color:var(--grey);background:var(--white);}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.wrap{max-width:1200px;margin:0 auto;padding:0 44px;}
@media(max-width:680px){.wrap{padding:0 22px;}}

.ribbon{background:var(--black);color:#fff;text-align:center;font-family:var(--disp);font-size:11px;letter-spacing:1px;padding:7px 16px;font-weight:500;text-transform:uppercase;}
.ribbon b{color:#fff;font-weight:700;}

.hd{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.96);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--line);}
.hd-in{display:flex;align-items:center;justify-content:space-between;height:84px;}
.hd .logo{height:46px;width:auto;}
.nav{display:flex;align-items:center;gap:36px;}
.nav a{font-family:var(--disp);font-size:12px;font-weight:600;letter-spacing:1.5px;color:var(--ink);text-transform:uppercase;transition:color .2s;}
.nav a:hover{color:var(--g600);}
.nav .lang{font-size:11px;color:var(--g400);letter-spacing:1px;font-weight:600;}
.nav .lang b{color:var(--ink);}
.hd-right{display:flex;align-items:center;gap:30px;}
.hd-tools{display:flex;align-items:center;gap:18px;}
.navtoggle{display:none;}
@media(max-width:820px){.hd .logo{height:34px;}.hd-in{height:62px;}}

.hero{position:relative;height:76vh;min-height:540px;overflow:hidden;display:flex;align-items:center;}
.hero-img{position:absolute;inset:0;background-size:cover;background-position:center;}
.hero-img::after{content:'';position:absolute;inset:0;background:linear-gradient(95deg,rgba(31,32,36,.74) 0%,rgba(31,32,36,.4) 52%,rgba(31,32,36,.1) 100%);}
.diamond{position:absolute;top:50%;right:7%;transform:translateY(-50%) rotate(45deg);width:min(36vw,400px);height:min(36vw,400px);z-index:2;pointer-events:none;}
.diamond span{position:absolute;inset:0;border:1px solid rgba(255,255,255,.5);}
.diamond span:nth-child(2){inset:30px;border-color:rgba(255,255,255,.28);}
@media(max-width:820px){.diamond{display:none;}}
.hero-in{position:relative;z-index:3;color:#fff;max-width:620px;}
.kicker{font-family:var(--disp);font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.85);margin-bottom:22px;display:flex;align-items:center;gap:14px;}
.kicker::before{content:'';width:38px;height:2px;background:#fff;}
.hero h1{font-family:var(--disp);font-weight:300;font-size:clamp(34px,5.4vw,62px);line-height:1.08;letter-spacing:-.5px;color:#fff;margin-bottom:20px;}
.hero h1 b{font-weight:700;}
.hero p{font-family:var(--body);font-size:17px;color:rgba(255,255,255,.9);max-width:440px;line-height:1.6;}
@media(max-width:680px){.hero-img::after{background:linear-gradient(180deg,rgba(31,32,36,.5),rgba(31,32,36,.74));}}

.cta-bar{background:var(--black);color:#fff;}
.cta-bar .wrap{display:flex;align-items:center;justify-content:space-between;gap:24px;padding-top:26px;padding-bottom:26px;flex-wrap:wrap;}
.cta-bar p{font-family:var(--disp);font-weight:500;font-size:clamp(16px,2vw,20px);letter-spacing:.3px;}
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--disp);font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:15px 30px;background:#fff;color:var(--ink);transition:opacity .2s,transform .2s;white-space:nowrap;cursor:pointer;border:none;}
.btn:hover{opacity:.85;transform:translateY(-1px);}
.btn.outline{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.5);}
.btn.outline:hover{background:#fff;color:var(--ink);}
.btn.dark{background:var(--ink);color:#fff;}
.btn.dark:hover{opacity:.88;}

.sec{padding:96px 0;}
@media(max-width:680px){.sec{padding:60px 0;}}
.sec-head{margin-bottom:50px;}
.sec-head .rule{width:48px;height:3px;background:var(--ink);margin-bottom:22px;}
.sec-head h2{font-family:var(--disp);font-weight:300;font-size:clamp(28px,4vw,44px);line-height:1.1;letter-spacing:-.3px;color:var(--ink);}
.sec-head h2 b{font-weight:700;}
.sec-head p{font-family:var(--body);font-size:16px;color:var(--g600);margin-top:14px;max-width:580px;line-height:1.6;}

.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
@media(max-width:900px){.grid{grid-template-columns:repeat(2,1fr);gap:18px;}}
@media(max-width:560px){.grid{grid-template-columns:1fr;}}
.stone{display:block;background:var(--white);border:1px solid var(--line);overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s var(--ease);}
.stone:hover{transform:translateY(-5px);box-shadow:0 24px 50px rgba(31,32,36,.12);}
.stone .ph{position:relative;aspect-ratio:4/3;overflow:hidden;background:#EDEDEB;}
.stone .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);}
.stone:hover .ph img{transform:scale(1.05);}
.stone .ph .badge{position:absolute;top:14px;left:14px;font-family:var(--disp);font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:#fff;background:rgba(31,32,36,.82);padding:6px 11px;}
.stone .body{padding:22px 24px 24px;}
.stone .nm{font-family:var(--disp);font-weight:700;font-size:18px;letter-spacing:.2px;color:var(--ink);text-transform:uppercase;}
.stone .en{font-family:var(--body);font-size:13px;color:var(--g400);margin-top:3px;}
.stone .foot{display:flex;align-items:center;justify-content:space-between;margin-top:18px;padding-top:15px;border-top:1px solid var(--line);}
.stone .avail{font-family:var(--body);font-size:12.5px;color:var(--g600);display:flex;align-items:center;gap:7px;}
.stone .avail::before{content:'';width:7px;height:7px;border-radius:50%;background:#3FA05E;}
.stone .see{font-family:var(--disp);font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--ink);}

/* ---- detail page ---- */
.detail{padding:40px 0 96px;}
.crumb{font-family:var(--disp);font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--g600);margin-bottom:32px;display:inline-flex;align-items:center;gap:9px;}
.crumb:hover{color:var(--ink);}
.dgrid{display:grid;grid-template-columns:1.15fr .85fr;gap:56px;align-items:start;}
@media(max-width:880px){.dgrid{grid-template-columns:1fr;gap:32px;}}
.stage{position:relative;width:100%;aspect-ratio:3/2;background:#26282C;background-size:cover;background-position:center;}
.stage .tagcap{position:absolute;bottom:0;left:0;right:0;padding:18px 24px;background:linear-gradient(0deg,rgba(0,0,0,.8),transparent);font-family:var(--disp);font-weight:600;font-size:12px;letter-spacing:.5px;color:#fff;text-transform:uppercase;}
.thumbs{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap;}
.thumbs button{width:84px;height:62px;border:2px solid var(--line);padding:0;background-size:cover;background-position:center;cursor:pointer;opacity:.7;transition:opacity .2s,border-color .2s;}
.thumbs button:hover{opacity:1;}
.thumbs button.on{opacity:1;border-color:var(--ink);}
.dinfo .type{font-family:var(--disp);font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--g600);margin-bottom:12px;}
.dinfo h1{font-family:var(--disp);font-weight:700;font-size:clamp(30px,4vw,46px);line-height:1.04;text-transform:uppercase;letter-spacing:-.3px;color:var(--ink);}
.dinfo .en{font-family:var(--body);font-size:15px;color:var(--g400);margin-bottom:8px;}
.dinfo .pick{font-family:var(--body);font-size:13px;color:var(--g600);margin:22px 0 26px;display:flex;align-items:center;gap:8px;}
.dinfo .pick::before{content:'';width:8px;height:8px;border-radius:50%;background:#3FA05E;}
.specs{border-top:1px solid var(--line);margin-bottom:30px;}
.specs .row{display:grid;grid-template-columns:140px 1fr;padding:13px 0;border-bottom:1px solid var(--line);}
.specs .k{font-family:var(--disp);font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--g600);align-self:center;}
.specs .v{font-family:var(--body);font-size:15px;color:var(--ink);}
.dcta{display:flex;gap:13px;flex-wrap:wrap;}
.dcta .btn{background:var(--ink);color:#fff;}
.dcta .btn.outline{background:transparent;color:var(--ink);border:1px solid var(--ink);}
.dcta .btn.outline:hover{background:var(--ink);color:#fff;}

.ft{background:var(--ink);color:#fff;padding:74px 0 44px;}
.ft-in{display:flex;align-items:flex-start;justify-content:space-between;gap:40px;flex-wrap:wrap;}
.ft .flogo{height:54px;width:auto;margin-bottom:18px;}
.ft .fcol h4{font-family:var(--disp);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:16px;}
.ft .fcol a,.ft .fcol p{font-family:var(--body);font-size:14px;color:rgba(255,255,255,.82);display:block;margin-bottom:9px;}
.ft .fcol a:hover{color:#fff;}
.ft .by{margin-top:48px;padding-top:24px;border-top:1px solid rgba(255,255,255,.12);font-family:var(--disp);font-size:11px;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,.4);}
.ft .by b{color:rgba(255,255,255,.7);font-weight:600;}

/* ---- preço ---- */
.stone .price{font-family:var(--disp);font-weight:700;font-size:20px;color:var(--ink);margin-top:16px;}
.stone .price span{font-family:var(--body);font-weight:500;font-size:12px;color:var(--g600);margin-left:3px;}
.dinfo .price{font-family:var(--disp);font-weight:700;font-size:clamp(28px,3.4vw,38px);color:var(--ink);margin:20px 0 4px;letter-spacing:-.5px;}
.dinfo .price span{font-family:var(--body);font-weight:500;font-size:15px;color:var(--g600);margin-left:5px;letter-spacing:0;}
.dinfo .parcela{font-family:var(--body);font-size:13.5px;color:var(--g600);margin-bottom:6px;}
.dinfo .parcela b{color:var(--ink);font-weight:600;}

/* ---- cart badge no header ---- */
.cart-link{position:relative;display:inline-flex;align-items:center;}
.cart-link svg{width:22px;height:22px;stroke:var(--ink);}
.cart-badge{position:absolute;top:-7px;right:-9px;min-width:17px;height:17px;padding:0 4px;border-radius:9px;background:var(--ink);color:#fff;font-family:var(--disp);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;}
.cart-badge.empty{display:none;}

/* ---- page generica ---- */
.page{padding:44px 0 96px;min-height:60vh;}
.page .crumb{margin-bottom:26px;}
.page h1{font-family:var(--disp);font-weight:700;font-size:clamp(26px,3.6vw,38px);text-transform:uppercase;letter-spacing:-.3px;color:var(--ink);margin-bottom:32px;}

/* ---- cart ---- */
.cartgrid{display:grid;grid-template-columns:1fr 340px;gap:44px;align-items:start;}
@media(max-width:840px){.cartgrid{grid-template-columns:1fr;gap:28px;}}
.citem{display:grid;grid-template-columns:120px 1fr auto;gap:20px;padding:20px 0;border-bottom:1px solid var(--line);align-items:center;}
.citem .ci-img{width:120px;height:90px;object-fit:cover;background:#EDEDEB;}
.citem .ci-nm{font-family:var(--disp);font-weight:700;font-size:16px;text-transform:uppercase;color:var(--ink);}
.citem .ci-meta{font-family:var(--body);font-size:13px;color:var(--g600);margin-top:4px;}
.citem .ci-price{font-family:var(--disp);font-weight:700;font-size:17px;color:var(--ink);text-align:right;white-space:nowrap;}
.citem .ci-rm{display:block;font-family:var(--body);font-size:12px;color:var(--g400);text-align:right;margin-top:8px;cursor:pointer;}
.citem .ci-rm:hover{color:#C0392B;}
.cempty{font-family:var(--body);font-size:16px;color:var(--g600);padding:30px 0;}
.csum{border:1px solid var(--line);padding:28px;position:sticky;top:100px;}
.csum h3{font-family:var(--disp);font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--g600);margin-bottom:18px;}
.csum .line{display:flex;justify-content:space-between;font-family:var(--body);font-size:14px;color:var(--grey);padding:8px 0;}
.csum .tot{display:flex;justify-content:space-between;align-items:baseline;border-top:2px solid var(--ink);margin-top:14px;padding-top:16px;}
.csum .tot .l{font-family:var(--disp);font-weight:700;font-size:13px;text-transform:uppercase;color:var(--ink);}
.csum .tot .v{font-family:var(--disp);font-weight:700;font-size:24px;color:var(--ink);}
.btn-full{width:100%;justify-content:center;margin-top:20px;}
.btn-blk{background:var(--ink);color:#fff;}
.btn-blk:hover{opacity:.88;}

/* ---- checkout ---- */
.cogrid{display:grid;grid-template-columns:1fr 340px;gap:44px;align-items:start;}
@media(max-width:840px){.cogrid{grid-template-columns:1fr;}}
.cosec{margin-bottom:36px;}
.cosec .h{font-family:var(--disp);font-weight:700;font-size:13px;letter-spacing:1px;text-transform:uppercase;color:var(--ink);margin-bottom:16px;display:flex;align-items:center;gap:10px;}
.cosec .h .n{width:24px;height:24px;border-radius:50%;background:var(--ink);color:#fff;font-size:12px;display:flex;align-items:center;justify-content:center;}
.field{margin-bottom:14px;}
.field label{display:block;font-family:var(--disp);font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--g600);margin-bottom:6px;}
.field input{width:100%;padding:12px 14px;border:1px solid var(--line);font-family:var(--body);font-size:15px;color:var(--ink);outline:none;transition:border-color .2s;background:#fff;}
.field input:focus{border-color:var(--ink);}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.pay-tabs{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap;}
.pay-tabs button{flex:1;min-width:90px;padding:14px;border:1px solid var(--line);background:#fff;font-family:var(--disp);font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--g600);cursor:pointer;transition:all .2s;}
.pay-tabs button.on{border-color:var(--ink);color:var(--ink);background:var(--soft);}
.pay-panel{display:none;padding:24px;border:1px solid var(--line);}
.pay-panel.on{display:block;}
.pix-box{display:flex;gap:24px;align-items:center;flex-wrap:wrap;}
.pix-box img{width:150px;height:150px;border:1px solid var(--line);}
.pix-box .pix-t{font-family:var(--disp);font-weight:700;font-size:15px;color:var(--ink);margin-bottom:8px;text-transform:uppercase;}
.pix-box .pix-d{font-family:var(--body);font-size:13px;color:var(--g600);line-height:1.5;max-width:320px;}
.pix-code{margin-top:12px;padding:10px 12px;background:var(--soft);font-family:monospace;font-size:11px;color:var(--grey);word-break:break-all;border:1px dashed var(--line);}
.boleto-d,.card-d{font-family:var(--body);font-size:14px;color:var(--g600);line-height:1.6;}

/* ---- pedido confirmado ---- */
.done{text-align:center;max-width:520px;margin:30px auto 0;}
.done .ck{width:74px;height:74px;border-radius:50%;background:#3FA05E;display:flex;align-items:center;justify-content:center;margin:0 auto 26px;}
.done .ck svg{width:38px;height:38px;stroke:#fff;stroke-width:3;fill:none;}
.done h1{font-size:clamp(26px,3.6vw,36px);margin-bottom:12px;}
.done p{font-family:var(--body);font-size:16px;color:var(--g600);line-height:1.6;margin-bottom:8px;}
.done .ordbox{border:1px solid var(--line);padding:24px;margin:28px 0;text-align:left;display:flex;gap:18px;align-items:center;}
.done .ordbox img{width:90px;height:68px;object-fit:cover;background:#EDEDEB;}
.done .ordbox .on{font-family:var(--disp);font-weight:700;text-transform:uppercase;color:var(--ink);}
.done .ordbox .om{font-family:var(--body);font-size:13px;color:var(--g600);margin-top:3px;}
.done .ordnum{font-family:var(--disp);font-weight:700;color:var(--ink);}

/* ---- floats: whatsapp + atendimento ---- */
.floats{position:fixed;bottom:24px;right:24px;z-index:200;display:flex;flex-direction:column;gap:14px;align-items:flex-end;}
.fab{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 8px 26px rgba(0,0,0,.22);border:none;transition:transform .2s;}
.fab:hover{transform:scale(1.07);}
.fab svg{width:28px;height:28px;}
.fab-wa{background:#25D366;}
.fab-at{background:var(--ink);}
.fab-lbl{position:absolute;right:66px;white-space:nowrap;background:var(--ink);color:#fff;font-family:var(--disp);font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;padding:7px 12px;border-radius:6px;opacity:0;pointer-events:none;transition:opacity .2s;}
.fab-wrap{position:relative;display:flex;align-items:center;}
.fab-wrap:hover .fab-lbl{opacity:1;}
.chatbox{position:fixed;bottom:24px;right:24px;z-index:201;width:344px;max-width:calc(100vw - 32px);background:#fff;border-radius:14px;box-shadow:0 24px 64px rgba(0,0,0,.28);overflow:hidden;display:none;flex-direction:column;}
.chatbox.open{display:flex;}
.chat-hd{background:var(--ink);color:#fff;padding:16px 20px;display:flex;align-items:flex-start;justify-content:space-between;}
.chat-hd .ct{font-family:var(--disp);font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.5px;}
.chat-hd .cs{font-family:var(--body);font-size:12px;color:rgba(255,255,255,.6);margin-top:3px;display:flex;align-items:center;gap:6px;}
.chat-hd .cs::before{content:'';width:7px;height:7px;border-radius:50%;background:#3FA05E;}
.chat-hd .cx{cursor:pointer;font-size:22px;line-height:1;color:rgba(255,255,255,.7);}
.chat-hd .cx:hover{color:#fff;}
.chat-body{padding:18px;max-height:320px;overflow-y:auto;background:var(--soft);}
.msg{background:#fff;border:1px solid var(--line);padding:12px 14px;border-radius:12px;font-family:var(--body);font-size:14px;color:var(--grey);margin-bottom:10px;line-height:1.5;}
.msg.me{background:var(--ink);color:#fff;border-color:var(--ink);margin-left:auto;max-width:85%;}
.qopts{display:flex;flex-direction:column;gap:8px;margin-top:4px;}
.qopts button{text-align:left;padding:11px 14px;border:1px solid var(--ink);background:#fff;font-family:var(--body);font-size:13px;color:var(--ink);cursor:pointer;border-radius:10px;transition:all .15s;}
.qopts button:hover{background:var(--ink);color:#fff;}
.chat-foot{padding:14px 16px;border-top:1px solid var(--line);background:#fff;}
.chat-foot a{display:flex;align-items:center;justify-content:center;gap:9px;background:#25D366;color:#fff;padding:12px;border-radius:10px;font-family:var(--disp);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;text-decoration:none;}
.chat-foot a svg{width:18px;height:18px;}

/* ---- O Grupo (about) ---- */
.about-hero{position:relative;height:46vh;min-height:340px;display:flex;align-items:flex-end;overflow:hidden;}
.about-hero .bg{position:absolute;inset:0;background-size:cover;background-position:center;}
.about-hero .bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(31,32,36,.3),rgba(31,32,36,.82));}
.about-hero .in{position:relative;z-index:2;color:#fff;padding-bottom:46px;}
.about-hero .k{font-family:var(--disp);font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.8);margin-bottom:14px;}
.about-hero h1{font-family:var(--disp);font-weight:300;font-size:clamp(34px,5vw,58px);color:#fff;letter-spacing:-.5px;}
.about-hero h1 b{font-weight:700;}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
@media(max-width:860px){.about-grid{grid-template-columns:1fr;gap:32px;}}
.about-grid .txt p{font-family:var(--body);font-size:16px;color:var(--grey);line-height:1.75;margin-bottom:18px;}
.about-grid .txt p b{color:var(--ink);font-weight:600;}
.about-grid img{width:100%;aspect-ratio:4/3;object-fit:cover;}
.statrow{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:60px;}
@media(max-width:760px){.statrow{grid-template-columns:repeat(2,1fr);}}
.statrow .s{background:#fff;padding:36px 24px;text-align:center;}
.statrow .v{font-family:var(--disp);font-weight:300;font-size:clamp(32px,4vw,46px);color:var(--ink);letter-spacing:-1px;}
.statrow .l{font-family:var(--body);font-size:13px;color:var(--g600);margin-top:8px;line-height:1.4;}

/* ---- features strip ---- */
.features{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:#fff;}
.features .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:0;padding-left:0;padding-right:0;}
@media(max-width:760px){.features .wrap{grid-template-columns:repeat(2,1fr);}}
.feat{display:flex;align-items:center;gap:14px;padding:26px 28px;border-right:1px solid var(--line);}
.feat:last-child{border-right:none;}
@media(max-width:760px){.feat{border-right:none;border-bottom:1px solid var(--line);padding:22px;}.feat:nth-child(odd){border-right:1px solid var(--line);}}
.feat svg{width:25px;height:25px;color:var(--ink);flex:0 0 25px;stroke-width:1.5;}
.feat .ft-t{font-family:var(--disp);font-weight:700;font-size:12.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--ink);}
.feat .ft-d{font-family:var(--body);font-size:12px;color:var(--g600);margin-top:3px;line-height:1.4;}

/* ---- filter bar ---- */
.filterbar{display:flex;gap:10px;margin-bottom:38px;flex-wrap:wrap;}
.filterbar button{font-family:var(--disp);font-size:11.5px;font-weight:600;letter-spacing:1px;text-transform:uppercase;padding:11px 22px;border:1px solid var(--line);background:#fff;color:var(--g600);cursor:pointer;transition:all .2s;}
.filterbar button.on{background:var(--ink);color:#fff;border-color:var(--ink);}
.filterbar button:hover{border-color:var(--ink);color:var(--ink);}
.filterbar button.on:hover{color:#fff;}
.stone.hide{display:none;}

/* ---- spec icons ---- */
.specs .row{grid-template-columns:26px 124px 1fr;}
.specs .ic{color:var(--g600);display:flex;align-items:center;}
.specs .ic svg{width:17px;height:17px;stroke-width:1.6;}

/* ---- pay tab icons ---- */
.pay-tabs button{display:flex;align-items:center;justify-content:center;gap:8px;}
.pay-tabs button svg{width:16px;height:16px;stroke-width:1.7;}

/* ---- trust strip (detail) ---- */
.trust{display:flex;gap:26px;flex-wrap:wrap;margin:24px 0 2px;padding:18px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.trust .t{display:flex;align-items:center;gap:9px;font-family:var(--body);font-size:12.5px;color:var(--g600);}
.trust .t svg{width:18px;height:18px;color:var(--ink);flex:0 0 18px;stroke-width:1.6;}

/* ---- footer social ---- */
.ft .fcol .fsocial{display:flex;gap:12px;margin-top:6px;}
.ft .fcol .fsocial a{width:40px;height:40px;margin-bottom:0;padding:0;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.045);border-radius:50%;display:inline-flex;align-items:center;justify-content:center;transition:background .2s,border-color .2s,transform .2s;}
.ft .fcol .fsocial a:hover{background:#fff;border-color:#fff;transform:translateY(-2px);}
.ft .fcol .fsocial a svg{width:18px;height:18px;display:block;stroke:#fff;stroke-width:1.7;fill:none;}
.ft .fcol .fsocial a:hover svg{stroke:var(--ink);}

/* stat/unit icons */
.statrow .v svg{width:34px;height:34px;stroke:var(--ink);stroke-width:1.3;}
.unit-ic{color:var(--ink);margin-bottom:14px;}
.unit-ic svg{width:24px;height:24px;stroke-width:1.5;}

/* ---- chapa COMPLETA no card (3:2 igual a foto, sem corte) + stage zoom ---- */
.stone .ph{aspect-ratio:3/2;background:#ECECEA;}
.stage{cursor:zoom-in;}
.stage::after{content:'⤢ ampliar';position:absolute;top:14px;right:14px;font-family:var(--disp);font-size:10px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:#fff;background:rgba(31,32,36,.7);padding:6px 10px;border-radius:4px;pointer-events:none;}

/* ---- lightbox (zoom igual PB) ---- */
.lightbox{position:fixed;inset:0;z-index:300;background:rgba(17,18,20,.95);display:none;align-items:center;justify-content:center;cursor:zoom-out;overflow:hidden;}
.lightbox.open{display:flex;}
.lightbox img{max-width:92vw;max-height:90vh;object-fit:contain;transition:transform .25s var(--ease);cursor:zoom-in;}
.lightbox img.zoomed{cursor:move;transition:none;}
.lb-x{position:absolute;top:22px;right:30px;font-size:32px;line-height:1;color:rgba(255,255,255,.85);cursor:pointer;z-index:2;font-family:var(--body);}
.lb-x:hover{color:#fff;}
.lb-hint{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);font-family:var(--disp);font-size:11px;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,.5);}

/* ---- HOVER-ZOOM (copiado do ImageGallery.tsx do Pedra Brasil) ---- */
.stage{overflow:hidden;background:#ECECEA;}
.stage img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .2s var(--ease);will-change:transform;}
.stage.zoom img{transform:scale(2);}
.stage .tagcap{z-index:3;}
.stage::after{z-index:3;content:'⤢ passe o mouse para ampliar';}
/* lightbox: contador + setas (igual PB) */
.lb-count{position:absolute;top:22px;left:50%;transform:translateX(-50%);font-family:var(--disp);font-size:12px;letter-spacing:1px;color:rgba(255,255,255,.85);background:rgba(255,255,255,.1);padding:6px 14px;border-radius:20px;z-index:2;}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.12);border:none;color:#fff;font-size:26px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2;transition:background .2s;font-family:var(--body);}
.lb-nav:hover{background:rgba(255,255,255,.25);}
.lb-prev{left:24px;} .lb-next{right:24px;}
.lightbox img{cursor:default;}

/* ---- botoes mais elegantes (copiando o capricho do PB: largura igual, cantos suaves, com icone) ---- */
.btn{border-radius:8px;letter-spacing:.6px;font-weight:600;}
.dcta{display:flex;flex-direction:column;gap:12px;margin-top:10px;}
.dcta .btn{width:100%;justify-content:center;gap:9px;padding:16px;font-size:12.5px;}
.dcta .btn svg{width:18px;height:18px;stroke-width:1.7;flex:0 0 18px;}
.btn-full{border-radius:8px;}
.pay-tabs button{border-radius:8px;}
.field input{border-radius:7px;}

/* rodape social: tres icones em linha, mesmo peso (WhatsApp agora em contorno) */

/* ---- feature: Veja no seu ambiente (IA) ---- */
.ambient{margin-top:6px;padding-top:40px;border-top:1px solid var(--line);}
.ambient .ah{display:flex;align-items:center;gap:12px;margin-bottom:10px;}
.ambient .ah .at{font-family:var(--disp);font-weight:700;font-size:15px;text-transform:uppercase;letter-spacing:.5px;color:var(--ink);display:flex;align-items:center;gap:9px;}
.ambient .ah .at svg{width:20px;height:20px;stroke-width:1.7;}
.ambient .ia-badge{font-family:var(--disp);font-size:9.5px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:#fff;background:var(--ink);padding:4px 10px;border-radius:20px;}
.ambient .ax{font-family:var(--body);font-size:14.5px;color:var(--g600);line-height:1.55;margin-bottom:18px;max-width:620px;}
.ambient .chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;}
.ambient .chips button{font-family:var(--disp);font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;padding:9px 16px;border:1px solid var(--line);background:#fff;color:var(--g600);cursor:pointer;border-radius:7px;transition:all .2s;}
.ambient .chips button.on{background:var(--ink);color:#fff;border-color:var(--ink);}
.ambient .chips button:hover{border-color:var(--ink);}
.ambient .astage{position:relative;width:100%;max-width:760px;aspect-ratio:3/2;border-radius:12px;overflow:hidden;background:var(--soft);border:1px solid var(--line);}
.ambient .astage img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .6s;}
.ambient .astage.done img{opacity:1;}
.ambient .astart{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px;}
.ambient .gen-btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--disp);font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;padding:15px 28px;background:var(--ink);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:opacity .2s;}
.ambient .gen-btn:hover{opacity:.88;}
.ambient .gen-btn svg{width:17px;height:17px;stroke-width:1.7;}
.ambient .gen-sub{font-family:var(--body);font-size:12.5px;color:var(--g500);margin-top:13px;}
.ambient .spin{position:absolute;inset:0;display:none;flex-direction:column;align-items:center;justify-content:center;gap:14px;background:var(--soft);z-index:2;}
.ambient .spin.show{display:flex;}
.ambient .spin .ring{width:34px;height:34px;border:3px solid var(--line);border-top-color:var(--ink);border-radius:50%;animation:spin .8s linear infinite;}
.ambient .spin .st{font-family:var(--disp);font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--g600);}
@keyframes spin{to{transform:rotate(360deg)}}
.ambient .acap{position:absolute;bottom:0;left:0;right:0;padding:14px 18px;background:linear-gradient(0deg,rgba(0,0,0,.78),transparent);font-family:var(--body);font-size:12px;color:rgba(255,255,255,.92);z-index:3;display:none;}
.ambient .astage.done .acap{display:block;}
.ambient .anote{font-family:var(--body);font-size:12px;color:var(--g500);margin-top:14px;max-width:620px;line-height:1.5;}

/* fix: imagem invisivel do ambiente nao pode roubar o clique do botao */
.ambient .astage img{pointer-events:none;}
.ambient .acap{pointer-events:none;}

/* chip de upload (tracejado, com icone) */
.ambient .chips .upchip{display:inline-flex;align-items:center;gap:7px;border-style:dashed;}
.ambient .chips .upchip svg{width:14px;height:14px;stroke-width:1.8;}

/* ---- gerador de ambiente: centralizado e mais claro ---- */
.ambient{max-width:900px;margin:0 auto;text-align:center;padding-top:48px;}
.ambient .ia-badge{display:inline-block;margin-bottom:14px;}
.ambient .atitle{font-family:var(--disp);font-weight:700;font-size:clamp(22px,3vw,30px);text-transform:uppercase;letter-spacing:.3px;color:var(--ink);display:flex;align-items:center;justify-content:center;gap:11px;margin-bottom:12px;}
.ambient .atitle svg{width:24px;height:24px;stroke-width:1.7;color:var(--ink);}
.ambient .ax{margin:0 auto 26px;max-width:580px;}
.opts{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:26px;}
.opt{display:inline-flex;align-items:center;gap:8px;padding:11px 18px;border:1px solid var(--line);background:#fff;border-radius:10px;cursor:pointer;font-family:var(--disp);font-size:12.5px;font-weight:600;letter-spacing:.3px;color:var(--g600);transition:all .2s;}
.opt svg{width:16px;height:16px;stroke-width:1.7;flex:0 0 16px;}
.opt:hover{border-color:var(--ink);color:var(--ink);}
.opt.on{background:var(--ink);color:#fff;border-color:var(--ink);}
.opt.on:hover{color:#fff;}
.opt.upopt{border-style:dashed;}
.ambient .astage{margin:0 auto;}
.ambient .anote{margin:14px auto 0;text-align:center;}

/* separador "ou" + botao de upload bem posicionado */
.opts{margin-bottom:18px;}
.orsep{display:flex;align-items:center;gap:14px;max-width:280px;margin:0 auto 16px;color:var(--g400);font-family:var(--disp);font-size:11px;letter-spacing:2px;text-transform:uppercase;}
.orsep::before,.orsep::after{content:'';flex:1;height:1px;background:var(--line);}
.ambient .upopt{margin-bottom:28px;}

/* ===== GATE DE ACESSO ===== */
#gp-gate{position:fixed;inset:0;z-index:99999;background:#1F2024;display:flex;align-items:center;justify-content:center;padding:24px}
.gp-gate-card{max-width:420px;width:100%;text-align:center;color:#fff}
.gp-gate-logo{height:42px;margin-bottom:30px;opacity:.96}
.gp-gate-k{font:600 12px/1 'Inter',sans-serif;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:14px}
.gp-gate-card h1{font:700 28px/1.1 'Montserrat',sans-serif;margin:0 0 12px}
.gp-gate-card p{font:400 15px/1.6 'Inter',sans-serif;color:rgba(255,255,255,.6);margin:0 0 26px}
#gp-gate-form{display:flex;gap:10px;flex-direction:column}
#gp-gate-pw{height:52px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.06);border-radius:10px;padding:0 18px;color:#fff;font:500 16px 'Inter',sans-serif;text-align:center;letter-spacing:.04em}
#gp-gate-pw:focus{outline:none;border-color:rgba(255,255,255,.5)}
#gp-gate-pw::placeholder{color:rgba(255,255,255,.35)}
#gp-gate-form button{height:52px;border:0;border-radius:10px;background:#fff;color:#1F2024;font:700 15px 'Montserrat',sans-serif;cursor:pointer;transition:opacity .15s}
#gp-gate-form button:hover{opacity:.88}
.gp-gate-err{margin-top:14px;font:500 13px 'Inter',sans-serif;color:#ff8a8a;opacity:0;transition:opacity .2s}
.gp-gate-err.show{opacity:1}

/* ===== LINK DE CONTA NO HEADER ===== */
.acct-link{display:inline-flex;align-items:center;gap:6px;font:600 13px 'Inter',sans-serif;color:var(--ink,#1F2024);text-decoration:none;padding:7px 14px;border:1px solid var(--line,#e6e6e6);border-radius:999px;transition:background .15s,border-color .15s;white-space:nowrap}
.acct-link:hover{background:#f5f5f5}
.acct-link.on{background:#1F2024;color:#fff;border-color:#1F2024}
.acct-link.on::before{content:'';width:7px;height:7px;border-radius:50%;background:#5ad17a;display:inline-block}

/* ===== TELAS DE CADASTRO / LOGIN / CONTA ===== */
.authsec{padding:54px 0 92px;background:#faf9f7;min-height:70vh}
.authwrap{display:grid;grid-template-columns:1.05fr .95fr;gap:0;max-width:920px;margin:0 auto;background:#fff;border:1px solid var(--line,#ececec);border-radius:16px;overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,.06)}
.authcard{padding:46px 44px}
.authk{font:600 11px/1 'Inter',sans-serif;letter-spacing:.16em;text-transform:uppercase;color:#9a9a9a;margin-bottom:13px}
.authcard h1{font:700 30px/1.05 'Montserrat',sans-serif;margin:0 0 10px;color:#1F2024}
.authsub{font:400 15px/1.55 'Inter',sans-serif;color:#777;margin:0 0 26px}
.authform{display:flex;flex-direction:column;gap:15px}
.afield{display:flex;flex-direction:column;gap:7px}
.afield span{font:600 12.5px 'Inter',sans-serif;color:#555}
.afield input{height:48px;border:1px solid #e0e0e0;border-radius:10px;padding:0 15px;font:500 15px 'Inter',sans-serif;color:#1F2024;background:#fff;transition:border-color .15s}
.afield input:focus{outline:none;border-color:#1F2024}
.autherr{font:500 13px 'Inter',sans-serif;color:#c0392b;min-height:0;opacity:0;transition:opacity .2s}
.autherr.show{opacity:1;min-height:18px}
.btn-full{width:100%;justify-content:center;margin-top:4px}
.authalt{margin-top:20px;font:400 14px 'Inter',sans-serif;color:#777;text-align:center}
.authalt a{color:#1F2024;font-weight:700;text-decoration:none}
.authalt a:hover{text-decoration:underline}
.authside{background:#1F2024;color:#fff;display:flex;align-items:center}
.authside-in{padding:46px 40px}
.authside-in h2{font:700 20px 'Montserrat',sans-serif;margin:0 0 22px}
.authside-in ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:18px}
.authside-in li{display:flex;align-items:flex-start;gap:13px;font:400 14.5px/1.45 'Inter',sans-serif;color:rgba(255,255,255,.82)}
.authside-in li svg{width:21px;height:21px;flex:0 0 21px;stroke:#fff;opacity:.9;margin-top:1px}
/* conta */
.contawrap{max-width:560px;margin:0 auto;background:#fff;border:1px solid var(--line,#ececec);border-radius:16px;padding:42px 40px;box-shadow:0 24px 60px rgba(0,0,0,.06)}
.contawrap h1{font:700 30px 'Montserrat',sans-serif;margin:0 0 10px;color:#1F2024}
.contagrid{display:flex;flex-direction:column;margin:8px 0 28px;border:1px solid #eee;border-radius:12px;overflow:hidden}
.contarow{display:flex;justify-content:space-between;align-items:center;padding:15px 18px;border-bottom:1px solid #f0f0f0}
.contarow:last-child{border-bottom:0}
.contarow .cl{font:600 13px 'Inter',sans-serif;color:#888}
.contarow .cv{font:600 15px 'Inter',sans-serif;color:#1F2024}
.contacta{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.authlogout{font:600 14px 'Inter',sans-serif;color:#c0392b;text-decoration:none;margin-left:auto;cursor:pointer}
.authlogout:hover{text-decoration:underline}
@media(max-width:720px){.authwrap{grid-template-columns:1fr}.authside{display:none}.authcard{padding:38px 26px}.contawrap{padding:34px 24px}.authlogout{margin-left:0;width:100%;text-align:center;margin-top:6px}}

/* ===== HEADER MOBILE (hamburger + dropdown) ===== */
.hd-in{position:relative;}
.navtoggle{width:42px;height:42px;border:1px solid var(--line);border-radius:9px;background:#fff;cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px;padding:0;}
.navtoggle span{display:block;width:18px;height:2px;background:var(--ink);border-radius:2px;transition:transform .25s var(--ease),opacity .2s;}
.navtoggle.on span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.navtoggle.on span:nth-child(2){opacity:0;}
.navtoggle.on span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
@media(max-width:820px){
  .navtoggle{display:flex;}
  .hd-right{gap:14px;}
  .nav{position:absolute;top:calc(100% + 1px);left:-22px;right:-22px;background:#fff;border-bottom:1px solid var(--line);box-shadow:0 18px 36px rgba(31,32,36,.12);flex-direction:column;align-items:stretch;gap:0;padding:8px 22px 16px;display:none;z-index:60;}
  .nav.open{display:flex;}
  .nav a{font-size:14px;letter-spacing:.6px;padding:15px 2px;border-bottom:1px solid var(--soft);width:100%;}
  .nav .lang{padding:15px 2px;border-bottom:1px solid var(--soft);font-size:13px;letter-spacing:.6px;}
  .nav .acct-link{margin-top:14px;justify-content:center;padding:13px;border-radius:10px;font-size:14px;}
  .nav .acct-link.on{background:#1F2024;color:#fff;}
}
@media(max-width:560px){.hd-tools{gap:14px;}}

/* ===== HARDENING TELAS DE CELULAR REAL (<500px) ===== */
@media(max-width:500px){
  .ribbon{font-size:9.5px;letter-spacing:.3px;padding:7px 14px;line-height:1.4;}
  .hero{height:auto;min-height:430px;padding:96px 0 56px;}
  .hero p{font-size:15.5px;}
  .cta-bar .wrap{flex-direction:column;align-items:flex-start;gap:16px;}
  .features .wrap{grid-template-columns:1fr;}
  .feat{border-right:none!important;border-bottom:1px solid var(--line);padding:18px 4px;}
  .feat:last-child{border-bottom:none;}
  .trust{gap:14px 24px;}
  .filterbar{gap:8px;margin-bottom:28px;}
  .filterbar button{padding:10px 16px;font-size:11px;}
  .authsec{padding:30px 0 60px;}
  .ambient .ah .at,.ambient .atitle{font-size:18px;}
}
@media(max-width:380px){
  .ribbon b{display:block;font-size:9px;margin-top:1px;}
}
