:root{--bg:#f5f0eb;--bg-card:#fffcf9;--bg-elevated:#ebe4dc;--accent:#a32f2f;--accent-hover:#b83a3a;--accent-soft:#a32f2f1a;--highlight:#7a2e2e;--ice:var(--highlight);--text:#2a2420;--text-muted:#6b625c;--border:#d4ccc4;--success:#2d7a52;--danger:#c43c3c;--radius:16px;--radius-sm:10px;--touch:52px;--font:"Inter", system-ui, -apple-system, sans-serif;--font-metal:"Metal Mania", cursive;--metal-red:#a84848;--metal-inner:#4a3f3c;--metal-outer:#c4b8b0;--header-bg:#fffcf9eb;--shadow:0 4px 20px #2a242014;--icon-wood:#c9a66b;--icon-dark:#2a2420;--icon-blade:#8a939c;--icon-boot:#faf7f3;--icon-boot-shade:#d8d0c8;--icon-skate-shade:#c5d0d8;--icon-sole:#1e1a18;--icon-spark:#e07030;--icon-wheel:#f0ebe5;--icon-wheel-edge:#b8aea4;--icon-machine:#9aa3ab}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font);background:radial-gradient(ellipse 120% 80% at 50% -20%, #a32f2f0f, transparent 55%), var(--bg);color:var(--text);overscroll-behavior:none;min-height:100dvh;line-height:1.5}#root{flex-direction:column;min-height:100dvh;display:flex}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none}img{max-width:100%;display:block}.app-shell{flex-direction:column;flex:1;width:100%;max-width:640px;margin:0 auto;display:flex}.site-header{z-index:100;background:var(--header-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex;position:sticky;top:0}.metal-text{font-family:var(--font-metal);text-transform:uppercase;letter-spacing:.05em;color:var(--metal-red);-webkit-text-stroke:1.25px var(--metal-inner);paint-order:stroke fill;filter:drop-shadow(0 1px 2px #4a3f3c33);text-shadow:1px 0 0 var(--metal-outer), -1px 0 0 var(--metal-outer), 0 1px 0 var(--metal-outer), 0 -1px 0 var(--metal-outer), 1px 1px 0 var(--metal-outer), -1px 1px 0 var(--metal-outer), 1px -1px 0 var(--metal-outer), -1px -1px 0 var(--metal-outer);font-weight:400;line-height:1.1}.metal-text--lg{-webkit-text-stroke:1.75px var(--metal-inner);filter:drop-shadow(0 2px 3px #4a3f3c2e);text-shadow:1.5px 0 0 var(--metal-outer), -1.5px 0 0 var(--metal-outer), 0 1.5px 0 var(--metal-outer), 0 -1.5px 0 var(--metal-outer), 1.5px 1.5px 0 var(--metal-outer), -1.5px 1.5px 0 var(--metal-outer), 1.5px -1.5px 0 var(--metal-outer), -1.5px -1.5px 0 var(--metal-outer), 2px 0 0 var(--metal-outer), -2px 0 0 var(--metal-outer), 0 2px 0 var(--metal-outer), 0 -2px 0 var(--metal-outer);font-size:clamp(1.75rem,8vw,2.25rem)}.logo{flex:1;min-width:0;font-size:clamp(1.15rem,5.5vw,1.55rem)}.header-actions{align-items:center;gap:8px;display:flex}.icon-btn{width:var(--touch);height:var(--touch);border-radius:var(--radius-sm);justify-content:center;align-items:center;transition:background .15s;display:flex;position:relative}.icon-btn:active{background:var(--accent-soft)}.cart-badge{background:var(--accent);color:#fff;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:.7rem;font-weight:700;display:flex;position:absolute;top:6px;right:6px}main{flex:1;padding:16px 16px 32px}.site-footer{text-align:center;color:var(--text-muted);border-top:1px solid var(--border);padding:24px 16px;font-size:.85rem}.hero-about{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow);margin-bottom:24px;padding:20px}.hero-about h1{margin-bottom:12px}.hero-about p{color:var(--text-muted);font-size:.95rem}.hero-about .location{color:var(--highlight);margin-top:12px;font-size:.85rem}.home-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.home-btn{background:var(--bg-card);border:2px solid var(--border);border-radius:var(--radius);text-align:center;touch-action:manipulation;min-height:140px;box-shadow:var(--shadow);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:20px 12px;transition:border-color .15s,transform .1s,box-shadow .15s;display:flex}.home-btn:active{border-color:var(--accent);background:var(--accent-soft);transform:scale(.97)}.home-btn-icon{object-fit:contain;flex-shrink:0;width:56px;height:56px;display:block}.home-btn-icon--sticks{object-position:center;width:auto;max-width:100%;height:58px}.home-btn-icon--helmet{width:58px;height:58px}.home-btn-icon--figure-skate,.home-btn-icon--sharpening{object-position:center;width:58px;height:58px}.home-btn-label{color:var(--text);font-size:.95rem;font-weight:600;line-height:1.3}.page-header{margin-bottom:20px}.page-header h1{letter-spacing:-.02em;font-size:1.4rem}.page-header p{color:var(--text-muted);margin-top:4px;font-size:.9rem}.back-link{color:var(--accent);min-height:var(--touch);align-items:center;gap:6px;margin-bottom:12px;font-size:.9rem;display:inline-flex}.filter-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:20px;padding:16px}.filter-group{margin-bottom:16px}.filter-group:last-child{margin-bottom:0}.filter-group label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:8px;font-size:.75rem;font-weight:600;display:block}.filter-chips{flex-wrap:wrap;gap:8px;display:flex}.chip{border:1px solid var(--border);background:var(--bg);touch-action:manipulation;border-radius:20px;min-height:40px;padding:8px 14px;font-size:.85rem;transition:all .15s}.chip.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.filter-select{width:100%;min-height:var(--touch);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%236b625c' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding:0 14px}.product-grid{gap:12px;display:grid}.product-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);gap:14px;padding:14px;transition:border-color .15s;display:flex}.product-card:active{border-color:var(--accent)}.product-thumb{border-radius:var(--radius-sm);background:var(--bg-elevated);width:80px;height:80px;color:var(--text-muted);text-align:center;flex-shrink:0;justify-content:center;align-items:center;font-size:.7rem;display:flex;overflow:hidden}.product-thumb img{object-fit:cover;width:100%;height:100%}.product-info{flex:1;min-width:0}.product-title{margin-bottom:4px;font-size:.95rem;font-weight:600}.product-meta{color:var(--text-muted);margin-bottom:6px;font-size:.8rem}.product-price{color:var(--ice);font-weight:700}.availability-tag{background:var(--accent-soft);color:var(--highlight);border-radius:4px;margin-top:6px;padding:2px 8px;font-size:.7rem;display:inline-block}.empty-state{text-align:center;color:var(--text-muted);padding:48px 24px}.product-detail{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.product-detail-image{aspect-ratio:1;background:var(--bg-elevated);justify-content:center;align-items:center;display:flex}.product-detail-body{padding:20px}.product-detail-body h1{margin-bottom:8px;font-size:1.3rem}.product-detail-body .price{color:var(--ice);margin-bottom:16px;font-size:1.5rem;font-weight:700}.product-detail-body .description{color:var(--text-muted);margin-bottom:20px;font-size:.95rem}.spec-list{gap:8px;margin-bottom:20px;display:grid}.spec-row{border-bottom:1px solid var(--border);justify-content:space-between;padding:8px 0;font-size:.9rem;display:flex}.spec-row span:first-child{color:var(--text-muted)}.form-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.form-group{margin-bottom:16px}.form-group label{margin-bottom:6px;font-size:.85rem;font-weight:500;display:block}.form-group label .required{color:var(--danger)}.form-input{width:100%;min-height:var(--touch);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:0 14px}.form-input:focus{outline:2px solid var(--accent);outline-offset:-1px}textarea.form-input{resize:vertical;min-height:100px;padding:12px 14px}.btn{width:100%;min-height:var(--touch);border-radius:var(--radius-sm);touch-action:manipulation;justify-content:center;align-items:center;gap:8px;padding:0 20px;font-size:1rem;font-weight:600;transition:all .15s;display:flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:active{background:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text)}.btn-secondary:active{background:var(--border)}.btn+.btn{margin-top:10px}.cart-overlay{z-index:200;opacity:0;pointer-events:none;background:#0009;transition:opacity .25s;position:fixed;inset:0}.cart-overlay.open{opacity:1;pointer-events:auto}.cart-drawer{background:var(--bg-card);border-top:1px solid var(--border);border-radius:var(--radius) var(--radius) 0 0;z-index:201;flex-direction:column;max-height:85dvh;transition:transform .3s;display:flex;position:fixed;bottom:0;left:0;right:0;transform:translateY(100%)}.cart-drawer.open{transform:translateY(0)}.cart-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.cart-header h2{font-size:1.1rem}.cart-items{flex:1;padding:16px 20px;overflow-y:auto}.cart-item{border-bottom:1px solid var(--border);gap:12px;padding:12px 0;display:flex}.cart-item-info{flex:1}.cart-item-title{font-size:.9rem;font-weight:600}.cart-item-variant{color:var(--text-muted);font-size:.8rem}.cart-item-price{color:var(--ice);margin-top:4px;font-weight:600}.qty-controls{align-items:center;gap:12px;margin-top:8px;display:flex}.qty-btn{background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.2rem;display:flex}.cart-footer{border-top:1px solid var(--border);padding:16px 20px;padding-bottom:max(16px, env(safe-area-inset-bottom))}.cart-subtotal{justify-content:space-between;margin-bottom:12px;font-size:1.1rem;font-weight:700;display:flex}.modal-overlay{z-index:300;background:#000000b3;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.modal-sheet{background:var(--bg-card);border-radius:var(--radius) var(--radius) 0 0;width:100%;max-width:640px;max-height:90dvh;padding:24px 20px;padding-bottom:max(24px, env(safe-area-inset-bottom));overflow-y:auto}.modal-sheet h2{margin-bottom:20px;font-size:1.2rem}.auth-tabs{gap:8px;margin-bottom:20px;display:flex}.auth-tab{border-radius:var(--radius-sm);background:var(--bg);border:1px solid var(--border);flex:1;min-height:44px;font-weight:600}.auth-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.error-msg{border:1px solid var(--danger);color:#9e2f2f;border-radius:var(--radius-sm);background:#c43c3c1a;margin-bottom:16px;padding:10px 14px;font-size:.85rem}.success-msg{border:1px solid var(--success);color:#1f5c3d;border-radius:var(--radius-sm);background:#2d7a521a;margin-bottom:16px;padding:10px 14px;font-size:.85rem}.locker-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:12px;padding:16px}.locker-card-header{justify-content:space-between;align-items:flex-start;margin-bottom:8px;display:flex}.locker-card h3{font-size:1rem}.locker-card .meta{color:var(--text-muted);font-size:.85rem}.ticket-badge{background:var(--success);color:#fff;border-radius:12px;padding:4px 10px;font-size:.75rem;font-weight:700}.section-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin:24px 0 12px;font-size:.75rem;font-weight:600}.qr-result{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.qr-code-display{text-align:center;color:var(--accent);margin:16px 0;font-family:monospace;font-size:1.2rem}.loading{text-align:center;color:var(--text-muted);padding:48px}@media (width>=480px){.home-btn{min-height:160px}.product-grid{grid-template-columns:1fr 1fr}.product-card{flex-direction:column}.product-thumb{width:100%;height:120px}}
