/* ================================================================
   Mais Pilar do Sul — v9 MODELO
   Fiel ao design de referência: lavanda, branco, pill buttons,
   sidebar branca com marcador lateral, zero sombras
   ================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

/* ── RESET ─────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Plus Jakarta Sans',system-ui,sans-serif;font-size:14px;line-height:1.6;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
h1,h2,h3,h4,h5,h6{font-family:inherit;line-height:1.1;font-weight:700;color:var(--text)}
button,input,select,textarea{font-family:inherit}

/* ── TOKENS FALLBACK ────────────────────────────────────────────── */
:root{
  --primary:#7C3AED; --primary-rgb:124,58,237;
  --primary-light:#EDE9FF; --primary-ultra:#F5F3FF;
  --accent:#7C3AED; --accent-rgb:124,58,237; --accent-light:#EDE9FF;
  --icon-color:#7C3AED;
  --bg:#EEEEF6; --bg-2:#EEEEF6; --card:#fff; --surface:#EEEEF6;
  --text:#1A1A2E; --text-2:#1A1A2E; --text-muted:#6B6B8A; --text-sub:#6B6B8A;
  --text-faint:rgba(124,58,237,.35); --text-mute:rgba(124,58,237,.35);
  --border:#E2E2EF; --border-hover:rgba(124,58,237,.3);
  --plight:#EDE9FF; --plighter:#F5F3FF;
  --r-xs:4px; --r-sm:12px; --r:16px; --r-md:16px;
  --r-lg:24px; --r-xl:32px; --r-2xl:40px; --r-full:9999px;
  --shadow-xs:none;--shadow-sm:none;--shadow:none;--shadow-md:none;--shadow-lg:none;--shadow-xl:none;
  --sh:none;--sh-sm:none;--sh-card:none;--sh-lg:none;--sh-xl:none;--sh-xs:none;
  --green:#22c55e; --red:#ef4444;
  --green-light:rgba(34,197,94,.12); --red-light:rgba(239,68,68,.12);
  --ease:cubic-bezier(.4,0,.2,1);
  --gf:var(--primary);--gm:var(--primary);--gt:var(--primary);
  --grad:var(--primary);--grad-btn:var(--primary);
  --ac:var(--primary);--ac-light:var(--primary-light);
  --ac-lighter:var(--primary-ultra);--ac-grad:var(--primary);
}

/* ── SVG ICONS ─────────────────────────────────────────────────── */
.ico{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.ico svg,svg.ico{color:var(--icon-color);display:block}
/* nunca cor nos ícones — apenas herdam var(--icon-color) */

/* ── UTILITIES ──────────────────────────────────────────────────── */
.ac{color:var(--primary)}.bl{color:var(--primary)}

/* ================================================================
   BUTTONS — pill, sem sombra, sem gradiente
   ================================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:10px 22px;border-radius:var(--r-full);
  font-weight:600;font-size:13.5px;cursor:pointer;
  border:1.5px solid transparent;
  transition:background .15s,border-color .15s,opacity .15s;
  white-space:nowrap;text-decoration:none;font-family:inherit;
  line-height:1.2;box-shadow:none!important;
}
.btn:active{opacity:.85;transition-duration:.07s}
.btn svg{flex-shrink:0;color:inherit}

.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn-primary:hover{background:rgba(var(--primary-rgb),.88)}

.btn-accent{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:700}
.btn-accent:hover{background:rgba(var(--primary-rgb),.88)}

.btn-outline{background:transparent;color:var(--primary);border-color:var(--primary)}
.btn-outline:hover{background:var(--primary-light)}

.btn-outline-white{background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.38)}
.btn-outline-white:hover{background:rgba(255,255,255,.24)}

.btn-ghost{background:transparent;color:var(--text-muted);border-color:transparent;padding:9px 16px}
.btn-ghost:hover{color:var(--primary);background:var(--primary-light)}

.btn-white{background:#fff;color:var(--primary);border-color:var(--border)}
.btn-white:hover{background:var(--primary-light);border-color:var(--primary)}

.btn-sm{padding:7px 16px;font-size:12.5px;border-radius:var(--r-full);gap:5px}
.btn-lg{padding:13px 30px;font-size:15px;border-radius:var(--r-full);gap:8px}
.btn-full{width:100%;justify-content:center}
.btn-icon{width:36px;height:36px;padding:0;border-radius:var(--r-full);background:var(--primary-light);color:var(--icon-color);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s;flex-shrink:0;box-shadow:none}
.btn-icon:hover{background:var(--primary);color:#fff}
.btn-icon svg{color:inherit}
.btn-whatsapp{background:#22c55e!important;color:#fff!important;border-color:#22c55e!important}
.btn-whatsapp:hover{background:#16a34a!important}

/* ================================================================
   NAVBAR — branca como no MODELO
   ================================================================ */
.navbar{position:sticky;top:0;z-index:200;background:var(--card);border-bottom:1.5px solid var(--border)}
/* manter compatibilidade com classes antigas */
.navbar-gradient,.navbar-solid,.navbar-glass{background:var(--card);border-bottom:1.5px solid var(--border)}
.nav-inner{max-width:1280px;margin:0 auto;padding:0 24px;display:flex;align-items:center;height:58px;gap:8px}
.nav-logo-wrap{flex-shrink:0;display:flex;align-items:center;text-decoration:none;gap:8px}
.brand-name{font-weight:800;font-size:14.5px;color:var(--text);letter-spacing:-.02em}
.brand-name em{color:var(--primary);font-style:normal}
.brand-city{font-size:9px;font-weight:600;color:var(--text-muted);letter-spacing:2px;text-transform:uppercase}
.nav-links{display:flex;gap:1px;list-style:none;flex:1;padding:0 14px;justify-content:center}
.nav-links a{padding:7px 13px;border-radius:var(--r-full);font-size:13px;font-weight:500;color:var(--text-muted);transition:all .14s;white-space:nowrap;display:flex;align-items:center;gap:5px}
.nav-links a:hover{color:var(--primary);background:var(--primary-light)}
.nav-links a.active{color:var(--primary);font-weight:700;background:var(--primary-light)}
.nav-actions{display:flex;gap:7px;align-items:center;margin-left:auto;flex-shrink:0}
.hamburger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:8px;border-radius:var(--r-full);margin-left:auto}
.hamburger span{display:block;width:20px;height:1.5px;background:var(--text);border-radius:2px;transition:all .18s}
.hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.mobile-menu{display:none;position:fixed;top:58px;inset-inline:0;z-index:199;background:var(--card);border-bottom:1.5px solid var(--border);padding:10px 14px 22px;flex-direction:column;gap:2px}
.mobile-menu.open{display:flex}
.mobile-menu a{padding:11px 14px;border-radius:var(--r-full);font-weight:500;color:var(--text-2);transition:all .12s;display:flex;align-items:center;gap:9px;font-size:13.5px}
.mobile-menu a:hover{background:var(--primary-light);color:var(--primary)}
.mobile-menu .m-divider{height:1px;background:var(--border);margin:7px 0}

/* ================================================================
   HERO — cor primária sólida
   ================================================================ */
