.app{min-height:100vh;display:flex;flex-direction:column;background:transparent;padding-bottom:68px;max-width:100%;margin:0 auto}@media (min-width: 1280px){.app{max-width:1200px}}.app-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:18px;color:#565959}.app-main{flex:1;display:flex;flex-direction:column;overflow-y:auto;-webkit-overflow-scrolling:touch;width:100%;min-height:0}.app-header{background:#141b22;height:80px;position:sticky;top:0;z-index:100;width:100%}.app-header-content{display:flex;align-items:flex-end;justify-content:space-between;height:100%;padding:0 12px;max-width:100%}@media (min-width: 768px){.app-header-content{padding:0 16px}}@media (min-width: 1280px){.app-header-content{max-width:1200px;margin:0 auto;padding:0 24px}}.app-header-logo{display:flex;align-items:center;gap:12px;margin-bottom:0;margin-top:9px}.app-header-logo img{height:56px;width:auto;object-fit:contain}.app-header-store-name{color:#fff;font-size:24px;font-weight:500;line-height:1}@media (min-width: 768px){.app-header-logo img{height:64px}.app-header-store-name{font-size:28px}}.app-header-actions{display:flex;align-items:center;gap:8px;margin-bottom:0;margin-top:0;align-self:center}.icon-button{width:44px;height:44px;border-radius:999px;background:transparent;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative;transition:background-color .12s cubic-bezier(.2,0,0,1)}.icon-button:active{background:#ffffff1f}.cart-button{position:relative}.cart-badge{position:absolute;top:4px;right:4px;background:#ffc233;color:#0f1111;font-size:10px;font-weight:600;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}.search-bar-container{padding:12px;background:#141b22;width:100%}@media (min-width: 768px){.search-bar-container{padding:16px}}@media (min-width: 1280px){.search-bar-container{max-width:1200px;margin:0 auto;padding:16px 24px}}.search-bar{display:flex;height:44px;border-radius:12px;background:#fff;border:1px solid #D5D9D9;overflow:hidden}.search-input{flex:1;border:none;outline:none;padding:0 16px;font-size:18px;font-weight:400;color:#0f1111;background:transparent}.search-input::placeholder{color:#767676}.search-action{width:56px;background:#f5b400;border:none;color:#0f1111;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .12s cubic-bezier(.2,0,0,1)}.search-action:active{background:#e5a400}.search-bar:focus-within{border:2px solid #F5B400;border-radius:12px}.filter-bar{display:flex;align-items:center;gap:12px;padding:12px;background:#fff;border-bottom:1px solid #E7E7E7;overflow-x:auto;overflow-y:visible;width:100%;position:relative}.category-chips-container{display:flex;align-items:center;gap:8px;flex:1;overflow-x:auto;-webkit-overflow-scrolling:touch;flex-shrink:1;min-width:0}.category-chips-container::-webkit-scrollbar{display:none}@media (min-width: 768px){.filter-bar{padding:16px}}@media (min-width: 1280px){.filter-bar{max-width:1200px;margin:0 auto;padding:16px 24px}}.filter-chip{height:36px;padding:0 14px;border-radius:999px;border:1px solid #D5D9D9;background:#fff;font-size:16px;font-weight:400;color:#0f1111;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all .12s cubic-bezier(.2,0,0,1);display:flex;align-items:center;gap:6px}.filter-chip:active{background:#f7f7f7}.filter-chip.selected{border-color:#2a69b8;background:#f7f7f7}.filter-button{flex-shrink:0;display:flex;align-items:center;gap:6px}.view-toggle{display:flex;gap:4px;margin-left:auto;background:#f7f7f7;border-radius:8px;padding:2px}.sort-button-wrapper{position:relative;z-index:100}.view-button{width:36px;height:36px;border:none;background:transparent;border-radius:6px;color:#565959;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s cubic-bezier(.2,0,0,1)}.view-button.active{background:#fff;color:#0f1111;box-shadow:0 1px 2px #0000001a}.sort-button{width:36px;height:36px}.sort-dropdown{position:fixed;background:#fff;border:1px solid #D5D9D9;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1000;width:auto;overflow:hidden;animation:dropdownFadeIn .15s cubic-bezier(.2,0,0,1)}.sort-dropdown-item{width:auto;padding:10px 12px;border:none;background:#fff;font-size:16px;font-weight:400;color:#0f1111;cursor:pointer;text-align:left;white-space:nowrap;display:block;transition:all .12s cubic-bezier(.2,0,0,1);border-bottom:1px solid #F7F7F7}.sort-dropdown-item:last-child{border-bottom:none}.sort-dropdown-item:hover{background:#f7f7f7}.sort-dropdown-item.selected{background:#f7f7f7;color:#2a69b8;font-weight:500}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.filter-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000008c;z-index:200;animation:fadeIn .2s cubic-bezier(.2,0,0,1)}.filter-panel{position:fixed;top:0;left:0;right:0;bottom:0;background:#fff;z-index:201;display:flex;flex-direction:column;animation:slideUp .28s cubic-bezier(.2,.9,.2,1)}.filter-panel-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid #E7E7E7}.filter-panel-header h3{margin:0;font-size:20px;font-weight:600;color:#0f1111}.close-button{width:44px;height:44px;border:none;background:transparent;color:#0f1111;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:999px}.close-button:active{background:#0000000d}.filter-panel-content{flex:1;overflow-y:auto;padding:16px}.filter-section{margin-bottom:24px}.filter-section h4{margin:0 0 12px;font-size:16px;font-weight:600;color:#0f1111}.sort-options,.view-options{display:flex;flex-direction:column;gap:8px}.sort-option,.view-option{padding:12px 16px;border:1px solid #D5D9D9;background:#fff;border-radius:8px;font-size:16px;font-weight:400;color:#0f1111;cursor:pointer;text-align:left;transition:all .12s cubic-bezier(.2,0,0,1)}.sort-option:active,.view-option:active{background:#f7f7f7}.sort-option.selected,.view-option.selected{border:2px solid #2A69B8;background:#fff;box-shadow:inset 0 0 0 1px #2a69b859}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.product-grid{display:grid;grid-template-columns:repeat(1,1fr);gap:12px;padding:12px;background:#fff;min-height:100%;height:100%}@media (min-width: 480px){.product-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 768px){.product-grid{grid-template-columns:repeat(3,1fr);gap:16px;padding:16px}}@media (min-width: 1024px){.product-grid{grid-template-columns:repeat(4,1fr)}}@media (min-width: 1280px){.product-grid{grid-template-columns:repeat(5,1fr)}}@media (min-width: 1536px){.product-grid{grid-template-columns:repeat(6,1fr)}}.product-card{background:#e0e0e0;border-radius:12px;border:1px solid #E7E7E7;padding:8px;cursor:pointer;transition:all .2s cubic-bezier(.2,0,0,1);display:flex;flex-direction:column;height:100%}.product-card:hover{border-color:#ffc233;box-shadow:0 2px 8px #ffc23333;transform:translateY(-2px)}.product-card:active{transform:translateY(0);box-shadow:0 1px 4px #ffc23326}.product-card-image{background:transparent;border-radius:8px;min-height:140px;padding:0;display:flex;align-items:center;justify-content:center;margin-bottom:8px;overflow:hidden}.product-card-image img{width:100%;height:100%;object-fit:cover;min-height:140px}.product-card-placeholder{color:#999;font-size:12px}.product-card-content{flex:1;display:flex;flex-direction:column}.product-card-title{font-size:14px;font-weight:400;color:#0f1111;margin:0 0 4px;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.product-card-rating{display:flex;align-items:center;gap:3px;margin-bottom:6px}.rating-stars{display:flex;gap:1px}.rating-stars svg{width:12px;height:12px}.rating-text{font-size:12px;color:#565959;margin-left:2px}.reviews-text{font-size:12px;color:#565959}.product-card-price{margin-top:auto;display:flex;align-items:baseline;gap:6px;flex-wrap:wrap}.product-card-rating-price-row{display:none}.original-price{font-size:11px;color:#767676;text-decoration:line-through}.current-price{display:flex;align-items:baseline;gap:1px}.price-currency{font-size:12px;font-weight:400;color:#0f1111}.price-major{font-size:18px;font-weight:400;color:#0f1111}.price-minor{font-size:11px;font-weight:400;color:#0f1111;vertical-align:super}@media (min-width: 768px){.product-card{padding:10px}.product-card-image{min-height:160px;padding:0;margin-bottom:10px}.product-card-image img{min-height:160px}.product-card-title{font-size:15px;margin-bottom:6px}.rating-stars svg{width:13px;height:13px}.rating-text,.reviews-text{font-size:13px}.price-currency{font-size:14px}.price-major{font-size:20px}.price-minor,.original-price{font-size:12px}}@media (min-width: 1024px){.product-card-image,.product-card-image img{min-height:180px}.product-card-title{font-size:16px}.price-major{font-size:22px}}.product-list{display:flex;flex-direction:column;gap:12px;padding:12px;background:#fff;max-width:100%;min-height:100%;align-self:stretch;flex:1}@media (min-width: 768px){.product-list{padding:16px;gap:16px}}.product-list .product-card{display:flex;flex-direction:row;max-height:none;padding:12px}.product-list .product-card-image{width:80px;min-height:80px;height:80px;flex-shrink:0;margin-bottom:0;margin-right:12px;padding:8px}.product-list .product-card-image img{max-height:80px}.product-list .product-card-content{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:space-between}.product-list .product-card-title{font-size:16px;margin-bottom:8px;-webkit-line-clamp:2}.product-list .product-card-rating-default,.product-list .product-card-price-default{display:none}.product-list .product-card-rating-price-row{display:flex;justify-content:space-between;align-items:center;margin-top:auto;gap:12px}.product-list .product-card-rating-price-row .product-card-rating{margin-bottom:0;order:2}.product-list .product-card-rating-price-row .product-card-price{margin-top:0;order:1}@media (min-width: 768px){.product-list .product-card-image{width:100px;min-height:100px;height:100px}.product-list .product-card-image img{max-height:100px}.product-list .product-card-title{font-size:18px}}.product-detail-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000008c;z-index:300;animation:fadeIn .2s cubic-bezier(.2,0,0,1)}.product-detail-panel{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:800px;background:#fff;border-radius:16px 16px 0 0;box-shadow:0 -8px 24px #00000038;z-index:301;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .28s cubic-bezier(.2,.9,.2,1)}.product-detail-header{display:flex;gap:16px;padding:24px;border-bottom:1px solid #E7E7E7;position:relative}.product-detail-thumbnail{width:180px;height:180px;flex-shrink:0;background:#f6f6f6;border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center}.product-detail-thumbnail img{width:100%;height:100%;object-fit:contain}.product-detail-header-info{flex:1;min-width:0;padding-right:20px;max-width:calc(100% - 196px)}.product-detail-title{font-size:18px;font-weight:400;color:#0f1111;margin:0 0 4px;line-height:1.3}.product-detail-description{font-size:14px;color:#565959;margin:0;line-height:1.3}.product-detail-header .close-button{position:absolute;top:12px;right:12px;width:44px;height:44px;border:none;background:transparent;color:#0f1111;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:999px}.product-detail-header .close-button:active{background:#0000000d}.product-detail-body{flex:1;overflow-y:auto;padding:10px 14px;background:#e0e0e0}.product-detail-images{display:flex;gap:6px;margin-bottom:10px;overflow-x:auto;-webkit-overflow-scrolling:touch}.image-thumbnail{width:78px;height:78px;flex-shrink:0;border:2px solid transparent;border-radius:6px;background:#f6f6f6;padding:0;cursor:pointer;overflow:hidden}.image-thumbnail.active{border-color:#ffc233}.image-thumbnail img{width:100%;height:100%;object-fit:cover}.product-detail-options,.option-group{margin-bottom:10px}.option-label{display:block;font-size:15px;font-weight:500;color:#0f1111;margin-bottom:6px}.option-buttons{display:flex;flex-wrap:wrap;gap:8px}.option-button{height:32px;padding:0 12px;border-radius:999px;border:1px solid #D5D9D9;background:#fff;font-size:14px;font-weight:400;color:#0f1111;cursor:pointer;white-space:nowrap;transition:all .12s cubic-bezier(.2,0,0,1);display:flex;align-items:center;justify-content:center}.option-button:active{background:#f7f7f7}.option-button.selected{border-color:#2a69b8;background:#f7f7f7}.option-button-with-image{height:auto;padding:8px;border-radius:8px;flex-direction:column;gap:6px;min-width:70px}.option-button-with-image .option-image{width:60px;height:60px;object-fit:cover;border-radius:6px;cursor:pointer}.option-button-with-image .option-name{font-size:12px;text-align:center;line-height:1.2}.product-detail-quantity{margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid #E7E7E7}.quantity-label{display:block;font-size:15px;font-weight:500;color:#0f1111;margin-bottom:6px}.quantity-controls{display:flex;align-items:center;gap:8px}.quantity-button{width:32px;height:32px;border:1px solid #D5D9D9;background:#fff;border-radius:8px;font-size:16px;font-weight:400;color:#0f1111;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s cubic-bezier(.2,0,0,1)}.quantity-button:active:not(:disabled){background:#f7f7f7}.quantity-button:disabled{opacity:.5;cursor:not-allowed}.quantity-input{width:100px;height:32px;border:1px solid #D5D9D9;background:#fff;border-radius:8px;padding:0 8px;font-size:14px;font-weight:400;color:#0f1111;text-align:center;-moz-appearance:textfield}.quantity-input::-webkit-inner-spin-button,.quantity-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.quantity-unit{font-size:13px;color:#565959;margin-left:4px}.product-detail-price-section{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap;margin-bottom:10px}.product-detail-price-section .original-price{font-size:14px;color:#767676;text-decoration:line-through}.product-detail-price-section .current-price{display:flex;align-items:baseline;gap:2px}.product-detail-price-section .price-currency{font-size:16px;font-weight:400;color:#0f1111}.product-detail-price-section .price-major{font-size:28px;font-weight:400;color:#0f1111}.product-detail-price-section .price-minor{font-size:13px;font-weight:400;color:#0f1111;vertical-align:super}.product-detail-footer{padding:16px;border-top:1px solid #E7E7E7;display:flex;gap:12px}.secondary-button{flex:1;height:44px;border-radius:999px;border:1px solid #D5D9D9;background:#fff;font-size:18px;font-weight:400;color:#0f1111;cursor:pointer;transition:all .12s cubic-bezier(.2,0,0,1)}.secondary-button:active{background:#f7f7f7}.primary-button{flex:1;height:44px;border-radius:999px;border:1px solid #F5B400;background:#ffc233;font-size:18px;font-weight:400;color:#0f1111;cursor:pointer;transition:all .12s cubic-bezier(.2,0,0,1)}.primary-button:active{background:#f7ca00}.cart-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000008c;z-index:400;animation:fadeIn .2s cubic-bezier(.2,0,0,1)}.cart-panel{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:800px;background:#fff;border-radius:16px 16px 0 0;box-shadow:0 -8px 24px #00000038;z-index:401;max-height:85vh;display:flex;flex-direction:column;animation:slideUp .28s cubic-bezier(.2,.9,.2,1)}.cart-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid #E7E7E7}.cart-header h2{margin:0;font-size:20px;font-weight:600;color:#0f1111}.cart-header .close-button{width:44px;height:44px;border:none;background:transparent;color:#0f1111;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:999px}.cart-header .close-button:active{background:#0000000d}.cart-body{flex:1;overflow-y:auto;padding:16px}.cart-empty{text-align:center;padding:48px 16px;color:#565959}.cart-item{display:flex;gap:12px;padding:16px 0;border-bottom:1px solid #E7E7E7}.cart-item:last-child{border-bottom:none}.cart-item-image{width:80px;height:80px;flex-shrink:0;background:#f6f6f6;border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center}.cart-item-image img{width:100%;height:100%;object-fit:contain}.cart-item-content{flex:1;min-width:0}.cart-item-title{font-size:16px;font-weight:400;color:#0f1111;margin:0 0 4px;line-height:1.3}.cart-item-options{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:8px}.cart-item-option{font-size:12px;color:#565959;background:#f7f7f7;padding:2px 6px;border-radius:4px}.cart-item-price{font-size:18px;font-weight:600;color:#0f1111;margin-bottom:8px}.cart-item-quantity{display:flex;align-items:center;gap:8px}.cart-item-quantity .quantity-button{width:36px;height:36px;border:1px solid #D5D9D9;background:#fff;border-radius:6px;font-size:18px;font-weight:400;color:#0f1111;cursor:pointer;display:flex;align-items:center;justify-content:center}.cart-item-quantity .quantity-button:active:not(:disabled){background:#f7f7f7}.cart-item-quantity .quantity-button:disabled{opacity:.5;cursor:not-allowed}.cart-item-quantity .quantity-input{width:60px;height:36px;border:1px solid #D5D9D9;background:#fff;border-radius:6px;padding:0 8px;font-size:16px;font-weight:400;color:#0f1111;text-align:center;-moz-appearance:textfield}.cart-item-quantity .quantity-input::-webkit-inner-spin-button,.cart-item-quantity .quantity-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.cart-item-quantity .quantity-unit{font-size:14px;color:#565959}.cart-item-remove{width:36px;height:36px;border:none;background:transparent;color:#565959;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:999px;flex-shrink:0}.cart-item-remove:active{background:#0000000d}.cart-total{display:flex;justify-content:space-between;align-items:center;padding:16px 0;margin-top:16px;border-top:2px solid #E7E7E7}.cart-total-label{font-size:18px;font-weight:600;color:#0f1111}.cart-total-amount{font-size:24px;font-weight:600;color:#0f1111}.cart-footer{padding:16px;border-top:1px solid #E7E7E7;display:flex;justify-content:center}.cart-footer .primary-button{width:100%;max-width:300px;height:44px;border-radius:999px;border:1px solid #F5B400;background:#ffc233;font-size:18px;font-weight:400;color:#0f1111;cursor:pointer;transition:all .12s cubic-bezier(.2,0,0,1)}.cart-footer .primary-button:active{background:#f7ca00}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translate(-50%) translateY(100%)}to{transform:translate(-50%) translateY(0)}}.fixed-cart-button-container{position:fixed;bottom:0;left:0;right:0;padding:12px;background:#141b22;border-top:1px solid rgba(255,255,255,.1);z-index:50;box-shadow:0 -2px 8px #0000004d;width:100%;display:flex;justify-content:center}@media (min-width: 1280px){.fixed-cart-button-container{max-width:1200px;margin:0 auto;padding:16px 24px}}.fixed-cart-button{width:100%;max-width:300px;height:44px;border-radius:999px;border:1px solid #F5B400;background:#ffc233;font-size:18px;font-weight:400;color:#0f1111;cursor:pointer;transition:all .12s cubic-bezier(.2,0,0,1)}.fixed-cart-button:active{background:#f7ca00}*{margin:0;padding:0;box-sizing:border-box}body{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5;color:#0f1111;background:radial-gradient(circle at center,#2a2a2a,#1f1f1f);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}
