/* ============================================================
   PAIOTTI MATERIAIS — STYLESHEET v3
   CSS Custom Properties dinâmicas — sobrescritas pelo PHP (Admin > Aparência)
   ============================================================ */

/* 1. RESET + VARIABLES */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --primary:#C8821A;--primary-dark:#A56914;--primary-light:#E09830;
  --primary-xlight:#FFF3E0;--primary-rgb:200,130,26;
  --dark:#1A1A1A;--dark-2:#2C2C2C;--dark-3:#3E3E3E;
  --mid:#6B7280;--light-3:#B0B0B0;--light-2:#E5E7EB;--light:#F3F4F6;
  --bg:#F8F8F5;--white:#FFFFFF;
  --success:#16A34A;--success-light:#DCFCE7;
  --danger:#DC2626;--danger-light:#FEE2E2;
  --warning:#D97706;--warning-light:#FEF3C7;
  --info:#2563EB;--info-light:#DBEAFE;
  --font-head:'Barlow Condensed',sans-serif;
  --font-body:'Barlow',sans-serif;
  --radius:8px;--radius-lg:14px;--radius-xl:20px;
  --shadow-xs:0 1px 3px rgba(0,0,0,.08);
  --shadow:0 2px 8px rgba(0,0,0,.10);
  --shadow-md:0 4px 20px rgba(0,0,0,.11);
  --shadow-lg:0 8px 40px rgba(0,0,0,.14);
  --transition:.2s ease;
  --container:1260px;--sidebar-w:260px;
  --topbar-h:36px;--header-h:70px;--navbar-h:44px;
  --grid-cols:4;--card-ratio:1/1;
}

/* 2. BASE */
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--font-body);background:var(--bg);color:var(--dark);font-size:.9375rem;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
ul{list-style:none}
img{max-width:100%;height:auto;display:block}
button{cursor:pointer;font-family:var(--font-body)}
input,select,textarea{font-family:var(--font-body)}
h1,h2,h3,h4,h5{line-height:1.2}
svg{flex-shrink:0}

/* 3. UTILS */
.container{max-width:var(--container);margin:0 auto;padding:0 20px}
.hidden{display:none!important}
.text-primary{color:var(--primary)}.text-mid{color:var(--mid)}
.text-success{color:var(--success)}.text-danger{color:var(--danger)}

.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;line-height:1}
.badge-primary{background:var(--primary);color:#fff}
.badge-success{background:var(--success-light);color:var(--success)}
.badge-danger{background:var(--danger-light);color:var(--danger)}
.badge-warning{background:var(--warning-light);color:var(--warning)}
.badge-info{background:var(--info-light);color:var(--info)}
.badge-dark{background:var(--dark-2);color:#fff}

/* 4. BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 22px;border-radius:var(--radius);font-size:14px;font-weight:600;border:2px solid transparent;cursor:pointer;transition:var(--transition);white-space:nowrap;text-decoration:none;line-height:1}
.btn:focus-visible{outline:3px solid rgba(var(--primary-rgb),.4);outline-offset:2px}
.btn svg{width:16px;height:16px}
.btn-lg{padding:13px 28px;font-size:15px}
.btn-sm{padding:7px 14px;font-size:13px}
.btn-sm svg{width:14px;height:14px}
.btn-xs{padding:5px 10px;font-size:12px}
.btn-block{width:100%}
.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--primary-rgb),.35)}
.btn-outline{background:transparent;color:var(--primary);border-color:var(--primary)}
.btn-outline:hover{background:var(--primary);color:#fff}
.btn-dark{background:var(--dark);color:#fff;border-color:var(--dark)}
.btn-dark:hover{background:var(--dark-2);border-color:var(--dark-2)}
.btn-light{background:var(--light);color:var(--dark-3);border-color:var(--light-2)}
.btn-light:hover{background:var(--light-2);border-color:#CBD5E1}
.btn-success{background:var(--success);color:#fff;border-color:var(--success)}
.btn-success:hover{filter:brightness(.9)}
.btn-danger{background:var(--danger);color:#fff;border-color:var(--danger)}
.btn-danger:hover{filter:brightness(.9)}
.btn-whatsapp{background:#25D366;color:#fff;border-color:#25D366}
.btn-whatsapp:hover{background:#1db954;border-color:#1db954}

/* 5. FORMS */
.form-group{margin-bottom:18px}
.form-label{display:block;font-size:13px;font-weight:600;color:var(--dark-3);margin-bottom:6px}
.form-control{width:100%;padding:11px 14px;border:1.5px solid var(--light-2);border-radius:var(--radius);font-size:15px;color:var(--dark);background:var(--white);transition:border-color .2s,box-shadow .2s;appearance:none}
.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.15)}
.form-control::placeholder{color:var(--light-3)}
.form-control:disabled{opacity:.6;cursor:not-allowed;background:var(--light)}
select.form-control{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px}
textarea.form-control{resize:vertical;min-height:96px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-row-3{grid-template-columns:1fr 1fr 1fr}
.form-hint{font-size:12px;color:var(--mid);margin-top:5px}
.form-error{font-size:12px;color:var(--danger);margin-top:5px}
.input-group{position:relative;display:flex}
.input-group .form-control{border-radius:var(--radius) 0 0 var(--radius)}
.input-group-btn{padding:0 14px;background:var(--light);border:1.5px solid var(--light-2);border-left:none;border-radius:0 var(--radius) var(--radius) 0;color:var(--mid);cursor:pointer;display:flex;align-items:center}
.input-group-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}