.hero{position:relative;overflow:hidden;background:var(--primary);padding:80px 28px 96px}
.hero::after{content:'';position:absolute;inset:0;z-index:0;background-image:radial-gradient(circle,rgba(255,255,255,.05) 1px,transparent 1px);background-size:28px 28px;pointer-events:none}
.hero-accent-bar{position:absolute;top:0;left:0;right:0;height:3px;background:rgba(255,255,255,.22);z-index:3}
.hero-blob-r,.hero-blob-l,.hero-wave,.hero-shape,.hero-deco{display:none}
.hero-inner{max-width:600px;margin:0 auto;text-align:center;position:relative;z-index:3}
.hero-pill{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);padding:4px 14px 4px 8px;border-radius:var(--r-full);font-size:10.5px;font-weight:600;color:rgba(255,255,255,.85);letter-spacing:1px;text-transform:uppercase;margin-bottom:22px}
.hero-pill-dot{width:18px;height:18px;border-radius:50%;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.hero-pill-dot svg{color:rgba(255,255,255,.9)}
.hero h1{font-size:clamp(1.9rem,4.8vw,3.2rem);color:#fff;margin-bottom:13px;font-weight:800;line-height:1.05;letter-spacing:-.04em}
.hero h1 .ac-word{color:rgba(255,255,255,.68)}
.hero-desc{font-size:15px;color:rgba(255,255,255,.5);max-width:400px;margin:0 auto 32px;line-height:1.8}
.hero-cta{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.hero-stats{display:flex;justify-content:center;margin-top:52px;padding-top:26px;border-top:1px solid rgba(255,255,255,.1)}
.hero-stat{flex:1;max-width:145px;text-align:center;padding:0 14px}
.hero-stat+.hero-stat{border-left:1px solid rgba(255,255,255,.1)}
.stat-num{font-size:1.9rem;font-weight:800;color:#fff;line-height:1;margin-bottom:4px;letter-spacing:-.05em}
.stat-num span{color:rgba(255,255,255,.55)}
.stat-label{font-size:9.5px;color:rgba(255,255,255,.32);font-weight:600;letter-spacing:.8px;text-transform:uppercase}

/* ================================================================
   SECTIONS
   ================================================================ */
.section,.section-bg,.section-alt{padding:68px 28px}
.section-inner{max-width:1280px;margin:0 auto}
.section-bg,.section-alt{background:var(--card)}
.section-hd{margin-bottom:38px}
.section-hd.centered{text-align:center}
.section-hd.spread{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:12px}
.eyebrow{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--primary);margin-bottom:9px}
.section-title{font-size:clamp(1.55rem,2.6vw,2rem);font-weight:800;color:var(--text);line-height:1.08;letter-spacing:-.035em}
.section-title .ac,.section-title .bl{color:var(--primary)}
.section-sub{color:var(--text-muted);margin-top:7px;font-size:13.5px;line-height:1.75}

/* ================================================================
   CARDS BASE
   ================================================================ */
.card{background:var(--card);border-radius:var(--r-lg);border:1.5px solid var(--border);transition:border-color .15s}
.card:hover{border-color:var(--border-hover)}

/* ================================================================
   CATEGORY GRID — sem caixinhas coloridas
   ================================================================ */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(86px,1fr));gap:10px}
.cat-card{background:var(--card);border-radius:var(--r-lg);padding:18px 7px 14px;text-align:center;border:1.5px solid var(--border);transition:all .16s var(--ease);text-decoration:none;display:flex;flex-direction:column;align-items:center;gap:9px;cursor:pointer}
.cat-card:hover{border-color:var(--primary);background:var(--primary-light)}
.cat-icon-wrap{width:44px;height:44px;border-radius:var(--r-md);background:var(--primary-light);display:flex;align-items:center;justify-content:center;transition:background .16s;flex-shrink:0}
.cat-icon-wrap svg{color:var(--icon-color)}
.cat-card:hover .cat-icon-wrap{background:rgba(var(--primary-rgb),.18)}
.cat-icon{font-size:24px;line-height:1;transition:transform .18s}
.cat-card:hover .cat-icon{transform:scale(1.1)}
.cat-name{font-size:10.5px;font-weight:600;color:var(--text-muted);line-height:1.2;transition:color .16s}
.cat-card:hover .cat-name{color:var(--primary)}

/* ================================================================
   OFFER CARDS
   ================================================================ */
.offers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(236px,1fr));gap:13px}
.offer-card{background:var(--card);border-radius:var(--r-lg);overflow:hidden;border:1.5px solid var(--border);transition:border-color .15s;cursor:pointer;display:block;text-decoration:none}
.offer-card:hover{border-color:var(--border-hover)}
.offer-thumb{height:128px;position:relative;background:var(--bg);display:flex;align-items:center;justify-content:center;overflow:hidden}
.offer-thumb-icon{width:60px;height:60px;border-radius:var(--r-md);background:var(--card);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center}
.offer-thumb-icon svg{color:var(--icon-color)}
.offer-thumb-emoji{font-size:46px;line-height:1}
.offer-badge{position:absolute;top:10px;left:10px;z-index:1;background:var(--primary);color:#fff;padding:3px 10px;border-radius:var(--r-full);font-size:10px;font-weight:700}
.offer-body{padding:13px 15px 17px}
.offer-store{font-size:9.5px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--text-faint);margin-bottom:3px}
.offer-title{font-size:13.5px;font-weight:700;color:var(--text);margin-bottom:10px;line-height:1.3}
.offer-price{display:flex;align-items:baseline;gap:7px}
.price-now{font-size:1.3rem;font-weight:800;color:var(--primary);line-height:1;letter-spacing:-.04em}
.price-was{font-size:12px;color:var(--text-faint);text-decoration:line-through}
.offer-valid{font-size:11px;color:var(--text-faint);margin-top:7px;display:flex;align-items:center;gap:4px}
.offer-valid svg{color:var(--icon-color)}
.expiry-badge{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;font-weight:700;padding:3px 9px;border-radius:var(--r-full);margin-top:7px}
.expiry-badge.urgent{background:var(--red-light);color:#b91c1c}
.expiry-badge.soon{background:rgba(245,158,11,.1);color:#92400e}
.expiry-badge svg{color:inherit}

/* ================================================================
   STORE CARDS
   ================================================================ */
.stores-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:11px}
.store-card{background:var(--card);border-radius:var(--r-lg);padding:15px;display:flex;gap:12px;align-items:center;border:1.5px solid var(--border);transition:border-color .15s;text-decoration:none;cursor:pointer}
.store-card:hover{border-color:var(--border-hover)}
.store-avatar{width:46px;height:46px;border-radius:var(--r-md);background:var(--primary-light);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:21px;border:1.5px solid var(--border)}
.store-card-body{flex:1;min-width:0}
.store-name{font-weight:700;font-size:13.5px;color:var(--text);margin-bottom:1px}
.store-cat{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-faint);margin-bottom:5px}
.store-rating{font-size:12px;font-weight:700;color:var(--primary);display:flex;align-items:center;gap:4px}
.store-rating svg{color:var(--icon-color)}
.store-rating span{color:var(--text-muted);font-weight:400;font-size:11px}
.store-phone{font-size:11.5px;color:var(--text-muted);margin-top:3px;display:flex;align-items:center;gap:4px}
.store-phone svg{color:var(--icon-color)}
.store-card-arr{color:var(--text-faint);flex-shrink:0;display:flex;align-items:center;margin-left:auto}
.store-card-arr svg{color:var(--text-faint)}

/* ================================================================
   BADGES & STATUS
   ================================================================ */
