:root{--oxxo-red:#df0024;--oxxo-red-deep:#d10022;--oxxo-red-600:#b3001d;--oxxo-red-50:#fee7eb;--oxxo-yellow:#ffe339;--oxxo-yellow-deep:#f4b400;--black:#1a2323;--ink:#2d2d2d;--ink-2:#231f20;--gray-700:#666;--gray-500:#969696;--gray-400:#cacaca;--gray-300:#dadada;--gray-200:#dfdfdf;--gray-150:#eee;--gray-100:#f1f3f4;--gray-75:#f2f2f2;--gray-50:#f6f8f8;--white:#fff;--off-white:#fcfcfc;--info:#2177f9;--info-surface:#e6f0fe;--info-ink:#1d4fd7;--success:#03a92c;--success-surface:#daf1e0;--warning:#f4b400;--warning-surface:#fff2cc;--danger:var(--oxxo-red);--danger-surface:var(--oxxo-red-50);--fg:var(--ink);--fg-muted:var(--gray-700);--fg-subtle:var(--gray-500);--fg-invert:var(--white);--fg-brand:var(--oxxo-red);--bg:var(--white);--bg-canvas:var(--off-white);--bg-subtle:var(--gray-75);--bg-muted:var(--gray-100);--bg-brand:var(--oxxo-red);--bg-brand-deep:var(--oxxo-red-deep);--border:var(--gray-200);--border-strong:var(--gray-500);--border-subtle:var(--gray-150);--border-input:var(--gray-300);--shadow-sm:0 1px 2px 0 #1d292f1a;--shadow-md:0 2px 12px 0 #1d292f14, 0 1px 2px 0 #1d292f1a;--shadow-lg:0 10px 24px 0 #1d292f1f, 0 1px 2px 0 #1d292f1f;--shadow-xl:0 18px 48px 0 #1d292f29, 0 2px 6px 0 #1d292f1a;--shadow-focus:0 0 0 4px #df002429;--shadow-btn:0 1px 2px 0 #1018280d;--font-ui:"Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--type-display-lg:700 60px/72px var(--font-ui);--type-display-md:700 48px/56px var(--font-ui);--type-display-sm:700 36px/44px var(--font-ui);--type-h1:700 32px/40px var(--font-ui);--type-h2:700 24px/32px var(--font-ui);--type-h3:700 20px/24px var(--font-ui);--type-h4:700 18px/24px var(--font-ui);--type-body-lg:400 16px/24px var(--font-ui);--type-body-lg-bold:700 16px/24px var(--font-ui);--type-body:400 14px/20px var(--font-ui);--type-body-bold:700 14px/20px var(--font-ui);--type-body-sm:400 12px/16px var(--font-ui);--type-body-sm-bold:700 12px/16px var(--font-ui);--panini-gold:#e5a23a;--panini-gold-deep:#b6781e;--panini-blue:#0b2c66;--panini-foil:linear-gradient(135deg, #ffe08a 0%, #e5a23a 38%, #ffedb5 60%, #b6781e 100%);--brand-primary:var(--oxxo-red);--brand-deep:var(--oxxo-red-deep);--brand-accent:var(--panini-gold);--ease-standard:cubic-bezier(.2, 0, 0, 1);--dur-fast:.12s;--dur-base:.18s;--dur-slow:.24s}*{box-sizing:border-box}html,body,#root{min-height:100vh;margin:0;padding:0}body{background:var(--bg-canvas);color:var(--fg);font:var(--type-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button{cursor:pointer;font-family:inherit}input{font-family:inherit}.app-shell{background:var(--bg-canvas);flex-direction:column;min-height:100vh;display:flex}.hero-v2{color:#fff;background:#da0027;position:relative;overflow:hidden}.hero-decorations{pointer-events:none;z-index:0;opacity:.4;position:absolute;inset:0;overflow:hidden}.hero-decorations .sunburst{opacity:.8;width:100%;position:absolute;top:50%;left:0;transform:translateY(-50%)}.hero-decorations .glow{filter:blur(60px);border-radius:50%;position:absolute}.hero-decorations .orb-1{background:#ffb40066;width:300px;height:300px;top:-50px;left:-50px}.hero-decorations .orb-2{background:#ff780040;width:400px;height:400px;bottom:-100px;right:-100px}.hero-decorations .cross{width:12px;height:12px;position:absolute}.hero-decorations .cross:before,.hero-decorations .cross:after{content:"";background:#ffd200;border-radius:2px;position:absolute}.hero-decorations .cross:before{width:12px;height:2px;top:5px;left:0}.hero-decorations .cross:after{width:2px;height:12px;top:0;left:5px}.hero-decorations .c-1{top:20%;left:10%;transform:rotate(45deg)}.hero-decorations .c-2{top:15%;right:40%;transform:rotate(20deg)}.hero-decorations .c-3{bottom:25%;right:15%;transform:rotate(60deg)}.hero-decorations .circle{border:2px solid #ffd200;border-radius:50%;position:absolute}.hero-decorations .o-1{width:12px;height:12px;bottom:30%;left:35%}.hero-decorations .o-2{width:8px;height:8px;top:25%;right:20%}.hero-v2-container{z-index:1;justify-content:space-between;align-items:center;gap:24px;max-width:1280px;margin:0 auto;padding:16px 32px 32px;display:flex;position:relative}.hero-v2-content{flex:1;max-width:600px}.tag-top{font:var(--type-body-sm);letter-spacing:.05em;color:#ffd200;align-items:center;gap:12px;margin-bottom:16px;font-weight:700;display:inline-flex}.tag-top .tag-logo{width:90px;height:auto}.hero-v2-title{font:var(--type-h1);margin-bottom:8px;font-size:2rem;line-height:1.1}.hero-v2-title .highlight{color:#1a1a1a;background:#ffd200;border-radius:8px;margin:4px 0;padding:2px 12px;display:inline-block;transform:rotate(-1deg)}.hero-v2-lead{font:var(--type-body-bold);color:#ffffffe6;margin-bottom:16px;font-size:.95rem;line-height:1.4}.hero-v2-badges{flex-wrap:wrap;gap:12px;display:flex}.hero-v2-badges .badge{font:var(--type-body-sm);border-radius:20px;align-items:center;gap:8px;padding:8px 16px;font-weight:600;display:flex}.hero-v2-badges .days-badge{background:#ffffff26;border:1px solid #ffffff4d}.hero-v2-badges .days-badge .badge-num{color:#1a1a1a;background:#ffd200;border-radius:12px;padding:4px 12px;font-size:1.5rem;font-weight:800}.hero-v2-badges a.days-badge{color:inherit;text-decoration:none;transition:opacity .2s}.hero-v2-badges a.days-badge:hover{opacity:.85}.hero-v2-badges .stores-badge{color:#fff;background:#1a1a1a}.hero-v2-visual{flex:0 0 360px;justify-content:center;align-items:center;display:flex}.hero-products{width:340px;height:360px;position:relative}.hero-album{filter:drop-shadow(0 16px 32px #00000059);z-index:2;width:220px;height:auto;transition:transform .4s;position:absolute;top:10px;left:0;transform:rotate(-4deg)}.hero-album:hover{transform:rotate(-2deg)scale(1.03)}.hero-sobres{filter:drop-shadow(0 12px 28px #0000004d);z-index:1;width:180px;height:auto;transition:transform .4s;position:absolute;bottom:10px;right:0;transform:rotate(6deg)}.hero-sobres:hover{transform:rotate(3deg)scale(1.05)}.toolbar{z-index:2;max-width:1280px;margin:-28px auto 0;padding:0 32px;position:relative}.toolbar .card{box-shadow:var(--shadow-lg);background:#fff;border-radius:20px;flex-wrap:nowrap;align-items:center;gap:16px;padding:14px 16px;display:flex}.search-input{border:1px solid var(--border-input);min-width:200px;transition:all var(--dur-fast) var(--ease-standard);background:#fff;border-radius:12px;flex:auto;align-items:center;gap:10px;padding:10px 14px;display:flex;position:relative}.search-input:focus-within{border-color:var(--brand-primary);box-shadow:var(--shadow-focus)}.search-input input{font:var(--type-body);color:var(--ink);background:0 0;border:none;outline:none;flex:1}.search-input input::placeholder{color:var(--fg-subtle)}.search-input .clear{background:var(--bg-muted);width:22px;height:22px;color:var(--fg-muted);border:none;border-radius:999px;justify-content:center;align-items:center;font-size:13px;line-height:1;display:flex}.search-input .clear:hover{background:var(--gray-200)}.chip-row{align-items:center;gap:8px;display:flex}.chip-filter{border:1px solid var(--border-input);color:var(--ink);font:var(--type-body-sm-bold);transition:all var(--dur-fast) var(--ease-standard);background:#fff;border-radius:999px;align-items:center;gap:8px;padding:8px 14px;display:inline-flex}.chip-filter:hover{background:var(--bg-subtle)}.chip-filter.active{background:var(--ink-2);color:#fff;border-color:var(--ink-2)}.chip-filter .dot{background:var(--gray-400);border-radius:999px;width:8px;height:8px}.chip-filter.active .dot{background:var(--brand-accent)}.chip-filter[data-kind=album] .dot{background:var(--panini-blue)}.chip-filter[data-kind=sobres] .dot{background:var(--panini-gold)}.chip-filter[data-kind=ambos] .dot{background:linear-gradient(90deg, var(--panini-blue) 50%, var(--panini-gold) 50%)}.btn-locate{background:var(--brand-primary);color:#fff;font:var(--type-body-bold);box-shadow:var(--shadow-btn);transition:all var(--dur-fast) var(--ease-standard);white-space:nowrap;border:none;border-radius:12px;flex-shrink:0;align-items:center;gap:8px;padding:10px 16px;display:inline-flex}.btn-locate:hover{background:var(--brand-deep)}.btn-locate:disabled{opacity:.6;cursor:not-allowed}.mobile-tabs{display:none}@media (width<=900px){.mobile-tabs{background:var(--gray-100);border-radius:12px;gap:0;max-width:1280px;margin:12px 16px 0;padding:0 16px;display:flex;overflow:hidden}.mobile-tab{font:var(--type-body-bold);color:var(--fg-muted);cursor:pointer;transition:all var(--dur-fast) var(--ease-standard);background:0 0;border:none;border-radius:10px;flex:1;padding:10px 0}.mobile-tab.active{color:var(--brand-primary);box-shadow:var(--shadow-sm);background:#fff}}.workspace{grid-template-columns:420px 1fr;align-items:stretch;gap:20px;width:100%;max-width:1280px;min-height:720px;margin:24px auto 32px;padding:0 32px;display:grid;position:relative}.stores-panel{box-shadow:var(--shadow-md);background:#fff;border-radius:20px;flex-direction:column;display:flex;overflow:hidden}.stores-panel .head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 18px 12px;display:flex}.stores-panel .head .count{font:var(--type-h4);color:var(--ink)}.stores-panel .head .count strong{color:var(--brand-primary)}.stores-list{flex-direction:column;gap:8px;max-height:720px;padding:8px;display:flex;overflow-y:auto}.stores-list::-webkit-scrollbar{width:8px}.stores-list::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:999px}.store-card{cursor:pointer;transition:all var(--dur-fast) var(--ease-standard);text-align:left;background:#fff;border:1px solid #0000;border-radius:14px;gap:12px;width:100%;padding:14px;display:flex}.store-card:hover{background:var(--bg-subtle)}.store-card.active{border-color:var(--brand-primary);background:#fff;box-shadow:0 0 0 4px #df00241a}.store-card .pin{width:40px;height:40px;font:var(--type-body-bold);color:#fff;background:var(--brand-primary);border-radius:12px;flex:none;justify-content:center;align-items:center;display:flex}.store-card .pin.album{background:var(--panini-blue)}.store-card .pin.sobres{background:var(--panini-gold);color:#2d2d2d}.store-card .pin.ambos{background:linear-gradient(135deg, var(--panini-blue) 0%, var(--panini-blue) 50%, var(--panini-gold) 50%, var(--panini-gold) 100%)}.store-card .body{flex:1;min-width:0}.store-card .row{align-items:center;gap:8px;display:flex}.store-card .name{font:var(--type-body-bold);color:var(--ink)}.store-card .badge-num{font:var(--type-body-sm-bold);color:var(--fg-muted);background:var(--bg-muted);border-radius:999px;padding:1px 8px}.store-card .addr{font:var(--type-body-sm);color:var(--fg-muted);-webkit-line-clamp:1;text-overflow:ellipsis;-webkit-box-orient:vertical;margin-top:2px;line-height:1.4;display:-webkit-box;overflow:hidden}.store-card .meta{flex-wrap:wrap;align-items:center;gap:10px;margin-top:8px;display:flex}.store-card .meta .open{color:var(--success);font:var(--type-body-sm-bold);align-items:center;gap:6px;display:inline-flex}.store-card .meta .closed{color:var(--oxxo-red);font:var(--type-body-sm-bold);align-items:center;gap:6px;display:inline-flex}.store-card .meta .open:before,.store-card .meta .closed:before{content:"";background:currentColor;border-radius:999px;width:8px;height:8px}.store-card .meta .dist{color:var(--ink);font:var(--type-body-sm-bold)}.store-card .meta .sep{color:var(--gray-300)}.store-card .tags{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.tag-pill{font:var(--type-body-sm-bold);background:var(--gray-100);color:var(--ink);border-radius:999px;align-items:center;gap:6px;padding:4px 10px;display:inline-flex}.tag-pill[data-k=album]{color:var(--panini-blue);background:#0b2c6614}.tag-pill[data-k=sobres]{color:var(--panini-gold-deep);background:#e5a23a29}.tag-pill[data-k=low]{background:var(--warning-surface);color:#8a5b00}.store-card .actions{gap:8px;margin-top:12px;display:flex}.btn-sm{font:var(--type-body-sm-bold);transition:all var(--dur-fast) var(--ease-standard);cursor:pointer;border:1px solid #0000;border-radius:10px;align-items:center;gap:6px;padding:8px 12px;display:inline-flex}.btn-sm.primary{background:var(--brand-primary);color:#fff}.btn-sm.primary:hover{background:var(--brand-deep)}.btn-sm.ghost{color:var(--ink);border-color:var(--border-input);background:#fff}.btn-sm.ghost:hover{background:var(--bg-subtle)}.btn-sm.whatsapp{color:#fff;background:#25d366;border-color:#25d366}.btn-sm.whatsapp:hover{background:#1da851}.map-panel{box-shadow:var(--shadow-md);border-radius:20px;height:720px;min-height:720px;position:relative}.google-map{border-radius:20px;width:100%;height:100%;overflow:hidden}.btn-search-area{z-index:5;background:var(--ink,#1a1a1a);color:#fff;font:var(--type-body-sm-bold);cursor:pointer;border:none;border-radius:999px;align-items:center;gap:8px;padding:10px 20px;transition:opacity .2s,transform .2s;animation:.25s ease-out search-area-in;display:flex;position:absolute;top:16px;left:50%;transform:translate(-50%);box-shadow:0 2px 8px #00000040}.btn-search-area:hover{opacity:.9;transform:translate(-50%)scale(1.03)}.btn-search-area:active{transform:translate(-50%)scale(.97)}@keyframes search-area-in{0%{opacity:0;transform:translate(-50%)translateY(-8px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.map-legend{z-index:5;font:var(--type-body-sm-bold);box-shadow:var(--shadow-sm);z-index:3;background:#fffffff5;border-radius:12px;align-items:center;gap:14px;padding:10px 14px;display:flex;position:absolute;bottom:16px;left:16px}.map-legend .swatch{vertical-align:-2px;border-radius:4px;width:12px;height:12px;margin-right:6px;display:inline-block}.info-window-content{min-width:260px;max-width:300px}.info-window-content .name{font:var(--type-body-bold);color:var(--ink)}.info-window-content .addr{font:var(--type-body-sm);color:var(--fg-muted);margin-top:2px}.info-window-content .meta{align-items:center;gap:10px;margin-top:8px;display:flex}.info-window-content .tags{gap:6px;margin-top:8px;display:flex}.info-window-content .actions{gap:8px;margin-top:12px;display:flex}.banner-permission{max-width:1280px;margin:16px auto 0;padding:0 32px 36px;position:relative}.banner-permission .inner{background:var(--info-surface);color:var(--info-ink);font:var(--type-body);border-radius:14px;align-items:center;gap:14px;padding:12px 16px;display:flex}.banner-permission .inner b{color:var(--info-ink)}.banner-permission .inner .close-b{color:var(--info-ink);cursor:pointer;background:0 0;border:none;margin-left:auto;padding:4px 8px}.geo-modal-bd{z-index:30;animation:fadein var(--dur-base) var(--ease-standard);background:#1a232373;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}@keyframes fadein{0%{opacity:0}to{opacity:1}}.geo-modal{width:480px;max-width:90vw;box-shadow:var(--shadow-xl);animation:pop var(--dur-slow) var(--ease-standard);background:#fff;border-radius:20px;overflow:hidden}@keyframes pop{0%{opacity:0;transform:translateY(8px)scale(.98)}to{opacity:1;transform:none}}.geo-modal .head{align-items:center;gap:14px;padding:22px 24px 0;display:flex}.geo-modal .head .ic{background:var(--brand-primary);color:#fff;border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;font-size:24px;display:flex}.geo-modal h3{font:var(--type-h2);margin:0}.geo-modal .body-pad{color:var(--fg-muted);font:var(--type-body-lg);padding:14px 24px 8px;line-height:1.5}.geo-modal .body-pad strong{color:var(--ink)}.geo-modal .foot{justify-content:flex-end;gap:10px;padding:16px 24px 22px;display:flex}.loading-card{align-items:center;gap:12px;padding:14px;display:flex}.shimmer{background:var(--gray-100);border-radius:8px;position:relative;overflow:hidden}.shimmer:after{content:"";background:linear-gradient(90deg,#0000,#ffffffb3,#0000);animation:1.4s linear infinite shim;position:absolute;inset:0}@keyframes shim{0%{transform:translate(-100%)}to{transform:translate(100%)}}.empty-state{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:48px 24px;display:flex}.empty-state h4{font:var(--type-h4);margin:0}.empty-state p{font:var(--type-body);color:var(--fg-muted);max-width:320px;margin:0}.error-state{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:48px 24px;display:flex}.error-state h4{font:var(--type-h4);color:var(--oxxo-red);margin:0}.error-state p{font:var(--type-body);color:var(--fg-muted);margin:0}@media (width<=900px){.hero-v2-container{flex-direction:column;gap:32px;padding:32px 20px 48px}.hero-v2-title{font-size:2.5rem}.hero-v2-visual{display:none}.toolbar{margin-top:-20px;padding:0 16px}.toolbar .card{flex-direction:column;align-items:stretch}.search-input{flex:none;min-width:100%}.chip-row{padding-bottom:2px;overflow-x:auto}.workspace{grid-template-columns:1fr;min-height:auto;margin-top:12px;padding:0 16px}.map-panel{height:calc(100vh - 260px);min-height:500px}.stores-list{max-height:none}.banner-permission{padding:0 16px 28px}.btn-sm{gap:4px;padding:6px 8px;font-size:11px}.store-card .actions,.info-window-content .actions{flex-wrap:wrap;gap:6px}.info-window-content{min-width:200px}.btn-search-area{top:16px;bottom:auto}}.site-footer{color:#fff;background:#333;margin-top:64px;padding:48px 32px}.footer-top{flex-direction:column;align-items:center;margin-bottom:48px;display:flex}.social-title{font:var(--type-h4);text-align:center;color:#fff;margin:0 0 20px;font-size:1.125rem}.footer-social{justify-content:center;gap:24px;display:flex}.footer-social a{color:#fff;transition:color .2s}.footer-social a:hover{color:#ffd200}.footer-main{justify-content:space-between;align-items:center;gap:32px;max-width:1400px;margin:0 auto;display:flex}.footer-links{flex-wrap:wrap;flex:1;align-items:center;gap:16px 32px;display:flex}.footer-link-item{color:#fff;font:var(--type-body-sm);font-size:.85rem;text-decoration:underline;transition:color .2s}.footer-link-item:hover{color:#ffd200}.footer-logo-wrapper{flex-shrink:0}.footer-logo{width:auto;height:48px}@media (width<=900px){.site-footer{padding:48px 20px}.footer-main{flex-direction:column;align-items:center}.footer-links{grid-template-columns:1fr 1fr;gap:32px 16px;width:100%;margin-bottom:48px;display:grid}}