/* 6. ALERTS */
.alert{padding:13px 16px;border-radius:var(--radius);font-size:14px;margin-bottom:16px;display:flex;align-items:flex-start;gap:10px;border:1px solid transparent}
.alert svg{width:16px;height:16px;flex-shrink:0;margin-top:1px}
.alert-success{background:var(--success-light);color:#14532D;border-color:#86EFAC}
.alert-danger{background:var(--danger-light);color:#7F1D1D;border-color:#FCA5A5}
.alert-warning{background:var(--warning-light);color:#78350F;border-color:#FCD34D}
.alert-info{background:var(--info-light);color:#1E3A8A;border-color:#93C5FD}

/* 7. TOPBAR */
.topbar{background:var(--dark);color:#9CA3AF;font-size:12px;height:var(--topbar-h);display:flex;align-items:center;overflow:hidden}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;gap:12px;width:100%}
.topbar-left,.topbar-right{display:flex;align-items:center;gap:14px;flex-shrink:0}
.topbar-left span,.topbar-right a{display:flex;align-items:center;gap:4px;white-space:nowrap;font-size:12px}
.topbar-right a{color:#9CA3AF;transition:color .2s;text-decoration:none}
.topbar-right a:hover{color:var(--primary-light)}
.topbar-whatsapp{color:#4ADE80!important;font-weight:700}
.topbar svg{width:12px;height:12px;flex-shrink:0}
.topbar-sair,.topbar-cadastro{opacity:.8}

/* ──────────────────────────────────────────
   8. HEADER — nova estrutura .hdr
   ────────────────────────────────────────── */
.header{
  background:var(--white);
  border-bottom:1px solid var(--light-2);
  position:sticky;top:0;z-index:200;
  box-shadow:var(--shadow-xs);
  transition:box-shadow .25s;
}
.header.scrolled{box-shadow:0 2px 16px rgba(0,0,0,.13)}

/* Linha única do header */
.hdr{
  display:flex;align-items:center;
  gap:14px;
  height:64px;
  padding:0 20px;
}

/* LOGO */
.logo{display:flex;align-items:center;gap:10px;flex-shrink:0;text-decoration:none}
.logo-icon{
  width:42px;height:42px;
  background:var(--primary);color:#fff;
  border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-head);font-size:22px;font-weight:800;
  flex-shrink:0;
}
.logo-text{display:flex;flex-direction:column;line-height:1}
.logo-nome{font-family:var(--font-head);font-size:20px;font-weight:800;color:var(--dark);letter-spacing:.2px}
.logo-sub{font-size:9px;color:var(--mid);text-transform:uppercase;letter-spacing:1px;margin-top:3px}

/* BUSCA DESKTOP */
.hdr-search{
  flex:1;
  position:relative;
  max-width:500px;
  margin:0 auto;
}
.hdr-search input{
  width:100%;height:42px;
  padding:0 48px 0 18px;
  border:1.5px solid var(--light-2);
  border-radius:21px;
  font-size:14px;
  background:var(--bg);
  transition:border-color .2s,background .2s,box-shadow .2s;
  color:var(--dark);
}
.hdr-search input:focus{
  outline:none;
  border-color:var(--primary);
  background:var(--white);
  box-shadow:0 0 0 3px rgba(var(--primary-rgb),.12);
}
.hdr-search input::placeholder{color:var(--light-3);font-size:13.5px}
.hdr-search-btn{
  position:absolute;right:0;top:0;
  width:44px;height:100%;
  background:var(--primary);border:none;
  border-radius:0 21px 21px 0;
  color:#fff;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s;cursor:pointer;
}
.hdr-search-btn svg{width:17px;height:17px}
.hdr-search-btn:hover{background:var(--primary-dark)}

/* Sugestões */
.search-suggestions{
  position:absolute;top:calc(100% + 8px);left:0;right:0;
  background:var(--white);
  border:1px solid var(--light-2);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg);
  z-index:500;
  max-height:340px;overflow-y:auto;
  display:none;
}
.search-suggestions.open{display:block}
.suggestion-item{
  padding:10px 14px;
  display:flex;align-items:center;gap:11px;
  cursor:pointer;
  transition:background .12s;
  border-bottom:1px solid var(--light);
  text-decoration:none;
}
.suggestion-item:last-child{border-bottom:none}
.suggestion-item:hover{background:var(--bg)}
.suggestion-img{width:36px;height:36px;object-fit:contain;border-radius:6px;background:var(--light);padding:3px;flex-shrink:0}
.suggestion-name{font-size:13px;font-weight:600;color:var(--dark);line-height:1.3}
.suggestion-price{font-size:12px;color:var(--primary);font-weight:700;margin-top:2px}

/* AÇÕES DO HEADER */
.hdr-actions{display:flex;align-items:center;gap:6px;flex-shrink:0;margin-left:auto}

/* Lupa mobile (oculto no desktop) */
.hdr-search-toggle{
  display:none;
  width:40px;height:40px;
  background:none;border:none;
  color:var(--dark-3);
  align-items:center;justify-content:center;
  border-radius:var(--radius);
  transition:background .2s;cursor:pointer;
}
.hdr-search-toggle svg{width:20px;height:20px}
.hdr-search-toggle:hover{background:var(--light)}

/* Botão orçamento */
.hdr-orc{
  display:flex;align-items:center;gap:7px;
  height:38px;padding:0 14px;
  background:var(--dark);color:#fff;
  border-radius:var(--radius);
  font-size:13px;font-weight:600;
  transition:background .2s;
  white-space:nowrap;
}
.hdr-orc svg{width:15px;height:15px;flex-shrink:0}
.hdr-orc:hover{background:var(--dark-2)}

/* Carrinho */
.hdr-cart{
  position:relative;
  width:40px;height:40px;
  background:var(--primary);color:#fff;
  border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;
  transition:background .2s,transform .15s;
}
.hdr-cart svg{width:19px;height:19px}
.hdr-cart:hover{background:var(--primary-dark);transform:scale(1.06)}
.hdr-cart-count{
  position:absolute;top:-5px;right:-5px;
  background:var(--dark);color:#fff;
  font-size:10px;font-weight:800;
  min-width:18px;height:18px;
  border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  padding:0 4px;
  border:2px solid var(--white);
  line-height:1;
}

/* Hamburger */
.hdr-burger{
  display:none;
  width:40px;height:40px;
  background:none;border:none;
  flex-direction:column;align-items:center;justify-content:center;gap:5px;
  cursor:pointer;padding:8px;border-radius:var(--radius);
  transition:background .2s;
}
.hdr-burger:hover{background:var(--light)}
.hdr-burger span{
  display:block;width:20px;height:2px;
  background:var(--dark-2);border-radius:2px;
  transition:transform .3s,opacity .3s;
}
.hdr-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hdr-burger.open span:nth-child(2){opacity:0}
.hdr-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* BUSCA EXPANDIDA MOBILE */
.hdr-search-expanded{
  display:none;
  background:var(--white);
  border-top:1px solid var(--light-2);
  padding:10px 0;
  box-shadow:0 4px 16px rgba(0,0,0,.10);
}
.hdr-search-expanded.open{display:block}
.hdr-search-exp-inner{
  display:flex;align-items:center;gap:10px;
  background:var(--bg);
  border:1.5px solid var(--light-2);
  border-radius:22px;
  padding:0 14px;
  height:44px;
  transition:border-color .2s;
}
.hdr-search-exp-inner:focus-within{border-color:var(--primary);background:var(--white)}
.hdr-search-exp-inner svg{width:17px;height:17px;color:var(--mid);flex-shrink:0}
.hdr-search-exp-inner input{
  flex:1;border:none;background:none;
  font-size:16px;color:var(--dark);
  outline:none;
}
.hdr-search-exp-inner input::placeholder{color:var(--light-3)}
.hdr-search-exp-inner button{
  background:none;border:none;
  color:var(--mid);cursor:pointer;padding:4px;
  border-radius:50%;transition:background .2s,color .2s;
  display:flex;align-items:center;
}
.hdr-search-exp-inner button:hover{background:var(--light-2);color:var(--dark)}
.hdr-search-exp-inner button svg{width:18px;height:18px}

/* ──────────────────────────────────────────
   9. NAVBAR CATEGORIAS
   ────────────────────────────────────────── */
.navbar{
  background:var(--dark-2);
  border-bottom:2px solid rgba(0,0,0,.2);
  position:relative;z-index:190;
}
.navbar-inner{
  display:flex;align-items:stretch;
  /* overflow:hidden estava cortando os últimos itens — removido */
}

/* Botão "Categorias" */
.navbar-all-cats{
  display:flex;align-items:center;gap:7px;
  padding:0 18px;height:var(--navbar-h);
  background:var(--primary);color:#fff;
  font-size:13px;font-weight:700;
  border:none;white-space:nowrap;
  font-family:var(--font-body);
  transition:background .2s;flex-shrink:0;cursor:pointer;
}
.navbar-all-cats:hover{background:var(--primary-dark)}
.navbar-all-cats svg{width:15px;height:15px}
.navbar-all-cats .caret{width:13px;height:13px;transition:transform .25s}
.navbar-all-cats[aria-expanded="true"] .caret{transform:rotate(180deg)}

/* Lista horizontal — scroll interno, não corta */
.navbar-cats{
  display:flex;
  overflow-x:auto;
  flex:1;
  min-width:0;           /* permite encolher */
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
}
.navbar-cats::-webkit-scrollbar{display:none}
.navbar-cats li{display:flex;flex-shrink:0}
.navbar-cats li a{
  display:flex;align-items:center;
  padding:0 13px;height:var(--navbar-h);
  color:#CBD5E1;font-size:13px;font-weight:500;
  white-space:nowrap;
  transition:color .2s,background .2s;
  border-bottom:2px solid transparent;margin-bottom:-2px;
  text-decoration:none;
}
.navbar-cats li a:hover{color:#fff;background:rgba(255,255,255,.07);border-bottom-color:var(--primary-light)}

/* Promoções — flex-shrink:0 garante que nunca some */
.navbar-promo{
  display:flex;align-items:center;gap:6px;
  padding:0 16px;height:var(--navbar-h);
  color:var(--primary-light);font-size:13px;font-weight:700;
  border-left:1px solid rgba(255,255,255,.1);
  white-space:nowrap;flex-shrink:0;
  transition:background .2s;text-decoration:none;
}
.navbar-promo:hover{background:rgba(255,255,255,.07)}
.navbar-promo svg{width:14px;height:14px}

/* Dropdown categorias — position:fixed em ambos os casos */
/* Desktop: aparece abaixo da navbar. Mobile: bottom sheet */
.cats-dropdown{
  position:fixed;
  left:0;right:0;top:0; /* JS define top correto */
  background:var(--white);
  border-top:3px solid var(--primary);
  box-shadow:var(--shadow-lg);
  visibility:hidden;
  opacity:0;
  pointer-events:none;
  z-index:500;
  max-height:60vh;
  overflow-y:auto;
  transition:opacity .2s ease, visibility .2s ease;
}
.cats-dropdown.open{
  visibility:visible;
  opacity:1;
  pointer-events:auto;
}
.cats-dropdown-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(185px,1fr));
  gap:2px;padding:14px;
}
.cat-dropdown-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 13px;border-radius:var(--radius);
  font-size:13px;font-weight:500;color:var(--dark-3);
  transition:background .15s,color .15s;text-decoration:none;
}
.cat-dropdown-item:hover{background:var(--primary-xlight);color:var(--primary-dark)}
.cat-dropdown-item svg{width:15px;height:15px;color:var(--primary);flex-shrink:0}

/* Overlay escuro universal (cats dropdown e mobile menu) */
#catsOverlay{
  display:none;
  position:fixed;inset:0;
  background:rgba(0,0,0,.45);
  z-index:499;
}
#catsOverlay.open{display:block}

/* ──────────────────────────────────────────
   10. BREADCRUMB
   ────────────────────────────────────────── */
.breadcrumb-bar{background:var(--light);border-bottom:1px solid var(--light-2);padding:9px 0}
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--mid);flex-wrap:wrap}
.breadcrumb a{color:var(--mid);transition:color .2s;text-decoration:none}
.breadcrumb a:hover{color:var(--primary)}
.breadcrumb-current{color:var(--dark);font-weight:600}

