.header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--tg-theme-bg-color, #ffffff);border-bottom:1px solid var(--tg-theme-hint-color, #999999);position:sticky;top:0;z-index:100}.header-logo{font-size:18px;font-weight:600;color:var(--tg-theme-text-color, #000000);text-decoration:none}.header-cart{position:relative;color:var(--tg-theme-text-color, #000000);padding:8px}.cart-badge{position:absolute;top:0;right:0;background:var(--tg-theme-button-color, #3390ec);color:var(--tg-theme-button-text-color, #ffffff);font-size:11px;font-weight:600;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;gap:16px}.loading-spinner{width:32px;height:32px;border:3px solid var(--tg-theme-secondary-bg-color, #f4f4f5);border-top-color:var(--tg-theme-button-color, #3390ec);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:14px;color:var(--tg-theme-hint-color, #999999);margin:0}.category-card{display:flex;align-items:center;gap:12px;padding:12px;background:var(--tg-theme-secondary-bg-color, #f4f4f5);border-radius:12px;text-decoration:none;color:inherit;transition:background .2s}.category-card:active{background:var(--tg-theme-bg-color, #e8e8e8)}.category-image{width:56px;height:56px;border-radius:8px;overflow:hidden;flex-shrink:0;background:var(--tg-theme-bg-color, #ffffff)}.category-image img{width:100%;height:100%;object-fit:cover}.category-no-image{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--tg-theme-hint-color, #999999)}.category-name{flex:1;font-size:16px;font-weight:500;color:var(--tg-theme-text-color, #000000)}.category-arrow{color:var(--tg-theme-hint-color, #999999);flex-shrink:0}.catalog{padding:16px}.catalog-title{font-size:24px;font-weight:600;color:var(--tg-theme-text-color, #000000);margin:0 0 16px}.categories-list{display:flex;flex-direction:column;gap:8px}.product-card{background:var(--tg-theme-secondary-bg-color, #f4f4f5);border-radius:12px;overflow:hidden;text-decoration:none;color:inherit;display:flex;flex-direction:column}.product-image{position:relative;aspect-ratio:1;background:var(--tg-theme-bg-color, #ffffff)}.product-image img{width:100%;height:100%;object-fit:cover}.product-no-image{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--tg-theme-hint-color, #999999)}.product-out-of-stock{position:absolute;inset:0;background:#0009;color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:500}.product-info{padding:10px;display:flex;flex-direction:column;gap:8px}.product-name{font-size:14px;font-weight:500;color:var(--tg-theme-text-color, #000000);margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.3}.product-footer{display:flex;justify-content:space-between;align-items:center}.product-price{font-size:15px;font-weight:600;color:var(--tg-theme-text-color, #000000)}.product-add-btn{width:36px;height:36px;border-radius:50%;border:none;background:var(--tg-theme-button-color, #3390ec);color:var(--tg-theme-button-text-color, #ffffff);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .1s,opacity .2s}.product-add-btn:active{transform:scale(.95)}.product-add-btn.in-cart{background:var(--tg-theme-link-color, #3390ec)}.product-add-btn.disabled{opacity:.5;cursor:not-allowed}.in-cart-badge{font-size:14px;font-weight:600}.category-page{padding:16px}.category-title{font-size:24px;font-weight:600;color:var(--tg-theme-text-color, #000000);margin:0 0 8px}.category-description{font-size:14px;color:var(--tg-theme-hint-color, #999999);margin:0 0 20px;line-height:1.4}.subcategories-section,.products-section{margin-bottom:24px}.section-title{font-size:16px;font-weight:600;color:var(--tg-theme-text-color, #000000);margin:0 0 12px}.subcategories-list{display:flex;flex-direction:column;gap:8px}.products-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.empty-state p{margin:0;font-size:16px}.product-page{padding-bottom:100px}.product-gallery{background:var(--tg-theme-secondary-bg-color, #f4f4f5)}.product-main-image{width:100%;aspect-ratio:1;object-fit:contain;background:var(--tg-theme-bg-color, #ffffff)}.product-thumbnails{display:flex;gap:8px;padding:12px;overflow-x:auto}.thumbnail{width:60px;height:60px;border-radius:8px;overflow:hidden;border:2px solid transparent;padding:0;background:var(--tg-theme-bg-color, #ffffff);cursor:pointer;flex-shrink:0}.thumbnail.active{border-color:var(--tg-theme-button-color, #3390ec)}.thumbnail img{width:100%;height:100%;object-fit:cover}.product-no-image{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:var(--tg-theme-secondary-bg-color, #f4f4f5);color:var(--tg-theme-hint-color, #999999)}.product-details{padding:16px}.product-name{font-size:22px;font-weight:600;color:var(--tg-theme-text-color, #000000);margin:0 0 8px;line-height:1.3}.product-price{font-size:24px;font-weight:700;color:var(--tg-theme-text-color, #000000);margin-bottom:12px}.product-stock{margin-bottom:16px}.in-stock{font-size:14px;color:var(--tg-theme-link-color, #3390ec)}.out-of-stock{font-size:14px;color:var(--tg-theme-destructive-text-color, #ff3b30)}.product-quantity-control{display:inline-flex;align-items:center;gap:12px;background:var(--tg-theme-secondary-bg-color, #f4f4f5);border-radius:12px;padding:8px;margin-bottom:20px}.qty-btn{width:40px;height:40px;border:none;border-radius:10px;background:var(--tg-theme-bg-color, #ffffff);color:var(--tg-theme-button-color, #3390ec);display:flex;align-items:center;justify-content:center;cursor:pointer}.qty-btn:disabled{opacity:.3;cursor:not-allowed}.qty-btn:active:not(:disabled){background:var(--tg-theme-button-color, #3390ec);color:var(--tg-theme-button-text-color, #ffffff)}.qty-value{font-size:18px;font-weight:600;min-width:32px;text-align:center;color:var(--tg-theme-text-color, #000000)}.product-description{margin-top:20px;padding-top:20px;border-top:1px solid var(--tg-theme-hint-color, #e0e0e0)}.product-description h2{font-size:16px;font-weight:600;color:var(--tg-theme-text-color, #000000);margin:0 0 12px}.product-description p{font-size:14px;color:var(--tg-theme-text-color, #000000);line-height:1.5;margin:0;white-space:pre-wrap}.cart-item{display:flex;gap:12px;padding:12px;background:var(--tg-theme-secondary-bg-color, #f4f4f5);border-radius:12px}.cart-item-image{width:80px;height:80px;border-radius:8px;overflow:hidden;flex-shrink:0;background:var(--tg-theme-bg-color, #ffffff)}.cart-item-image img{width:100%;height:100%;object-fit:cover}.cart-item-no-image{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--tg-theme-hint-color, #999999)}.cart-item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.cart-item-name{font-size:14px;font-weight:500;color:var(--tg-theme-text-color, #000000);margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.cart-item-price{font-size:13px;color:var(--tg-theme-hint-color, #999999)}.cart-item-controls{display:flex;align-items:center;gap:12px;margin-top:auto}.quantity-control{display:flex;align-items:center;gap:8px;background:var(--tg-theme-bg-color, #ffffff);border-radius:8px;padding:4px}.quantity-btn{width:28px;height:28px;border:none;border-radius:6px;background:transparent;color:var(--tg-theme-button-color, #3390ec);display:flex;align-items:center;justify-content:center;cursor:pointer}.quantity-btn:disabled{opacity:.3;cursor:not-allowed}.quantity-btn:active:not(:disabled){background:var(--tg-theme-secondary-bg-color, #f4f4f5)}.quantity-value{font-size:14px;font-weight:600;min-width:24px;text-align:center;color:var(--tg-theme-text-color, #000000)}.remove-btn{width:32px;height:32px;border:none;border-radius:8px;background:transparent;color:var(--tg-theme-destructive-text-color, #ff3b30);display:flex;align-items:center;justify-content:center;cursor:pointer}.remove-btn:active{background:#ff3b301a}.cart-item-subtotal{font-size:15px;font-weight:600;color:var(--tg-theme-text-color, #000000);align-self:flex-start;flex-shrink:0}.cart-page{padding:16px 16px 120px}.cart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.cart-title{font-size:24px;font-weight:600;color:var(--tg-theme-text-color, #000000);margin:0}.clear-btn{font-size:14px;color:var(--tg-theme-destructive-text-color, #ff3b30);background:none;border:none;cursor:pointer;padding:8px}.cart-items{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.cart-summary{background:var(--tg-theme-secondary-bg-color, #f4f4f5);border-radius:12px;padding:16px}.summary-row{display:flex;justify-content:space-between;font-size:14px;color:var(--tg-theme-hint-color, #999999);margin-bottom:8px}.summary-row.total{font-size:18px;font-weight:600;color:var(--tg-theme-text-color, #000000);margin-bottom:0;padding-top:8px;border-top:1px solid var(--tg-theme-hint-color, #e0e0e0)}.checkout-page{padding:16px 16px 120px}.checkout-title{font-size:24px;font-weight:600;color:var(--tg-theme-text-color, #000000);margin:0 0 20px}.order-summary{background:var(--tg-theme-secondary-bg-color, #f4f4f5);border-radius:12px;padding:16px;margin-bottom:20px}.order-summary h2{font-size:16px;font-weight:600;color:var(--tg-theme-text-color, #000000);margin:0 0 12px}.order-items{display:flex;flex-direction:column;gap:8px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid var(--tg-theme-hint-color, #e0e0e0)}.order-item{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.item-name{font-size:14px;color:var(--tg-theme-text-color, #000000);flex:1}.item-qty{color:var(--tg-theme-hint-color, #999999)}.item-price{font-size:14px;font-weight:500;color:var(--tg-theme-text-color, #000000);flex-shrink:0}.order-total{display:flex;justify-content:space-between;font-size:18px;font-weight:600;color:var(--tg-theme-text-color, #000000)}.note-section{margin-bottom:20px}.note-section label{display:block;font-size:14px;font-weight:500;color:var(--tg-theme-text-color, #000000);margin-bottom:8px}.note-section textarea{width:100%;padding:12px;font-size:15px;border:none;border-radius:12px;background:var(--tg-theme-secondary-bg-color, #f4f4f5);color:var(--tg-theme-text-color, #000000);resize:none;font-family:inherit}.note-section textarea::placeholder{color:var(--tg-theme-hint-color, #999999)}.note-section textarea:focus{outline:2px solid var(--tg-theme-button-color, #3390ec);outline-offset:-2px}.checkout-hint{font-size:13px;color:var(--tg-theme-hint-color, #999999);line-height:1.4;text-align:center;margin:0}.orders-page{padding:16px}.orders-title{font-size:24px;font-weight:600;color:var(--tg-theme-text-color, #000000);margin:0 0 16px}.orders-list{display:flex;flex-direction:column;gap:12px}.order-card{background:var(--tg-theme-secondary-bg-color, #f4f4f5);border-radius:12px;padding:16px}.order-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.order-number{font-size:16px;font-weight:600;color:var(--tg-theme-text-color, #000000)}.order-status{font-size:12px;font-weight:500;padding:4px 8px;border-radius:6px}.order-status.warning{background:#ff9f0a26;color:#ff9f0a}.order-status.success{background:#34c75926;color:#34c759}.order-status.info{background:#007aff26;color:#007aff}.order-status.error{background:#ff3b3026;color:#ff3b30}.order-info{display:flex;justify-content:space-between;align-items:center}.order-date{font-size:13px;color:var(--tg-theme-hint-color, #999999)}.order-amount{font-size:15px;font-weight:600;color:var(--tg-theme-text-color, #000000)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:var(--tg-theme-hint-color, #999999)}.empty-state svg{margin-bottom:16px;opacity:.5}.empty-state p{margin:0 0 20px;font-size:16px}.go-shopping-btn{padding:12px 24px;background:var(--tg-theme-button-color, #3390ec);color:var(--tg-theme-button-text-color, #ffffff);border:none;border-radius:10px;font-size:15px;font-weight:500;cursor:pointer}.go-shopping-btn:active{opacity:.8}*{box-sizing:border-box}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--tg-theme-bg-color, #ffffff);color:var(--tg-theme-text-color, #000000)}#root{min-height:100vh}.main-content{padding-bottom:env(safe-area-inset-bottom)}.auth-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:20px;text-align:center}.auth-error h2{font-size:20px;font-weight:600;margin:0 0 12px;color:var(--tg-theme-text-color, #000000)}.auth-error p{font-size:14px;color:var(--tg-theme-hint-color, #999999);margin:0}a{color:var(--tg-theme-link-color, #3390ec)}button{font-family:inherit}