.open-badge{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;font-weight:600;padding:3px 9px;border-radius:var(--r-full)}
.open-badge.open{background:var(--green-light);color:#15803d}
.open-badge.closing{background:rgba(245,158,11,.1);color:#92400e}
.open-badge.closed{background:var(--primary-ultra);color:var(--text-muted)}
.open-badge-dot{width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0;animation:pulse-dot 2s infinite}
@keyframes pulse-dot{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.6)}}
.open-dot-live{width:6px;height:6px;border-radius:50%;background:var(--green);display:inline-block;animation:pulse-dot 2s infinite}
.badge{padding:3px 10px;border-radius:var(--r-full);font-size:10.5px;font-weight:600;display:inline-block;line-height:1.5}
.badge-active{background:var(--green-light);color:#15803d}
.badge-pending{background:rgba(245,158,11,.1);color:#92400e}
.badge-inactive{background:var(--primary-ultra);color:var(--text-muted)}
.badge-blue{background:var(--primary-light);color:var(--primary)}
.badge-yellow{background:rgba(245,158,11,.1);color:#92400e}

/* ================================================================
   ALERTS
   ================================================================ */
.alert{padding:11px 15px;border-radius:var(--r-md);font-size:13px;font-weight:500;margin-bottom:14px;border:1.5px solid;display:flex;align-items:flex-start;gap:8px}
.alert svg{color:inherit;flex-shrink:0;margin-top:1px}
.alert-error{background:var(--red-light);color:#b91c1c;border-color:rgba(239,68,68,.2)}
.alert-success,.alert-ok{background:var(--green-light);color:#15803d;border-color:rgba(34,197,94,.2)}
.alert-warn{background:rgba(245,158,11,.08);color:#92400e;border-color:rgba(245,158,11,.2)}
.alert-info{background:var(--primary-light);color:var(--primary);border-color:rgba(var(--primary-rgb),.18)}

/* ================================================================
   FORMS
   ================================================================ */
.form-group{margin-bottom:15px}
.form-group label{display:block;font-size:11px;font-weight:700;color:var(--text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}
.form-group input:not([type=color]):not([type=range]),
.form-group textarea,
.form-group select{width:100%;padding:10px 13px;border:1.5px solid var(--border);border-radius:var(--r-md);font-family:inherit;font-size:13.5px;color:var(--text);background:var(--bg);outline:none;transition:border-color .14s,background .14s;-webkit-appearance:none;appearance:none}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus{border-color:var(--primary);background:var(--card)}
.form-group textarea{min-height:105px;resize:vertical}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-hint{font-size:11px;color:var(--text-muted);margin-top:4px}
.form-card{background:var(--card);border-radius:var(--r-lg);border:1.5px solid var(--border);overflow:hidden}
.form-card-hd{padding:14px 20px;border-bottom:1px solid var(--border);background:var(--bg);display:flex;align-items:center;gap:10px}
.form-card-hd svg{color:var(--icon-color)}
.form-card-title{font-size:.86rem;font-weight:700;color:var(--text)}
.form-card-sub{font-size:11px;color:var(--text-muted)}
.form-card .form-group{padding:0 20px}
.form-card .form-group:first-of-type{margin-top:18px}
.form-card .form-row{padding:0 20px;gap:12px}
.form-card .form-row .form-group{padding:0}
.form-card .btn-full{margin:0 20px 20px;width:calc(100% - 40px)}
.form-type-row{display:flex;flex-wrap:wrap;gap:6px;padding:14px 20px 0}
.form-type-btn{padding:6px 13px;border:1.5px solid var(--border);border-radius:var(--r-full);font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;color:var(--text-muted);background:var(--bg);transition:all .12s}
.form-type-btn:hover{border-color:var(--primary);color:var(--primary)}
.form-type-btn.sel{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}

/* ================================================================
   LOGIN — sidebar primária + form branco
   ================================================================ */
.login-page{min-height:100vh;display:flex}
.login-left,.ll{flex:1;background:var(--primary);display:flex;flex-direction:column;justify-content:center;padding:52px 48px;position:relative;overflow:hidden}
.login-left::after{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.04) 1px,transparent 1px);background-size:28px 28px;pointer-events:none}
.ll-shape,.ll-shape-1,.ll-shape-2{position:absolute;border-radius:50%;pointer-events:none}
.ll-shape-1{width:300px;height:300px;background:rgba(255,255,255,.05);bottom:-90px;right:-70px}
.ll-shape-2{width:170px;height:170px;background:rgba(255,255,255,.04);top:-55px;left:-38px}
.ll-deco,.ll-deco span,.ll-accent{display:none}
.ll-content{position:relative;z-index:1}
.ll-logo{margin-bottom:32px}
.ll-logo img{height:35px;width:auto}
.ll-logo-fallback{display:flex;align-items:center;gap:8px}
.ll-logo-icon{width:36px;height:36px;border-radius:var(--r-md);background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;font-size:17px;color:#fff}
.ll-logo-name{font-size:15px;font-weight:800;color:#fff}
.ll-logo-city{font-size:10px;color:rgba(255,255,255,.35);margin-top:1px;font-weight:500}
.ll-headline{font-size:clamp(1.65rem,2.7vw,2.2rem);font-weight:800;color:#fff;line-height:1.07;margin-bottom:9px;letter-spacing:-.03em}
.ll-headline .ac{color:rgba(255,255,255,.65)}
.ll-sub{font-size:13px;color:rgba(255,255,255,.45);margin-bottom:28px;line-height:1.8;max-width:310px}
.ll-features{list-style:none;display:flex;flex-direction:column;gap:10px}
.ll-features li{display:flex;align-items:center;gap:9px;color:rgba(255,255,255,.55);font-size:13px;font-weight:500}
.ll-dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.45);flex-shrink:0}
.login-right,.lr{width:420px;background:var(--card);display:flex;flex-direction:column;justify-content:center;padding:44px 36px;overflow-y:auto;border-left:1.5px solid var(--border)}
.back-link{display:inline-flex;align-items:center;gap:5px;color:var(--text-muted);font-size:13px;font-weight:500;margin-bottom:26px;transition:color .12s}
.back-link svg{color:var(--icon-color)}
.back-link:hover{color:var(--primary)}
.login-tabs{display:flex;background:var(--bg);border-radius:var(--r-full);padding:4px;margin-bottom:22px;gap:3px}
.login-tab{flex:1;padding:9px;text-align:center;font-weight:600;font-size:12.5px;cursor:pointer;color:var(--text-muted);background:none;border:none;font-family:inherit;border-radius:var(--r-full);transition:all .15s}
.login-tab.active{background:var(--primary);color:#fff}
.login-form-title{font-size:1.45rem;font-weight:800;color:var(--text);margin-bottom:3px;letter-spacing:-.03em}
.login-form-sub{font-size:13px;color:var(--text-muted);margin-bottom:20px}
.utype-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:13px}
.utype-btn{padding:11px;border:1.5px solid var(--border);border-radius:var(--r-md);text-align:center;cursor:pointer;font-size:12.5px;font-weight:600;color:var(--text-muted);background:var(--bg);transition:all .13s}
.utype-btn:hover{border-color:var(--primary);color:var(--primary)}
.utype-btn.sel{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}
.utype-icon{font-size:17px;margin-bottom:3px;display:block}

/* ================================================================
   ADMIN SIDEBAR — branca, item ativo com marcador lateral
   ================================================================ */
.admin-wrap{display:flex;min-height:100vh;background:var(--bg)}
.admin-sidebar{width:236px;background:var(--card);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:300;transition:transform .22s var(--ease);overflow:hidden;border-right:1.5px solid var(--border)}
.sb-accent{display:none} /* não precisamos mais */
.admin-sidebar.hidden{transform:translateX(-100%)}
.sb-head{padding:16px 14px 14px;border-bottom:1.5px solid var(--border);display:flex;align-items:center;gap:8px;flex-shrink:0}
.sb-logo{display:flex;align-items:center;gap:8px;text-decoration:none}
.sb-logo-img{height:24px;width:auto}
.sb-logo-fallback{width:28px;height:28px;border-radius:var(--r-sm);background:var(--primary-light);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sb-logo-fallback svg{color:var(--icon-color)}
.sb-logo-text{font-size:12px;font-weight:800;color:var(--text);line-height:1.2}
.sb-logo-text small{font-size:10px;color:var(--text-muted);display:block;font-weight:500}
.sb-nav{flex:1;padding:10px 8px;overflow-y:auto}
.sb-section{padding:13px 10px 4px;font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--text-faint)}
.sb-item{display:flex;align-items:center;gap:9px;padding:9px 12px;cursor:pointer;color:var(--text-muted);font-size:13px;font-weight:500;border-radius:var(--r-md);text-decoration:none;margin-bottom:1px;transition:all .13s;position:relative}
.sb-item:hover{background:var(--primary-light);color:var(--primary)}
.sb-item.active{background:var(--primary-light);color:var(--primary);font-weight:600}
/* marcador lateral como no MODELO */
.sb-item.active::before{content:'';position:absolute;left:-8px;top:50%;transform:translateY(-50%);width:3px;height:18px;background:var(--primary);border-radius:0 3px 3px 0}
.sb-icon{width:16px;text-align:center;flex-shrink:0;display:flex;align-items:center}
.sb-icon svg{color:var(--text-muted);transition:color .13s}
.sb-item:hover .sb-icon svg,.sb-item.active .sb-icon svg{color:var(--icon-color)}
.sb-badge{margin-left:auto;background:var(--primary-light);color:var(--primary);font-size:10px;font-weight:700;padding:1px 8px;border-radius:var(--r-full)}
.sb-badge.alert{background:var(--red-light);color:#b91c1c}
.sb-foot{padding:10px 8px;border-top:1.5px solid var(--border);flex-shrink:0}
.sb-user{display:flex;align-items:center;gap:8px;margin-bottom:7px;padding:8px 12px;background:var(--bg);border-radius:var(--r-full)}
.sb-avatar{width:28px;height:28px;border-radius:50%;background:var(--primary-light);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:11px;color:var(--primary);flex-shrink:0}
.sb-uname{font-size:12px;font-weight:700;color:var(--text);line-height:1.2}
.sb-urole{font-size:10px;color:var(--text-muted)}
.sb-logout{width:100%;padding:9px 12px;background:var(--bg);border:1.5px solid var(--border);border-radius:var(--r-full);color:var(--text-muted);font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .13s;text-decoration:none;display:flex;align-items:center;justify-content:center;gap:7px}
.sb-logout svg{color:var(--icon-color)}
.sb-logout:hover{background:var(--primary-light);color:var(--primary);border-color:var(--primary)}

/* ================================================================
   ADMIN MAIN / TOPBAR
   ================================================================ */
.admin-main{margin-left:236px;flex:1;display:flex;flex-direction:column;min-height:100vh}
.admin-topbar{background:var(--card);border-bottom:1.5px solid var(--border);height:56px;padding:0 20px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}
.tb-left{display:flex;align-items:center;gap:9px}
.tb-toggle{background:none;border:none;cursor:pointer;padding:7px;border-radius:var(--r-full);color:var(--text-muted);display:none;transition:background .13s;line-height:1}
.tb-toggle:hover{background:var(--primary-light);color:var(--primary)}
.tb-title{font-size:.86rem;font-weight:700;color:var(--text)}
.tb-right{display:flex;gap:7px;align-items:center}
.tb-badge-wrap{position:relative}
.tb-notif{width:32px;height:32px;border-radius:var(--r-full);background:var(--bg);border:1.5px solid var(--border);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .13s}
.tb-notif:hover{background:var(--primary-light);border-color:var(--primary)}
.tb-notif svg{color:var(--icon-color)}
.tb-notif-dot{position:absolute;top:1px;right:1px;width:7px;height:7px;background:var(--primary);border-radius:50%;border:2px solid var(--card)}
.admin-content{padding:20px;flex:1}
.panel{display:none}.panel.active{display:block}

/* admin stat cards */
.stats-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(186px,1fr));gap:11px;margin-bottom:16px}
.stat-card{background:var(--card);border-radius:var(--r-lg);padding:17px 18px;display:flex;gap:12px;align-items:center;border:1.5px solid var(--border);transition:border-color .15s}
.stat-card:hover{border-color:var(--border-hover)}
.stat-icon{width:42px;height:42px;border-radius:var(--r-md);flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--primary-light)}
.stat-icon svg{color:var(--icon-color)}
.si-blue,.si-yellow,.si-green,.si-slate{background:var(--primary-light)}
.stat-val{font-size:1.65rem;font-weight:800;color:var(--text);line-height:1;letter-spacing:-.04em}
.stat-lbl{font-size:11px;color:var(--text-muted);font-weight:500;margin-top:2px}
.stat-delta{font-size:11px;font-weight:600;margin-top:3px}
.stat-delta.up{color:#15803d}.stat-delta.dn{color:#b91c1c}.stat-delta.warn{color:#92400e}

/* admin cards */
.acard{background:var(--card);border-radius:var(--r-lg);border:1.5px solid var(--border);overflow:hidden;margin-bottom:13px}
.acard-head{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;background:var(--bg)}
.acard-title{font-size:.84rem;font-weight:700;color:var(--text);display:flex;align-items:center;gap:6px}
.acard-title-dot{width:5px;height:5px;border-radius:50%;background:var(--primary)}
.acard-actions{display:flex;gap:5px;align-items:center;flex-wrap:wrap}
.acard-body{padding:18px}
.acard-accent::before{content:'';display:block;height:3px;background:var(--primary)}

/* admin table */
.admin-table{width:100%;border-collapse:collapse}
.admin-table th{padding:8px 13px;text-align:left;font-size:9.5px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.7px;background:var(--bg);border-bottom:1.5px solid var(--border)}
.admin-table td{padding:11px 13px;font-size:13px;border-bottom:1px solid var(--border);color:var(--text-2);vertical-align:middle}
.admin-table tr:last-child td{border-bottom:none}
.admin-table tbody tr:hover{background:var(--bg)}
.tbl-name{font-weight:700;color:var(--text)}
.tbl-sub{font-size:11px;color:var(--text-muted);margin-top:1px}
.tbl-actions{display:flex;gap:2px}
.action-btn{background:none;border:none;cursor:pointer;font-size:13px;padding:4px 9px;border-radius:var(--r-full);transition:background .12s;line-height:1;color:var(--text-muted)}
.action-btn:hover{background:var(--primary-light);color:var(--primary)}
.action-btn.danger:hover{background:var(--red-light);color:#b91c1c}
.admin-search{padding:7px 13px;border:1.5px solid var(--border);border-radius:var(--r-full);font-family:inherit;font-size:13px;outline:none;width:200px;transition:all .13s;background:var(--bg);color:var(--text)}
.admin-search:focus{border-color:var(--primary);background:var(--card)}
.mini-bars{display:flex;gap:4px;align-items:flex-end;height:58px;padding:0 2px}
.mini-bar{flex:1;border-radius:4px 4px 0 0;min-width:8px;background:var(--primary-light);transition:all .2s}
.mini-bar.bl{background:var(--primary)}.mini-bar.ac{background:var(--primary)}
.mini-bar:hover{filter:brightness(1.1)}
.mini-bar-labels{display:flex;gap:4px;margin-top:3px;padding:0 2px}
.mini-bar-labels span{flex:1;text-align:center;font-size:10px;color:var(--text-muted);font-weight:500}
.emoji-row{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:3px}
.emoji-opt{font-size:17px;cursor:pointer;padding:4px;border-radius:var(--r-sm);border:1.5px solid transparent;transition:all .12s}
.emoji-opt:hover,.emoji-opt.sel{border-color:var(--primary);background:var(--primary-light)}

/* ================================================================
   THEME EDITOR — admin cores
   ================================================================ */
.preset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(105px,1fr));gap:8px;margin-bottom:18px}
.preset-card{padding:10px 7px;border-radius:var(--r-md);border:1.5px solid var(--border);cursor:pointer;text-align:center;font-weight:600;font-size:11px;line-height:1.4;transition:all .13s;background:var(--card);color:var(--text)}
.preset-card:hover{border-color:var(--primary)}
.preset-card.active{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}
.preset-swatch{width:100%;height:5px;border-radius:3px;margin-bottom:5px}
.color-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.color-field label{font-size:9.5px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:5px}
.color-row{display:flex;gap:6px;align-items:center}
.color-row input[type=color]{width:36px;height:36px;border:1.5px solid var(--border);border-radius:var(--r-md);cursor:pointer;padding:3px;background:var(--card);flex-shrink:0}
.color-row input[type=text]{flex:1;padding:7px 10px;border:1.5px solid var(--border);border-radius:var(--r-sm);font-family:monospace;font-size:12px;font-weight:700;background:var(--bg);color:var(--text);outline:none;transition:border .13s}
.color-row input[type=text]:focus{border-color:var(--primary);background:var(--card)}
.radio-group{display:flex;gap:6px;flex-wrap:wrap}
.radio-pill{padding:6px 13px;border:1.5px solid var(--border);border-radius:var(--r-full);cursor:pointer;font-size:12px;font-weight:600;color:var(--text-muted);transition:all .13s;background:var(--bg)}
.radio-pill:hover{border-color:var(--primary);color:var(--primary)}
.radio-pill.sel{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}
.toggle-row{display:flex;align-items:center;gap:9px}
.toggle{position:relative;width:40px;height:21px}
.toggle input{display:none}
.t-sl{position:absolute;inset:0;border-radius:var(--r-full);background:var(--border);cursor:pointer;transition:all .17s}
.t-sl::before{content:'';position:absolute;left:3px;top:3px;width:15px;height:15px;border-radius:50%;background:#fff;transition:all .17s}
.toggle input:checked+.t-sl{background:var(--primary)}
.toggle input:checked+.t-sl::before{transform:translateX(19px)}
/* preview */
.preview-card{background:var(--primary);border-radius:var(--r-lg);padding:18px;text-align:center;color:#fff;position:relative;overflow:hidden;margin-bottom:10px}
.preview-ac-bar{position:absolute;top:0;left:0;right:0;height:2px;background:rgba(255,255,255,.22)}
.preview-btn{display:inline-block;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.25);color:#fff;padding:7px 16px;border-radius:var(--r-full);font-weight:600;font-size:12px;margin-top:9px}
.preview-card-mini{background:var(--card);border-radius:var(--r-md);padding:9px 12px;margin-top:9px;display:flex;align-items:center;gap:8px;border:1.5px solid var(--border)}
.preview-card-icon{width:28px;height:28px;border-radius:var(--r-sm);background:var(--primary-light);display:flex;align-items:center;justify-content:center;font-size:13px}
.preview-blob,.preview-blob-1,.preview-blob-2{display:none}
.logo-upload-area{border:1.5px dashed var(--border);border-radius:var(--r-md);padding:20px;text-align:center;background:var(--bg);cursor:pointer;transition:all .13s}
.logo-upload-area:hover{border-color:var(--primary);background:var(--primary-light)}
.logo-preview{max-height:42px;width:auto;margin:0 auto 7px;display:block}
.logo-size-grid,.logo-pos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.logo-size-btn,.logo-pos-btn{padding:7px 4px;border:1.5px solid var(--border);border-radius:var(--r-md);cursor:pointer;text-align:center;font-size:10.5px;font-weight:600;color:var(--text-muted);background:var(--bg);transition:all .13s}
.logo-size-btn:hover,.logo-pos-btn:hover{border-color:var(--primary);color:var(--primary)}
.logo-size-btn.sel,.logo-pos-btn.sel{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}

/* ================================================================
   MODALS
   ================================================================ */
.modal-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.22);backdrop-filter:blur(3px);z-index:500;align-items:center;justify-content:center;padding:16px}
.modal-backdrop.open{display:flex}
.modal{background:var(--card);border-radius:var(--r-xl);padding:0;width:min(500px,100%);max-height:90vh;overflow:hidden;border:1.5px solid var(--border);animation:modal-in .17s var(--ease);display:flex;flex-direction:column}
@keyframes modal-in{from{opacity:0;transform:scale(.94) translateY(14px)}to{opacity:1;transform:scale(1) translateY(0)}}
.modal-hd{padding:15px 20px;border-bottom:1px solid var(--border);background:var(--bg);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;position:relative}
.modal-hd::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--primary)}
.modal-title{font-size:.88rem;font-weight:700;color:var(--text)}
.modal-close{background:none;border:none;font-size:16px;cursor:pointer;color:var(--text-muted);line-height:1;border-radius:var(--r-full);padding:3px 6px;transition:all .12s}
.modal-close:hover{color:var(--text);background:var(--primary-light)}
.modal-body{padding:19px;overflow-y:auto;flex:1}
.modal-foot{padding:12px 20px;border-top:1px solid var(--border);background:var(--bg);display:flex;justify-content:flex-end;gap:7px;flex-shrink:0}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.18);z-index:299}
.sidebar-overlay.show{display:block}