/* ──────────────────────────────────────────
   11. MOBILE MENU (novo .mob-*)
   ────────────────────────────────────────── */
.mob-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.55);
  z-index:500;backdrop-filter:blur(3px);
}
.mob-overlay.open{display:block}

.mob-menu{
  position:fixed;top:0;right:-100%;
  width:min(320px,92vw);height:100%;
  background:var(--white);z-index:600;
  transition:right .32s cubic-bezier(.4,0,.2,1);
  overflow-y:auto;
  display:flex;flex-direction:column;
  box-shadow:-4px 0 24px rgba(0,0,0,.18);
}
.mob-menu.open{right:0}

/* Cabeçalho do menu */
.mob-menu-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:0 16px;height:58px;
  background:var(--dark);
  flex-shrink:0;
}
.mob-menu-logo{display:flex;align-items:center;gap:9px}
.mob-menu-head button{
  background:none;border:none;color:rgba(255,255,255,.7);
  width:36px;height:36px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background .2s,color .2s;
}
.mob-menu-head button:hover{background:rgba(255,255,255,.1);color:#fff}
.mob-menu-head button svg{width:20px;height:20px}

/* Busca dentro do menu */
.mob-search{padding:12px 14px;background:var(--bg);border-bottom:1px solid var(--light-2)}
.mob-search-inner{
  display:flex;align-items:center;gap:9px;
  background:var(--white);border:1.5px solid var(--light-2);
  border-radius:10px;padding:0 12px;height:42px;
  transition:border-color .2s;
}
.mob-search-inner:focus-within{border-color:var(--primary)}
.mob-search-inner svg{width:16px;height:16px;color:var(--mid);flex-shrink:0}
.mob-search-inner input{flex:1;border:none;background:none;font-size:15px;color:var(--dark);outline:none}
.mob-search-inner input::placeholder{color:var(--light-3)}
.mob-search-inner button{
  background:none;border:none;
  color:var(--primary);cursor:pointer;padding:4px;
  display:flex;align-items:center;
}
.mob-search-inner button svg{width:16px;height:16px}

/* Usuário logado */
.mob-user{
  display:flex;align-items:center;gap:11px;
  padding:14px 16px;
  background:var(--primary-xlight);
  border-bottom:1px solid var(--light-2);
}
.mob-user-avatar{
  width:38px;height:38px;border-radius:50%;
  background:var(--primary);color:#fff;
  font-family:var(--font-head);font-size:18px;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}

/* Botões de auth */
.mob-auth{
  display:flex;gap:8px;padding:12px 14px;
  border-bottom:1px solid var(--light-2);
}

/* Título de seção */
.mob-section-title{
  display:flex;align-items:center;gap:8px;
  padding:13px 16px 8px;
  font-size:10.5px;font-weight:700;
  text-transform:uppercase;letter-spacing:1px;
  color:var(--mid);
}
.mob-section-title svg{width:14px;height:14px}

/* Grid de categorias no mobile */
.mob-cats-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:1px;
  background:var(--light-2);
  border-top:1px solid var(--light-2);
  border-bottom:1px solid var(--light-2);
  margin-bottom:4px;
}
.mob-cat-item{
  display:flex;align-items:center;gap:9px;
  padding:11px 14px;
  background:var(--white);
  font-size:13px;font-weight:500;color:var(--dark-3);
  text-decoration:none;
  transition:background .15s,color .15s;
}
.mob-cat-item:hover{background:var(--primary-xlight);color:var(--primary-dark)}
.mob-cat-icon{
  width:30px;height:30px;border-radius:7px;
  background:var(--primary-xlight);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.mob-cat-icon svg{width:15px;height:15px;color:var(--primary)}
.mob-cat-item span{font-size:12px;line-height:1.3}

/* Links do menu mobile */
.mob-links{display:flex;flex-direction:column}
.mob-links a{
  display:flex;align-items:center;gap:12px;
  padding:13px 18px;
  font-size:14px;color:var(--dark-3);
  text-decoration:none;
  transition:background .15s,color .15s;
  border-bottom:1px solid var(--light);
}
.mob-links a:last-child{border-bottom:none}
.mob-links a:hover{background:var(--bg);color:var(--primary)}
.mob-links a svg{width:17px;height:17px;flex-shrink:0;color:var(--mid)}
.mob-link-danger{color:var(--danger)!important}
.mob-link-danger svg{color:var(--danger)!important}

/* 12. HERO */
.hero{position:relative;overflow:hidden;background:var(--dark)}
.hero-slides{position:relative;height:clamp(220px,40vw,420px)}
.hero-slide{position:absolute;inset:0;display:flex;align-items:center;opacity:0;transition:opacity .65s ease;pointer-events:none}
.hero-slide.active{opacity:1;z-index:1;pointer-events:auto}
.hero-slide img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.78) 0%,rgba(0,0,0,.15) 65%,transparent 100%)}
.hero-slide-bg{position:absolute;inset:0;background:linear-gradient(135deg,#1A1A1A 0%,#2C2C2C 60%,#3E2010 100%)}
.hero-content{position:relative;z-index:2;padding:0 clamp(20px,5vw,56px);max-width:600px}
.hero-content h1{font-family:var(--font-head);font-size:clamp(26px,5vw,50px);font-weight:800;color:#fff;line-height:1.05;text-transform:uppercase;margin-bottom:14px}
.hero-content h1 span{color:var(--primary-light)}
.hero-content p{color:rgba(255,255,255,.78);font-size:clamp(13px,2vw,16px);margin-bottom:24px}
.hero-dots{position:absolute;bottom:16px;left:50%;transform:translateX(-50%);display:flex;gap:7px;z-index:5}
.hero-dot{width:8px;height:8px;border-radius:4px;background:rgba(255,255,255,.35);border:none;transition:width .3s,background .3s;cursor:pointer}
.hero-dot.active{width:26px;background:var(--primary)}
.hero-arrows{position:absolute;top:50%;transform:translateY(-50%);width:100%;display:flex;justify-content:space-between;padding:0 12px;z-index:5;pointer-events:none}
.hero-arrow{width:38px;height:38px;border-radius:50%;background:rgba(0,0,0,.35);border:1.5px solid rgba(255,255,255,.25);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s;pointer-events:auto;backdrop-filter:blur(4px)}
.hero-arrow:hover{background:var(--primary);border-color:var(--primary)}
.hero-arrow svg{width:18px;height:18px}

/* 13. SEÇÕES HOME */
.section{padding:52px 0}
.section-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:28px;gap:16px}
.section-title{font-family:var(--font-head);font-size:clamp(20px,3vw,30px);font-weight:800;color:var(--dark);text-transform:uppercase;line-height:1}
.section-title span{color:var(--primary)}
.section-link{font-size:13px;color:var(--primary);font-weight:600;display:flex;align-items:center;gap:5px;white-space:nowrap;flex-shrink:0}
.section-link:hover{color:var(--primary-dark)}
.section-link svg{width:14px;height:14px}

/* Vantagens */
.vantagens-bar{background:var(--white);border-bottom:1px solid var(--light-2);padding:16px 0}
.vantagens-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.vantagem-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--radius)}
.vantagem-icon{width:42px;height:42px;background:var(--primary-xlight);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.vantagem-icon svg{width:20px;height:20px;color:var(--primary)}
.vantagem-title{font-size:13px;font-weight:700;color:var(--dark)}
.vantagem-sub{font-size:12px;color:var(--mid);margin-top:1px}

/* Categorias grid */
.cats-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.cat-card{background:var(--white);border-radius:var(--radius-lg);padding:20px 14px;text-align:center;border:2px solid transparent;transition:border-color .2s,transform .2s,box-shadow .2s;cursor:pointer}
.cat-card:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:var(--shadow-md)}
.cat-card-icon{width:50px;height:50px;background:var(--primary-xlight);border-radius:12px;display:flex;align-items:center;justify-content:center;margin:0 auto 10px;transition:background .2s}
.cat-card-icon svg{width:22px;height:22px;color:var(--primary);transition:color .2s}
.cat-card:hover .cat-card-icon{background:var(--primary)}
.cat-card:hover .cat-card-icon svg{color:#fff}
.cat-card-name{font-size:12px;font-weight:700;color:var(--dark);line-height:1.35}

/* 14. PRODUCT CARDS */
.products-grid{display:grid;grid-template-columns:repeat(var(--grid-cols,4),1fr);gap:16px}
.products-grid-5{--grid-cols:5}
.products-grid-3{--grid-cols:3}
.products-grid-2{--grid-cols:2}

.product-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--light-2);display:flex;flex-direction:column;transition:transform .22s,box-shadow .22s,border-color .22s;overflow:hidden}
.product-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--light-3)}
.product-card-img{position:relative;background:var(--light);aspect-ratio:var(--card-ratio,1/1);overflow:hidden}
.product-card-img img{width:100%;height:100%;object-fit:contain;padding:12px;transition:transform .35s ease}
.product-card:hover .product-card-img img{transform:scale(1.06)}
.product-card-badges{position:absolute;top:8px;left:8px;display:flex;flex-direction:column;gap:4px;z-index:2}
.product-card-body{padding:14px;flex:1;display:flex;flex-direction:column}
.product-card-cat{font-size:10.5px;color:var(--mid);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-weight:600}
.product-card-name{font-size:13px;font-weight:600;color:var(--dark);line-height:1.4;margin-bottom:10px;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.product-card-name:hover{color:var(--primary)}
.product-card-price{margin-bottom:12px}
.price-old{font-size:11px;color:var(--light-3);text-decoration:line-through;margin-bottom:2px}
.price-main{font-family:var(--font-head);font-size:22px;font-weight:700;color:var(--primary);line-height:1}
.price-unit{font-size:11px;color:var(--mid);margin-top:2px}
.price-consult{font-size:13px;color:var(--mid);font-weight:600;display:flex;align-items:center;gap:5px}
.price-consult svg{width:14px;height:14px}
.product-card-footer{display:flex;gap:6px}
.product-card-footer .btn{flex:1;font-size:12px;padding:9px 8px}
.product-card-footer .btn svg{width:14px;height:14px}

/* Modo lista */
.products-list .product-card{flex-direction:row;align-items:stretch}
.products-list .product-card-img{width:140px;flex-shrink:0;aspect-ratio:auto;border-radius:0}
.products-list .product-card-body{padding:16px 18px;flex-direction:row;align-items:center;gap:20px}
.products-list .product-card-name{font-size:14px;-webkit-line-clamp:3;margin-bottom:0}
.products-list .product-card-price{margin-bottom:0;white-space:nowrap}
.products-list .product-card-footer{flex-direction:column;width:160px;flex-shrink:0}

/* 15. BANNERS DUPLOS */
.banners-double{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:52px}
.banner-item{position:relative;border-radius:var(--radius-lg);overflow:hidden;min-height:170px;display:flex;align-items:center;background:var(--dark)}
.banner-item img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.55}
.banner-content{position:relative;z-index:2;padding:28px}
.banner-content h3{font-family:var(--font-head);font-size:clamp(20px,3vw,30px);font-weight:800;color:#fff;text-transform:uppercase;line-height:1.1}
.banner-content p{color:rgba(255,255,255,.75);font-size:13px;margin:8px 0 16px}

/* 16. PRODUTO SINGLE */
.product-single{display:grid;grid-template-columns:1fr 1fr;gap:48px;padding:36px 0;align-items:start}
.product-gallery{position:sticky;top:calc(var(--topbar-h) + var(--header-h) + var(--navbar-h) + 16px)}
.gallery-main{aspect-ratio:1;background:var(--white);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--light-2);display:flex;align-items:center;justify-content:center;margin-bottom:10px}
.gallery-main img{width:100%;height:100%;object-fit:contain;padding:24px}
.gallery-thumbs{display:flex;gap:8px;flex-wrap:wrap}
.gallery-thumb{width:66px;height:66px;background:var(--white);border:2px solid var(--light-2);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:border-color .2s}
.gallery-thumb.active,.gallery-thumb:hover{border-color:var(--primary)}
.gallery-thumb img{width:100%;height:100%;object-fit:contain;padding:5px}
.product-info h1{font-family:var(--font-head);font-size:clamp(24px,3vw,34px);font-weight:800;color:var(--dark);line-height:1.15;margin-bottom:10px}
.product-meta{display:flex;align-items:center;gap:10px;margin-bottom:20px;flex-wrap:wrap}
.product-sku{font-size:12px;color:var(--mid);background:var(--light);padding:3px 8px;border-radius:4px}
.product-price-box{background:var(--bg);border-radius:var(--radius-lg);padding:22px;margin-bottom:22px;border:1px solid var(--light-2)}
.product-price-consult{font-size:15px;color:var(--mid);font-style:italic}
.product-price-promo{font-size:13px;color:var(--light-3);text-decoration:line-through;margin-bottom:2px}
.product-price-main{font-family:var(--font-head);font-size:clamp(32px,4vw,44px);font-weight:800;color:var(--primary);line-height:1}
.product-price-unit{font-size:13px;color:var(--mid);margin-top:5px}
.product-qty{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.qty-control{display:flex;align-items:center;border:2px solid var(--light-2);border-radius:var(--radius);overflow:hidden}
.qty-btn{width:38px;height:40px;background:var(--light);border:none;font-size:20px;color:var(--dark);transition:background .2s,color .2s;line-height:1}
.qty-btn:hover{background:var(--primary);color:#fff}
.qty-input{width:54px;height:40px;border:none;text-align:center;font-size:16px;font-weight:700;color:var(--dark);background:var(--white)}
.product-actions{display:flex;flex-direction:column;gap:10px;margin-bottom:22px}
.product-actions .btn{padding:14px 20px;font-size:15px}
.tab-btn{padding:12px 20px;font-weight:700;font-size:14px;border:none;background:none;color:var(--mid);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s}
.tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}
.tab-btn:hover{color:var(--primary)}
.specs-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:8px}
.specs-table tr{border-bottom:1px solid var(--light)}
.specs-table tr:last-child{border-bottom:none}
.specs-table td{padding:9px 12px}
.specs-table td:first-child{color:var(--mid);font-weight:600;width:42%;background:var(--bg)}

