:root{
  --red:#d42629; --red-dark:#a81d20; --red-soft:#fdeaea;
  --ink:#15161a; --ink-2:#3a3d45; --muted:#7c818c;
  --line:#e8e9ed; --bg:#f6f7f9; --card:#ffffff; --white:#fff;
  --green:#1eb858; --green-dark:#179a48;
  --amber:#f5a623;
  --r-sm:10px; --r:16px; --r-lg:22px;
  --sh-sm:0 1px 2px rgba(20,22,26,.06),0 1px 1px rgba(20,22,26,.04);
  --sh:0 4px 16px rgba(20,22,26,.08);
  --sh-lg:0 18px 50px rgba(20,22,26,.16);
  --maxw:1280px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Sora',system-ui,sans-serif;color:var(--ink);background:var(--bg);line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font-family:inherit;cursor:pointer;border:none;background:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.display{font-family:'Archivo',sans-serif}

/* ===== TOPBAR ===== */
.topbar{background:var(--ink);color:#cfd2da;font-size:13px}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:38px;gap:20px}
.topbar a{color:#cfd2da;transition:color .2s}
.topbar a:hover{color:#fff}
.topbar .tb-left{display:flex;gap:22px;align-items:center}
.topbar .tb-left span i{color:var(--red);margin-right:7px}
.topbar .tb-right{display:flex;gap:18px;align-items:center}
@media(max-width:768px){.topbar .tb-left span:not(:first-child){display:none}.topbar .tb-right a span{display:none}}

/* ===== HEADER ===== */
.header{background:var(--white);position:sticky;top:0;z-index:200;box-shadow:var(--sh-sm);border-bottom:1px solid var(--line)}
.header .wrap{display:flex;align-items:center;gap:28px;height:84px}
.logo{display:flex;align-items:center;gap:12px;flex-shrink:0}
.logo-mark{width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,var(--red),var(--red-dark));display:grid;place-items:center;color:#fff;font-family:'Archivo';font-weight:900;font-size:22px;box-shadow:0 6px 16px rgba(225,29,35,.35);transform:rotate(-4deg)}
.logo-txt b{font-family:'Archivo';font-weight:900;font-size:21px;letter-spacing:-.5px;display:block;line-height:1}
.logo-txt small{font-size:11px;color:var(--muted);font-weight:600;letter-spacing:2px;text-transform:uppercase}

/* SEARCH */
.search{flex:1;position:relative;max-width:620px}
.search-form{display:flex;align-items:center;background:var(--bg);border:2px solid var(--line);border-radius:var(--r);transition:.2s;overflow:hidden}
.search-form:focus-within{border-color:var(--red);background:#fff;box-shadow:0 0 0 4px var(--red-soft)}
.search-form i.fa-magnifying-glass{padding:0 16px;color:var(--muted)}
.search-form input{flex:1;border:none;background:none;padding:14px 0;font-size:15px;outline:none;font-family:inherit;color:var(--ink)}
.search-form button{background:var(--red);color:#fff;padding:0 22px;align-self:stretch;font-weight:700;font-size:14px;transition:.2s}
.search-form button:hover{background:var(--red-dark)}
.search-suggest{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fff;border-radius:var(--r);box-shadow:var(--sh-lg);overflow:hidden;display:none;z-index:50;border:1px solid var(--line)}
.search-suggest.on{display:block}
.ss-item{display:flex;gap:12px;padding:11px 16px;align-items:center;transition:.15s;cursor:pointer;border-bottom:1px solid var(--bg)}
.ss-item:hover{background:var(--red-soft)}
.ss-item img{width:40px;height:40px;object-fit:contain;border-radius:8px;background:#fff;border:1px solid var(--line);flex-shrink:0}
.ss-item .ss-info{min-width:0;flex:1}
.ss-item .ss-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ss-item .ss-meta{font-size:11px;color:var(--muted)}
.ss-head{padding:9px 16px;font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--muted);background:var(--bg)}

.head-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}
.cart-btn{position:relative;display:flex;align-items:center;gap:10px;background:var(--ink);color:#fff;padding:13px 20px;border-radius:var(--r);font-weight:700;font-size:14px;transition:.2s}
.cart-btn:hover{background:var(--red);transform:translateY(-1px)}
.cart-btn .badge{position:absolute;top:-7px;right:-7px;background:var(--amber);color:var(--ink);min-width:22px;height:22px;border-radius:11px;display:grid;place-items:center;font-size:12px;font-weight:800;padding:0 5px;border:2px solid #fff}
.icon-btn{width:48px;height:48px;border-radius:var(--r);display:none;place-items:center;font-size:20px;color:var(--ink);background:var(--bg)}
@media(max-width:920px){.search{order:3;flex-basis:100%;max-width:none}.header .wrap{height:auto;flex-wrap:wrap;padding-top:16px;padding-bottom:16px;gap:14px 20px}.cart-btn span.lbl{display:none}.cart-btn{padding:13px 16px}}

/* NAV CATEGORIES */
.catnav{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:84px;z-index:150}
@media(max-width:920px){.catnav{top:0;position:relative}}
.catnav .wrap{display:flex;gap:4px}
.catnav-item{position:relative}
.catnav button{padding:15px 16px;font-size:14px;font-weight:600;color:var(--ink-2);white-space:nowrap;border-bottom:3px solid transparent;transition:.15s;display:flex;align-items:center;gap:8px;cursor:pointer}
.catnav button i{font-size:14px;color:var(--muted)}
.catnav-caret{font-size:10px !important;transition:transform .2s}
.catnav button:hover{color:var(--red)}
.catnav button:hover i{color:var(--red)}
.catnav button.active{color:var(--red);border-bottom-color:var(--red)}
.catnav button.active i{color:var(--red)}
.catnav-item.has-sub:hover .catnav-caret{transform:rotate(180deg);color:var(--red)}
/* dropdown de subcategorias */
.catnav-dropdown{position:absolute;top:100%;left:0;min-width:230px;background:#fff;border:1px solid var(--line);border-radius:0 0 var(--r) var(--r);box-shadow:var(--sh-lg);padding:8px;opacity:0;visibility:hidden;transform:translateY(8px);transition:.18s;z-index:200;max-height:70vh;overflow-y:auto}
.catnav-item.has-sub:hover .catnav-dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.catnav-dropdown a{display:block;padding:9px 14px;font-size:13.5px;font-weight:500;color:var(--ink-2);border-radius:8px;transition:.12s;white-space:nowrap}
.catnav-dropdown a:hover{background:var(--red-soft);color:var(--red)}
.catnav-dropdown .dd-all{font-weight:700;color:var(--red);border-bottom:1px solid var(--line);border-radius:0;margin-bottom:5px;padding-bottom:11px}
/* versão mobile: scroll horizontal e sem dropdown hover */
@media(max-width:920px){
  .catnav .wrap{overflow-x:auto;scrollbar-width:none}
  .catnav .wrap::-webkit-scrollbar{display:none}
  .catnav-caret{display:none}
  .catnav-dropdown{display:none}
}

/* ===== HERO ===== */
.hero{background:linear-gradient(120deg,#15161a 0%,#2a1416 60%,var(--red-dark) 130%);color:#fff;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.07) 1px,transparent 0);background-size:22px 22px}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center;padding:56px 24px}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);padding:7px 15px;border-radius:30px;font-size:13px;font-weight:600;margin-bottom:20px;backdrop-filter:blur(8px)}
.hero-tag i{color:var(--amber)}
.hero h1{font-family:'Archivo';font-weight:900;font-size:clamp(34px,4.5vw,56px);line-height:1.02;letter-spacing:-1.5px;margin-bottom:18px}
.hero h1 em{font-style:normal;color:var(--amber)}
.hero p{font-size:17px;color:#d7d9e0;max-width:480px;margin-bottom:28px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 26px;border-radius:var(--r);font-weight:700;font-size:15px;transition:.2s;border:2px solid transparent}
.btn-primary{background:var(--red);color:#fff}
.btn-primary:hover{background:var(--red-dark);transform:translateY(-2px);box-shadow:0 12px 28px rgba(225,29,35,.4)}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border-color:rgba(255,255,255,.25)}
.btn-ghost:hover{background:rgba(255,255,255,.16)}
.hero-stats{display:flex;gap:30px;margin-top:36px}
.hero-stats .hs b{font-family:'Archivo';font-weight:900;font-size:30px;display:block;line-height:1}
.hero-stats .hs span{font-size:13px;color:#b6b9c2}
.hero-art{position:relative;height:340px}
.hero-card{position:absolute;background:#fff;border-radius:18px;box-shadow:var(--sh-lg);padding:14px;width:160px}
.hero-card img{width:100%;height:110px;object-fit:contain;margin-bottom:8px}
.hero-card .hc-name{font-size:12px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hero-card .hc-tag{font-size:10px;color:var(--green);font-weight:700}
.hc1{top:10px;left:20px;transform:rotate(-6deg);z-index:3}
.hc2{top:40px;right:10px;transform:rotate(5deg);z-index:2}
.hc3{bottom:0;left:90px;transform:rotate(2deg);z-index:4}
@media(max-width:920px){.hero .wrap{grid-template-columns:1fr;padding:40px 24px}.hero-art{display:none}}

/* ===== TRUST BAR ===== */
.trust{background:#fff;border-bottom:1px solid var(--line)}
.trust .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:24px}
.trust-item{display:flex;align-items:center;gap:14px}
.trust-item i{width:46px;height:46px;border-radius:12px;background:var(--red-soft);color:var(--red);display:grid;place-items:center;font-size:19px;flex-shrink:0}
.trust-item b{font-size:14px;display:block}
.trust-item span{font-size:12.5px;color:var(--muted)}
@media(max-width:920px){.trust .wrap{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.trust .wrap{grid-template-columns:1fr}}

/* ===== CATALOG ===== */
.catalog{padding:44px 0 80px}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:26px;gap:20px;flex-wrap:wrap}
.sec-head h2{font-family:'Archivo';font-weight:800;font-size:30px;letter-spacing:-.8px}
.sec-head h2 .count{color:var(--red);font-size:18px;font-weight:700;margin-left:8px}
.sec-head p{color:var(--muted);font-size:14px;margin-top:4px}
.toolbar{display:flex;gap:10px;align-items:center}
.chip{padding:9px 15px;border-radius:30px;font-size:13px;font-weight:600;background:#fff;border:1.5px solid var(--line);color:var(--ink-2);transition:.15s;white-space:nowrap}
.chip:hover{border-color:var(--red);color:var(--red)}
.chip.active{background:var(--red);color:#fff;border-color:var(--red)}
.sort-sel{padding:10px 14px;border-radius:var(--r-sm);border:1.5px solid var(--line);font-family:inherit;font-size:13px;font-weight:600;color:var(--ink-2);background:#fff;cursor:pointer;outline:none}

.subnav{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:20px}

/* PRODUCT CARD */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:.22s;display:flex;flex-direction:column;position:relative}
.card:hover{box-shadow:var(--sh-lg);transform:translateY(-4px);border-color:transparent}
.card-badges{position:absolute;top:12px;left:12px;display:flex;flex-direction:column;gap:6px;z-index:5}
.bdg{font-size:10.5px;font-weight:800;padding:5px 9px;border-radius:7px;letter-spacing:.5px;text-transform:uppercase}
.bdg-new{background:var(--green);color:#fff}
.bdg-feat{background:var(--amber);color:var(--ink)}
.card-img{position:relative;aspect-ratio:1;background:#fff;padding:22px;display:grid;place-items:center;cursor:pointer;border-bottom:1px solid var(--bg)}
.card-img img{max-width:100%;max-height:100%;object-fit:contain;transition:.3s;mix-blend-mode:multiply}
.card:hover .card-img img{transform:scale(1.07)}
.card-img .ph{font-size:42px;color:var(--line)}
.card-body{padding:15px 16px 16px;display:flex;flex-direction:column;flex:1}
.card-cat{font-size:11px;font-weight:700;color:var(--red);text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px}
.card-name{font-size:14px;font-weight:600;line-height:1.35;color:var(--ink);margin-bottom:10px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:38px;cursor:pointer}
.card-name:hover{color:var(--red)}
.card-meta{display:flex;flex-direction:column;gap:3px;margin-bottom:14px;font-size:11.5px;color:var(--muted)}
.card-meta b{color:var(--ink-2);font-weight:600}
.card-foot{margin-top:auto;display:flex;gap:8px;align-items:center}
.qty{display:flex;align-items:center;border:1.5px solid var(--line);border-radius:var(--r-sm);overflow:hidden;flex-shrink:0}
.qty button{width:32px;height:38px;font-size:16px;color:var(--ink-2);font-weight:700;transition:.15s}
.qty button:hover{background:var(--bg);color:var(--red)}
.qty input{width:36px;height:38px;text-align:center;border:none;font-family:inherit;font-weight:700;font-size:14px;outline:none;color:var(--ink)}
.add-btn{flex:1;background:var(--red-soft);color:var(--red);height:38px;border-radius:var(--r-sm);font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center;gap:7px;transition:.18s}
.add-btn:hover{background:var(--red);color:#fff}
.add-btn.added{background:var(--green);color:#fff}

.empty{text-align:center;padding:80px 20px;color:var(--muted)}
.empty i{font-size:54px;color:var(--line);margin-bottom:18px}
.empty h3{font-family:'Archivo';font-size:22px;color:var(--ink);margin-bottom:8px}

.load-more{display:block;margin:36px auto 0;background:#fff;border:2px solid var(--line);color:var(--ink);padding:14px 38px;border-radius:var(--r);font-weight:700;font-size:15px;transition:.2s}
.load-more:hover{border-color:var(--red);color:var(--red)}
/* ===== CART DRAWER ===== */
.overlay{position:fixed;inset:0;background:rgba(20,22,26,.5);backdrop-filter:blur(3px);opacity:0;visibility:hidden;transition:.25s;z-index:300}
.overlay.on{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:0;height:100%;width:430px;max-width:92vw;background:#fff;z-index:310;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--sh-lg)}
.drawer.on{transform:translateX(0)}
.drawer-head{padding:22px 24px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.drawer-head h3{font-family:'Archivo';font-weight:800;font-size:20px;display:flex;align-items:center;gap:10px}
.drawer-head .dh-count{background:var(--red-soft);color:var(--red);font-size:13px;font-weight:800;padding:3px 10px;border-radius:20px}
.drawer-close{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;font-size:18px;color:var(--ink-2);background:var(--bg);transition:.15s}
.drawer-close:hover{background:var(--red-soft);color:var(--red)}
.drawer-body{flex:1;overflow-y:auto;padding:8px 24px}
.cart-item{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--bg)}
.cart-item img{width:64px;height:64px;object-fit:contain;border:1px solid var(--line);border-radius:10px;background:#fff;flex-shrink:0;padding:4px}
.ci-info{flex:1;min-width:0}
.ci-name{font-size:13.5px;font-weight:600;line-height:1.3;margin-bottom:3px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ci-meta{font-size:11.5px;color:var(--muted);margin-bottom:8px}
.ci-foot{display:flex;align-items:center;justify-content:space-between;gap:10px}
.ci-qty{display:flex;align-items:center;border:1.5px solid var(--line);border-radius:8px;overflow:hidden}
.ci-qty button{width:28px;height:32px;font-weight:700;color:var(--ink-2);transition:.15s}
.ci-qty button:hover{background:var(--bg);color:var(--red)}
.ci-qty span{min-width:34px;text-align:center;font-weight:700;font-size:13px}
.ci-remove{font-size:12.5px;color:var(--muted);font-weight:600;display:flex;align-items:center;gap:5px;transition:.15s}
.ci-remove:hover{color:var(--red)}
.cart-empty{text-align:center;padding:70px 20px;color:var(--muted)}
.cart-empty i{font-size:50px;color:var(--line);margin-bottom:16px}
.cart-empty p{font-size:15px;margin-bottom:6px;color:var(--ink-2);font-weight:600}
.cart-empty small{font-size:13px}

.drawer-foot{padding:20px 24px;border-top:1px solid var(--line);background:var(--bg)}
.summary-row{display:flex;justify-content:space-between;font-size:14px;margin-bottom:8px;color:var(--ink-2)}
.summary-row.total{font-size:16px;font-weight:800;color:var(--ink);padding-top:10px;border-top:1px dashed var(--line);margin-top:6px}
.checkout-btn{width:100%;background:var(--green);color:#fff;padding:16px;border-radius:var(--r);font-weight:800;font-size:16px;display:flex;align-items:center;justify-content:center;gap:10px;transition:.2s;margin-top:14px}
.checkout-btn:hover{background:var(--green-dark);transform:translateY(-2px);box-shadow:0 12px 28px rgba(30,184,88,.4)}
.checkout-btn:disabled{background:var(--line);color:var(--muted);cursor:not-allowed;transform:none;box-shadow:none}
.clear-cart{width:100%;text-align:center;color:var(--muted);font-size:13px;font-weight:600;padding:10px;margin-top:6px;transition:.15s}
.clear-cart:hover{color:var(--red)}

/* CHECKOUT FORM */
.co-field{margin-bottom:14px}
.co-field label{display:block;font-size:12.5px;font-weight:700;color:var(--ink-2);margin-bottom:6px}
.co-field label .req{color:var(--red)}
.co-field input,.co-field textarea{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:var(--r-sm);font-family:inherit;font-size:14px;outline:none;transition:.15s;color:var(--ink)}
.co-field input:focus,.co-field textarea:focus{border-color:var(--red);box-shadow:0 0 0 3px var(--red-soft)}
.co-field textarea{resize:vertical;min-height:64px}
.co-field.err input{border-color:var(--red)}
.co-back{font-size:13px;color:var(--muted);font-weight:600;display:inline-flex;align-items:center;gap:6px;margin-bottom:16px;transition:.15s}
.co-back:hover{color:var(--red)}

/* TOAST */
.toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(120px);background:var(--ink);color:#fff;padding:14px 24px;border-radius:var(--r);font-weight:600;font-size:14px;display:flex;align-items:center;gap:10px;z-index:400;box-shadow:var(--sh-lg);transition:transform .3s cubic-bezier(.4,0,.2,1);max-width:90vw}
.toast.on{transform:translateX(-50%) translateY(0)}
.toast i{color:var(--green);font-size:18px}

/* PRODUCT MODAL */
.modal-card{position:fixed;top:50%;left:50%;transform:translate(-50%,-48%) scale(.96);background:#fff;border-radius:var(--r-lg);z-index:320;width:760px;max-width:94vw;max-height:90vh;overflow:hidden;opacity:0;visibility:hidden;transition:.25s;display:grid;grid-template-columns:1fr 1fr}
.modal-card.on{opacity:1;visibility:visible;transform:translate(-50%,-50%) scale(1)}
.modal-img{background:#fff;padding:40px;display:grid;place-items:center;border-right:1px solid var(--line)}
.modal-img img{max-width:100%;max-height:340px;object-fit:contain;mix-blend-mode:multiply}
.modal-info{padding:32px;overflow-y:auto;position:relative;display:flex;flex-direction:column}
.modal-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:10px;background:var(--bg);display:grid;place-items:center;font-size:16px;color:var(--ink-2);transition:.15s;z-index:10;cursor:pointer}
.modal-close:hover{background:var(--red-soft);color:var(--red)}
.modal-cat{font-size:12px;font-weight:700;color:var(--red);text-transform:uppercase;letter-spacing:.6px;margin-bottom:10px}
.modal-name{font-family:'Archivo';font-weight:800;font-size:22px;line-height:1.2;margin-bottom:18px}
.modal-specs{display:flex;flex-direction:column;gap:0;margin-bottom:24px;border:1px solid var(--line);border-radius:var(--r-sm);overflow:hidden}
.spec-row{display:flex;justify-content:space-between;padding:11px 14px;font-size:13px}
.spec-row:nth-child(odd){background:var(--bg)}
.spec-row span{color:var(--muted);font-weight:600}
.spec-row b{color:var(--ink);font-weight:700;text-align:right}
.modal-foot{margin-top:auto;display:flex;gap:10px;align-items:center}
@media(max-width:680px){.modal-card{grid-template-columns:1fr;max-height:88vh;overflow-y:auto}.modal-img{border-right:none;border-bottom:1px solid var(--line);padding:24px}.modal-img img{max-height:220px}}

/* ===== FOOTER ===== */
.footer{background:var(--ink);color:#a8acb5;padding:56px 0 0}
.footer .wrap{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:40px}
.footer h4{color:#fff;font-family:'Archivo';font-weight:700;font-size:15px;margin-bottom:18px;letter-spacing:.5px}
.footer .f-logo{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.footer .f-logo .logo-mark{width:42px;height:42px;font-size:20px}
.footer .f-logo b{color:#fff;font-family:'Archivo';font-weight:900;font-size:19px}
.footer p{font-size:13.5px;line-height:1.7;margin-bottom:16px}
.footer ul{list-style:none}
.footer ul li{margin-bottom:10px}
.footer ul li a{font-size:13.5px;transition:.15s}
.footer ul li a:hover{color:#fff;padding-left:4px}
.footer .f-contact li{display:flex;gap:10px;font-size:13.5px;margin-bottom:12px}
.footer .f-contact i{color:var(--red);margin-top:2px}
.f-social{display:flex;gap:10px;margin-top:8px}
.f-social a{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.07);display:grid;place-items:center;color:#fff;transition:.2s}
.f-social a:hover{background:var(--red);transform:translateY(-2px)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:22px 0;font-size:12.5px;text-align:center}
@media(max-width:920px){.footer .wrap{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer .wrap{grid-template-columns:1fr}}

/* WHATSAPP FLOAT */
.wa-float{position:fixed;bottom:26px;right:26px;width:60px;height:60px;border-radius:50%;background:var(--green);color:#fff;display:grid;place-items:center;font-size:30px;box-shadow:0 10px 30px rgba(30,184,88,.45);z-index:250;transition:.2s;animation:wapulse 2.5s infinite}
.wa-float:hover{transform:scale(1.08)}
@keyframes wapulse{0%,100%{box-shadow:0 10px 30px rgba(30,184,88,.45)}50%{box-shadow:0 10px 30px rgba(30,184,88,.45),0 0 0 14px rgba(30,184,88,.1)}}
@media(max-width:920px){.wa-float{bottom:18px;right:18px;width:54px;height:54px;font-size:27px}}

@media(max-width:600px){
  .grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .card-img{padding:14px}
  .card-body{padding:12px}
  .card-name{font-size:12.5px;min-height:34px}
  .sec-head h2{font-size:24px}
  .wrap{padding:0 16px}
}

/* ===== CATEGORY TILES (home) ===== */
.cat-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}
.cat-tile{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:28px 16px;text-align:center;transition:.2s}
.cat-tile i{font-size:30px;color:var(--red);transition:.2s}
.cat-tile span{font-size:14px;font-weight:700;color:var(--ink)}
.cat-tile:hover{border-color:var(--red);box-shadow:var(--sh);transform:translateY(-3px)}
.cat-tile:hover i{transform:scale(1.12)}

/* ===== PAGINATION ===== */
.pagination{display:flex;justify-content:center;align-items:center;gap:6px;margin-top:44px;flex-wrap:wrap}
.pagination a,.pagination span{min-width:42px;height:42px;display:grid;place-items:center;border-radius:var(--r-sm);font-weight:700;font-size:14px;border:1.5px solid var(--line);background:#fff;color:var(--ink-2);transition:.15s;padding:0 8px}
.pagination a:hover{border-color:var(--red);color:var(--red)}
.pagination .current{background:var(--red);color:#fff;border-color:var(--red)}
.pagination .disabled{opacity:.4;pointer-events:none}

/* ===== SIDEBAR FILTERS (categoria) ===== */
.cat-layout{display:grid;grid-template-columns:260px 1fr;gap:32px;align-items:start}
.sidebar{position:sticky;top:150px;align-self:start;max-height:calc(100vh - 170px);overflow-y:auto;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:22px;display:flex;flex-direction:column;gap:24px;scrollbar-width:thin}
.sb-group h4{font-family:'Archivo';font-size:14px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px;color:var(--ink);display:flex;align-items:center;gap:8px}
.sb-group h4 i{color:var(--red);font-size:13px}
.sb-list{display:flex;flex-direction:column;gap:2px;max-height:280px;overflow-y:auto}
.sb-list a{font-size:13.5px;color:var(--ink-2);padding:8px 10px;border-radius:8px;transition:.15s;display:flex;justify-content:space-between;align-items:center;font-weight:500}
.sb-list a:hover{background:var(--bg);color:var(--red)}
.sb-list a.active{background:var(--red-soft);color:var(--red);font-weight:700}
.sb-list a .n{font-size:11px;color:var(--muted);font-weight:600}
.mobile-filter-btn{display:none}
@media(max-width:920px){
  .cat-layout{grid-template-columns:1fr}
  .sidebar{position:fixed;top:0;left:0;height:100%;width:300px;max-width:88vw;z-index:310;border-radius:0;transform:translateX(-100%);transition:.3s;overflow-y:auto;box-shadow:var(--sh-lg)}
  .sidebar.on{transform:translateX(0)}
  .mobile-filter-btn{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1.5px solid var(--line);padding:11px 18px;border-radius:var(--r);font-weight:700;font-size:14px;color:var(--ink)}
  .sb-close{display:block !important}
}
.sb-close{display:none;position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:9px;background:var(--bg);place-items:center;font-size:16px;color:var(--ink-2)}

/* ===== BREADCRUMB ===== */
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted);flex-wrap:wrap}
.breadcrumb a{font-weight:600;color:var(--ink-2);transition:.15s}
.breadcrumb a:hover{color:var(--red)}
.breadcrumb i{font-size:10px;color:var(--line)}

/* ===== PRODUCT DETAIL ===== */
.product-detail{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:start;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:36px}
.pd-img{position:relative;aspect-ratio:1;background:#fff;border:1px solid var(--line);border-radius:var(--r);display:grid;place-items:center;padding:40px}
.pd-img img{max-width:100%;max-height:100%;object-fit:contain;mix-blend-mode:multiply}
.pd-name{font-family:'Archivo';font-weight:800;font-size:28px;line-height:1.15;margin:10px 0 14px}
.pd-brand{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:700;color:var(--red);background:var(--red-soft);padding:6px 13px;border-radius:20px;margin-bottom:24px}
.pd-specs{border:1px solid var(--line);border-radius:var(--r);overflow:hidden;margin-bottom:24px}
.pd-desc{margin-bottom:22px}
.pd-desc h4{font-family:'Archivo';font-size:15px;font-weight:700;margin-bottom:8px}
.pd-desc p{font-size:14px;color:var(--ink-2);line-height:1.7}
.pd-actions{display:flex;gap:12px;align-items:center;margin-bottom:14px}
.pd-actions .qty button{height:50px;width:42px}
.pd-actions .qty input{height:50px;width:48px;font-size:16px}
.pd-actions .btn{height:50px;font-size:16px;justify-content:center}
.pd-wa{display:flex;align-items:center;justify-content:center;gap:9px;width:100%;padding:13px;border:1.5px solid var(--green);color:var(--green-dark);border-radius:var(--r);font-weight:700;font-size:14px;transition:.18s}
.pd-wa:hover{background:var(--green);color:#fff}
@media(max-width:820px){.product-detail{grid-template-columns:1fr;gap:28px;padding:22px}.pd-name{font-size:23px}}

/* ===== HERO BANNER SLIDER ===== */
.hero-banner{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-lg);background:#000;aspect-ratio:16/7}
.banner-slide{position:absolute;inset:0;opacity:0;transition:opacity .8s ease}
.banner-slide.active{opacity:1}
.banner-slide img{width:100%;height:100%;object-fit:cover}
.banner-dots{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:3}
.banner-dots span{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.5);cursor:pointer;transition:.2s}
.banner-dots span.active{background:#fff;width:26px;border-radius:5px}
@media(max-width:920px){.hero-banner{aspect-ratio:16/9;margin-top:8px}}

/* ===== CALAMEO BOX ===== */
.calameo-box{display:flex;justify-content:space-between;align-items:center;gap:24px;background:linear-gradient(120deg,var(--ink),#2a1416);color:#fff;border-radius:var(--r-lg);padding:32px 36px;flex-wrap:wrap}
.calameo-box h3{font-family:'Archivo';font-weight:800;font-size:24px;margin-bottom:6px}
.calameo-box p{color:#c9ccd4;font-size:14.5px}