/* ================================================================
   TOAST
   ================================================================ */
.toast{position:fixed;bottom:22px;right:22px;z-index:9999;background:var(--text);color:#fff;padding:11px 18px;border-radius:var(--r-full);font-size:13px;font-weight:600;transform:translateY(10px) scale(.95);opacity:0;transition:all .19s var(--ease);pointer-events:none;max-width:290px}
.toast.show{transform:translateY(0) scale(1);opacity:1}

/* ================================================================
   FOOTER — cor primária
   ================================================================ */
.site-footer{background:var(--primary);color:rgba(255,255,255,.42);padding:52px 28px 26px}
.footer-inner{max-width:1280px;margin:0 auto}
.footer-top{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:36px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.08)}
.footer-brand-logo{margin-bottom:12px}
.footer-brand-logo img{height:26px;width:auto;opacity:.5}
.footer-brand-logo-fallback{font-size:.95rem;font-weight:800;color:#fff;margin-bottom:12px;display:flex;align-items:center;gap:6px}
.footer-brand-logo-fallback em{color:rgba(255,255,255,.52);font-style:normal}
.footer-desc{font-size:12px;color:rgba(255,255,255,.22);line-height:1.85;margin-bottom:16px}
.social-row{display:flex;gap:6px}
.social-btn{width:28px;height:28px;border-radius:var(--r-full);background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.10);display:flex;align-items:center;justify-content:center;font-size:10.5px;font-weight:700;color:rgba(255,255,255,.28);transition:all .14s;cursor:pointer;text-decoration:none}
.social-btn:hover{background:rgba(255,255,255,.18);color:#fff}
.footer-col h5{font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.12);margin-bottom:13px}
.footer-col a,.footer-col span{display:block;font-size:12px;color:rgba(255,255,255,.26);margin-bottom:9px;transition:color .13s;cursor:pointer}
.footer-col a:hover{color:rgba(255,255,255,.7)}
.footer-bottom{padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:7px;font-size:11px;color:rgba(255,255,255,.1)}