/* 17. CARRINHO */
.cart-layout{display:grid;grid-template-columns:1fr 360px;gap:24px;padding:32px 0;align-items:start}
.cart-items{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--light-2);overflow:hidden}
.cart-items-header{padding:16px 20px;border-bottom:1px solid var(--light-2);display:flex;align-items:center;justify-content:space-between}
.cart-items-header h2{font-family:var(--font-head);font-size:22px;font-weight:800}
.cart-item{display:grid;grid-template-columns:84px 1fr auto;gap:16px;padding:18px 20px;border-bottom:1px solid var(--light);align-items:start;transition:background .15s}
.cart-item:last-child{border-bottom:none}
.cart-item:hover{background:var(--bg)}
.cart-item-img{display:block;width:84px;height:84px;flex-shrink:0;background:var(--light);border-radius:var(--radius);overflow:hidden}
.cart-item-img img{width:100%;height:100%;object-fit:contain;padding:8px}
.cart-item-name{font-size:14px;font-weight:600;color:var(--dark);margin-bottom:5px;line-height:1.35}
.cart-item-price{font-size:17px;font-weight:800;color:var(--primary);font-family:var(--font-head)}
.cart-item-remove{background:none;border:none;color:var(--light-3);transition:color .2s;padding:4px;border-radius:var(--radius);cursor:pointer}
.cart-item-remove:hover{color:var(--danger)}
.cart-item-remove svg{width:16px;height:16px}
.order-summary{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--light-2);padding:24px;position:sticky;top:calc(var(--topbar-h) + var(--header-h) + 16px)}
.order-summary h3{font-family:var(--font-head);font-size:22px;font-weight:800;margin-bottom:20px;color:var(--dark)}
.summary-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;font-size:14px;border-bottom:1px solid var(--light)}
.summary-row:last-of-type{border-bottom:none}
.summary-total{font-weight:800;font-size:22px;color:var(--primary);font-family:var(--font-head)}
.summary-total-label{font-weight:700;font-size:15px}

