:root{
  --primary:#c60a09;--primary-dark:#970504;--primary-soft:#fff0ef;--accent:#ffb300;
  --ink:#171717;--muted:#6d6d73;--line:#e8e8ec;--surface:#fff;--canvas:#f7f7f9;
  --success:#178447;--danger:#c52727;--radius:18px;--shadow:0 10px 30px rgba(25,25,32,.08);
  --topbar:78px;--content:1240px;
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--canvas);color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;-webkit-font-smoothing:antialiased}button,input,textarea{font:inherit}button{border:0;cursor:pointer;color:inherit}img{display:block;max-width:100%}a{color:inherit;text-decoration:none}h1,h2,h3,p{margin-top:0}button:focus-visible,input:focus-visible,textarea:focus-visible,a:focus-visible{outline:3px solid rgba(198,10,9,.25);outline-offset:2px}
.topbar{height:var(--topbar);position:sticky;z-index:800;top:0;display:flex;align-items:center;gap:18px;padding:0 max(24px,calc((100vw - var(--content))/2));background:rgba(255,255,255,.94);border-bottom:1px solid rgba(0,0,0,.06);backdrop-filter:blur(16px)}
.brand{display:flex;align-items:center;background:none}.brand img{width:132px;height:44px;object-fit:contain;object-position:left center}.location{max-width:220px;min-width:180px;display:flex;align-items:center;gap:8px;text-align:left;background:none}.location-icon{font-size:22px;color:var(--primary)}.location small,.location b{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.location small{font-size:11px;color:var(--muted)}.location b{font-size:13px}.search{height:46px;flex:1;display:flex;align-items:center;gap:9px;padding:0 15px;background:#f1f1f4;border:1px solid transparent;border-radius:999px}.search:focus-within{background:#fff;border-color:#d3d3d9;box-shadow:0 0 0 4px rgba(198,10,9,.06)}.search input{width:100%;border:0;background:none;outline:0}.desktop-nav{display:flex;gap:6px}.desktop-nav button{padding:10px 12px;background:none;border-radius:12px;font-weight:650}.desktop-nav button:hover{background:#f3f3f5}.account-button,.cart-button,.icon-btn,.notification-btn{width:44px;height:44px;display:grid;place-items:center;border-radius:50%;background:#f2f2f5;font-weight:800}.account-button{background:var(--primary);color:#fff}.cart-button{position:relative}.cart-button b{position:absolute;right:-3px;top:-4px;min-width:20px;height:20px;padding:0 5px;display:grid;place-items:center;border-radius:10px;background:var(--primary);color:#fff;font-size:11px}
.page{width:min(var(--content),calc(100% - 40px));margin:0 auto;padding:28px 0 78px}.home-page{padding-top:16px}.section{margin:34px 0}.section-head{display:flex;align-items:end;justify-content:space-between;gap:16px;margin-bottom:16px}.section-head h2{margin:0;font-size:25px;line-height:1.1}.section-head p{margin:5px 0 0;color:var(--muted);font-size:14px}.link-button,.text-button,.text-back{background:none;color:var(--primary);font-weight:750}.page-title{padding:12px 0 10px}.page-title.row{display:flex;align-items:center;justify-content:space-between}.page-title h1{font-size:34px;margin:5px 0}.page-title p{color:var(--muted);margin:0}.eyebrow{font-size:12px;letter-spacing:.14em;color:var(--primary);font-weight:900}.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 5px 18px rgba(30,30,38,.035);padding:22px}.row{display:flex;align-items:center;justify-content:space-between;gap:14px}.full{width:100%}
.mobile-home-header,.mobile-nav{display:none}.home-search{display:none}.category-rail,.filter-rail,.horizontal-cards,.stories,.promo-strip,.interest-row{display:flex;gap:14px;overflow-x:auto;scrollbar-width:none;padding:3px 2px 8px}.category-rail::-webkit-scrollbar,.filter-rail::-webkit-scrollbar,.horizontal-cards::-webkit-scrollbar,.stories::-webkit-scrollbar,.promo-strip::-webkit-scrollbar,.interest-row::-webkit-scrollbar{display:none}.category{flex:0 0 92px;background:none;text-align:center;padding:4px}.category img{width:64px;height:64px;margin:auto;border-radius:50%;object-fit:cover;background:#fff0ef;padding:10px}.category b{display:block;margin-top:7px;font-size:12px;white-space:nowrap}.chip{flex:none;border:1px solid var(--line);background:#fff;border-radius:999px;padding:10px 16px;font-weight:700}.chip.active{border-color:var(--primary);background:var(--primary-soft);color:var(--primary)}
.stories-section{margin-top:20px}.story{flex:0 0 78px;background:none;text-align:center}.story span{width:66px;height:66px;display:block;margin:auto;padding:3px;border-radius:50%;background:linear-gradient(135deg,#ffc400,#df123c,#8b23d8)}.story.viewed span{background:#ddd}.story img{width:100%;height:100%;border-radius:50%;border:3px solid #fff;object-fit:cover}.story b{display:block;margin-top:5px;font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.store-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}.nearby-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:17px}.horizontal-cards .store-card{flex:0 0 300px}.store-card{background:#fff;border-radius:17px;overflow:hidden;border:1px solid var(--line);box-shadow:0 7px 22px rgba(28,28,33,.05);transition:.2s transform,.2s box-shadow;cursor:pointer}.store-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}.store-cover-wrap{position:relative;aspect-ratio:16/9;background:#eee;overflow:hidden}.store-cover{width:100%;height:100%;object-fit:cover;transition:transform .35s}.store-card:hover .store-cover{transform:scale(1.035)}.favorite{position:absolute;right:11px;top:11px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.94);font-size:22px;box-shadow:0 3px 12px rgba(0,0,0,.13)}.favorite.active{color:var(--primary)}.sponsored-badge{position:absolute;left:10px;top:10px;padding:5px 8px;border-radius:7px;background:rgba(22,22,22,.72);color:#fff;font-size:10px;font-weight:800}.closed-overlay{position:absolute;inset:auto 10px 10px 10px;padding:7px;border-radius:8px;text-align:center;background:rgba(0,0,0,.7);color:#fff;font-weight:800}.store-body{padding:14px}.store-title{display:flex;align-items:start;justify-content:space-between;gap:8px}.store-title h3{margin:0;font-size:16px}.store-title h3 img{display:inline-block;width:15px;vertical-align:-2px}.rating{flex:none;font-size:12px;background:#f3f3f5;padding:5px 7px;border-radius:8px}.store-meta{margin-top:7px;font-size:13px;font-weight:650}.store-tags{margin-top:5px;color:var(--muted);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.store-card.compact .store-body{padding:12px}.store-card.compact .store-title h3{font-size:15px}
.sponsor-section{display:flex;gap:18px;overflow-x:auto}.sponsor-slide{position:relative;flex:0 0 min(850px,85vw);height:330px;border-radius:24px;overflow:hidden;background:#222;color:#fff;cursor:pointer}.sponsor-slide>img{width:100%;height:100%;object-fit:cover;opacity:.65}.sponsor-slide:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.75),rgba(0,0,0,.05))}.sponsor-slide>div{position:absolute;z-index:1;left:36px;bottom:35px;width:min(480px,75%)}.sponsor-slide span{font-size:11px;text-transform:uppercase;letter-spacing:.12em}.sponsor-slide h2{font-size:34px;margin:7px 0}.sponsor-slide p{color:#eee}.btn{min-height:44px;padding:11px 18px;border-radius:12px;font-weight:800;transition:.18s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-outline{background:#fff;border:1px solid #d8d8de}.btn-white{background:#fff;color:#111}.btn:disabled{opacity:.5;cursor:not-allowed}
.popular-layout{display:grid;grid-template-columns:1.5fr 1fr;gap:22px}.popular-stores{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:15px}.popular-products{display:grid;gap:12px}.popular-products article{display:grid;grid-template-columns:1fr 82px;grid-template-rows:auto auto auto;padding:13px;background:#fff;border:1px solid var(--line);border-radius:15px;cursor:pointer}.popular-products article span{font-size:11px;color:var(--muted)}.popular-products article h3{font-size:14px;margin:5px 0}.popular-products article b{color:var(--primary)}.popular-products article img{grid-column:2;grid-row:1/4;width:82px;height:82px;object-fit:cover;border-radius:11px}.interest-row article{flex:0 0 220px;background:#fff;border:1px solid var(--line);border-radius:15px;overflow:hidden;cursor:pointer}.interest-row article img{width:100%;height:135px;object-fit:cover}.interest-row article h3{font-size:14px;margin:11px 12px 4px}.interest-row article b{display:block;margin:0 12px 13px;color:var(--primary)}.promo-strip .promo-card{flex:0 0 330px}.promo-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin:20px 0}.promo-card{position:relative;height:190px;border-radius:18px;overflow:hidden;background:#222;color:#fff;cursor:pointer}.promo-card>img{width:100%;height:100%;object-fit:cover;opacity:.7}.promo-card:after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.75),transparent 70%)}.promo-card>div{position:absolute;z-index:1;left:17px;right:17px;bottom:14px}.promo-card span{display:inline-block;padding:4px 7px;background:var(--primary);border-radius:6px;font-size:10px;font-weight:900}.promo-card h3{margin:6px 0 2px}.promo-card p{margin:0;font-size:12px;color:#eee}
.search-large{height:58px;display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:0 18px}.search-large input{border:0;outline:0;width:100%;font-size:17px}.suggestion-list{display:flex;flex-wrap:wrap;gap:8px}.suggestion-list button{background:#fff;border:1px solid var(--line);border-radius:999px;padding:10px 14px}.category-grid{display:grid;grid-template-columns:repeat(8,minmax(0,1fr));gap:15px}
.store-hero{height:390px;position:relative;border-radius:0 0 28px 28px;overflow:hidden;color:#fff;margin-top:-28px}.store-hero>img{width:100%;height:100%;object-fit:cover}.store-hero:after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.85),transparent 70%)}.back-float,.store-actions button{width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.92);box-shadow:0 4px 15px rgba(0,0,0,.15)}.back-float{position:absolute;z-index:2;left:22px;top:22px}.store-actions{position:absolute;z-index:2;right:22px;top:22px;display:flex;gap:8px}.store-actions .active{color:var(--primary)}.store-overlay{position:absolute;z-index:1;left:28px;right:28px;bottom:26px}.store-overlay h1{font-size:38px;margin:8px 0}.store-overlay p{font-weight:700;margin:0 0 7px}.store-overlay small{color:#ddd}.badge{display:inline-flex;padding:6px 9px;border-radius:8px;font-size:11px;font-weight:800;background:#555}.badge.success{background:var(--success)}.badge.danger{background:var(--danger)}.catalog-layout{display:grid;grid-template-columns:220px minmax(0,1fr);gap:24px;margin-top:26px}.catalog-nav{position:sticky;top:calc(var(--topbar) + 18px);align-self:start;display:grid;background:#fff;border:1px solid var(--line);border-radius:15px;padding:7px}.catalog-nav button{text-align:left;background:none;padding:12px;border-radius:9px}.catalog-nav button.active,.catalog-nav button:hover{background:var(--primary-soft);color:var(--primary);font-weight:800}.product-section{scroll-margin-top:100px;margin-bottom:30px}.product-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.product-card{min-height:166px;display:grid;grid-template-columns:1fr 140px;gap:10px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:15px;cursor:pointer}.product-card h3{font-size:16px;margin-bottom:7px}.product-card p{font-size:12px;color:var(--muted);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.product-card>img{width:140px;height:136px;object-fit:cover;border-radius:12px}.price-row{display:flex;align-items:center;justify-content:space-between}.price-row b{color:var(--primary)}.add{width:34px;height:34px;border-radius:50%;background:var(--primary);color:#fff;font-size:22px}.floating-cart{position:fixed;z-index:600;left:50%;bottom:25px;transform:translateX(-50%);width:min(500px,calc(100% - 40px));display:flex;justify-content:space-between;padding:15px 20px;background:var(--primary);color:#fff;border-radius:15px;box-shadow:0 12px 28px rgba(198,10,9,.35);font-weight:800}
.cart-layout{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:22px}.cart-tabs{display:flex;gap:10px;overflow-x:auto;margin-bottom:17px}.cart-tabs button{min-width:160px;text-align:left;padding:11px;background:#fff;border:1px solid var(--line);border-radius:12px}.cart-tabs button small{display:block;color:var(--muted)}.cart-tabs button.active{border-color:var(--primary);background:var(--primary-soft)}.cart-store-head{display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--line);padding-bottom:16px}.cart-store-head img{width:52px;height:52px;border-radius:12px;object-fit:cover}.cart-store-head h2{margin:0;font-size:18px}.cart-store-head button{background:none;color:var(--primary);padding:4px 0}.cart-item{position:relative;display:grid;grid-template-columns:72px 1fr auto;gap:13px;padding:17px 30px 17px 0;border-bottom:1px solid var(--line)}.cart-item>img{width:72px;height:72px;border-radius:11px;object-fit:cover}.cart-item-main h3{font-size:15px;margin:1px 0 5px}.cart-item-main p,.cart-item-main small{display:block;font-size:12px;color:var(--muted);margin-bottom:5px}.qty{display:flex;align-items:center;gap:8px}.qty button,.quantity-picker button{width:31px;height:31px;border-radius:50%;background:#f1f1f4;font-size:18px}.remove{position:absolute;right:0;top:12px;background:none;color:#999;font-size:22px}.cart-summary{align-self:start;position:sticky;top:calc(var(--topbar) + 18px)}.cart-summary>div,.summary-items>div,.order-summary>div{display:flex;align-items:center;justify-content:space-between;gap:15px;padding:7px 0;font-size:13px}.cart-summary .total,.order-summary .total{font-size:17px;padding:14px 0}.cart-summary small{display:block;color:var(--muted);text-align:center;margin-top:10px}.upsell{margin-top:22px}.upsell .interest-row article{flex-basis:155px}.upsell .interest-row article img{height:95px}
.checkout-layout{display:grid;grid-template-columns:minmax(0,1fr) 390px;gap:22px}.checkout-main{display:grid;gap:16px}.checkout-main .panel h2{font-size:19px}.segmented{display:grid;grid-template-columns:1fr 1fr;background:#f1f1f4;padding:4px;border-radius:12px;margin-bottom:16px}.segmented button{background:none;padding:10px;border-radius:9px;font-weight:800}.segmented .active{background:#fff;color:var(--primary);box-shadow:0 2px 8px rgba(0,0,0,.08)}.checkout-option{width:100%;display:flex;align-items:center;gap:13px;text-align:left;background:none;padding:10px 0}.checkout-option>div{flex:1}.checkout-option small,.checkout-option b,.checkout-option p{display:block}.checkout-option small,.checkout-option p{color:var(--muted);font-size:12px;margin:2px 0}.checkout-option>button{background:none;color:var(--primary);font-weight:800}.option-icon{width:42px;height:42px;display:grid;place-items:center;flex:none;border-radius:12px;background:var(--primary-soft);color:var(--primary);font-size:20px}.mini-map{height:170px;border-radius:13px;overflow:hidden;margin-top:10px}.route-line{display:flex;justify-content:space-between;padding-top:11px;font-size:13px;color:var(--muted)}.payment-methods{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px}.payment-option{min-width:0;padding:11px 6px;border:1px solid var(--line);border-radius:12px;background:#fff;text-align:center}.payment-option.active{border:2px solid var(--primary);background:var(--primary-soft)}.payment-option img{width:35px;height:35px;object-fit:contain;margin:0 auto 6px}.payment-option b,.payment-option small{display:block}.payment-option b{font-size:12px}.payment-option small{font-size:9px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.payment-detail{margin-top:15px;padding:15px;background:#f8f8fa;border-radius:13px}.lookup-state{font-size:12px;color:var(--muted);margin:8px 0 0}.phone-input{display:flex;align-items:center;background:#fff;border:1px solid #dcdce1;border-radius:11px;overflow:hidden}.phone-input b{padding:12px;border-right:1px solid #e5e5e9;background:#f6f6f8}.phone-input input{flex:1;min-width:0;border:0;padding:12px;outline:0}.tip-options{display:flex;gap:8px;flex-wrap:wrap}.tip-options button{padding:9px 13px;border-radius:10px;background:#f1f1f4;font-weight:750}.tip-options .active{background:var(--primary);color:#fff}.order-total{align-self:start;position:sticky;top:calc(var(--topbar) + 18px)}.security-note{margin-top:12px;text-align:center;color:var(--muted);font-size:11px}.promo-entry{display:flex;gap:8px}.promo-entry input{flex:1;border:1px solid var(--line);border-radius:11px;padding:11px}.card-fields{display:grid;grid-template-columns:1fr 1fr;gap:10px}.card-fields .field:first-child,.card-fields .field:last-child{grid-column:1/-1}
.field{display:grid;gap:6px;margin:12px 0}.field>span{font-size:12px;font-weight:750}.field input,.field textarea{width:100%;border:1px solid #d9d9df;border-radius:11px;padding:12px;background:#fff;outline:0}.field input:focus,.field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(198,10,9,.07)}.two-fields{display:grid;grid-template-columns:1fr 1fr;gap:10px}.option-group{border:0;padding:0;margin:20px 0}.option-group legend{width:100%;display:flex;justify-content:space-between;padding:0 0 8px;font-weight:800}.option-group legend small{font-size:10px;color:var(--muted)}.option{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--line)}.option small{display:block;color:var(--muted);font-size:11px}.quantity-picker{display:flex;align-items:center;justify-content:center;gap:15px;margin:16px 0}
.map-page{height:calc(100vh - var(--topbar));position:relative;overflow:hidden}.map-page #restaurantMap{position:absolute;inset:0}.map-top{position:absolute;z-index:500;top:18px;left:50%;transform:translateX(-50%);width:min(680px,calc(100% - 35px));display:flex;gap:8px}.map-top label{height:50px;flex:1;display:flex;align-items:center;gap:8px;padding:0 15px;background:#fff;border-radius:14px;box-shadow:var(--shadow)}.map-top input{width:100%;border:0;outline:0}.map-top button{width:50px;border-radius:14px;background:#fff;box-shadow:var(--shadow);font-size:20px}.map-cards{position:absolute;z-index:500;left:0;right:0;bottom:20px;display:flex;gap:12px;overflow-x:auto;padding:8px calc((100vw - min(var(--content),100vw))/2 + 20px);pointer-events:auto}.map-cards .store-card{flex:0 0 280px}.map-popup-open{margin-top:6px;padding:6px 9px;border-radius:6px;background:var(--primary);color:#fff}.leaflet-control-attribution{font-size:9px!important}
.orders-list{display:grid;gap:16px}.order-card{background:#fff;border:1px solid var(--line);border-radius:17px;padding:18px}.order-main{display:flex;gap:14px}.order-logo{width:56px;height:56px;border-radius:12px;object-fit:cover}.order-main>div{flex:1}.order-main h3{margin:0 0 5px}.order-main p{margin:0;color:var(--muted);font-size:12px}.order-main>strong{color:var(--primary)}.order-progress{height:7px;margin:16px 0;background:#eee;border-radius:9px;overflow:hidden}.order-progress i{display:block;height:100%;background:var(--primary);border-radius:9px}.confirmation-code{padding:15px;border:1px dashed var(--primary);border-radius:12px;text-align:center;background:var(--primary-soft)}.confirmation-code b{display:block;font-size:28px;letter-spacing:.15em;color:var(--primary)}
.profile-header{display:flex;align-items:center;gap:18px;background:linear-gradient(135deg,var(--primary),#840000);color:#fff;border-radius:22px;padding:26px}.avatar{width:78px;height:78px;border-radius:50%;object-fit:cover;border:4px solid rgba(255,255,255,.7)}.profile-header h1{margin:0 0 4px}.profile-header p{margin:0;color:#f5dada}.profile-shortcuts{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:18px 0}.profile-shortcuts button{display:grid;place-items:center;gap:7px;padding:17px 8px;background:#fff;border:1px solid var(--line);border-radius:15px;font-weight:750}.profile-shortcuts span{font-size:24px;color:var(--primary)}.profile-menu{padding:7px}.profile-menu button,.profile-menu a{width:100%;display:grid;grid-template-columns:40px 1fr auto;align-items:center;text-align:left;background:none;padding:14px 10px;border-bottom:1px solid var(--line)}.profile-menu span{width:34px;height:34px;display:grid;place-items:center;background:#f3f3f5;border-radius:10px;color:var(--primary)}.profile-menu i{font-style:normal;color:#999}.profile-auth{margin:18px auto;display:block;min-width:220px}.wallet-card{background:linear-gradient(135deg,#19191d,#3d1515);color:#fff;padding:28px;border-radius:22px;box-shadow:var(--shadow);margin-bottom:20px}.wallet-card span{letter-spacing:.15em;font-size:11px}.wallet-card h2{font-size:39px;margin:10px 0 0}.wallet-card button{margin-top:15px;padding:10px 14px;border-radius:10px;background:#fff}.wallet-methods article,.transaction{display:flex;align-items:center;gap:13px;padding:13px 0;border-bottom:1px solid var(--line)}.wallet-methods img{width:38px;height:38px;object-fit:contain}.wallet-methods div,.transaction div{flex:1}.wallet-methods b,.wallet-methods small,.transaction b,.transaction small{display:block}.wallet-methods small,.transaction small{color:var(--muted);font-size:11px}.transaction strong{color:var(--danger)}.transaction.positive strong{color:var(--success)}.coupon-list article{display:flex;justify-content:space-between;padding:13px 0;border-bottom:1px solid var(--line)}.coupon-list p{margin:3px 0;color:var(--muted);font-size:12px}.coupon-list button{background:var(--primary-soft);color:var(--primary);border-radius:9px;padding:7px 10px}.account-tabs,.auth-tabs{display:flex;gap:5px;margin-bottom:14px;background:#eeeef1;padding:4px;border-radius:12px}.account-tabs button,.auth-tabs button{flex:1;padding:10px;background:none;border-radius:9px}.account-tabs .active,.auth-tabs .active{background:#fff;color:var(--primary);font-weight:800}.settings-row{width:100%;display:flex;justify-content:space-between;padding:14px 0;background:none;border-bottom:1px solid var(--line)}.settings-list label{display:flex;justify-content:space-between;align-items:center;padding:14px 0;border-bottom:1px solid var(--line)}.settings-list b,.settings-list small{display:block}.settings-list small{font-size:11px;color:var(--muted)}.danger-text{color:var(--danger)!important}.success-text,.positive{color:var(--success)}.about-hero{text-align:center;padding:35px}.about-hero img{width:90px;margin:auto}.about-hero h1{font-size:38px;color:var(--primary);margin:10px 0}.about-hero p{color:var(--muted)}
.auth-page{min-height:calc(100vh - var(--topbar));display:grid;grid-template-columns:1fr 520px;align-items:stretch}.auth-brand{display:grid;place-content:center;padding:70px;background:linear-gradient(135deg,var(--primary),#7e0000);color:#fff}.auth-brand img{width:120px;filter:brightness(0) invert(1)}.auth-brand h1{font-size:45px;margin:20px 0 10px}.auth-brand p{max-width:540px;color:#f7dddd}.auth-card{align-self:center;margin:50px;padding:28px;background:#fff;border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow)}.demo-link{width:100%;margin-top:12px;background:none;color:var(--primary);padding:10px}.config-state{display:block;text-align:center;margin-top:13px;color:var(--muted)}
.modal{border:0;padding:0;background:transparent;max-width:min(640px,calc(100% - 28px));max-height:90vh;overflow:visible}.modal::backdrop{background:rgba(12,12,16,.68);backdrop-filter:blur(3px)}.product-modal,.dialog-card,.result-card{position:relative;background:#fff;border-radius:22px;overflow:auto;max-height:88vh}.product-modal>img{width:100%;height:260px;object-fit:cover}.modal-body,.dialog-card,.result-card{padding:24px}.modal-close{position:absolute;z-index:2;right:13px;top:13px;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.94);font-size:22px}.story-dialog{width:min(430px,calc(100% - 25px));height:min(760px,90vh)}.story-viewer{position:relative;width:100%;height:100%;border-radius:20px;overflow:hidden;background:#111;color:#fff}.story-viewer>img{width:100%;height:100%;object-fit:cover}.story-viewer:after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.65),transparent 50%,rgba(0,0,0,.5))}.story-progress{position:absolute;z-index:2;left:10px;right:10px;top:9px;height:3px;background:rgba(255,255,255,.4)}.story-progress i{display:block;width:68%;height:100%;background:#fff}.story-head{position:absolute;z-index:2;left:14px;right:14px;top:20px;display:flex;align-items:center;gap:9px}.story-head img{width:35px;height:35px;border-radius:50%;object-fit:cover}.story-head b{flex:1}.story-head button{background:none;color:#fff;font-size:28px}.story-caption{position:absolute;z-index:2;left:18px;right:18px;bottom:22px}.story-caption span{display:block;font-weight:800;font-size:20px;margin-bottom:12px}.story-caption button{width:100%;padding:12px;border-radius:10px;background:#fff}.result-card{text-align:center;min-width:min(420px,90vw)}.result-icon{width:70px;height:70px;margin:0 auto 15px;display:grid;place-items:center;border-radius:50%;font-size:34px;background:#ffeded;color:var(--danger)}.result-card.success .result-icon{background:#e6f7ed;color:var(--success)}.result-card .btn{margin-top:9px}.otp-input{width:100%;font-size:30px;letter-spacing:.35em;text-align:center;padding:13px;border:1px solid var(--line);border-radius:12px}
.toast{position:fixed;z-index:2000;left:50%;top:90px;transform:translate(-50%,-18px);padding:12px 18px;border-radius:12px;background:#202025;color:#fff;box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:.25s}.toast.show{opacity:1;transform:translate(-50%,0)}.toast[data-type="success"]{background:var(--success)}.toast[data-type="error"]{background:var(--danger)}.blocking{position:fixed;z-index:1900;inset:0;display:grid;place-content:center;text-align:center;background:rgba(255,255,255,.78);backdrop-filter:blur(4px)}.blocking[hidden]{display:none}.spinner{width:38px;height:38px;margin:auto;border:4px solid #e8e8ec;border-top-color:var(--primary);border-radius:50%;animation:spin .75s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.initial-loader{min-height:65vh;display:grid;place-content:center;text-align:center;color:var(--muted)}.empty{min-height:300px;display:grid;place-content:center;text-align:center;padding:30px}.empty .big{font-size:58px}.empty p{color:var(--muted);max-width:420px}.prose{line-height:1.65}
@media(max-width:1050px){.desktop-nav{display:none}.store-grid,.nearby-grid,.promo-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.category-grid{grid-template-columns:repeat(6,minmax(0,1fr))}.payment-methods{grid-template-columns:repeat(3,1fr)}.cart-layout,.checkout-layout{grid-template-columns:minmax(0,1fr) 330px}.auth-page{grid-template-columns:1fr 460px}}
@media(max-width:780px){:root{--topbar:0px}.topbar{display:none}body{padding-bottom:72px}.page{width:100%;padding:14px 14px 86px}.mobile-home-header{display:flex;align-items:center;justify-content:space-between}.mobile-home-header>button:first-child{min-width:0;display:flex;align-items:center;gap:9px;background:none;text-align:left}.mobile-home-header>button:first-child div{min-width:0}.mobile-home-header small,.mobile-home-header b{display:block}.mobile-home-header small{font-size:10px;color:var(--muted)}.mobile-home-header b{max-width:245px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.home-search{display:block;margin:14px 0}.home-search label{height:49px;display:flex;align-items:center;gap:8px;border-radius:13px;background:#eeeef1;padding:0 14px}.home-search input{width:100%;border:0;background:none;outline:0}.mobile-nav{position:fixed;z-index:900;left:0;right:0;bottom:0;height:calc(66px + env(safe-area-inset-bottom));padding:5px 5px env(safe-area-inset-bottom);display:grid;grid-template-columns:repeat(5,1fr);background:rgba(255,255,255,.97);border-top:1px solid #ddd;backdrop-filter:blur(14px)}.mobile-nav button{position:relative;display:grid;place-items:center;gap:1px;background:none;font-size:10px;color:#777}.mobile-nav button>span{font-size:21px}.mobile-nav button.active{color:var(--primary);font-weight:850}.mobile-nav i{position:absolute;top:0;right:18%;min-width:17px;height:17px;padding:0 3px;display:grid;place-items:center;border-radius:9px;background:var(--primary);color:#fff;font-style:normal;font-size:9px}.section{margin:28px 0}.section-head h2{font-size:21px}.category-rail{margin-left:-14px;margin-right:-14px;padding-left:12px}.category{flex-basis:78px}.category img{width:56px;height:56px}.filter-rail{margin-left:-14px;margin-right:-14px;padding-left:14px}.stories{margin-left:-14px;margin-right:-14px;padding-left:14px}.horizontal-cards,.promo-strip,.interest-row{margin-left:-14px;margin-right:-14px;padding-left:14px}.horizontal-cards .store-card{flex-basis:270px}.store-grid,.nearby-grid,.promo-grid{grid-template-columns:1fr;gap:15px}.popular-layout{grid-template-columns:1fr}.popular-stores{display:flex;overflow-x:auto;gap:13px}.popular-stores .store-card{flex:0 0 270px}.sponsor-slide{height:260px;flex-basis:92vw}.sponsor-slide>div{left:22px;bottom:22px}.sponsor-slide h2{font-size:27px}.page-title h1{font-size:28px}.category-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:9px}.catalog-page{padding-top:0}.store-hero{margin:0 -14px;height:330px;border-radius:0}.store-overlay{left:18px;right:18px}.store-overlay h1{font-size:29px}.catalog-layout{display:block;margin-top:14px}.catalog-nav{position:sticky;z-index:10;top:0;display:flex;overflow-x:auto;border-radius:0;margin:0 -14px;padding:8px 14px}.catalog-nav button{white-space:nowrap}.product-grid{grid-template-columns:1fr}.product-card{grid-template-columns:1fr 115px;min-height:140px}.product-card>img{width:115px;height:110px}.floating-cart{bottom:78px}.cart-layout,.checkout-layout{display:block}.cart-layout>.panel,.checkout-layout>.order-total{margin-bottom:14px}.cart-summary,.order-total{position:static}.cart-item{grid-template-columns:60px 1fr;align-items:start}.cart-item>img{width:60px;height:60px}.cart-item .qty{grid-column:2;justify-content:start}.payment-methods{grid-template-columns:repeat(3,1fr)}.mini-map{height:150px}.map-page{height:calc(100vh - 72px)}.map-cards{bottom:10px;padding-left:12px}.map-cards .store-card{flex-basis:265px}.profile-shortcuts{grid-template-columns:repeat(2,1fr)}.profile-header{border-radius:0;margin:-14px -14px 0}.auth-page{min-height:calc(100vh - 72px);display:block;background:linear-gradient(135deg,var(--primary),#7e0000);padding:30px 14px}.auth-brand{display:block;background:none;padding:20px;text-align:center}.auth-brand img{width:85px;margin:auto}.auth-brand h1{font-size:31px}.auth-card{margin:0 auto;max-width:520px}.modal{max-width:calc(100% - 18px)}.product-modal>img{height:220px}.dialog-card,.result-card,.modal-body{padding:20px}.story-dialog{height:calc(100vh - 30px)}.toast{top:15px;width:calc(100% - 28px);text-align:center}}
@media(max-width:420px){.category-grid{grid-template-columns:repeat(3,1fr)}.payment-methods{grid-template-columns:repeat(2,1fr)}.two-fields,.card-fields{grid-template-columns:1fr}.card-fields .field{grid-column:1}.profile-header{align-items:flex-start}.profile-header .avatar{width:64px;height:64px}.profile-shortcuts button{font-size:12px}.order-main{flex-wrap:wrap}.order-main>strong{margin-left:70px}.sponsor-slide{height:235px}.sponsor-slide p{display:none}}
.map-fallback{position:relative;overflow:hidden;background:linear-gradient(35deg,#edf1ed,#f6eee9)}.map-fallback .fallback-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(95,120,105,.12) 1px,transparent 1px),linear-gradient(90deg,rgba(95,120,105,.12) 1px,transparent 1px);background-size:42px 42px;transform:rotate(-8deg) scale(1.2)}.fallback-pin{position:absolute;z-index:2;display:flex;align-items:center;gap:5px;max-width:150px;background:#fff;padding:5px 8px 5px 5px;border-radius:999px;box-shadow:0 5px 15px rgba(0,0,0,.13);font-size:10px}.fallback-pin span{width:23px;height:23px;display:grid;place-items:center;border-radius:50%;background:var(--primary);color:#fff}.fallback-pin b{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.map-fallback>small{position:absolute;z-index:2;left:10px;right:10px;bottom:8px;padding:5px 8px;background:rgba(255,255,255,.8);border-radius:8px;text-align:center;font-size:9px}.fallback-user{position:absolute;z-index:2;left:50%;top:50%;color:#1a73e8;text-shadow:0 0 0 4px #fff;font-size:18px}
.auth-separator{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:12px;margin:14px 0}.auth-separator:before,.auth-separator:after{content:"";height:1px;flex:1;background:var(--line)}.google-button{width:100%;min-height:46px;display:flex;align-items:center;justify-content:center;gap:10px;border:1px solid #d7d7dc;border-radius:12px;background:#fff;font-weight:800}.google-g{font:900 20px Arial;color:#4285f4}.order-detail-head{display:flex;align-items:center;gap:14px;padding-right:35px}.order-detail-head>img{width:58px;height:58px;border-radius:13px;object-fit:cover}.order-detail-head h2{margin:5px 0 2px}.order-detail-head p{color:var(--muted);margin:0}.timeline{display:grid;gap:0;margin:22px 0}.timeline>div{display:flex;gap:12px;min-height:56px;position:relative}.timeline>div:after{content:"";position:absolute;left:14px;top:28px;bottom:-1px;width:2px;background:#ddd}.timeline>div:last-child:after{display:none}.timeline i{position:relative;z-index:1;width:30px;height:30px;display:grid;place-items:center;border-radius:50%;background:#eee;color:#999;font-style:normal}.timeline .done i{background:var(--primary);color:#fff}.timeline b,.timeline small{display:block}.timeline small{color:var(--muted);font-size:11px}.order-detail-actions{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin:15px 0}.review-box{border-top:1px solid var(--line);margin-top:20px;padding-top:18px}.stars{display:flex;gap:5px}.stars button{background:none;color:#ffaf00;font-size:32px;padding:0}.photo-upload{display:block;margin:10px 0}.photo-upload input{display:none}.photo-upload span{display:block;padding:13px;border:1px dashed #bbb;border-radius:11px;text-align:center;color:var(--muted)}
.order-logo img,.avatar img{width:100%;height:100%;object-fit:cover;border-radius:inherit}.avatar{display:grid;place-items:center;background:rgba(255,255,255,.2);font-size:31px;font-weight:900}.payment-option i{display:block;margin-top:5px;font-style:normal;color:var(--primary)}.profile-shortcuts small{font-size:10px;color:var(--muted)}.warning{background:#fff3d6;color:#8a5a00}.discount{color:var(--success)}
.priority-option{display:flex;align-items:center;gap:12px;margin-top:14px;padding:13px;border:1px solid var(--line);border-radius:13px;background:#fff}.priority-option>span:nth-child(2){flex:1}.priority-option b,.priority-option small{display:block}.priority-option small{font-size:11px;color:var(--muted);margin-top:2px}.priority-option input{width:20px;height:20px;accent-color:var(--primary)}
.google-user-location{width:18px;height:18px;border:4px solid #fff;border-radius:999px;background:#1a73e8;box-shadow:0 1px 7px rgba(0,0,0,.35)}
.google-map-popup{display:grid;gap:4px;min-width:145px;font-family:Inter,system-ui,sans-serif}.google-map-popup b{font-size:14px}.google-map-popup span{font-size:12px;color:#5f6368}.google-map-popup .map-popup-open{border:0;cursor:pointer}

/* Autenticação e estados da aplicação */
.auth-gated .topbar,.auth-gated .mobile-nav{display:none!important}
.data-error{max-width:820px;margin:56px auto;padding:28px;background:#fff;border:1px solid #f1c7c7;border-radius:20px;box-shadow:var(--shadow)}
.data-error h1{color:var(--danger)}.data-error pre{white-space:pre-wrap;word-break:break-word;padding:14px;border-radius:12px;background:#fff6f6;border:1px solid #f2d7d7}
button:disabled{cursor:not-allowed;opacity:.55}
.review-box p{margin-bottom:0;color:var(--muted);line-height:1.55}

.map-unavailable{height:100%;min-height:260px;display:grid;place-content:center;justify-items:center;text-align:center;padding:28px;background:#f2f2f5;color:var(--muted)}.map-unavailable>span{font-size:40px;color:var(--primary)}.map-unavailable h3{margin:8px 0;color:var(--ink)}.map-unavailable p{margin-bottom:8px}

/* ═══════════════════════════════════════════
   MODERN APP REDESIGN — v2
   ═══════════════════════════════════════════ */

/* ── 1. Ripple animation ── */
@keyframes ripple-out{from{transform:scale(0);opacity:.18}to{transform:scale(1);opacity:0}}
.ripple-effect{position:absolute;border-radius:50%;background:currentColor;animation:ripple-out .52s ease-out forwards;pointer-events:none;z-index:9;transform-origin:center}

/* ── 2. Button base: remove iOS tap flash, add ripple container ── */
button,a{-webkit-tap-highlight-color:transparent}
button{user-select:none;position:relative;overflow:hidden}

/* Exceptions: these buttons have absolutely-positioned badges that must overflow */
.cart-button,.mobile-nav button{overflow:visible}

/* ── 3. Press / sink effect ── */
/* Normal → use spring easing so the release "pops" back */
button:not(:disabled){transition:transform .22s cubic-bezier(.34,1.56,.64,1),filter .14s,background .14s,color .14s,box-shadow .14s}
/* Entering :active → quick press-down */
button:not(:disabled):active{transform:scale(.95);transition:transform .08s ease-in}

/* Fine-tuned per-element active states */
.add:not(:disabled):active{transform:scale(.86)!important;box-shadow:0 1px 4px rgba(198,10,9,.15)!important}
.favorite:not(:disabled):active,.modal-close:not(:disabled):active{transform:scale(.82)!important}
.floating-cart:not(:disabled):active{transform:translateX(-50%) scale(.96)!important}
.store-card:active{transform:scale(.985)!important;box-shadow:0 2px 10px rgba(0,0,0,.07)!important}
.product-card:active{transform:scale(.975)!important}

/* ── 4. Cards must be ripple containers ── */
.store-card,.product-card{position:relative;overflow:hidden}

/* ── 5. Enhance .add button ── */
.add{box-shadow:0 2px 8px rgba(198,10,9,.22);transition:transform .22s cubic-bezier(.34,1.56,.64,1),box-shadow .14s!important}
.add:hover{transform:scale(1.12)!important;box-shadow:0 5px 16px rgba(198,10,9,.34)!important}

/* ── 6. .btn hover dim + press ── */
.btn:not(:disabled){transition:filter .14s,transform .22s cubic-bezier(.34,1.56,.64,1),background .14s!important}
.btn:not(:disabled):hover{filter:brightness(.94)}
.btn:not(:disabled):active{transform:scale(.96)!important;transition:transform .08s ease-in!important}
.btn-primary:not(:disabled):active{background:var(--primary-dark)!important}

/* ── 7. Catalog nav — clear active state (applies desktop & mobile) ── */
.catalog-nav button{transition:background .18s ease,color .14s ease,transform .22s cubic-bezier(.34,1.56,.64,1)!important;position:relative;overflow:hidden}
.catalog-nav button.active{background:var(--primary)!important;color:#fff!important;font-weight:800!important}
.catalog-nav button:not(.active):hover{background:#f5f5f8!important}

/* ── 8. Mobile catalog nav — horizontal pill chips ── */
@media(max-width:780px){
  .catalog-nav{gap:8px!important;padding-bottom:10px!important;scrollbar-width:none}
  .catalog-nav::-webkit-scrollbar{display:none}
  .catalog-nav button{flex:none;padding:9px 16px!important;border-radius:999px!important;background:#f0f0f4!important;font-size:13px!important;font-weight:650;white-space:nowrap}
  .catalog-nav button.active{background:var(--primary)!important;color:#fff!important}
  .product-section{scroll-margin-top:62px!important}
}

/* ── 9. Category buttons — flex column, centered ── */
.category{display:inline-flex!important;flex-direction:column!important;align-items:center!important;justify-content:flex-start!important}
.category img{margin:0 auto!important}
.category b{width:100%;text-align:center}

/* ── 10. Chip active — stronger emphasis ── */
.chip{transition:background .14s,border-color .14s,color .14s,box-shadow .14s}
.chip.active{box-shadow:0 2px 8px rgba(198,10,9,.16);font-weight:800}
.chip:not(.active):hover{background:#f5f5f8;border-color:#d0d0d6}

/* ── 11. Profile shortcuts — flex centrado (corrige 3 itens em grelha de 4 colunas) ── */
/* Independentemente de quantos botões existam, ficam sempre centrados e a mesma largura */
.profile-shortcuts{display:flex!important;flex-wrap:wrap!important;justify-content:center!important;gap:12px!important}
.profile-shortcuts button{flex:1 1 0!important;min-width:96px!important;max-width:none!important;display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;text-align:center!important;gap:6px!important}
.profile-shortcuts b{display:block;text-align:center;width:100%}
.profile-shortcuts small{display:block;text-align:center;width:100%}
@media(max-width:400px){
  .profile-shortcuts button{min-width:80px!important;max-width:120px!important;padding:14px 6px!important}
}

/* ── 12. Product card image — vertical centering ── */
.product-card>img{align-self:center;border-radius:13px!important}

/* ── 13. Cart item — align nicely ── */
.cart-item{align-items:center!important}
.cart-item>img{align-self:flex-start;margin-top:2px}

/* ── 14. Mobile nav — active pill indicator above icon ── */
@media(max-width:780px){
  .mobile-nav button{transition:color .18s ease}
  .mobile-nav button::before{content:'';position:absolute;top:5px;left:50%;transform:translateX(-50%) scaleX(0);width:22px;height:3px;border-radius:2px;background:var(--primary);transition:transform .22s cubic-bezier(.34,1.56,.64,1)}
  .mobile-nav button.active::before{transform:translateX(-50%) scaleX(1)}
  .mobile-nav button.active>span{display:inline-block;transform:scale(1.15);transition:transform .22s cubic-bezier(.34,1.56,.64,1)}
  .mobile-nav button>span{display:inline-block;transform:scale(1);transition:transform .22s cubic-bezier(.34,1.56,.64,1)}
}

/* ── 15. Floating cart — more polished ── */
.floating-cart{border-radius:18px!important;box-shadow:0 14px 32px rgba(198,10,9,.38)!important;transition:transform .14s,box-shadow .14s!important}

/* ── 16. Toast — modern look ── */
.toast{border-radius:14px!important;padding:14px 22px!important;font-weight:650;font-size:14px!important;letter-spacing:.01em}

/* ── 17. Spinner centering ── */
.initial-loader{align-items:center}

/* ── 18. Store card hover — smoother ── */
.store-card{transition:.22s transform cubic-bezier(.34,1.56,.64,1),.2s box-shadow!important}
.store-card:hover{transform:translateY(-4px) scale(1.008)!important;box-shadow:0 14px 32px rgba(0,0,0,.11)!important}

/* ── 19. Modal close button hover ── */
.modal-close:hover{background:rgba(0,0,0,.08)!important;transform:scale(1.05)}

/* ── 20. Segmented control transition ── */
.segmented button{transition:background .18s,color .14s,box-shadow .14s}

/* ── 21. Story ring press ── */
.story:active .story span{transform:scale(.92);transition:transform .08s ease-in}
.story span{transition:transform .22s cubic-bezier(.34,1.56,.64,1)}

/* ── 22. Rating badge uniform size ── */
.rating{min-width:58px;text-align:center;font-weight:750!important}

/* ── 23. Sponsor slide press ── */
.sponsor-slide{transition:transform .22s cubic-bezier(.34,1.56,.64,1),box-shadow .2s;cursor:pointer}
.sponsor-slide:active{transform:scale(.98)!important}

/* ── 24. Payment option press ── */
.payment-option:active{transform:scale(.96)!important}

/* ── 25. Scrollable rails — smooth snap ── */
.category-rail,.horizontal-cards,.promo-strip,.interest-row{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
.category-rail .category,.horizontal-cards .store-card,.promo-strip .promo-card,.interest-row article{scroll-snap-align:start}

/* ── 26. Focus ring modern ── */
button:focus-visible,input:focus-visible,textarea:focus-visible{outline:2.5px solid rgba(198,10,9,.35);outline-offset:2px;border-radius:6px}

/* ── 27. Cart qty button ── */
.qty button:not(:disabled):active,.quantity-picker button:not(:disabled):active{transform:scale(.88)!important}

/* ── 28. Google/social auth button hover ── */
.google-button:hover{background:#f7f7fa!important;box-shadow:0 2px 8px rgba(0,0,0,.08)}

/* ── 29. Order card hover ── */
.order-card{transition:box-shadow .18s,transform .18s}
.order-card:hover{box-shadow:0 8px 24px rgba(0,0,0,.09);transform:translateY(-2px)}

/* ── 30. Profile menu items hover ── */
.profile-menu button,.profile-menu a{transition:background .14s}
.profile-menu button:hover,.profile-menu a:hover{background:#f5f5f8}

/* =========================================================
   Teike Web 3.5 — checkout multi-pagamento e tracking
   ========================================================= */

/* Corrige a row Popular na sua região: a coluna de produtos já não estica
   para acompanhar a altura da grelha de restaurantes. */
.popular-layout{align-items:start!important}
.popular-products{align-self:start!important;align-content:start!important;grid-auto-rows:max-content!important}
.popular-products article{min-height:112px!important;height:auto!important;align-items:center!important;align-content:center!important;gap:8px!important}
.popular-products article h3{align-self:center!important}
.popular-products article b{align-self:end!important}

.payment-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}
.payment-panel-head h2{margin:0 0 4px}
.payment-panel-head p{margin:0;color:var(--muted);font-size:12px}
.test-badge{display:inline-flex;align-items:center;justify-content:center;padding:6px 9px;border-radius:999px;background:#fff4d8;color:#8a5a00;font-size:10px;font-weight:900;letter-spacing:.08em}
.payment-methods{grid-template-columns:repeat(3,minmax(0,1fr))!important}
.payment-option{min-height:105px!important;display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;gap:2px!important;transition:.16s transform,.16s border-color,.16s background!important}
.payment-option:hover{border-color:#c8c8ce;background:#fafafd}
.payment-option.active{box-shadow:0 0 0 3px rgba(198,10,9,.07)}
.payment-option img{width:38px!important;height:38px!important}
.payment-option span{min-width:0;width:100%}
.payment-option small{font-size:9.5px!important}
.payment-detail{border:1px solid #ececf0}
.card-payment-detail{background:linear-gradient(145deg,#fafafa,#f5f5f8)}
.card-brand-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:2px;color:var(--muted);font-size:11px}
.card-brand-row>div{display:flex;gap:7px}
.card-brand-row b{padding:5px 7px;border-radius:6px;background:#fff;border:1px solid var(--line);font-size:10px;color:#1d2c61}
.test-data{margin-top:11px;padding:10px 11px;border-radius:9px;background:#fff8e7;color:#6f5200;font-size:10.5px;line-height:1.5;border:1px solid #f2dfa5}
.wallet-payment>div{display:flex;align-items:center;justify-content:space-between;gap:20px}
.wallet-payment>div>b{font-size:24px;color:var(--primary)}
.wallet-payment p,.cash-payment p{margin:6px 0 0;color:var(--muted);font-size:12px}
.cash-payment{display:flex;align-items:center;gap:13px}
.cash-icon{width:46px;height:46px;display:grid;place-items:center;border-radius:13px;background:#eaf7ef;color:var(--success);font-size:24px}

body.tracking-active{padding-bottom:0!important;overflow:hidden;background:#e8ecef}
body.tracking-active .topbar,body.tracking-active .mobile-nav{display:none!important}
.tracking-page{position:relative;width:100%;height:100vh;overflow:hidden;background:#e8ecef}
.tracking-map{position:absolute;inset:0;background:#e5e9ec}
.tracking-map .leaflet-control-attribution{display:none}
.tracking-top-actions{position:absolute;z-index:20;left:24px;right:24px;top:22px;display:flex;justify-content:space-between;pointer-events:none}
.tracking-top-actions button{pointer-events:auto;min-height:46px;border-radius:999px;background:rgba(255,255,255,.97);box-shadow:0 8px 24px rgba(0,0,0,.13);font-weight:850}
.tracking-top-actions button:first-child{width:46px;font-size:28px;line-height:1}
.tracking-top-actions button:last-child{padding:0 17px;display:flex;align-items:center;gap:8px}
.tracking-top-actions button:last-child span{width:22px;height:22px;display:grid;place-items:center;border:2px solid currentColor;border-radius:50%}
.tracking-sheet{position:absolute;z-index:15;left:24px;bottom:24px;width:min(430px,calc(100% - 48px));max-height:calc(100vh - 112px);overflow:auto;padding:16px 18px 17px;border-radius:24px;background:rgba(255,255,255,.98);box-shadow:0 18px 48px rgba(0,0,0,.22);backdrop-filter:blur(18px)}
.tracking-handle{display:none;width:44px;height:5px;border-radius:4px;background:#dedee2;margin:0 auto 14px}
.tracking-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.tracking-head>div{min-width:0}
.tracking-head small{display:block;margin-bottom:6px;color:var(--muted);font-size:9px;font-weight:800;letter-spacing:.07em}
.tracking-head h1{margin:0;font-size:23px;line-height:1.14}
.tracking-head p{margin:7px 0 0;color:#5f5f65;font-size:15px}
.tracking-status-badge{flex:none;padding:6px 9px;border-radius:999px;background:var(--primary-soft);color:var(--primary);font-size:9px;font-weight:900}
.tracking-subtitle{margin:9px 0 14px;color:var(--muted);font-size:12px;line-height:1.45}
.tracking-progress-wrap{margin-bottom:15px}
.tracking-progress{display:grid;grid-template-columns:repeat(4,1fr);gap:7px;margin:0}
.tracking-progress span{height:6px;border-radius:999px;background:#ececef;overflow:hidden}
.tracking-progress span i{display:block;width:0;height:100%;background:var(--primary);transition:.4s width}
.tracking-progress span.done i{width:100%}
.tracking-progress span.current i{width:100%;animation:trackingPulse 1s ease-in-out infinite;box-shadow:0 0 0 rgba(198,10,9,0)}
.tracking-progress-labels{display:grid;grid-template-columns:repeat(4,1fr);gap:5px;margin-top:7px}
.tracking-progress-labels span{font-size:9px;color:#9a9aa0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tracking-progress-labels span.current{color:var(--primary);font-weight:850}
.tracking-delivery-card{padding:14px;border:1px solid #e7e7eb;border-radius:17px;background:#fff;box-shadow:0 3px 10px rgba(0,0,0,.035)}
.tracking-card-title span,.tracking-card-title b{display:block}
.tracking-card-title span{color:var(--muted);font-size:11px}
.tracking-card-title b{margin-top:4px;font-size:16px}
.tracking-pin{display:inline-flex;align-items:center;gap:6px;margin-top:9px;padding:6px 9px;border-radius:8px;background:var(--primary-soft);color:var(--primary);font-size:11px}
.tracking-actions{display:flex;gap:8px;overflow-x:auto;margin-top:14px;padding-bottom:1px;scrollbar-width:none}
.tracking-actions::-webkit-scrollbar{display:none}
.tracking-actions button{flex:none;min-height:40px;padding:0 13px;border-radius:999px;background:#f3f3f5;font-size:12px;font-weight:800;white-space:nowrap}
.tracking-actions button span{font-size:15px;margin-right:4px}
.tracking-stage-list{display:none!important}
.tracking-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:12px}
.tracking-refresh{min-height:36px;padding:0 12px;border-radius:999px;background:var(--primary-soft);color:var(--primary);font-size:11px;font-weight:850}
.tracking-footer .text-button{font-size:11px}
.tracking-map-pin{width:44px;height:44px;display:grid;place-items:center;border:4px solid #fff;border-radius:50%;background:#fff;box-shadow:0 6px 18px rgba(0,0,0,.25);font-size:21px}
.tracking-map-pin.customer{background:var(--primary);color:#fff}
.tracking-map-fallback{overflow:hidden;background:linear-gradient(135deg,#e8ecef,#dfe5e9)}
.tracking-road{position:absolute;height:70px;border:12px solid #fff;background:#f8f9fa;transform:rotate(-15deg);border-radius:50px;box-shadow:inset 0 0 0 2px #dde2e5}
.tracking-road.road-one{width:120%;left:-10%;top:26%}
.tracking-road.road-two{width:95%;right:-15%;top:54%;transform:rotate(18deg)}
.tracking-road.road-three{width:80%;left:-15%;top:71%;transform:rotate(-7deg)}
.tracking-fallback-pin{position:absolute;z-index:2;width:48px;height:48px;display:grid;place-items:center;border:4px solid #fff;border-radius:50%;background:#fff;box-shadow:0 8px 20px rgba(0,0,0,.2);font-size:22px}
.tracking-fallback-pin.store{left:38%;top:34%}
.tracking-fallback-pin.customer{right:27%;top:58%;background:var(--primary);color:#fff}

@media(max-width:1050px){
  .popular-layout{grid-template-columns:1.35fr 1fr}
  .tracking-sheet{width:min(700px,calc(100% - 32px))}
}
@media(max-width:780px){
  .popular-products{display:flex!important;overflow-x:auto;gap:12px;padding-bottom:4px}
  .popular-products article{flex:0 0 270px;min-height:120px!important}
  .payment-methods{grid-template-columns:repeat(3,minmax(0,1fr))!important}
  .tracking-page{height:100dvh}
  .tracking-top-actions{left:18px;right:18px;top:calc(16px + env(safe-area-inset-top))}
  .tracking-sheet{left:0;bottom:0;transform:none;width:100%;max-height:68dvh;padding:10px 18px calc(20px + env(safe-area-inset-bottom));border-radius:25px 25px 0 0}
  .tracking-head h1{font-size:24px}
  .tracking-head p{font-size:16px}
  .tracking-stage-list{display:none}
  .tracking-delivery-card{padding:16px}
}
@media(max-width:430px){
  .payment-methods{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  .payment-option{min-height:96px!important}
  .tracking-sheet{max-height:72dvh}
  .tracking-head{display:block}
  .tracking-status-badge{display:inline-flex;margin-top:10px}
  .tracking-footer{flex-direction:column;align-items:stretch}
}

/* Tracking compacto — Teike v3.6 */
@media(max-width:1050px){.tracking-sheet{left:20px;bottom:20px;width:min(410px,calc(100% - 40px));transform:none}}
@media(max-width:780px){body.tracking-active{overflow:hidden}.tracking-page{height:100dvh}.tracking-top-actions{left:16px;right:16px;top:calc(14px + env(safe-area-inset-top))}.tracking-sheet{left:0;bottom:0;width:100%;max-height:47dvh;padding:9px 17px calc(16px + env(safe-area-inset-bottom));border-radius:24px 24px 0 0;transform:none}.tracking-handle{display:block}.tracking-head{display:flex}.tracking-head h1{font-size:21px}.tracking-head p{font-size:14px}.tracking-status-badge{display:inline-flex;margin-top:0}.tracking-subtitle{margin-bottom:12px}.tracking-delivery-card{padding:13px}.tracking-progress-labels span{font-size:8px}.tracking-footer{margin-top:10px;flex-direction:row;align-items:center}}
@media(max-width:430px){.tracking-sheet{max-height:50dvh}.tracking-actions button{min-height:38px;padding:0 11px}}


/* Teike Web 3.7 — rota real e simulação acelerada do motorista */
.tracking-driver-marker{--driver-heading:0deg;width:31px;height:65px;display:flex;align-items:center;justify-content:center;pointer-events:none;filter:drop-shadow(0 6px 8px rgba(0,0,0,.24));transform:rotate(var(--driver-heading));transform-origin:50% 50%;transition:transform .16s linear}
.tracking-driver-marker img{display:block;width:31px;height:auto;max-height:65px;object-fit:contain;user-select:none;-webkit-user-drag:none}
.tracking-driver-leaflet-icon{background:transparent!important;border:0!important}
.tracking-route-notice{position:absolute;z-index:8;top:86px;left:50%;transform:translateX(-50%);padding:9px 14px;border-radius:999px;background:rgba(255,255,255,.96);box-shadow:0 6px 18px rgba(0,0,0,.15);font-size:12px;font-weight:750;color:#555;white-space:nowrap}
@media(max-width:780px){.tracking-driver-marker{width:28px;height:58px}.tracking-driver-marker img{width:28px;max-height:58px}.tracking-route-notice{top:78px;max-width:calc(100% - 120px);white-space:normal;text-align:center}}


/* Popular na sua região — blocos iguais e organizados */
.popular-region .section-head{margin-bottom:16px}
.popular-equal-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.popular-equal-card{position:relative;display:flex;flex-direction:column;min-height:360px;background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;box-shadow:0 7px 22px rgba(28,28,33,.05);cursor:pointer;transition:.2s transform,.2s box-shadow}.popular-equal-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.popular-equal-media{position:relative;aspect-ratio:16/9;background:#eee;overflow:hidden}.popular-equal-media img{width:100%;height:100%;object-fit:cover}
.popular-equal-card .favorite{z-index:2}
.popular-equal-body{display:flex;flex-direction:column;gap:10px;padding:14px;flex:1}
.popular-equal-store{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.popular-equal-store h3{margin:0;font-size:16px;line-height:1.25}
.popular-equal-meta{margin:0;color:var(--muted);font-size:13px;line-height:1.35;min-height:36px}
.popular-equal-product{display:grid;grid-template-columns:1fr 76px;align-items:center;gap:12px;padding:10px 12px;border-radius:14px;background:#fafafb;border:1px solid #efeff3;min-height:92px}.popular-equal-product small{display:block;margin-bottom:4px;color:var(--muted);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.03em}.popular-equal-product b{display:block;font-size:14px;line-height:1.3}
.popular-product-thumb{width:76px;height:76px;object-fit:cover;border-radius:12px}
.popular-equal-footer{margin-top:auto;display:flex;align-items:flex-end;justify-content:space-between;gap:10px}.popular-equal-footer strong{font-size:18px;color:var(--primary)}.popular-equal-footer span{max-width:60%;font-size:12px;color:var(--muted);text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media(max-width:1050px){.popular-equal-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:780px){.popular-equal-grid{grid-template-columns:1fr;gap:15px}.popular-equal-card{min-height:auto}.popular-equal-footer span{max-width:55%}}

@keyframes trackingPulse{0%,100%{opacity:1;filter:saturate(100%);box-shadow:0 0 0 0 rgba(198,10,9,.10)}50%{opacity:.35;filter:saturate(145%);box-shadow:0 0 0 4px rgba(198,10,9,.18)}}


/* Teike Web 3.9 — footer e páginas institucionais */
.site-footer{margin-top:72px;background:#151518;color:#fff}.site-footer[hidden]{display:none!important}.site-footer-main{width:min(1460px,calc(100% - 48px));margin:auto;display:grid;grid-template-columns:1.45fr repeat(3,minmax(145px,.75fr)) 1.2fr;gap:38px;padding:58px 0 42px}.footer-brand img{width:148px;max-height:48px;object-fit:contain;object-position:left center}.footer-brand p{max-width:280px;margin:18px 0 8px;color:#c8c8ce;line-height:1.55}.footer-brand strong{display:block;color:#fff;font-size:13px}.footer-socials{display:flex;gap:10px;margin-top:22px}.footer-social-link{height:42px;display:inline-flex;align-items:center;gap:8px;padding:0 12px;border:1px solid #34343a;border-radius:12px;background:#202025;color:#fff;text-decoration:none;font-size:12px;font-weight:800}.footer-social-link svg{width:20px;height:20px;fill:currentColor}.footer-social-link:hover{border-color:var(--primary);background:#2b2022}.footer-social-link.unavailable{opacity:.55;cursor:not-allowed}.footer-column h3,.footer-apps h3{margin:0 0 17px;font-size:14px}.footer-column button,.footer-download-page{display:block;width:max-content;max-width:100%;margin:0 0 12px;padding:0;background:none;color:#b9b9c0;text-align:left;font-size:13px}.footer-column button:hover,.footer-download-page:hover{color:#fff}.footer-apps p{margin:0 0 16px;color:#b9b9c0;font-size:13px;line-height:1.45}.store-badge{position:relative;width:190px;min-height:57px;margin:0 0 10px;display:flex;align-items:center;gap:11px;padding:8px 13px;border:1px solid #45454c;border-radius:12px;background:#050506;color:#fff;text-decoration:none;text-align:left}.store-badge svg{flex:none;width:30px;height:30px;fill:#fff}.store-badge span{display:grid}.store-badge small{font-size:9px;line-height:1.1;text-transform:uppercase;letter-spacing:.03em}.store-badge b{font-size:17px;line-height:1.1}.store-badge em{position:absolute;right:7px;top:5px;padding:2px 5px;border-radius:5px;background:#2f2f34;color:#aaa;font-size:8px;font-style:normal}.store-badge.unavailable{opacity:.64;cursor:not-allowed}.footer-download-page{margin-top:13px;color:#fff;text-decoration:underline;text-underline-offset:4px}.site-footer-bottom{width:min(1460px,calc(100% - 48px));margin:auto;padding:20px 0 26px;display:flex;justify-content:space-between;gap:20px;border-top:1px solid #303036;color:#97979f;font-size:11px}.site-footer-bottom a{color:#ddd;text-decoration:none}.site-footer-bottom a:hover{color:#fff}
.info-page{padding-bottom:30px}.info-hero{margin:8px 0 28px;padding:54px clamp(24px,5vw,72px);border-radius:25px;background:linear-gradient(135deg,#c60a09,#740000);color:#fff;overflow:hidden}.info-hero>span{display:inline-block;margin-bottom:11px;padding:5px 9px;border-radius:999px;background:rgba(255,255,255,.16);font-size:10px;font-weight:900;letter-spacing:.07em;text-transform:uppercase}.info-hero h1{max-width:800px;margin:0;font-size:clamp(34px,5vw,64px);line-height:1.02}.info-hero p{max-width:720px;margin:17px 0 0;color:#ffe5e5;font-size:17px;line-height:1.55}.info-section{margin:20px 0;padding:28px;border:1px solid var(--line);border-radius:20px;background:#fff;box-shadow:0 7px 22px rgba(28,28,33,.04)}.info-section h2{margin:0 0 14px;font-size:24px}.info-section h3{margin:0 0 7px}.info-section p,.info-section li{color:#626269;line-height:1.7}.info-section ul{padding-left:22px}.value-grid,.steps-grid,.contact-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.value-grid article,.steps-grid article,.contact-grid article{padding:20px;border:1px solid #ececf0;border-radius:16px;background:#fafafb}.value-grid article>span,.contact-grid article>span{width:42px;height:42px;margin-bottom:14px;display:grid;place-items:center;border-radius:13px;background:var(--primary-soft);color:var(--primary);font-size:22px}.steps-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.steps-grid article>b{width:38px;height:38px;margin-bottom:14px;display:grid;place-items:center;border-radius:50%;background:var(--primary);color:#fff;font-size:15px}.value-grid article p,.steps-grid article p,.contact-grid article p{margin:0;font-size:13px}.faq-list{display:grid;gap:10px}.faq-list details{padding:16px 18px;border:1px solid #e8e8ec;border-radius:14px;background:#fafafb}.faq-list summary{cursor:pointer;font-weight:850}.faq-list details p{margin:12px 0 0}.contact-form{display:grid;gap:15px}.contact-form select{width:100%;min-height:48px;padding:0 12px;border:1px solid var(--line);border-radius:11px;background:#fff}.app-download-hero{margin:20px 0;padding:34px;display:grid;grid-template-columns:150px 1fr;align-items:center;gap:32px;border-radius:22px;background:#17171a;color:#fff}.app-download-hero>img{width:150px;height:150px;object-fit:contain}.app-download-hero h2{margin:0 0 8px;font-size:32px}.app-download-hero p{margin:0 0 18px;color:#c9c9cf}.download-badges{display:flex;flex-wrap:wrap;gap:10px}.download-badges .store-badge{margin:0}
body.auth-gated .site-footer{display:none!important}
@media(max-width:1150px){.site-footer-main{grid-template-columns:1.4fr repeat(2,1fr);gap:34px}.footer-apps{grid-column:2/4}.steps-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:780px){.site-footer{margin-top:42px}.site-footer-main{width:calc(100% - 32px);grid-template-columns:1fr 1fr;gap:32px 20px;padding:40px 0 30px}.footer-brand,.footer-apps{grid-column:1/-1}.footer-column button{font-size:12px}.site-footer-bottom{width:calc(100% - 32px);display:grid;padding-bottom:calc(94px + env(safe-area-inset-bottom))}.value-grid,.contact-grid,.steps-grid{grid-template-columns:1fr}.info-hero{margin:0 -14px 22px;border-radius:0;padding:42px 22px}.info-hero h1{font-size:38px}.info-section{padding:21px}.app-download-hero{grid-template-columns:1fr;text-align:center}.app-download-hero>img{margin:auto}.download-badges{justify-content:center}}
@media(max-width:430px){.site-footer-main{grid-template-columns:1fr}.footer-brand,.footer-apps{grid-column:auto}.site-footer-bottom{font-size:10px}.store-badge{width:100%}.app-download-hero{padding:25px 18px}}

/* ═══════════════════════════════════════════════════════════════
   TEIKE WEB 4.0 — marketplace full-width, lojas e drawer lateral
   Baseado na navegação atual da app: Restaurantes, Lojas, Mapa,
   Carrinho e Perfil. Mantém a identidade vermelha da Teike.
   ═══════════════════════════════════════════════════════════════ */
:root{--market-sidebar:224px;--market-gutter:24px;--topbar:72px;--content:none}
body{background:#fff}
.marketplace-topbar{height:var(--topbar);padding:0 22px;gap:14px;background:rgba(255,255,255,.97)}
.menu-button{width:42px;height:42px;display:grid;place-content:center;gap:5px;border-radius:50%;background:#fff}
.menu-button:hover{background:#f3f3f5}.menu-button span{display:block;width:20px;height:2px;border-radius:2px;background:#171717}
.marketplace-topbar .brand img{width:94px;height:38px}.desktop-market-switch{flex:none}.market-switch{display:inline-flex;align-items:center;gap:3px;padding:4px;border-radius:999px;background:#f1f1f4}
.market-switch button{min-height:34px;padding:0 15px;border-radius:999px;background:transparent;font-size:12px;font-weight:800;color:#5e5e65}.market-switch button.active{background:#fff;color:var(--primary);box-shadow:0 2px 8px rgba(0,0,0,.10)}
.marketplace-topbar .location{min-width:220px;max-width:275px}.marketplace-topbar .search{max-width:none;min-width:220px}.marketplace-topbar .account-button,.marketplace-topbar .cart-button{flex:none}
.site-main{min-height:calc(100vh - var(--topbar));transition:margin-left .2s ease}.page{width:100%;max-width:none;margin:0;padding:24px var(--market-gutter) 78px}.home-page{padding-top:15px}
body.has-category-sidebar .site-main,body.has-category-sidebar .site-footer{margin-left:var(--market-sidebar)}
body.auth-gated .category-sidebar{display:none!important}body.auth-gated .site-main,body.auth-gated .site-footer{margin-left:0!important}

/* Sidebar permanente de categorias */
.category-sidebar{position:fixed;z-index:650;top:var(--topbar);left:0;bottom:0;width:var(--market-sidebar);padding:15px 12px 24px;background:#fff;border-right:1px solid #ececf0;overflow-y:auto;scrollbar-width:thin}
.category-sidebar[hidden]{display:none!important}.category-sidebar-nav{display:grid;gap:3px}.sidebar-category{width:100%;min-height:44px;display:grid;grid-template-columns:30px 1fr;align-items:center;gap:10px;padding:7px 10px;border-radius:10px;background:transparent;text-align:left;color:#45454d;font-size:13px;font-weight:680}
.sidebar-category:hover{background:#f5f5f7}.sidebar-category.active{background:var(--primary-soft);color:var(--primary);box-shadow:inset 3px 0 0 var(--primary)}
.sidebar-category-icon{width:28px;height:28px;display:grid;place-items:center;border-radius:8px;object-fit:contain;background:#fff7f6;padding:4px}.sidebar-category .category-symbol{font-size:17px;font-weight:900}.sidebar-divider{height:1px;margin:10px 7px;background:#ededf1}

/* Drawer da conta */
.drawer-backdrop{position:fixed;z-index:1800;inset:0;background:rgba(18,18,22,.52);opacity:0;transition:opacity .2s ease;backdrop-filter:blur(2px)}.drawer-backdrop[hidden]{display:none}.drawer-backdrop.open{opacity:1}
.account-drawer{width:min(390px,92vw);height:100%;padding:24px 20px 30px;background:#fff;box-shadow:20px 0 50px rgba(0,0,0,.2);overflow:auto;transform:translateX(-18px);animation:drawerIn .22s ease forwards}.drawer-head{position:relative;display:grid;grid-template-columns:64px 1fr auto;align-items:center;gap:14px;padding:7px 2px 22px;border-bottom:1px solid #ededf1}
.drawer-avatar{width:64px;height:64px;display:grid;place-items:center;border-radius:50%;overflow:hidden;background:var(--primary-soft);color:var(--primary);font-size:24px;font-weight:900}.drawer-avatar img{width:100%;height:100%;object-fit:cover}.drawer-head h2{margin:0 0 4px;font-size:22px}.drawer-head>div:nth-child(2)>button{padding:0;background:none;color:var(--primary);font-weight:800}.drawer-close{width:38px;height:38px;border-radius:50%;background:#f4f4f6;font-size:23px}.drawer-menu{display:grid;padding:18px 0}.drawer-menu>button{min-height:50px;display:grid;grid-template-columns:34px 1fr auto;align-items:center;gap:10px;padding:0 10px;border-radius:11px;background:transparent;text-align:left;font-size:15px;font-weight:720}.drawer-menu>button:hover{background:#f6f6f8}.drawer-menu>button>span{font-size:20px;text-align:center}.drawer-menu small{color:var(--muted);font-size:10px}.drawer-logout{margin-top:10px;color:#666!important;border-top:1px solid #ededf1;border-radius:0!important;padding-top:12px!important}
@keyframes drawerIn{to{transform:translateX(0)}}

/* Homepage e páginas de marketplace */
.marketplace-page .section{margin:30px 0}.marketplace-title{display:flex;align-items:end;justify-content:space-between}.market-category-rail,.store-type-rail{display:flex;gap:19px;overflow-x:auto;padding:5px 2px 12px;scrollbar-width:none}.market-category-rail::-webkit-scrollbar,.store-type-rail::-webkit-scrollbar{display:none}
.market-category,.store-type-pill{flex:0 0 84px;display:grid;justify-items:center;gap:7px;padding:5px 2px;background:transparent;text-align:center}.market-category img,.store-type-pill img,.store-type-pill>.category-symbol{width:58px;height:58px;display:grid;place-items:center;border-radius:50%;object-fit:contain;background:#fff4f3;padding:9px}.market-category b,.store-type-pill b{max-width:90px;font-size:11px;line-height:1.2;white-space:normal}.store-type-pill.active img,.store-type-pill.active>.category-symbol{box-shadow:0 0 0 3px var(--primary);background:#fff}.store-type-pill.active b{color:var(--primary)}
.mobile-market-switch{display:none}.marketplace-promotions{margin-top:10px!important}.promotion-showcase{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.promotion-showcase .promo-card{height:190px;margin:0}.promotion-showcase .promo-card h3{font-size:19px}
.market-store-row{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(260px,320px);grid-template-rows:1fr;gap:16px;overflow-x:auto;padding:2px 2px 11px;scrollbar-width:thin;scroll-snap-type:x proximity}.market-store-row .store-card{min-width:260px;scroll-snap-align:start}.market-store-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}
.marketplace-page .store-card{border-radius:15px;box-shadow:none}.marketplace-page .store-card:hover{box-shadow:0 10px 25px rgba(25,25,32,.10)}.marketplace-page .store-cover-wrap{aspect-ratio:1.72}.marketplace-page .store-body{padding:11px 12px 13px}.marketplace-page .store-title h3{font-size:15px}.marketplace-page .store-meta{font-size:12px}.marketplace-page .store-tags{font-size:11px}
.marketplace-page .section-head{align-items:center}.marketplace-page .section-head h2{font-size:24px}.marketplace-page .link-button{font-size:13px}

/* Catálogo mais compacto */
.catalog-marketplace{padding-top:0}.catalog-cover{position:relative;height:230px;margin:0 calc(var(--market-gutter)*-1);overflow:hidden;background:#eee}.catalog-cover>img{width:100%;height:100%;object-fit:cover}.catalog-cover:after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.24),transparent 65%)}.catalog-cover .back-float,.catalog-cover .store-actions{z-index:2}
.catalog-store-header{position:relative;display:grid;grid-template-columns:88px minmax(0,1fr) minmax(300px,430px);align-items:center;gap:18px;padding:18px 4px 16px}.catalog-store-logo{width:88px;height:88px;margin-top:-52px;z-index:2;border:4px solid #fff;border-radius:18px;overflow:hidden;background:#fff;box-shadow:0 8px 22px rgba(0,0,0,.16)}.catalog-store-logo img{width:100%;height:100%;object-fit:cover}.catalog-store-copy h1{margin:5px 0 5px;font-size:31px}.catalog-store-copy p,.catalog-store-copy small{color:var(--muted)}.catalog-search{height:45px;display:flex;align-items:center;gap:8px;padding:0 14px;border-radius:999px;background:#f2f2f5}.catalog-search input{width:100%;border:0;outline:0;background:none}
.catalog-service-bar{display:grid;grid-template-columns:auto 1fr 1fr;align-items:center;gap:0;margin:4px 0 22px;padding:12px 18px;border:1px solid var(--line);border-radius:14px;background:#fff}.catalog-service-bar>div:not(:first-child){padding:0 24px;border-left:1px solid var(--line);text-align:center}.catalog-service-bar b,.catalog-service-bar small{display:block}.catalog-service-bar small{margin-top:3px;color:var(--muted);font-size:10px}
.catalog-savings{margin:20px 0 28px}.catalog-promo-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.catalog-promo-row .promo-card{height:150px}.compact-catalog-layout{display:grid;grid-template-columns:220px minmax(0,1fr);gap:26px;align-items:start}.compact-catalog-layout .catalog-nav{position:sticky;top:calc(var(--topbar) + 15px);display:grid;gap:3px;padding:10px 0;border:0;border-radius:0;background:transparent;box-shadow:none}.compact-catalog-layout .catalog-nav strong{padding:8px 12px 12px;font-size:13px}.compact-catalog-layout .catalog-nav button{text-align:left;padding:11px 12px;border-left:3px solid transparent;border-radius:0;background:transparent}.compact-catalog-layout .catalog-nav button.active{background:#f2f2f4!important;color:var(--ink)!important;border-left-color:var(--primary)}
.compact-product-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.compact-product-card{display:flex;flex-direction:column;min-height:0;border-radius:14px;background:#fff;border:1px solid #ececf0;box-shadow:none;overflow:hidden}.compact-product-card:hover{box-shadow:0 10px 25px rgba(25,25,32,.10)}.product-media{position:relative;aspect-ratio:1.25;background:#f0f0f2;overflow:hidden}.product-media .product-image{width:100%;height:100%;object-fit:cover}.product-media .add{position:absolute;right:10px;bottom:10px;width:38px;height:38px;border-radius:50%;background:#fff;color:var(--primary);font-size:25px;box-shadow:0 5px 15px rgba(0,0,0,.18)}.product-card-body{display:flex;flex-direction:column;gap:5px;padding:11px 12px 13px}.product-card-body h3{margin:0;font-size:14px;line-height:1.3}.product-card-body p{display:-webkit-box;min-height:34px;margin:0;color:var(--muted);font-size:11px;line-height:1.45;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-card-body b{margin-top:2px;color:var(--primary);font-size:14px}.product-section{margin-bottom:32px}.product-section .section-head h2{font-size:24px}

/* Footer segue a largura útil */
.site-footer{margin-top:40px}.site-footer-main,.site-footer-bottom{width:calc(100% - 48px);max-width:none}

/* Tablets */
@media(max-width:1280px){:root{--market-sidebar:205px}.marketplace-topbar .location{min-width:180px;max-width:220px}.market-store-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.compact-product-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.promotion-showcase{grid-template-columns:repeat(2,minmax(0,1fr))}.promotion-showcase .promo-card:last-child{display:none}}
@media(max-width:1050px){.desktop-market-switch{display:none}.category-sidebar{display:none!important}body.has-category-sidebar .site-main,body.has-category-sidebar .site-footer{margin-left:0}.marketplace-topbar .location{display:none}.market-store-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.catalog-store-header{grid-template-columns:74px 1fr}.catalog-store-logo{width:74px;height:74px}.catalog-search{grid-column:1/-1}.compact-catalog-layout{grid-template-columns:180px minmax(0,1fr)}.compact-product-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}

/* Mobile */
@media(max-width:780px){:root{--topbar:62px;--market-gutter:14px}.marketplace-topbar{display:flex!important;height:var(--topbar);padding:0 12px;gap:9px}.marketplace-topbar .brand img{width:72px}.marketplace-topbar .search{height:40px;min-width:0;padding:0 11px}.marketplace-topbar .account-button{display:none}.marketplace-topbar .cart-button{width:40px;height:40px}.menu-button{width:40px;height:40px}.site-main{min-height:calc(100dvh - var(--topbar))}.page{padding:17px var(--market-gutter) 90px}.mobile-home-header{display:none}.mobile-market-switch{display:block;margin-bottom:13px}.home-search{display:none}.market-category-rail,.store-type-rail{margin-left:-14px;margin-right:-14px;padding-left:14px}.market-category,.store-type-pill{flex-basis:75px}.market-category img,.store-type-pill img,.store-type-pill>.category-symbol{width:52px;height:52px}.promotion-showcase{display:flex;overflow-x:auto;gap:12px;margin-left:-14px;margin-right:-14px;padding:0 14px 8px}.promotion-showcase .promo-card,.promotion-showcase .promo-card:last-child{display:block;flex:0 0 84vw;height:172px}.market-store-row{grid-auto-columns:76vw;margin-left:-14px;margin-right:-14px;padding-left:14px}.market-store-grid{grid-template-columns:1fr;gap:15px}.marketplace-page .section-head h2{font-size:21px}.catalog-cover{height:180px}.catalog-store-header{display:grid;grid-template-columns:65px 1fr;gap:12px;padding-top:12px}.catalog-store-logo{width:65px;height:65px;margin-top:-38px;border-radius:14px}.catalog-store-copy h1{font-size:23px}.catalog-search{grid-column:1/-1}.catalog-service-bar{grid-template-columns:1fr 1fr;padding:10px 12px}.catalog-service-bar>.market-switch{grid-column:1/-1;margin-bottom:10px}.catalog-service-bar>div:not(:first-child){padding:0 8px}.catalog-promo-row{display:flex;overflow-x:auto;margin-left:-14px;margin-right:-14px;padding:0 14px}.catalog-promo-row .promo-card{flex:0 0 82vw}.compact-catalog-layout{display:block}.compact-catalog-layout .catalog-nav{position:sticky;z-index:10;top:var(--topbar);display:flex;overflow-x:auto;margin:0 -14px;padding:8px 14px;background:#fff;border-bottom:1px solid var(--line)}.compact-catalog-layout .catalog-nav strong{display:none}.compact-catalog-layout .catalog-nav button{flex:none;border:0;border-radius:999px!important;padding:9px 13px}.compact-catalog-layout .catalog-nav button.active{background:var(--primary)!important;color:#fff!important}.compact-product-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:11px}.product-card-body{padding:9px 10px 11px}.product-card-body h3{font-size:13px}.product-card-body p{font-size:10px;min-height:30px}.product-media .add{right:7px;bottom:7px;width:34px;height:34px}.site-footer-main,.site-footer-bottom{width:calc(100% - 32px)}}
@media(max-width:430px){.marketplace-topbar .brand{display:none}.market-store-row{grid-auto-columns:84vw}.compact-product-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.catalog-service-bar{grid-template-columns:1fr 1fr}.account-drawer{width:92vw}.marketplace-page .store-title h3{font-size:14px}}

/* =========================================================
   Teike Web 4.1 — paridade de checkout, endereço e entrega
   ========================================================= */
.cart-main-stack{display:grid;gap:18px}.cart-order-options{display:grid;gap:14px}.cart-order-options h2{margin-bottom:0}.cart-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px 0;border-bottom:1px solid var(--line)}.cart-toggle-row span{min-width:0}.cart-toggle-row b,.cart-toggle-row small{display:block}.cart-toggle-row small{margin-top:4px;color:var(--muted);font-size:12px;line-height:1.4}.cart-toggle-row input{width:21px;height:21px;accent-color:var(--primary)}.cart-address-row{width:100%;border:1px solid var(--line);border-radius:15px;background:#fff;text-align:left}.fee-info-button{padding:0;background:none;color:var(--muted);font-weight:900}.discount-row b{color:var(--primary)}
.route-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:12px 0}.route-metrics>div,.pickup-estimate{padding:12px 14px;border-radius:13px;background:#f6f6f8}.route-metrics span,.route-metrics b,.pickup-estimate span,.pickup-estimate b{display:block}.route-metrics span,.pickup-estimate span{color:var(--muted);font-size:11px}.route-metrics b,.pickup-estimate b{margin-top:3px;font-size:14px}.delivery-speed-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:13px}.delivery-speed-card{position:relative;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:11px;min-height:92px;padding:14px;border:1.5px solid var(--line);border-radius:16px;background:#fff;text-align:left}.delivery-speed-card.active{border-color:var(--primary);background:var(--primary-soft);box-shadow:0 0 0 3px rgba(198,10,9,.06)}.delivery-speed-card .speed-radio,.delivery-speed-card .speed-icon{width:28px;height:28px;display:grid;place-items:center;border-radius:50%;background:#f1f1f4;color:var(--primary);font-weight:900}.delivery-speed-card div b,.delivery-speed-card div small,.delivery-speed-card div em{display:block}.delivery-speed-card div small{margin-top:4px;font-size:12px}.delivery-speed-card div em{margin-top:3px;color:var(--muted);font-size:10px;font-style:normal}.delivery-speed-card strong{color:var(--primary);white-space:nowrap}.full-option{width:100%;text-align:left}.checkout-photo-strip{display:flex;align-items:center;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--line);overflow-x:auto}.checkout-photo-strip img{flex:0 0 48px;width:48px;height:48px;border-radius:10px;object-fit:cover}.checkout-photo-strip span{color:var(--muted);font-size:12px}.checkout-terms{margin:12px 0 0;color:var(--muted);font-size:11px;line-height:1.45}.checkout-terms button{padding:0;background:none;color:var(--primary);font-weight:800}.fee-info-dialog{max-width:520px}.fee-explanation{padding:14px 0;border-bottom:1px solid var(--line)}.fee-explanation:last-child{border-bottom:0}.fee-explanation p{margin:5px 0 0;color:var(--muted);line-height:1.55}

/* Map picker semelhante à app */
.map-picker-modal{width:100vw!important;max-width:none!important;height:100dvh!important;max-height:none!important;margin:0!important;padding:0!important;border:0!important;border-radius:0!important;background:#fff!important}.map-picker-modal::backdrop{background:rgba(0,0,0,.34)}.map-picker-shell{height:100dvh;display:grid;grid-template-rows:auto auto auto minmax(300px,1fr) auto;background:#fff}.map-picker-shell>header{display:flex;align-items:center;gap:14px;padding:15px 20px;border-bottom:1px solid var(--line)}.map-picker-shell>header button{width:42px;height:42px;border-radius:50%;background:#f1f1f4;font-size:25px}.map-picker-shell>header h2{margin:0;font-size:21px}.map-picker-shell>header p{margin:3px 0 0;color:var(--muted);font-size:12px}.map-picker-search{position:relative;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:9px;margin:12px 20px;padding:0 10px 0 15px;border:1px solid var(--line);border-radius:15px;background:#f5f5f7;z-index:30}.map-picker-search input{height:48px;border:0;outline:0;background:none}.map-picker-search>button{width:37px;height:37px;border-radius:50%;background:#fff;color:var(--primary);font-size:19px}.address-suggestions{position:absolute;left:0;right:0;top:55px;max-height:280px;overflow:auto;padding:7px;border:1px solid var(--line);border-radius:14px;background:#fff;box-shadow:0 16px 35px rgba(0,0,0,.17)}.address-suggestions button{width:100%;display:block;padding:11px 12px;border-radius:10px;background:#fff;text-align:left}.address-suggestions button:hover{background:#f5f5f7}.address-suggestions b,.address-suggestions small{display:block}.address-suggestions small{margin-top:3px;color:var(--muted)}.recent-addresses{padding:0 20px 10px}.recent-addresses>b{display:block;margin-bottom:7px;font-size:12px}.recent-addresses>div{display:flex;gap:9px;overflow-x:auto}.recent-addresses button{flex:0 0 220px;display:flex;align-items:center;gap:9px;padding:10px;border:1px solid var(--line);border-radius:13px;background:#fff;text-align:left}.recent-addresses button>span:first-child{width:32px;height:32px;display:grid;place-items:center;border-radius:50%;background:var(--primary-soft);color:var(--primary)}.recent-addresses b,.recent-addresses small{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.recent-addresses small{margin-top:2px;color:var(--muted);font-size:10px}.map-picker-stage{position:relative;min-height:320px;overflow:hidden;background:#e7ebed}.map-picker-stage>#addressPickerMap{position:absolute;inset:0}.fixed-map-pin{position:absolute;z-index:10;left:50%;top:50%;transform:translate(-50%,-100%);pointer-events:none}.fixed-map-pin:after{content:"";display:block;width:14px;height:5px;margin:1px auto 0;border-radius:50%;background:rgba(0,0,0,.24);filter:blur(2px)}.fixed-map-pin span{width:48px;height:48px;display:grid;place-items:center;border:4px solid #fff;border-radius:50% 50% 50% 0;background:var(--primary);color:#fff;box-shadow:0 8px 20px rgba(0,0,0,.25);transform:rotate(-45deg)}.fixed-map-pin span::first-letter{transform:rotate(45deg)}.map-picker-loading{position:absolute;z-index:12;left:50%;top:18px;transform:translateX(-50%);padding:8px 13px;border-radius:999px;background:rgba(255,255,255,.95);box-shadow:0 5px 18px rgba(0,0,0,.12);font-size:12px;font-weight:750}.address-confirm-card{padding:15px 20px calc(18px + env(safe-area-inset-bottom));border-top:1px solid var(--line);background:#fff;box-shadow:0 -9px 28px rgba(0,0,0,.08)}.selected-address{display:flex;align-items:flex-start;gap:11px;margin-bottom:12px}.selected-address>span{width:35px;height:35px;display:grid;place-items:center;border-radius:50%;background:var(--primary-soft);color:var(--primary)}.selected-address small,.selected-address b,.selected-address em{display:block}.selected-address small{color:var(--muted);font-size:10px}.selected-address b{margin-top:3px}.selected-address em{margin-top:3px;color:#999;font-size:10px;font-style:normal}

/* Instruções completas e anexos */
.delivery-instructions-modal{width:min(760px,calc(100% - 24px));max-width:760px}.delivery-instructions-form{max-width:none;max-height:88dvh;overflow:auto}.dialog-heading p,.section-inline-title p{color:var(--muted)}.delivery-instructions-form section{margin:20px 0;padding-top:18px;border-top:1px solid var(--line)}.delivery-instructions-form section:first-of-type{border-top:0;padding-top:0}.building-type-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px}.building-type-grid button{min-height:76px;padding:10px 8px;border:1px solid var(--line);border-radius:12px;background:#fff}.building-type-grid button.active{border-color:var(--primary);background:var(--primary-soft);color:var(--primary)}.building-type-grid b,.building-type-grid small{display:block}.building-type-grid small{margin-top:4px;color:var(--muted);font-size:9px;line-height:1.3}.building-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:14px}.building-fields .field:last-child:nth-child(odd){grid-column:1/-1}.handoff-options{display:grid;gap:8px}.handoff-option{display:flex;align-items:center;gap:10px;padding:13px;border:1px solid var(--line);border-radius:13px;cursor:pointer}.handoff-option.active{border-color:var(--primary);background:var(--primary-soft)}.handoff-option input{accent-color:var(--primary)}.handoff-option b,.handoff-option small{display:block}.handoff-option small{margin-top:3px;color:var(--muted);font-size:11px}.section-inline-title{display:flex;align-items:center;justify-content:space-between;gap:12px}.section-inline-title h3,.section-inline-title p{margin-bottom:3px}.delivery-photo-add{position:relative;display:inline-flex;align-items:center;justify-content:center}.delivery-photo-preview{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:13px}.delivery-photo-item{position:relative;padding:7px;border:1px solid var(--line);border-radius:13px;background:#fff}.delivery-photo-item img{width:100%;aspect-ratio:1.2;object-fit:cover;border-radius:9px}.delivery-photo-item input{width:100%;margin-top:6px;padding:7px;border:1px solid var(--line);border-radius:8px;font-size:10px}.delivery-photo-item button{position:absolute;right:3px;top:3px;width:26px;height:26px;border-radius:50%;background:#fff;color:var(--danger);box-shadow:0 2px 9px rgba(0,0,0,.2)}.photo-empty{grid-column:1/-1;margin:0;padding:18px;border:1px dashed #ccc;border-radius:12px;color:var(--muted);text-align:center}.delivery-phone-row{display:grid;grid-template-columns:2fr 1fr;gap:12px}.delivery-phones-form>p{color:var(--muted)}.delivery-phones-form select{height:46px;padding:0 10px;border:1px solid var(--line);border-radius:10px;background:#fff}

@media(max-width:780px){.delivery-speed-grid{grid-template-columns:1fr}.route-metrics{grid-template-columns:1fr 1fr}.map-picker-shell{grid-template-rows:auto auto auto minmax(250px,1fr) auto}.map-picker-shell>header,.address-confirm-card{padding-left:14px;padding-right:14px}.map-picker-search{margin-left:14px;margin-right:14px}.recent-addresses{padding-left:14px;padding-right:14px}.address-confirm-card .two-fields{grid-template-columns:1fr 1fr}.delivery-instructions-modal{width:100%;max-width:none;height:100dvh;max-height:none;margin:0;border-radius:0}.delivery-instructions-form{height:100dvh;max-height:none;border-radius:0;padding:20px 15px 30px}.building-type-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.building-fields{grid-template-columns:1fr}.building-fields .field{grid-column:auto!important}.delivery-photo-preview{grid-template-columns:repeat(2,minmax(0,1fr))}.section-inline-title{align-items:flex-start;flex-direction:column}.delivery-phone-row{grid-template-columns:1fr}.cart-order-options{padding:17px}}

/* ═══════════════════════════════════════════════════════════════
   TEIKE WEB 4.2 — pesquisa contextual e diálogo de produto
   ═══════════════════════════════════════════════════════════════ */

/* Pesquisa global: painel contínuo por baixo da barra principal */
.search-page{
  position:fixed!important;
  z-index:740;
  top:var(--topbar);
  right:0;
  bottom:0;
  left:var(--market-sidebar);
  width:auto!important;
  max-width:none!important;
  margin:0!important;
  padding:0!important;
  overflow:hidden;
  background:#fff;
  box-shadow:0 18px 45px rgba(18,18,24,.14);
}
body:not(.has-category-sidebar) .search-page{left:0}
.search-scope-tabs{
  min-height:57px;
  display:flex;
  align-items:end;
  gap:28px;
  padding:0 24px;
  border-bottom:1px solid #e7e7eb;
  background:#fff;
}
.search-scope-tabs>button:not(.search-close){
  height:57px;
  padding:0 1px;
  border-radius:0;
  background:transparent;
  color:#5d5d64;
  font-size:13px;
  font-weight:760;
  overflow:visible;
}
.search-scope-tabs>button:not(.search-close)::after{
  content:"";
  position:absolute;
  right:0;
  bottom:0;
  left:0;
  height:3px;
  border-radius:3px 3px 0 0;
  background:transparent;
}
.search-scope-tabs>button.active{color:#161619}
.search-scope-tabs>button.active::after{background:var(--primary)}
.search-scope-tabs .search-close{
  width:38px;
  height:38px;
  margin:0 0 9px auto;
  border-radius:50%;
  background:#f1f1f4;
  font-size:22px;
  line-height:1;
}
.search-sheet{
  height:calc(100dvh - var(--topbar) - 57px);
  overflow-y:auto;
  overscroll-behavior:contain;
  background:#fff;
  padding-bottom:52px;
}
.search-suggestions-card,.search-results-block{
  padding:24px clamp(24px,4vw,64px);
}
.search-suggestions-card{border-bottom:1px solid #ececf0}
.search-block-title{
  min-height:28px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-bottom:8px;
}
.search-block-title h2{margin:0;font-size:17px}
.search-block-title p{margin:4px 0 0;color:var(--muted);font-size:12px}
.search-block-title>button{padding:7px 0;background:transparent;color:var(--primary);font-size:12px;font-weight:800}
.search-row{
  width:100%;
  min-height:64px;
  display:grid;
  grid-template-columns:38px minmax(0,1fr) auto;
  align-items:center;
  gap:14px;
  padding:10px 2px;
  border-bottom:1px solid #ededf0;
  border-radius:0;
  background:#fff;
  text-align:left;
}
.search-row:hover{background:#fafafb}
.search-row-icon{
  width:34px;
  height:34px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:#f2f2f5;
  color:#4e4e55;
  font-size:17px;
}
.search-row b,.search-row small{display:block}
.search-row b{font-size:15px}
.search-row small{margin-top:3px;color:var(--muted);font-size:11px}
.search-row i{color:#8b8b92;font-style:normal;font-size:17px}
.search-start-hint{
  min-height:150px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:15px;
  padding:28px;
  text-align:left;
  color:var(--muted);
}
.search-start-hint>span{
  width:48px;
  height:48px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:#f1f1f4;
  color:var(--primary);
  font-size:24px;
}
.search-start-hint b{color:var(--ink)}
.search-start-hint p{margin:4px 0 0;font-size:12px}
.search-results-block{background:#fafafb}
.search-result-group{margin-top:24px}
.search-result-group>h3{margin:0 0 13px;font-size:15px}
.search-store-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
.search-products-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.search-product-result{
  min-width:0;
  display:grid;
  grid-template-columns:78px minmax(0,1fr) auto;
  align-items:center;
  gap:12px;
  padding:10px;
  border:1px solid var(--line);
  border-radius:14px;
  background:#fff;
  cursor:pointer;
  transition:transform .18s ease,box-shadow .18s ease;
}
.search-product-result:hover{transform:translateY(-2px);box-shadow:0 9px 24px rgba(22,22,28,.08)}
.search-product-result>img{width:78px;height:78px;border-radius:11px;object-fit:cover}
.search-product-result h3{margin:0 0 4px;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.search-product-result p{margin:0 0 7px;color:var(--muted);font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.search-product-result b{color:var(--primary);font-size:13px}
.search-product-result>span{color:#999;font-size:20px}

/* Sugestões compactas nos restantes campos de pesquisa */
.catalog-search-box{position:relative;min-width:0}
.catalog-search-box .catalog-search{width:100%}
.catalog-search button,.map-search-box label button{
  flex:none;
  width:30px;
  height:30px;
  display:grid;
  place-items:center;
  border-radius:50%;
  background:#fff;
  color:#777;
  font-size:18px;
}
.inline-search-suggestions{
  position:absolute;
  z-index:90;
  top:calc(100% + 8px);
  right:0;
  left:0;
  max-height:320px;
  overflow:auto;
  padding:7px;
  border:1px solid var(--line);
  border-radius:15px;
  background:#fff;
  box-shadow:0 17px 40px rgba(18,18,24,.17);
}
.inline-search-suggestions:empty{display:none}
.inline-search-suggestions>button{
  width:100%;
  min-height:47px;
  display:grid;
  grid-template-columns:28px minmax(0,1fr) auto;
  align-items:center;
  gap:9px;
  padding:8px 10px;
  border-radius:10px;
  background:#fff;
  text-align:left;
}
.inline-search-suggestions>button:hover{background:#f5f5f7}
.inline-search-suggestions>button>span{color:#777}
.inline-search-suggestions>button>b{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}
.inline-search-suggestions>button>i{color:#999;font-style:normal}
.map-search-box{position:relative;flex:1;min-width:0}
.map-search-box>label{width:100%}
.map-search-suggestions{top:58px}

/* Produto: diálogo largo, equilibrado e com opções organizadas */
#productDialog.modal{
  width:min(1040px,calc(100vw - 56px));
  max-width:1040px;
  height:min(780px,calc(100dvh - 48px));
  max-height:calc(100dvh - 48px);
  margin:auto;
  overflow:hidden;
  border-radius:24px;
  background:#fff;
  box-shadow:0 28px 90px rgba(0,0,0,.34);
}
#productDialog .product-modal{
  width:100%;
  height:100%;
  max-height:none;
  display:grid;
  grid-template-columns:minmax(340px,42%) minmax(0,58%);
  overflow:hidden;
  border-radius:24px;
  background:#fff;
}
.product-modal-media{position:relative;min-width:0;min-height:0;background:#ededf0;overflow:hidden}
.product-modal-media:after{content:"";position:absolute;inset:auto 0 0;height:28%;background:linear-gradient(0deg,rgba(0,0,0,.15),transparent);pointer-events:none}
.product-modal-media>img{width:100%;height:100%;object-fit:cover}
.product-modal-content{min-width:0;min-height:0;display:grid;grid-template-rows:minmax(0,1fr) auto;background:#fff}
#productDialog .modal-body{min-height:0;overflow-y:auto;padding:34px 34px 24px;scrollbar-gutter:stable}
.product-modal-heading{padding-right:42px}
.product-modal-heading h2{margin:0 0 10px;font-size:29px;line-height:1.12}
.product-modal-heading p{margin:0 0 15px;color:var(--muted);line-height:1.55}
.product-modal-heading h3{margin:0;color:var(--ink);font-size:21px}
.product-options-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin:25px 0 4px}
.product-options-grid>.option-group:only-child,.product-options-grid>.option-group:last-child:nth-child(odd){grid-column:1/-1}
#productDialog .option-group{
  min-width:0;
  margin:0;
  padding:14px 15px 4px;
  border:1px solid var(--line);
  border-radius:15px;
  background:#fff;
}
#productDialog .option-group legend{align-items:center;padding:0 0 9px;font-size:14px}
#productDialog .option-group legend small{padding:4px 7px;border-radius:999px;background:#f1f1f4;font-size:9px}
#productDialog .option{min-height:46px;padding:9px 0}
#productDialog .option:last-child{border-bottom:0}
#productDialog .option b{font-size:13px}
#productDialog .option input{width:18px;height:18px;accent-color:var(--primary)}
.product-note{margin-top:18px!important}
.product-note textarea{resize:vertical;min-height:76px}
.product-modal-footer{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  align-items:center;
  gap:18px;
  padding:15px 24px calc(15px + env(safe-area-inset-bottom));
  border-top:1px solid var(--line);
  background:rgba(255,255,255,.97);
  box-shadow:0 -10px 26px rgba(20,20,26,.06);
}
#productDialog .quantity-picker{margin:0;gap:10px}
#productDialog .quantity-picker button{width:38px;height:38px}
#productDialog .quantity-picker b{min-width:24px;text-align:center}
.product-modal-footer>.btn{
  min-height:50px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:0 19px;
  border-radius:13px;
}
.product-modal-footer>.btn b{white-space:nowrap}
#productDialog .modal-close{right:17px;top:17px;width:42px;height:42px;box-shadow:0 4px 16px rgba(0,0,0,.16)}

@media(max-width:1280px){
  .search-store-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .search-products-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:1050px){
  .search-page{left:0}
  #productDialog.modal{width:min(920px,calc(100vw - 32px))}
  #productDialog .product-modal{grid-template-columns:minmax(300px,39%) minmax(0,61%)}
  .product-options-grid{grid-template-columns:1fr}
  .product-options-grid>.option-group{grid-column:auto!important}
}
@media(max-width:780px){
  .search-page{top:var(--topbar);left:0}
  .search-scope-tabs{gap:20px;padding:0 13px;overflow-x:auto;align-items:end}
  .search-scope-tabs>button:not(.search-close){flex:none}
  .search-scope-tabs .search-close{position:sticky;right:0;flex:none;margin-left:auto;background:#f1f1f4}
  .search-sheet{height:calc(100dvh - var(--topbar) - 57px);padding-bottom:90px}
  .search-suggestions-card,.search-results-block{padding:19px 14px}
  .search-row{min-height:60px}
  .search-store-grid{grid-template-columns:1fr}
  .search-products-grid{grid-template-columns:1fr}
  .catalog-search-box{grid-column:1/-1}
  #productDialog.modal{
    width:100%;
    max-width:none;
    height:100dvh;
    max-height:none;
    margin:0;
    border-radius:0;
  }
  #productDialog .product-modal{
    display:grid;
    grid-template-columns:1fr;
    grid-template-rows:245px minmax(0,1fr);
    border-radius:0;
  }
  .product-modal-content{min-height:0}
  #productDialog .modal-body{padding:24px 17px 18px}
  .product-modal-heading h2{font-size:24px}
  .product-options-grid{grid-template-columns:1fr;gap:11px}
  .product-modal-footer{grid-template-columns:auto minmax(0,1fr);gap:12px;padding:12px 13px calc(12px + env(safe-area-inset-bottom))}
  #productDialog .quantity-picker{gap:6px}
  #productDialog .quantity-picker button{width:34px;height:34px}
  .product-modal-footer>.btn{min-height:48px;padding:0 13px;font-size:12px}
  #productDialog .modal-close{position:fixed;right:13px;top:calc(13px + env(safe-area-inset-top))}
}
@media(max-width:430px){
  .search-scope-tabs{gap:16px}
  .search-scope-tabs>button:not(.search-close){font-size:12px}
  #productDialog .product-modal{grid-template-rows:220px minmax(0,1fr)}
  .product-modal-footer{grid-template-columns:112px minmax(0,1fr)}
  .product-modal-footer>.btn span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
}


/* Authentication page with local Lottie artwork — isolated from the rest of the website. */
.auth-login-page{
  min-height:100dvh;
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(430px,520px);
  align-items:stretch;
  overflow:hidden;
  background:#fff;
}
.auth-login-page .auth-visual{
  position:relative;
  isolation:isolate;
  min-width:0;
  display:grid;
  grid-template-rows:auto minmax(280px,1fr) auto;
  align-content:center;
  place-items:stretch;
  gap:12px;
  padding:42px clamp(42px,6vw,96px) 46px;
  overflow:hidden;
  background:
    radial-gradient(circle at 82% 16%,rgba(198,10,9,.09),transparent 24%),
    linear-gradient(145deg,#fff 0%,#fff 58%,#fff5f4 100%);
  color:var(--ink);
}
.auth-login-page .auth-visual::before{
  content:"";
  position:absolute;
  z-index:-3;
  left:-230px;
  bottom:-330px;
  width:620px;
  height:620px;
  border-radius:50%;
  background:var(--primary);
  box-shadow:0 28px 80px rgba(198,10,9,.24);
}
.auth-login-page .auth-visual::after{
  content:"";
  position:absolute;
  z-index:-2;
  left:92px;
  bottom:60px;
  width:92px;
  height:12px;
  border-radius:999px;
  background:var(--primary);
  opacity:.16;
  transform:rotate(-18deg);
}
.auth-primary-orbit{
  position:absolute;
  z-index:-2;
  border:1px solid rgba(198,10,9,.15);
  border-radius:50%;
  pointer-events:none;
}
.auth-primary-orbit-one{width:210px;height:210px;right:-92px;top:82px}
.auth-primary-orbit-two{width:116px;height:116px;right:68px;top:24px}
.auth-visual-header{
  position:relative;
  z-index:2;
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:22px;
}
.auth-login-page .auth-wordmark{
  width:138px;
  height:46px;
  object-fit:contain;
  object-position:left center;
  filter:none;
}
.auth-visual-header span{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  padding:8px 13px;
  border:1px solid rgba(198,10,9,.13);
  border-radius:999px;
  background:rgba(255,255,255,.8);
  color:var(--primary);
  font-size:11px;
  font-weight:850;
  letter-spacing:.03em;
  white-space:nowrap;
  box-shadow:0 8px 24px rgba(58,18,18,.05);
}
.auth-lottie-wrap{
  position:relative;
  z-index:1;
  width:min(100%,780px);
  min-height:0;
  display:grid;
  place-items:center;
  justify-self:center;
}
.auth-lottie-wrap::before{
  content:"";
  position:absolute;
  z-index:-1;
  width:min(70%,500px);
  aspect-ratio:1;
  border-radius:50%;
  background:radial-gradient(circle,rgba(198,10,9,.08),rgba(198,10,9,0) 70%);
  filter:blur(2px);
}
.auth-lottie{
  position:relative;
  width:100%;
  max-height:min(52vh,500px);
  aspect-ratio:3/2;
  display:grid;
  place-items:center;
  overflow:hidden;
}
.auth-lottie svg{width:100%!important;height:100%!important;display:block}
.auth-lottie-fallback{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  transition:opacity .2s ease;
}
.auth-lottie-fallback img{
  width:84px;
  height:84px;
  object-fit:contain;
  opacity:.15;
  filter:none;
}
.auth-lottie.is-ready .auth-lottie-fallback{opacity:0;pointer-events:none}
.auth-lottie.has-error .auth-lottie-fallback{opacity:1}
.auth-copy{
  position:relative;
  z-index:2;
  width:min(100%,650px);
  justify-self:center;
  text-align:center;
}
.auth-copy-kicker{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:30px;
  margin-bottom:10px;
  padding:6px 12px;
  border-radius:999px;
  background:var(--primary-soft);
  color:var(--primary);
  font-size:11px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.auth-login-page .auth-copy h1{
  margin:0 0 9px;
  color:var(--ink);
  font-size:clamp(34px,3.3vw,52px);
  line-height:1.02;
  letter-spacing:-.035em;
}
.auth-login-page .auth-copy p{
  max-width:620px;
  margin:0 auto;
  color:var(--muted);
  font-size:clamp(14px,1.15vw,17px);
  line-height:1.55;
}
.auth-login-page .auth-card{
  width:calc(100% - 80px);
  max-width:440px;
  align-self:center;
  justify-self:center;
  margin:40px;
  padding:28px;
  border:1px solid #e4e4e8;
  border-radius:22px;
  background:rgba(255,255,255,.98);
  box-shadow:0 22px 60px rgba(28,28,38,.10);
}
.auth-login-page .auth-card::before{
  content:"";
  display:block;
  width:44px;
  height:4px;
  margin:0 auto 20px;
  border-radius:999px;
  background:var(--primary);
}
.auth-login-page .auth-tabs{margin-bottom:18px}
.auth-login-page .field{margin-bottom:14px}
.auth-login-page .field input{min-height:46px}
.auth-login-page .btn-primary{min-height:46px}

@media(max-width:980px){
  .auth-login-page{grid-template-columns:minmax(0,1fr) minmax(390px,460px)}
  .auth-login-page .auth-visual{padding-left:38px;padding-right:38px}
  .auth-login-page .auth-card{width:calc(100% - 48px);margin:24px}
  .auth-visual-header span{display:none}
}
@media(max-width:780px){
  body:has(.auth-login-page){padding-bottom:0}
  .auth-login-page{
    min-height:100dvh;
    display:flex;
    flex-direction:column;
    overflow:visible;
    background:#fff;
    padding:0 14px 28px;
  }
  .auth-login-page .auth-visual{
    flex:none;
    display:grid;
    grid-template-rows:auto auto auto;
    gap:4px;
    margin:0 -14px;
    padding:22px 20px 26px;
    border-radius:0 0 34px 34px;
    background:linear-gradient(155deg,#fff 0%,#fff 58%,#fff1f0 100%);
    box-shadow:inset 0 -5px 0 var(--primary);
    text-align:center;
  }
  .auth-login-page .auth-visual::before{display:none}
  .auth-primary-orbit-one{width:150px;height:150px;right:-75px;top:38px}
  .auth-primary-orbit-two{display:none}
  .auth-visual-header{justify-content:center}
  .auth-login-page .auth-wordmark{width:122px;height:40px;object-position:center}
  .auth-lottie-wrap{width:min(100%,440px)}
  .auth-lottie{max-height:none;aspect-ratio:3/2}
  .auth-copy-kicker{display:none}
  .auth-login-page .auth-copy h1{font-size:29px;margin-bottom:7px}
  .auth-login-page .auth-copy p{max-width:430px;font-size:13px;line-height:1.45}
  .auth-login-page .auth-card{
    position:relative;
    z-index:4;
    width:min(100%,520px);
    max-width:520px;
    margin:-5px auto 0;
    padding:22px;
    border-radius:20px;
  }
  .auth-login-page .auth-card::before{margin-bottom:16px}
}
@media(max-width:420px){
  .auth-login-page{padding-left:10px;padding-right:10px}
  .auth-login-page .auth-visual{margin-left:-10px;margin-right:-10px;padding:18px 15px 22px}
  .auth-login-page .auth-wordmark{width:110px}
  .auth-login-page .auth-copy h1{font-size:27px}
  .auth-login-page .auth-copy p{font-size:12px}
  .auth-login-page .auth-card{padding:18px 16px}
  .auth-login-page .auth-tabs button{padding:9px 5px;font-size:13px}
}
@media(prefers-reduced-motion:reduce){
  .auth-lottie-fallback{transition:none}
}

/* Auth visual correction 4.3.1: the Lottie fills the entire former red panel. */
.auth-login-page .auth-visual{
  position:relative;
  display:block;
  padding:0;
  overflow:hidden;
  background:#eef3f1;
  color:var(--ink);
}
.auth-login-page .auth-visual::before{display:none}
.auth-login-page .auth-visual::after{
  content:"";
  position:absolute;
  z-index:3;
  top:0;
  right:0;
  bottom:0;
  width:7px;
  height:auto;
  border-radius:0;
  background:var(--primary);
  opacity:1;
  transform:none;
  pointer-events:none;
}
.auth-primary-orbit{display:none}
.auth-login-page .auth-lottie-wrap{
  position:absolute;
  z-index:0;
  inset:0;
  width:100%;
  height:100%;
  min-height:0;
  display:block;
}
.auth-login-page .auth-lottie-wrap::before{display:none}
.auth-login-page .auth-lottie{
  width:100%;
  height:100%;
  max-height:none;
  aspect-ratio:auto;
  display:block;
  overflow:hidden;
}
.auth-login-page .auth-lottie svg{
  width:100%!important;
  height:100%!important;
  display:block;
}
.auth-login-page .auth-lottie-fallback{
  background:linear-gradient(145deg,#f4f7f5,#e8efeb);
}
.auth-login-page .auth-visual-header{
  position:absolute;
  z-index:5;
  top:34px;
  left:40px;
  right:47px;
  width:auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}
.auth-login-page .auth-wordmark{
  width:154px;
  height:50px;
  padding:9px 13px;
  border-radius:15px;
  background:rgba(255,255,255,.93);
  box-shadow:0 14px 36px rgba(28,38,33,.13);
  backdrop-filter:blur(12px);
}
.auth-login-page .auth-visual-header span{
  min-height:38px;
  padding:9px 14px;
  border-color:rgba(198,10,9,.18);
  background:rgba(255,255,255,.93);
  box-shadow:0 14px 36px rgba(28,38,33,.10);
  backdrop-filter:blur(12px);
}
.auth-login-page .auth-copy{
  position:absolute;
  z-index:5;
  left:40px;
  bottom:40px;
  width:min(520px,calc(100% - 94px));
  padding:21px 24px 22px;
  border-left:7px solid var(--primary);
  border-radius:0 19px 19px 0;
  background:rgba(255,255,255,.93);
  box-shadow:0 18px 46px rgba(28,38,33,.16);
  backdrop-filter:blur(16px);
  text-align:left;
}
.auth-login-page .auth-copy-kicker{
  margin-bottom:8px;
}
.auth-login-page .auth-copy h1{
  margin:0 0 7px;
  color:var(--ink);
  font-size:clamp(31px,3vw,46px);
}
.auth-login-page .auth-copy p{
  max-width:none;
  margin:0;
  color:#555b58;
  font-size:15px;
  line-height:1.5;
}

@media(max-width:980px){
  .auth-login-page .auth-visual-header{left:28px;right:35px;top:26px}
  .auth-login-page .auth-copy{left:28px;bottom:30px;width:min(470px,calc(100% - 70px))}
}

@media(max-width:780px){
  .auth-login-page{
    min-height:100dvh;
    display:flex;
    flex-direction:column;
    overflow:visible;
    background:#fff;
    padding:0 14px 28px;
  }
  .auth-login-page .auth-visual{
    position:relative;
    flex:none;
    display:block;
    min-height:390px;
    margin:0 -14px;
    padding:0;
    border-radius:0 0 28px 28px;
    background:#eef3f1;
    box-shadow:none;
    text-align:left;
  }
  .auth-login-page .auth-visual::after{
    top:auto;
    left:0;
    right:0;
    bottom:0;
    width:auto;
    height:6px;
  }
  .auth-login-page .auth-visual-header{
    top:16px;
    left:16px;
    right:16px;
    justify-content:flex-start;
  }
  .auth-login-page .auth-wordmark{
    width:124px;
    height:42px;
    padding:7px 10px;
    object-position:center;
  }
  .auth-login-page .auth-visual-header span{display:none}
  .auth-login-page .auth-copy{
    left:16px;
    right:16px;
    bottom:20px;
    width:auto;
    padding:15px 17px 16px;
    border-left-width:5px;
    border-radius:0 15px 15px 0;
  }
  .auth-login-page .auth-copy-kicker{display:none}
  .auth-login-page .auth-copy h1{font-size:27px;margin-bottom:5px}
  .auth-login-page .auth-copy p{font-size:12.5px;line-height:1.4}
  .auth-login-page .auth-card{
    width:min(100%,520px);
    max-width:520px;
    margin:18px auto 0;
  }
}

@media(max-width:420px){
  .auth-login-page .auth-visual{min-height:350px;margin-left:-10px;margin-right:-10px}
  .auth-login-page .auth-visual-header{left:13px;top:13px}
  .auth-login-page .auth-wordmark{width:112px;height:39px}
  .auth-login-page .auth-copy{left:13px;right:13px;bottom:16px;padding:13px 14px 14px}
  .auth-login-page .auth-copy h1{font-size:24px}
  .auth-login-page .auth-copy p{font-size:11.5px}
}