/* ================================================================
   PAGE BANNERS
   ================================================================ */
.page-banner,.page-hero{background:var(--primary);padding:56px 28px 52px;position:relative;overflow:hidden;text-align:center}
.page-banner::after,.page-hero::after{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.04) 1px,transparent 1px);background-size:28px 28px;pointer-events:none;z-index:0}
.page-hero-wave,.page-hero-blob,.page-hero-shape,.page-hero-deco{display:none}
.page-banner-inner,.page-hero-inner{max-width:640px;margin:0 auto;position:relative;z-index:3}
.page-banner h1,.page-hero h1{font-size:clamp(1.65rem,3.3vw,2.3rem);font-weight:800;color:#fff;line-height:1.06;letter-spacing:-.035em;margin-bottom:10px}
.page-banner h1 .ac,.page-hero h1 .ac{color:rgba(255,255,255,.65)}
.page-banner p,.page-hero-sub{color:rgba(255,255,255,.45);font-size:14px;max-width:440px;line-height:1.78;margin:0 auto}
.page-banner .eyebrow,.page-hero .eyebrow{color:rgba(255,255,255,.65);margin-bottom:9px}
.search-bar,.banner-search{display:flex;align-items:center;background:rgba(255,255,255,.1);border:1.5px solid rgba(255,255,255,.2);border-radius:var(--r-full);overflow:hidden;width:100%}
.search-bar:focus-within,.banner-search:focus-within{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.38)}
.search-icon{display:none}
.search-input,.banner-search input{flex:1;border:none;outline:none;padding:11px 18px;font-size:13.5px;font-weight:500;color:#fff;background:transparent;font-family:inherit}
.search-input::placeholder,.banner-search input::placeholder{color:rgba(255,255,255,.36)}
.banner-search-btn{padding:9px 18px;background:rgba(255,255,255,.12);color:#fff;border:none;cursor:pointer;font-size:13px;font-weight:600;font-family:inherit;transition:background .13s;border-left:1px solid rgba(255,255,255,.1)}
.banner-search-btn:hover{background:rgba(255,255,255,.22)}

/* browse / lojas */
.browse-layout,.lojas-layout{display:grid;grid-template-columns:206px 1fr;gap:18px;align-items:start}
.browse-sidebar,.lojas-sidebar{position:sticky;top:74px}
.filter-panel,.filter-card{background:var(--card);border-radius:var(--r-lg);border:1.5px solid var(--border);overflow:hidden;margin-bottom:10px}
.filter-panel-head,.filter-title{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);padding:10px 13px 9px;border-bottom:1px solid var(--border);background:var(--bg)}
.filter-link,.filter-item{display:flex;align-items:center;gap:8px;padding:9px 13px;text-decoration:none;color:var(--text-2);font-size:13px;font-weight:500;transition:background .12s;border-bottom:1px solid var(--border)}
.filter-link:last-child,.filter-item:last-child{border-bottom:none}
.filter-link:hover,.filter-item:hover{background:var(--primary-light);color:var(--primary)}
.filter-link.active,.filter-item.active{background:var(--primary-light);color:var(--primary);font-weight:600}
.filter-count{margin-left:auto;background:var(--bg);border-radius:var(--r-full);padding:2px 8px;font-size:10.5px;font-weight:600;color:var(--text-muted)}
.filter-link.active .filter-count{background:var(--primary-ultra);color:var(--primary)}
.filter-cta,.sidebar-cta{background:var(--primary);border-radius:var(--r-lg);padding:17px;text-align:center;margin-bottom:10px;position:relative;overflow:hidden}
.sidebar-cta-title,.filter-cta-title{font-size:12.5px;font-weight:700;color:#fff;margin-bottom:4px}
.sidebar-cta-sub,.filter-cta-sub{font-size:11px;color:rgba(255,255,255,.45);margin-bottom:11px;line-height:1.6}
.browse-toolbar,.results-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:13px;flex-wrap:wrap;gap:8px;padding-bottom:12px;border-bottom:1.5px solid var(--border)}
.browse-count,.results-info{font-size:13px;font-weight:600;color:var(--text-2)}
.results-info strong{color:var(--primary)}
.browse-sort{padding:7px 12px;border:1.5px solid var(--border);border-radius:var(--r-full);font-size:12px;font-weight:500;outline:none;background:var(--card);color:var(--text);cursor:pointer;transition:border .13s}
.browse-sort:focus{border-color:var(--primary)}
.browse-empty,.empty-state{text-align:center;padding:64px 20px;background:var(--card);border-radius:var(--r-lg);border:1.5px solid var(--border)}
.empty-ico,.browse-empty-icon,.empty-state-icon{margin:0 auto 13px;opacity:.5;display:flex;justify-content:center}
.empty-ico svg{color:var(--icon-color)}
.empty-state-title,.browse-empty-title,.empty-title{font-size:15px;font-weight:700;color:var(--text);margin-bottom:5px}
.empty-state-sub,.browse-empty-sub,.empty-sub{font-size:13px;color:var(--text-muted);margin-bottom:17px;max-width:270px;margin-inline:auto;line-height:1.7}
.lojas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:13px}
.loja-card{background:var(--card);border-radius:var(--r-lg);overflow:hidden;border:1.5px solid var(--border);transition:border-color .15s;display:flex;flex-direction:column}
.loja-card:hover{border-color:var(--border-hover)}
.loja-card-hd{position:relative;overflow:hidden;padding:18px 15px 14px;display:flex;align-items:flex-end;justify-content:space-between;min-height:76px;background:var(--bg)}
.loja-card-hd-blob{display:none}
.loja-card-avatar{font-size:36px;line-height:1}
.loja-offer-badge{background:var(--primary);color:#fff;font-size:10.5px;font-weight:700;padding:3px 10px;border-radius:var(--r-full)}
.loja-card-body{padding:11px 15px 15px;flex:1;display:flex;flex-direction:column}
.loja-card-cat{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-faint);margin-bottom:2px}
.loja-card-name{font-size:.9rem;font-weight:700;color:var(--text);margin-bottom:5px;line-height:1.2}
.loja-card-desc{font-size:12px;color:var(--text-muted);margin-bottom:8px;line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.loja-rating{display:flex;align-items:center;gap:2px;margin-bottom:7px}
.star.full{color:var(--primary)}.star.half{color:var(--primary);opacity:.5}.star.empty{color:var(--border)}
.rating-num{font-size:12px;font-weight:700;color:var(--text-2);margin-left:4px}
.rating-count{font-size:11px;color:var(--text-muted)}
.loja-info-item{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-muted)}
.loja-info-item svg{color:var(--icon-color)}
.loja-actions{display:flex;gap:5px;flex-wrap:wrap;padding-top:9px;border-top:1px solid var(--border);margin-top:auto}
.loja-card-footer{padding:9px 13px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;background:var(--bg)}
.ofertas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(225px,1fr));gap:13px}
.oferta-card{background:var(--card);border-radius:var(--r-lg);overflow:hidden;border:1.5px solid var(--border);transition:border-color .15s;display:flex;flex-direction:column;text-decoration:none;display:block}
.oferta-card:hover{border-color:var(--border-hover)}
.oferta-card.expired{opacity:.4;pointer-events:none}
.oferta-thumb{background:var(--bg);height:112px;display:flex;align-items:center;justify-content:center;position:relative;border-bottom:1px solid var(--border)}
.oferta-icon{font-size:44px;display:block;line-height:1}
.oferta-badge{position:absolute;top:9px;right:9px;z-index:2;background:var(--primary);color:#fff;font-size:10px;font-weight:700;padding:3px 10px;border-radius:var(--r-full)}
.oferta-body{padding:11px 13px 14px;display:flex;flex-direction:column;flex:1}
.oferta-store-tag{display:inline-flex;align-items:center;gap:4px;font-size:9.5px;font-weight:700;color:var(--text-faint);margin-bottom:3px;text-transform:uppercase;letter-spacing:.4px}
.oferta-title{font-size:.86rem;font-weight:700;color:var(--text);margin-bottom:5px;line-height:1.3}
.oferta-price-now{font-size:1.25rem;font-weight:800;color:var(--primary);line-height:1;letter-spacing:-.04em}
.oferta-price-was{font-size:11px;color:var(--text-faint);text-decoration:line-through}
.oferta-saving{display:inline-flex;background:var(--green-light);color:#15803d;border-radius:var(--r-full);padding:2px 9px;font-size:11px;font-weight:600;margin-bottom:7px}
.oferta-valid{font-size:11px;font-weight:500;color:var(--text-muted)}
.oferta-valid.red{color:#b91c1c}
.oferta-actions{margin-top:auto;padding-top:9px;border-top:1px solid var(--border)}
.top-disc-item{display:flex;align-items:center;gap:7px;padding:8px 13px;border-bottom:1px solid var(--border)}
.top-disc-item:last-child{border-bottom:none}
.top-disc-pct{background:var(--primary-light);color:var(--primary);font-size:10.5px;font-weight:700;padding:2px 8px;border-radius:var(--r-full);flex-shrink:0}

/* CTA BANNER */
.cta-banner{background:var(--primary);padding:68px 28px;text-align:center;position:relative;overflow:hidden}
.cta-banner::after{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.04) 1px,transparent 1px);background-size:28px 28px;pointer-events:none}
.cta-banner-inner{position:relative;z-index:1;max-width:480px;margin:0 auto}
.cta-badge{margin:0 auto 16px;display:flex;justify-content:center}
.cta-badge svg{color:rgba(255,255,255,.7)}
.cta-banner h2{font-size:clamp(1.5rem,2.7vw,2rem);font-weight:800;color:#fff;margin-bottom:9px;letter-spacing:-.04em;line-height:1.06}
.cta-banner p{color:rgba(255,255,255,.45);font-size:14.5px;margin-bottom:24px;line-height:1.78}
.cta-banner-btns{display:flex;gap:9px;justify-content:center;flex-wrap:wrap}

/* STATS STRIP */
.stats-strip{background:var(--card);border-bottom:1.5px solid var(--border)}
.stats-strip-inner{max-width:1280px;margin:0 auto;display:flex;overflow-x:auto;scrollbar-width:none}
.stats-strip-inner::-webkit-scrollbar{display:none}
.sstat{padding:13px 22px;flex-shrink:0;border-right:1px solid var(--border);display:flex;flex-direction:column;justify-content:center}
.sstat:last-child{border-right:none}
.sstat-num{font-size:.97rem;font-weight:800;color:var(--primary);line-height:1;letter-spacing:-.03em}
.sstat-lbl{font-size:10px;color:var(--text-muted);font-weight:500;margin-top:2px}

/* ================================================================
   HOMEPAGE COMPONENTS
   ================================================================ */
/* hero search */
.hs-wrap{width:100%;max-width:520px;margin:26px auto 0;position:relative;z-index:10}
.hs-bar{display:flex;align-items:center;background:rgba(255,255,255,.12);border:1.5px solid rgba(255,255,255,.22);border-radius:var(--r-full);overflow:hidden}
.hs-bar:focus-within{background:rgba(255,255,255,.2);border-color:rgba(255,255,255,.44)}
.hs-ico{padding:0 9px 0 15px;color:rgba(255,255,255,.55);flex-shrink:0;display:flex;align-items:center}
.hs-ico svg{color:rgba(255,255,255,.55)}
.hs-input{flex:1;border:none;outline:none;background:transparent;font-size:13.5px;font-weight:500;color:#fff;padding:12px 0;font-family:inherit}
.hs-input::placeholder{color:rgba(255,255,255,.38)}
.hs-btn{border-radius:var(--r-full)!important;margin:4px 4px 4px 0;flex-shrink:0}
.hs-sug{position:absolute;top:calc(100% + 7px);left:0;right:0;background:var(--card);border-radius:var(--r-lg);overflow:hidden;display:none;z-index:20;border:1.5px solid var(--border)}
.hs-sug.open{display:block}
.hs-sug-item{display:flex;align-items:center;gap:10px;padding:10px 13px;text-decoration:none;color:var(--text);transition:background .1s}
.hs-sug-item:hover{background:var(--primary-light)}
.hs-sug-av{width:28px;height:28px;border-radius:var(--r-full);background:var(--primary-light);color:var(--primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex-shrink:0}
.hs-sug-name{font-size:13px;font-weight:700;color:var(--text)}
.hs-sug-cat{font-size:10.5px;color:var(--text-faint);margin-top:1px}
.hs-tags{display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin-top:11px}
.hs-tag{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.1);color:rgba(255,255,255,.72);padding:5px 12px;border-radius:var(--r-full);font-size:11px;font-weight:500;text-decoration:none;border:1px solid rgba(255,255,255,.18);transition:background .14s}
.hs-tag svg{color:rgba(255,255,255,.55)}
.hs-tag:hover{background:rgba(255,255,255,.2)}
@media(max-width:460px){.hs-ico{display:none}.hs-input{padding:11px 8px}}

/* promo strip */
.promo-strip{background:var(--primary);opacity:.92}
.promo-strip-inner{max-width:1280px;margin:0 auto;padding:10px 22px;display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.promo-label{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.14);border-radius:var(--r-full);padding:2px 10px;font-size:9.5px;font-weight:700;color:#fff;letter-spacing:.5px;white-space:nowrap;flex-shrink:0}
.promo-label svg{color:#fff}
.promo-info{flex:1;min-width:0}
.promo-title{font-weight:700;font-size:12.5px;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.promo-store{font-size:10px;color:rgba(255,255,255,.6)}
.promo-right{display:flex;align-items:center;gap:8px;flex-shrink:0;flex-wrap:wrap}
.promo-now{font-size:1.05rem;font-weight:800;color:#fff}
.promo-was{font-size:10px;color:rgba(255,255,255,.52);text-decoration:line-through}
.promo-disc{background:rgba(255,255,255,.18);color:#fff;font-weight:700;font-size:11.5px;padding:3px 10px;border-radius:var(--r-full)}
.promo-timer{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;font-weight:600;color:rgba(255,255,255,.78)}
.promo-timer svg{color:rgba(255,255,255,.78)}
@media(max-width:560px){.promo-info,.promo-now{display:none}}

/* benefit cards */
.benefits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:11px}
.benefit-card{background:var(--card);border-radius:var(--r-lg);padding:19px;border:1.5px solid var(--border);display:flex;gap:13px;align-items:flex-start;transition:border-color .15s}
.benefit-card:hover{border-color:var(--border-hover)}
.benefit-ico{width:40px;height:40px;border-radius:var(--r-md);background:var(--primary-light);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.benefit-ico svg{color:var(--icon-color)}
.benefit-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:5px}
.benefit-desc{font-size:12px;color:var(--text-muted);line-height:1.7}
@media(max-width:860px){.benefits-grid{grid-template-columns:1fr 1fr}}
@media(max-width:500px){.benefits-grid{grid-template-columns:1fr}}

/* steps */
.steps-row{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;align-items:start;gap:0;margin-top:8px}
.step-card{background:var(--card);border-radius:var(--r-lg);padding:24px 18px;border:1.5px solid var(--border);text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px;position:relative;transition:border-color .15s}
.step-card:hover{border-color:var(--border-hover)}
.step-num{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--primary);color:#fff;font-size:9.5px;font-weight:700;padding:3px 10px;border-radius:var(--r-full)}
.step-ico{width:46px;height:46px;border-radius:var(--r-md);background:var(--primary-light);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.step-ico svg{color:var(--icon-color)}
.step-title{font-size:.88rem;font-weight:700;color:var(--text)}
.step-desc{font-size:12px;color:var(--text-muted);line-height:1.7}
.step-sep{display:flex;align-items:center;justify-content:center;padding:0 9px;margin-top:50px;color:var(--text-faint)}
.step-sep svg{color:var(--text-faint)}
.perks-box{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin-top:28px;background:var(--card);border-radius:var(--r-lg);padding:20px;border:1.5px solid var(--border)}
.perk-item{display:flex;align-items:flex-start;gap:7px;font-size:12.5px;font-weight:500;color:var(--text-2);line-height:1.55}
.perk-icon{color:var(--icon-color);flex-shrink:0;margin-top:2px;display:flex}
.perk-icon svg{color:var(--icon-color)}
.steps-cta{display:flex;gap:9px;justify-content:center;flex-wrap:wrap;margin-top:26px}
@media(max-width:840px){.steps-row{grid-template-columns:1fr;gap:24px}.step-sep{display:none}.perks-box{grid-template-columns:1fr 1fr}}
@media(max-width:460px){.perks-box{grid-template-columns:1fr;padding:15px}}

/* contact */
.contact-layout{display:grid;grid-template-columns:1fr 1.4fr;gap:40px;align-items:start}
.contact-channels{display:flex;flex-direction:column;gap:7px}
.channel-row{display:flex;align-items:center;gap:10px;padding:11px 13px;background:var(--card);border-radius:var(--r-full);border:1.5px solid var(--border);text-decoration:none;transition:border-color .14s}
.channel-row:hover{border-color:var(--border-hover)}
.channel-ico{width:34px;height:34px;border-radius:var(--r-full);background:var(--primary-light);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.channel-ico svg{color:var(--icon-color)}
.channel-lbl{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-faint)}
.channel-val{font-size:13px;font-weight:600;color:var(--text)}
.channel-arr{margin-left:auto;color:var(--text-faint);display:flex}
.channel-arr svg{color:var(--text-faint)}
.form-success{background:var(--card);border-radius:var(--r-lg);border:1.5px solid var(--green-light);padding:44px 26px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:11px}
.form-success svg{color:var(--icon-color)}
.form-success-title{font-size:1.05rem;font-weight:800;color:var(--text)}
.form-success-sub{font-size:13px;color:var(--text-muted)}
@media(max-width:700px){.contact-layout{grid-template-columns:1fr;gap:18px}.form-card .form-row{grid-template-columns:1fr;padding:0 15px}.form-card .form-group{padding:0 15px}.form-card-hd{padding:12px 15px}.form-type-row{padding:12px 15px 0}.form-card .btn-full{margin:0 15px 16px;width:calc(100% - 30px)}}

/* ── TOUCH ────────────────────────────────────────────────────── */
a,button,.cat-card,.offer-card,.store-card,.loja-card,.oferta-card{-webkit-tap-highlight-color:transparent}
.cat-pills-scroll{display:flex;gap:7px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none;-ms-overflow-style:none}
.cat-pills-scroll::-webkit-scrollbar{display:none}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media(max-width:1024px){
  .footer-top{grid-template-columns:1fr 1fr;gap:22px}
  .browse-layout,.lojas-layout{grid-template-columns:1fr}
  .browse-sidebar,.lojas-sidebar{position:static}
  .section,.section-bg,.section-alt{padding:58px 20px}
  .hero{padding:72px 20px 84px}
}
@media(max-width:768px){
  .nav-links,.nav-actions{display:none}
  .hamburger{display:flex}
  .ll,.login-left{display:none}
  .login-right,.lr{width:100%;padding:26px 18px;border-left:none}
  .admin-sidebar{transform:translateX(-100%)}
  .admin-sidebar.open{transform:translateX(0)}
  .admin-main{margin-left:0}
  .tb-toggle{display:flex!important}
  .admin-content{padding:12px}
  .stats-row{grid-template-columns:1fr 1fr}
  .form-row{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr;gap:16px}
  .hero{padding:52px 16px 72px}
  .hero h1{font-size:clamp(1.8rem,6vw,2.3rem)}
  .hero-stats{margin-top:36px;padding-top:22px}
  .hero-stat{flex:0 0 33.33%;max-width:33.33%;padding:7px 6px;border-left:1px solid rgba(255,255,255,.1)}
  .hero-stat:first-child{border-left:none}
  .section,.section-bg,.section-alt{padding:44px 15px}
  .section-hd.spread{flex-direction:column;align-items:flex-start;gap:10px}
  .page-banner,.page-hero{padding:40px 15px 46px}
  .cta-banner{padding:48px 16px}
  .cta-banner-btns{flex-direction:column;align-items:center}
  .cta-banner-btns .btn{width:100%;max-width:300px}
  .cat-grid{grid-template-columns:repeat(4,1fr);gap:7px}
  .offers-grid{grid-template-columns:1fr 1fr;gap:9px}
  .stores-grid{grid-template-columns:1fr;gap:8px}
  .lojas-grid,.ofertas-grid{grid-template-columns:1fr 1fr;gap:9px}
}
@media(max-width:500px){
  .footer-top{grid-template-columns:1fr}
  .stats-row{grid-template-columns:1fr}
  .nav-inner{padding:0 13px}
  .cat-grid{grid-template-columns:repeat(3,1fr);gap:7px}
  .cat-card{padding:15px 5px 12px}
  .offers-grid{grid-template-columns:1fr;gap:9px}
  .hero h1{font-size:1.85rem}
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn{justify-content:center}
  .hero-stat{flex:0 0 50%;max-width:50%}
  .hero-stat:nth-child(3){flex:0 0 100%;max-width:100%;border-left:none;border-top:1px solid rgba(255,255,255,.1)}
  .lojas-grid,.ofertas-grid{grid-template-columns:1fr}
  .section-title{font-size:1.45rem}
}