/* 18. CHECKOUT */
.checkout-layout{display:grid;grid-template-columns:1fr 390px;gap:24px;padding:32px 0;align-items:start}
.checkout-steps{display:flex;align-items:center;margin-bottom:28px}
.checkout-step{flex:1;display:flex;align-items:center;gap:8px}
.step-num{width:34px;height:34px;border-radius:50%;background:var(--light-2);color:var(--mid);font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .3s,color .3s}
.step-num.active{background:var(--primary);color:#fff}
.step-num.done{background:var(--success);color:#fff}
.step-label{font-size:12px;font-weight:600;color:var(--mid)}
.step-label.active{color:var(--primary)}
.step-line{flex:1;height:2px;background:var(--light-2);margin:0 6px}
.checkout-block{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--light-2);padding:24px;margin-bottom:14px}
.checkout-block h3{font-family:var(--font-head);font-size:20px;font-weight:700;margin-bottom:20px;display:flex;align-items:center;gap:10px;color:var(--dark)}
.payment-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.payment-opt{display:flex;align-items:center;gap:9px;padding:13px 12px;border:2px solid var(--light-2);border-radius:var(--radius);cursor:pointer;transition:border-color .2s,background .2s;font-size:13px;font-weight:600}
.payment-opt:hover{border-color:var(--primary);background:var(--primary-xlight)}
.payment-opt.selected{border-color:var(--primary);background:var(--primary-xlight)}
.payment-opt svg{width:18px;height:18px;color:var(--primary);flex-shrink:0}

/* 19. ÁREA CLIENTE */
.account-layout{display:grid;grid-template-columns:250px 1fr;gap:24px;padding:32px 0;align-items:start}
.account-sidebar{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--light-2);overflow:hidden;position:sticky;top:calc(var(--topbar-h) + var(--header-h) + var(--navbar-h) + 16px)}
.account-user{padding:22px;border-bottom:1px solid var(--light)}
.account-avatar{width:56px;height:56px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-head);font-size:24px;font-weight:800;color:#fff;margin-bottom:10px}
.account-name{font-weight:700;font-size:15px}
.account-email{font-size:12px;color:var(--mid);margin-top:2px}
.account-menu a,.account-nav a{display:flex;align-items:center;gap:10px;padding:13px 22px;font-size:14px;color:var(--dark-3);border-left:3px solid transparent;transition:all .15s}
.account-menu a:hover,.account-nav a:hover,
.account-menu a.active,.account-nav a.active{color:var(--primary);background:var(--primary-xlight);border-left-color:var(--primary)}
.account-menu a svg,.account-nav a svg{width:16px;height:16px;flex-shrink:0}
.account-content{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--light-2);padding:28px}

/* 20. TABELAS */
.orders-table,.admin-table{width:100%;border-collapse:collapse;font-size:13px}
.orders-table th,.admin-table th{padding:11px 16px;background:var(--bg);text-align:left;font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--mid)}
.orders-table td,.admin-table td{padding:13px 16px;border-bottom:1px solid var(--light);vertical-align:middle}
.orders-table tr:last-child td,.admin-table tr:last-child td{border-bottom:none}
.admin-table tr:hover td,.orders-table tr:hover td{background:var(--bg)}
.status-badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.4px}
.status-pendente{background:var(--warning-light);color:var(--warning)}
.status-confirmado{background:var(--info-light);color:var(--info)}
.status-em_separacao{background:#EDE9FE;color:#6D28D9}
.status-saiu_entrega{background:#CCFBF1;color:#0D9488}
.status-entregue{background:var(--success-light);color:var(--success)}
.status-cancelado{background:var(--danger-light);color:var(--danger)}

/* 21. PAGINAÇÃO */
.pagination{display:flex;gap:4px;justify-content:center;padding:24px 0;flex-wrap:wrap}
.page-btn{min-width:36px;height:36px;padding:0 8px;border:1.5px solid var(--light-2);border-radius:var(--radius);background:var(--white);color:var(--dark-3);font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:center;transition:border-color .2s,background .2s,color .2s;cursor:pointer}
.page-btn:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-xlight)}
.page-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}
.page-btn:disabled{opacity:.4;cursor:not-allowed}

/* 22. FILTROS */
.catalog-layout{display:grid;grid-template-columns:248px 1fr;gap:24px;padding:24px 0;align-items:start}
.filter-sidebar{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--light-2);overflow:hidden;position:sticky;top:calc(var(--topbar-h) + var(--header-h) + var(--navbar-h) + 12px)}
.filter-header{padding:14px 18px;border-bottom:1px solid var(--light-2);font-family:var(--font-head);font-size:17px;font-weight:700;display:flex;align-items:center;justify-content:space-between}
.filter-section{padding:15px 18px;border-bottom:1px solid var(--light)}
.filter-section:last-child{border-bottom:none}
.filter-section h4{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--mid);margin-bottom:12px}
.filter-check{display:flex;align-items:center;gap:9px;padding:5px 0;cursor:pointer;font-size:13px;color:var(--dark-3);line-height:1.3}
.filter-check input{width:15px;height:15px;accent-color:var(--primary);flex-shrink:0}
.filter-check:hover{color:var(--primary)}
.price-range{display:flex;align-items:center;gap:8px}
.price-range input{flex:1;min-width:0}
.catalog-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:12px;flex-wrap:wrap}
.result-count{font-size:13px;color:var(--mid)}
.toolbar-right{display:flex;align-items:center;gap:10px}
.sort-select{height:36px;padding:0 36px 0 12px;border:1.5px solid var(--light-2);border-radius:var(--radius);font-size:13px;background:var(--white);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}
.view-toggle{display:flex;gap:4px}
.view-toggle button{width:34px;height:34px;border:1.5px solid var(--light-2);background:var(--white);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;color:var(--mid);cursor:pointer;transition:background .15s,border-color .15s,color .15s}
.view-toggle button svg{width:15px;height:15px}
.view-toggle button.active{background:var(--primary);border-color:var(--primary);color:#fff}
.view-toggle button:hover:not(.active){background:var(--primary-xlight);border-color:var(--primary);color:var(--primary)}

/* 23. ADMIN */
.admin-body{background:#F1F4F8;font-family:var(--font-body);min-height:100vh}
.admin-sidebar{width:var(--sidebar-w);background:#111827;min-height:100vh;position:fixed;left:0;top:0;bottom:0;display:flex;flex-direction:column;z-index:100;transition:transform .3s cubic-bezier(.4,0,.2,1);overflow:hidden}
.admin-logo{padding:18px 20px;border-bottom:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:11px;flex-shrink:0}
.admin-logo .logo-nome{color:#fff;font-size:18px}
.admin-logo .logo-sub{color:#6B7280;font-size:9px}
.admin-logo .logo-icon{width:38px;height:38px;font-size:20px}
.admin-nav{flex:1;overflow-y:auto;padding:8px 0;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.1) transparent}
.admin-nav::-webkit-scrollbar{width:4px}
.admin-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}
.admin-nav-section{padding:14px 20px 5px;font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:1.2px;color:#4B5563}
.admin-nav a{display:flex;align-items:center;gap:10px;padding:10px 20px;color:#9CA3AF;font-size:13px;font-weight:500;transition:color .15s,background .15s;border-left:3px solid transparent}
.admin-nav a svg{width:16px;height:16px;flex-shrink:0}
.admin-nav a:hover{color:#fff;background:rgba(255,255,255,.05)}
.admin-nav a.active{color:#fff;background:rgba(var(--primary-rgb),.15);border-left-color:var(--primary)}
.admin-nav a .nav-badge{margin-left:auto;background:var(--primary);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px}
.admin-nav-footer{padding:14px 20px;border-top:1px solid rgba(255,255,255,.07);flex-shrink:0;display:flex;align-items:center;gap:10px}
.admin-nav-avatar{width:32px;height:32px;background:var(--primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0}
.admin-nav-info{flex:1;min-width:0}
.admin-nav-name{font-size:13px;font-weight:600;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.admin-nav-level{font-size:10px;color:#6B7280}
.admin-nav-logout{color:#6B7280;transition:color .2s;text-decoration:none}
.admin-nav-logout:hover{color:var(--danger)}
.admin-nav-logout svg{width:15px;height:15px}
.admin-main{margin-left:var(--sidebar-w);min-height:100vh;display:flex;flex-direction:column}
.admin-topbar{background:var(--white);padding:0 24px;height:56px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--light-2);position:sticky;top:0;z-index:50;box-shadow:var(--shadow-xs)}
.admin-topbar-left{display:flex;align-items:center;gap:12px}
.admin-topbar h1{font-family:var(--font-head);font-size:22px;font-weight:800;color:var(--dark)}
.admin-topbar-right{display:flex;align-items:center;gap:8px}
.admin-menu-btn{display:none;width:36px;height:36px;background:var(--light);border:none;border-radius:var(--radius);align-items:center;justify-content:center;color:var(--dark);cursor:pointer}
.admin-menu-btn svg{width:18px;height:18px}
.admin-content{padding:24px;flex:1;max-width:100%}

/* Admin stats */
.admin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.stat-card{background:var(--white);border-radius:var(--radius-lg);padding:20px;border:1px solid var(--light-2);display:flex;align-items:flex-start;gap:16px;transition:box-shadow .2s}
.stat-card:hover{box-shadow:var(--shadow-md)}
.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.stat-icon svg{width:22px;height:22px}
.stat-icon-orange{background:var(--primary-xlight);color:var(--primary)}
.stat-icon-blue{background:var(--info-light);color:var(--info)}
.stat-icon-green{background:var(--success-light);color:var(--success)}
.stat-icon-purple{background:#EDE9FE;color:#7C3AED}
.stat-value{font-family:var(--font-head);font-size:28px;font-weight:800;color:var(--dark);line-height:1}
.stat-label{font-size:12px;color:var(--mid);margin-top:3px}
.stat-sub{font-size:11px;margin-top:5px}
.admin-card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--light-2);overflow:hidden;margin-bottom:20px}
.admin-card-header{padding:15px 20px;border-bottom:1px solid var(--light-2);display:flex;align-items:center;justify-content:space-between;gap:10px}
.admin-card-header h3{font-family:var(--font-head);font-size:17px;font-weight:700;color:var(--dark)}
.admin-card-body{padding:20px}
.admin-prod-img{width:44px;height:44px;background:var(--light);border-radius:var(--radius);overflow:hidden;flex-shrink:0}
.admin-prod-img img{width:100%;height:100%;object-fit:contain;padding:3px}
.admin-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:99;backdrop-filter:blur(2px)}
.admin-overlay.open{display:block}

/* 24. FOOTER */
.footer{background:#0F172A;color:#94A3B8;margin-top:72px}
.footer-top{padding:52px 0}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.3fr;gap:44px}
.footer-about .footer-logo{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.footer-about .logo-icon{background:var(--primary)}
.footer-about .logo-nome{color:#fff}
.footer-about .logo-sub{color:#475569}
.footer-about p{font-size:13px;line-height:1.75;margin-bottom:18px}
.footer-social{display:flex;gap:8px}
.footer-social a{width:36px;height:36px;background:rgba(255,255,255,.06);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#94A3B8;transition:background .2s,color .2s}
.footer-social a:hover{background:var(--primary);color:#fff}
.footer-col h4{color:#fff;font-size:13px;font-weight:700;margin-bottom:18px;text-transform:uppercase;letter-spacing:.7px}
.footer-col ul li{margin-bottom:9px}
.footer-col ul li a{color:#94A3B8;font-size:13px;transition:color .2s}
.footer-col ul li a:hover{color:var(--primary-light)}
.footer-contact li{display:flex;align-items:flex-start;gap:10px;font-size:13px;margin-bottom:13px}
.footer-contact li svg{width:15px;height:15px;flex-shrink:0;margin-top:2px;color:var(--primary)}
.footer-contact a{color:#94A3B8}
.footer-contact a:hover{color:var(--primary-light)}
.footer-payments{margin-top:18px}
.footer-payments span{font-size:11px;color:#475569;display:block;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}
.payment-icons{display:flex;gap:6px;flex-wrap:wrap}
.payment-badge{background:rgba(255,255,255,.07);color:#94A3B8;font-size:10px;font-weight:700;padding:4px 9px;border-radius:5px;letter-spacing:.4px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding:18px 0}
.footer-bottom-inner{display:flex;justify-content:space-between;align-items:center;font-size:12px;gap:10px;flex-wrap:wrap}
.footer-bottom a{color:var(--primary-light)}
.whatsapp-float{position:fixed;bottom:24px;left:24px;width:56px;height:56px;background:#25D366;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.45);z-index:400;transition:transform .2s,box-shadow .2s}
.whatsapp-float:hover{transform:scale(1.1);box-shadow:0 6px 28px rgba(37,211,102,.55)}
.whatsapp-float svg{width:28px;height:28px}

/* 25. TOAST */
#toastContainer{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;max-width:340px;width:calc(100vw - 32px)}
.toast{background:#111827;color:#fff;padding:14px 18px;border-radius:var(--radius-lg);font-size:13px;font-weight:500;display:flex;align-items:center;gap:11px;box-shadow:var(--shadow-lg);animation:toastIn .3s ease;pointer-events:auto}
.toast.out{animation:toastOut .3s ease forwards}
.toast-success{border-left:4px solid var(--success)}
.toast-error{border-left:4px solid var(--danger)}
.toast-warning{border-left:4px solid var(--warning)}
@keyframes toastIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@keyframes toastOut{from{opacity:1}to{opacity:0;transform:translateY(8px)}}

/* 26. EMPTY STATES */
.empty-state{text-align:center;padding:60px 20px;color:var(--mid)}
.empty-state svg{width:56px;height:56px;margin:0 auto 16px;opacity:.3}
.empty-state h3{font-family:var(--font-head);font-size:22px;font-weight:700;color:var(--dark-3);margin-bottom:8px}
.empty-state p{font-size:14px;margin-bottom:20px}

/* 27. ANIMAÇÕES */
@keyframes spin{to{transform:rotate(360deg)}}
.spin{animation:spin .7s linear infinite;display:inline-block}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.fade-in{animation:fadeIn .3s ease forwards}

/* 28. RESPONSIVE 1100px */
@media(max-width:1100px){
  :root{--sidebar-w:240px}
  .products-grid{--grid-cols:3}
  .cats-grid{grid-template-columns:repeat(4,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .admin-stats{grid-template-columns:repeat(2,1fr)}
  .vantagens-grid{grid-template-columns:repeat(2,1fr)}
  .hdr-search{max-width:380px}
}

/* 29. RESPONSIVE 900px */
@media(max-width:900px){
  .product-single{grid-template-columns:1fr;gap:28px}
  .product-gallery{position:static}
  .cart-layout,.checkout-layout{grid-template-columns:1fr}
  .account-layout{grid-template-columns:1fr}
  .account-sidebar{position:static}
  .catalog-layout{grid-template-columns:1fr}
  .filter-sidebar{position:static}
  .topbar-left{display:none}
  .payment-grid{grid-template-columns:repeat(2,1fr)}
  .banners-double{gap:12px}
  /* Busca com espaço menor */
  .hdr-search{max-width:280px}
  /* Sugestões garantem largura mínima */
  .search-suggestions{min-width:260px}
}

/* 30. RESPONSIVE 768px — MOBILE */
@media(max-width:768px){
  /* ---- TOPBAR ---- */
  .topbar-left{display:none}
  .topbar-right .topbar-cadastro{display:none}

  /* ---- HEADER ---- */
  .hdr{height:56px;padding:0 14px;gap:8px}

  /* Busca desktop some; lupa aparece */
  .hdr-search{display:none}
  .hdr-search-toggle{display:flex}

  /* Orçamento: só ícone */
  .hdr-orc span{display:none}
  .hdr-orc{width:38px;padding:0;justify-content:center}

  /* Hamburger aparece */
  .hdr-burger{display:flex}

  /* Busca expandida fica visível quando .open */
  .hdr-search-expanded{display:block;display:none} /* reset; JS controla */
  .hdr-search-expanded.open{display:block}

  /* Sugestões no mobile: fullscreen quase */
  .search-suggestions{
    position:fixed;top:0;left:0;right:0;
    width:100%;max-width:100%;
    margin-top:0;border-radius:0;
    max-height:60vh;
    border-top:3px solid var(--primary);
    box-shadow:0 8px 32px rgba(0,0,0,.2);
  }

  /* ---- NAVBAR ---- */
  .navbar-cats,.navbar-promo{display:none}
  .navbar-all-cats{width:100%;justify-content:space-between;padding:0 16px}

  /* Mobile: dropdown vira bottom sheet */
  .cats-dropdown{
    top:auto !important;
    bottom:0;
    border-radius:18px 18px 0 0;
    max-height:72vh;
    box-shadow:0 -6px 40px rgba(0,0,0,.22);
    /* Animação via transform — visibility/opacity já controlam display */
    transform:translateY(20px);
    transition:opacity .28s ease, visibility .28s ease, transform .28s cubic-bezier(.4,0,.2,1);
  }
  .cats-dropdown.open{
    transform:translateY(0);
  }
  .cats-dropdown::before{
    content:'';display:block;
    width:36px;height:4px;background:var(--light-2);
    border-radius:2px;margin:10px auto 4px;
  }
  .cats-dropdown-grid{grid-template-columns:1fr 1fr;padding:8px 12px 28px;gap:4px}
  .cat-dropdown-item{padding:11px 10px;font-size:13px}

  /* ---- PRODUTOS / GRID ---- */
  .products-grid{--grid-cols:2;gap:12px}
  .products-grid-5{--grid-cols:2}
  .cats-grid{grid-template-columns:repeat(3,1fr);gap:10px}
  .cat-card{padding:14px 10px}

  /* ---- ADMIN ---- */
  .admin-sidebar{transform:translateX(-100%)}
  .admin-sidebar.open{transform:translateX(0)}
  .admin-main{margin-left:0}
  .admin-stats{grid-template-columns:1fr 1fr}
  .admin-menu-btn{display:flex}
  .admin-content{padding:16px}

  /* ---- FOOTER ---- */
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .footer-top{padding:36px 0}
  .footer-bottom-inner{flex-direction:column;text-align:center}

  /* ---- FORMS ---- */
  .form-row,.form-row-3{grid-template-columns:1fr}
  .payment-grid{grid-template-columns:repeat(2,1fr)}

  /* ---- MISC ---- */
  .hero-arrows{display:none}
  .banners-double{grid-template-columns:1fr}
  .vantagens-grid{grid-template-columns:1fr 1fr}
  .order-summary{position:static}

  /* iOS zoom fix */
  .form-control,select.form-control,textarea.form-control,
  .hdr-search input,.hdr-search-exp-inner input,
  .mob-search-inner input,.sort-select{font-size:16px!important}
}

/* 31. RESPONSIVE 480px */
@media(max-width:480px){
  .hdr{padding:0 12px;gap:6px}
  .logo-sub{display:none}
  .products-grid{--grid-cols:2;gap:10px}
  .product-card-footer{flex-direction:column}
  .cats-grid{grid-template-columns:repeat(2,1fr)}
  .admin-stats{grid-template-columns:1fr}
  .vantagens-grid{grid-template-columns:1fr}
  .checkout-steps .step-label{display:none}
  .payment-grid{grid-template-columns:1fr 1fr}
  .hero-content p{display:none}
  .banners-double .banner-content h3{font-size:20px}
  .cart-item{grid-template-columns:72px 1fr auto;gap:12px}
  .cart-item-img{width:72px;height:72px}
  .cats-dropdown-grid{grid-template-columns:1fr}
  .mob-cats-grid{grid-template-columns:1fr}
}

/* ══════════════════════════════════════════════════════
   32. RESPONSIVIDADE ESPECÍFICA POR PÁGINA
   Corrige grids inline e tabelas em todas as páginas
   ══════════════════════════════════════════════════════ */

/* ── Tabelas: wrapper overflow em todas ── */
.orders-table-wrap,
.table-scroll-wrap { overflow-x:auto; -webkit-overflow-scrolling:touch; border-radius: var(--radius-lg); }
.orders-table,.admin-table,.specs-table{min-width:480px}

/* ── Catálogo: filter sidebar toggle mobile ── */
.filter-toggle-btn{
  display:none;
  width:100%;padding:10px 16px;
  background:var(--white);border:1.5px solid var(--light-2);
  border-radius:var(--radius);font-size:14px;font-weight:600;
  color:var(--dark);cursor:pointer;
  align-items:center;justify-content:space-between;gap:8px;
  margin-bottom:12px;
}
.filter-toggle-btn svg{width:16px;height:16px;transition:transform .25s}
.filter-toggle-btn.open svg{transform:rotate(180deg)}

@media(max-width:768px){
  /* Catálogo */
  .filter-toggle-btn{display:flex}
  .filter-sidebar{
    border-radius:var(--radius-lg);
    border:1.5px solid var(--light-2);
    overflow:hidden;
    margin-bottom:16px;
  }
  .filter-sidebar-body{
    display:none;
  }
  .filter-sidebar.open .filter-sidebar-body{display:block}

  /* Checkout: grid colapsa */
  .checkout-layout{grid-template-columns:1fr}
  /* Resumo vai primeiro no mobile */
  .checkout-layout .order-summary{order:-1}

  /* Orçamento: grid colapsa */
  .orc-layout{grid-template-columns:1fr!important}
  .orc-sidebar{position:static!important}
  .orc-item-grid{grid-template-columns:1fr 70px 90px 36px!important}

  /* Minha conta: stats 2 cols */
  .account-stats{grid-template-columns:1fr 1fr!important}

  /* Produto: grid pagamento */
  .checkout-block [style*="grid-template-columns:repeat(3"]{
    grid-template-columns:1fr 1fr!important
  }

  /* Orçamento: linha de item colapsa */
  .orc-item-row{
    grid-template-columns:1fr 70px!important;
  }
  .orc-item-row .orc-remove-col{display:none}
  .orc-item-row-full{margin-top:6px}

  /* Tabelas com scroll */
  .orders-table-wrap,
  .account-content > div > table,
  .account-content table{
    display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;
  }

  /* Produto single: botões não quebram */
  .product-actions .btn{font-size:14px;padding:12px 16px}
}

@media(max-width:600px){
  /* Conta: stats empilha */
  .account-stats{grid-template-columns:1fr!important}

  /* Pagamento: 2 cols */
  .checkout-block [style*="grid-template-columns:repeat(3"]{
    grid-template-columns:1fr 1fr!important
  }

  /* Orçamento: item row full colapsa */
  .orc-item-grid{
    display:flex!important;flex-direction:column;gap:8px;
  }
}

/* ══ ADMIN RESPONSIVO ══════════════════════════════════ */
@media(max-width:768px){
  /* Admin: form grids colapsam */
  .admin-content .form-row{grid-template-columns:1fr!important}
  .admin-content .form-row-3{grid-template-columns:1fr!important}

  /* Admin: coluna principal + sidebar viram coluna única */
  .admin-content > form > div[style*="grid-template-columns:1fr 3"]{
    grid-template-columns:1fr!important;
  }
  .admin-content > div[style*="grid-template-columns:1fr 3"]{
    grid-template-columns:1fr!important;
  }

  /* Admin aparência: preview sidebar vai pra baixo */
  #aparenciaForm > div{grid-template-columns:1fr!important}
  #aparenciaForm > div > div:last-child{position:static!important}

  /* Admin produtos sidebar vai pra baixo */
  #prodForm > div{grid-template-columns:1fr!important}

  /* Admin stats */
  .admin-stats{grid-template-columns:1fr 1fr}

  /* Admin tabelas com scroll */
  .admin-card .admin-table,
  .admin-card table{min-width:600px}
  .admin-card > div[style*="overflow"]{overflow-x:auto;-webkit-overflow-scrolling:touch}

  /* Admin topbar */
  .admin-topbar h1{font-size:17px}
  .admin-content{padding:14px 12px}

  /* Admin aparencia: paletas wrap */
  .admin-card-body > div[style*="flex;flex-wrap"]{flex-wrap:wrap}

  /* Admin: dimensões 2 cols */
  .form-row[style*="grid-template-columns:1fr 1fr 1fr 1fr"]{
    grid-template-columns:1fr 1fr!important
  }
}

@media(max-width:480px){
  .admin-stats{grid-template-columns:1fr}
  .admin-topbar{padding:0 12px}
  .admin-topbar h1{font-size:15px}
}

/* ══ WISHLIST ══════════════════════════════════════════════ */
.wish-btn{
  position:absolute;top:8px;right:8px;
  width:32px;height:32px;border-radius:50%;
  background:rgba(255,255,255,.92);border:none;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;z-index:3;
  transition:background .2s,transform .2s;
  box-shadow:0 1px 4px rgba(0,0,0,.15);
}
.wish-btn:hover{background:#fff;transform:scale(1.15)}
.wish-btn svg{color:#CBD5E1;transition:color .2s,fill .2s;width:18px;height:18px}
.wish-btn:hover svg,.wish-btn.wish-active svg{color:#EF4444;fill:#EF4444}
.wish-btn-prod{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 20px;border:2px solid var(--light-2);
  border-radius:var(--radius);background:var(--white);
  cursor:pointer;font-size:14px;font-weight:600;
  transition:.2s;
}
.wish-btn-prod:hover,.wish-btn-prod.wish-active{border-color:#EF4444;color:#EF4444}
.wish-btn-prod svg{width:18px;height:18px;color:inherit;transition:.2s}
.wish-btn-prod.wish-active svg{fill:#EF4444}

/* ══ ESTRELAS ══════════════════════════════════════════════ */
.product-card-stars{display:flex;align-items:center;gap:2px;margin-bottom:6px}

/* ══ RASTREAMENTO DE PEDIDO (TIMELINE) ══════════════════════ */
.order-timeline{
  display:flex;align-items:flex-start;
  gap:0;margin-top:4px;
  overflow-x:auto;-webkit-overflow-scrolling:touch;
  scrollbar-width:none;padding-bottom:4px;
}
.order-timeline::-webkit-scrollbar{display:none}
.ot-step{
  display:flex;flex-direction:column;align-items:center;
  position:relative;flex:1;min-width:70px;
}
.ot-icon{
  width:32px;height:32px;border-radius:50%;
  background:var(--light-2);color:var(--mid);
  display:flex;align-items:center;justify-content:center;
  z-index:2;position:relative;flex-shrink:0;
  transition:.3s;border:2px solid transparent;
}
.ot-icon svg{width:14px;height:14px}
.ot-step.done .ot-icon{background:var(--success-light);color:var(--success)}
.ot-step.active .ot-icon{background:var(--primary);color:#fff;border-color:var(--primary-light);
  box-shadow:0 0 0 3px rgba(var(--primary-rgb),.2)}
.ot-label{
  font-size:10.5px;font-weight:600;color:var(--mid);
  text-align:center;margin-top:6px;line-height:1.3;white-space:nowrap;
}
.ot-step.done .ot-label{color:var(--success)}
.ot-step.active .ot-label{color:var(--primary)}
.ot-line{
  position:absolute;top:15px;left:calc(50% + 16px);
  width:calc(100% - 32px);height:2px;
  background:var(--light-2);z-index:1;transition:.3s;
}
.ot-step.done .ot-line{background:var(--success)}

/* ══ COMPARADOR ════════════════════════════════════════════ */
.compare-bar{
  position:fixed;bottom:0;left:0;right:0;
  background:#111827;color:#fff;
  transform:translateY(100%);
  transition:transform .3s cubic-bezier(.4,0,.2,1);
  z-index:600;border-top:3px solid var(--primary);
}
.compare-bar.open{transform:translateY(0)}
.compare-bar-inner{
  display:flex;align-items:center;gap:16px;
  padding:12px 20px;max-width:var(--container,1260px);
  margin:0 auto;flex-wrap:wrap;
}
.compare-item{
  display:flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.1);border-radius:var(--radius);
  padding:6px 12px;font-size:13px;font-weight:600;
}
.compare-item button{
  background:none;border:none;color:rgba(255,255,255,.6);
  cursor:pointer;line-height:1;padding:0;margin-left:4px;
  font-size:14px;
}
.compare-item button:hover{color:#fff}
.btn-compare{
  width:32px;height:32px;border-radius:var(--radius);
  background:var(--light);border:1.5px solid var(--light-2);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:.2s;flex-shrink:0;color:var(--mid);
}
.btn-compare:hover,.btn-compare.active{
  background:var(--info-light);border-color:var(--info);color:var(--info);
}
.btn-compare svg{width:14px;height:14px;color:inherit}

/* ══ BADGE PREÇO BAIXOU ════════════════════════════════════ */
.badge-preco-baixou{
  background:#DCFCE7;color:#166534;
  font-size:10px;font-weight:700;
  padding:2px 7px;border-radius:10px;
  display:inline-flex;align-items:center;gap:3px;
}

/* ══ PONTOS FIDELIDADE ══════════════════════════════════════ */
.pontos-badge{
  display:inline-flex;align-items:center;gap:5px;
  background:linear-gradient(135deg,var(--primary),var(--primary-dark));
  color:#fff;padding:4px 12px;border-radius:20px;
  font-size:12px;font-weight:700;
}
.pontos-badge svg{width:14px;height:14px}

/* ══ RESPONSIVE FEATURES ════════════════════════════════════ */
@media(max-width:768px){
  .order-timeline{gap:0}
  .ot-label{font-size:9px}
  .ot-icon{width:26px;height:26px}
  .compare-bar-inner{padding:10px 14px;gap:10px}
}

/* ══ PRINT ════════════════════════════════════════════ */
@media print{
  .topbar,.header,.navbar,.footer,.whatsapp-float,
  #toastContainer,.admin-sidebar,.admin-topbar{display:none!important}
  body{background:#fff;overflow-x:visible}
  .container{max-width:100%;padding:0}
}
