/* ==============================================
   СЕГОДНЯ МОЖНО — DODO STYLE v3
   ============================================== */
:root{
  --orange:#ff6723;
  --orange-hover:#e85a1b;
  --orange-light:#fff4ee;
  --orange-bg:rgba(255,103,35,.07);
  --bg:#f7f7f7;
  --white:#fff;
  --black:#222;
  --gray:#73737a;
  --gray-light:#b0b0b5;
  --border:#ebebeb;
  --green:#1db45a;
  --red:#e53935;
  --vk:#0077ff;
  --r:16px;
  --r-sm:12px;
  --shadow:0 4px 24px rgba(0,0,0,.06);
  --shadow-hover:0 8px 32px rgba(0,0,0,.12);
  --font:'Nunito',system-ui,-apple-system,sans-serif;
  --topbar-h:36px;
  --header-h:64px;
  --mobile-cat-h:48px;
  --max-w:1280px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font);background:var(--bg);color:var(--black);line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,textarea{font-family:inherit;border:none;outline:none}
img{display:block;max-width:100%}

/* ===== TOPBAR ===== */
.topbar{background:var(--black);color:#fff;font-size:12px;height:var(--topbar-h);display:flex;align-items:center}
.topbar-inner{max-width:var(--max-w);margin:0 auto;width:100%;padding:0 32px;display:flex;justify-content:space-between;align-items:center}
.topbar-status i,.topbar-city i{margin-right:5px;font-size:10px}
.topbar-status{opacity:.85}

/* ===== HEADER ===== */
.header{position:sticky;top:0;background:var(--white);height:var(--header-h);z-index:100;border-bottom:1px solid var(--border)}
.header-inner{max-width:var(--max-w);margin:0 auto;height:100%;display:flex;align-items:center;padding:0 32px;gap:32px}
.logo{display:flex;align-items:center;gap:10px;flex-shrink:0}
.logo-icon{font-size:32px}
.logo-text{font-size:18px;font-weight:900;color:var(--black);letter-spacing:-.5px;white-space:nowrap}
.header-nav{display:flex;gap:4px;flex:1;overflow-x:auto;scrollbar-width:none}
.header-nav::-webkit-scrollbar{display:none}
.header-nav .nav-link{padding:8px 14px;font-size:13px;font-weight:700;color:var(--gray);border-radius:20px;white-space:nowrap;transition:.2s}
.header-nav .nav-link:hover{background:var(--bg);color:var(--black)}
.header-nav .nav-link.active{background:var(--orange);color:#fff}
.header-right{display:flex;align-items:center;gap:10px;flex-shrink:0;margin-left:auto}

.btn-login{display:flex;align-items:center;gap:8px;padding:10px 18px;border-radius:var(--r-sm);font-size:13px;font-weight:700;color:var(--black);transition:.2s}
.btn-login:hover{background:var(--bg)}
.btn-login i{font-size:18px;color:var(--gray)}
.btn-login.logged-in{background:var(--orange-light);color:var(--orange)}
.btn-login.logged-in i{color:var(--orange)}

.btn-cart{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--r-sm);background:var(--orange);color:#fff;font-size:14px;font-weight:800;position:relative;transition:.2s}
.btn-cart:hover{background:var(--orange-hover)}
.btn-cart i{font-size:16px}
.cart-badge{position:absolute;top:-5px;right:-5px;background:var(--white);color:var(--orange);font-size:11px;font-weight:900;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 4px rgba(0,0,0,.15)}

/* ===== STORIES ===== */
.stories-bar{background:var(--white);border-bottom:1px solid var(--border);padding:16px 0}
.stories-inner{max-width:var(--max-w);margin:0 auto;padding:0 32px;display:flex;gap:16px;overflow-x:auto;scrollbar-width:none}
.stories-inner::-webkit-scrollbar{display:none}
.story-circle{display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;flex-shrink:0;width:76px}
.story-ring{width:68px;height:68px;border-radius:50%;padding:3px;background:linear-gradient(135deg,var(--orange),#ff9a5c,#f97316);display:flex;align-items:center;justify-content:center;transition:.2s}
.story-ring:hover{transform:scale(1.08)}
.story-circle.viewed .story-ring{background:var(--border)}
.story-ava{width:60px;height:60px;border-radius:50%;background:var(--bg);border:3px solid var(--white);overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:28px}
.story-ava img{width:100%;height:100%;object-fit:cover}
.story-label{font-size:11px;font-weight:700;color:var(--black);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}

/* Story viewer */
.story-viewer-wrap{position:fixed;inset:0;background:#000;z-index:10;display:flex;align-items:center;justify-content:center}
.story-progress{position:absolute;top:8px;left:12px;right:12px;display:flex;gap:4px;z-index:20}
.story-prog-bar{flex:1;height:3px;background:rgba(255,255,255,.3);border-radius:2px;overflow:hidden}
.story-prog-fill{height:100%;background:#fff;border-radius:2px;width:0;transition:width linear}
.story-prog-bar.done .story-prog-fill{width:100%}
.story-prog-bar.active .story-prog-fill{width:100%;transition-duration:5s}
.story-close{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.15);color:#fff;font-size:18px;display:flex;align-items:center;justify-content:center;z-index:20;cursor:pointer;border:none}
.story-close:hover{background:rgba(255,255,255,.3)}
.story-title-bar{position:absolute;top:20px;left:16px;color:#fff;font-size:14px;font-weight:800;z-index:20;display:flex;align-items:center;gap:8px}
.story-content{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative}
.story-content img{max-width:100%;max-height:100%;object-fit:contain}
.story-content .story-text-slide{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;text-align:center;color:#fff}
.story-content .story-text-slide h3{font-size:28px;font-weight:900;margin-bottom:8px;text-shadow:0 2px 8px rgba(0,0,0,.5)}
.story-content .story-text-slide p{font-size:16px;opacity:.85;text-shadow:0 1px 4px rgba(0,0,0,.5)}
.story-content .story-text-slide .story-btn{display:inline-block;margin-top:20px;padding:12px 28px;background:var(--orange);color:#fff;border-radius:var(--r-sm);font-size:14px;font-weight:800;text-decoration:none}
.story-nav{position:absolute;top:0;bottom:0;width:30%;z-index:15;cursor:pointer}
.story-prev{left:0}
.story-next{right:0}

@media(max-width:640px){
  .stories-inner{padding:0 12px;gap:12px}
  .story-circle{width:66px}
  .story-ring{width:60px;height:60px}
  .story-ava{width:52px;height:52px;font-size:24px}
  .story-label{font-size:10px}
}

/* ===== MOBILE CATEGORY NAV ===== */
.cat-nav-mobile{display:none;position:sticky;top:var(--header-h);background:var(--white);border-bottom:1px solid var(--border);z-index:90;height:var(--mobile-cat-h)}
.cat-nav-scroll{display:flex;gap:4px;padding:6px 16px;overflow-x:auto;scrollbar-width:none;height:100%;align-items:center}
.cat-nav-scroll::-webkit-scrollbar{display:none}
.cat-pill{padding:6px 16px;border-radius:20px;font-size:13px;font-weight:700;color:var(--gray);white-space:nowrap;flex-shrink:0;transition:.2s}
.cat-pill.active{background:var(--orange);color:#fff}

/* ===== DELIVERY TOGGLE ===== */
.delivery-bar{background:var(--white);border-bottom:1px solid var(--border)}
.delivery-bar-inner{max-width:var(--max-w);margin:0 auto;padding:12px 32px}
.delivery-toggle{display:inline-flex;background:var(--bg);border-radius:var(--r-sm);padding:4px;gap:4px}
.co-toggle{width:100%}
.dt-btn{padding:10px 24px;border-radius:10px;font-size:14px;font-weight:700;color:var(--gray);transition:.2s;display:flex;align-items:center;gap:8px}
.dt-btn.active{background:var(--white);color:var(--orange);box-shadow:0 2px 8px rgba(0,0,0,.06)}
.dt-btn i{font-size:13px}

/* ===== PROMO SLIDER ===== */
.promo-slider{background:var(--white);padding:24px 0 32px}
.promo-slider-inner{max-width:var(--max-w);margin:0 auto;padding:0 32px;overflow:hidden}
.promo-track{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;padding-bottom:4px}
.promo-track::-webkit-scrollbar{display:none}
.promo-slide{min-width:calc(50% - 8px);height:180px;border-radius:var(--r);padding:32px 36px;display:flex;align-items:center;justify-content:space-between;color:#fff;scroll-snap-align:start;flex-shrink:0;overflow:hidden;position:relative}
.promo-slide-text{position:relative;z-index:2}
.promo-slide-text h2{font-size:24px;font-weight:900;margin-bottom:6px;line-height:1.2}
.promo-slide-text p{font-size:14px;opacity:.9}
.promo-slide-img{font-size:72px;flex-shrink:0;position:relative;z-index:2}
.promo-dots{display:flex;justify-content:center;gap:8px;margin-top:16px}
.promo-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:.2s;cursor:pointer}
.promo-dot.active{background:var(--orange);width:24px;border-radius:4px}

/* ===== MAIN ===== */
.main{padding:32px 0 60px}
.main-inner{max-width:var(--max-w);margin:0 auto;padding:0 32px}
.loading-state{display:flex;flex-direction:column;align-items:center;padding:80px 0;color:var(--gray)}
.spinner{width:44px;height:44px;border:3px solid var(--border);border-top-color:var(--orange);border-radius:50%;animation:spin .7s linear infinite;margin-bottom:16px}
@keyframes spin{to{transform:rotate(360deg)}}

/* ===== CATEGORY SECTIONS ===== */
.cat-section{margin-bottom:48px;scroll-margin-top:calc(var(--header-h) + 20px)}
.cat-section-title{font-size:28px;font-weight:900;letter-spacing:-.5px;margin-bottom:20px}

/* ===== PRODUCT CARDS ===== */
.product-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}

.product-card{background:var(--white);border-radius:var(--r);overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.07);transition:transform .2s,box-shadow .2s;cursor:pointer;display:flex;flex-direction:column}
.product-card:hover{box-shadow:0 6px 24px rgba(0,0,0,.12);transform:translateY(-3px)}
.product-card:active{transform:scale(.97)}

/* --- Card Image --- */
.pc-img{width:100%;aspect-ratio:3/2;background:linear-gradient(145deg,#fff8f4 0%,#fdeee3 100%);overflow:visible;position:relative;display:flex;align-items:center;justify-content:center;padding:10px}
.pc-img img{width:100%;height:100%;object-fit:contain;transition:transform .25s;filter:drop-shadow(0 4px 10px rgba(0,0,0,.16))}
.product-card:hover .pc-img img{transform:scale(1.06)}
/* Placeholder when no image */
.pc-img .pc-no-img{font-size:48px;opacity:.3;color:var(--orange)}

/* --- Badges --- */
.pc-badge{position:absolute;top:8px;left:8px;padding:4px 10px;border-radius:7px;font-size:11px;font-weight:800;color:#fff;letter-spacing:.3px;z-index:2;text-transform:uppercase;backdrop-filter:blur(4px)}
.b-new{background:linear-gradient(135deg,#3b82f6dd,#60a5fadd)}
.b-hit{background:linear-gradient(135deg,#ff6723dd,#ff9a5cdd)}
.b-spicy{background:linear-gradient(135deg,#e53935dd,#ff5252dd)}
.b-vegan{background:linear-gradient(135deg,#1db45add,#4ade80dd)}
.b-popular{background:linear-gradient(135deg,#8b5cf6dd,#a78bfadd)}

/* --- Card Body --- */
.pc-body{padding:12px 14px 14px;display:flex;flex-direction:column;flex:1}
.pc-name{font-size:14px;font-weight:800;line-height:1.3;margin-bottom:4px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pc-desc{font-size:12px;color:var(--gray);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:6px;min-height:34px}
.pc-weight{font-size:11px;color:var(--gray-light);margin-bottom:8px}

/* --- Price + Button --- */
.pc-bottom{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:8px}
.pc-price{font-size:17px;font-weight:900;color:var(--black);white-space:nowrap}
.btn-choose{padding:9px 14px;border-radius:var(--r-sm);background:var(--orange-light);color:var(--orange);font-size:13px;font-weight:800;text-align:center;transition:.2s;border:none;white-space:nowrap;flex-shrink:0}
.btn-choose:hover{background:var(--orange);color:#fff}
.btn-choose.in-cart{background:var(--orange);color:#fff;font-size:12px}

/* ===== OVERLAYS & POPUPS ===== */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:500;opacity:0;visibility:hidden;transition:.25s;display:flex;align-items:center;justify-content:center}
.overlay.open{opacity:1;visibility:visible}
.popup-close{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:50%;background:var(--bg);color:var(--black);font-size:16px;display:flex;align-items:center;justify-content:center;z-index:10;transition:.2s}
.popup-close:hover{background:var(--border)}

/* Product popup */
.product-popup{background:var(--white);border-radius:var(--r);width:520px;max-width:calc(100vw - 32px);max-height:90vh;display:flex;flex-direction:column;position:relative;overflow:hidden;transform:scale(.95) translateY(10px);transition:.25s}
.overlay.open .product-popup,.overlay.open .cart-popup,.overlay.open .checkout-popup,.overlay.open .login-popup,.overlay.open .success-popup{transform:scale(1) translateY(0)}
.product-popup-scroll{overflow-y:auto;flex:1}
.product-popup-img{width:100%;aspect-ratio:1;background:linear-gradient(135deg,#fef3ec,#fde8d8);overflow:hidden;display:flex;align-items:center;justify-content:center}
.product-popup-img img{width:100%;height:100%;object-fit:cover}
.product-popup-img .pc-no-img{font-size:80px;opacity:.2;color:var(--orange)}
.product-popup-body{padding:24px}
.product-popup-body h2{font-size:24px;font-weight:900;margin-bottom:8px}
.product-popup-desc{font-size:14px;color:var(--gray);line-height:1.6;margin-bottom:16px}
.product-popup-meta{display:flex;gap:20px;flex-wrap:wrap;font-size:13px;color:var(--gray-light)}
.product-popup-meta span{display:flex;align-items:center;gap:5px}
.product-popup-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;align-items:center;gap:12px;background:var(--white)}
.qty-control{display:flex;align-items:center;gap:2px;background:var(--bg);border-radius:var(--r-sm);padding:4px}
.qty-btn{width:40px;height:40px;border-radius:10px;font-size:14px;display:flex;align-items:center;justify-content:center;transition:.15s;color:var(--black)}
.qty-btn:hover{background:var(--border)}
.qty-val{font-size:17px;font-weight:900;min-width:32px;text-align:center}
.btn-add-cart{flex:1;padding:14px;border-radius:var(--r-sm);background:var(--orange);color:#fff;font-size:15px;font-weight:800;text-align:center;transition:.2s}
.btn-add-cart:hover{background:var(--orange-hover)}

/* Cart popup */
.cart-popup{background:var(--white);border-radius:var(--r);width:520px;max-width:calc(100vw - 32px);max-height:90vh;display:flex;flex-direction:column;position:relative;overflow:hidden;transform:scale(.95) translateY(10px);transition:.25s}
.cart-popup-title{font-size:22px;font-weight:900;padding:24px 24px 0;display:flex;align-items:center;gap:10px}
.cart-popup-title i{color:var(--orange)}
.cart-popup-empty{padding:48px 24px;text-align:center;color:var(--gray)}
.cart-empty-icon{font-size:56px;margin-bottom:12px;opacity:.4}
.cart-popup-empty p{font-weight:700;font-size:16px;margin-bottom:4px;color:var(--black)}
.cart-popup-items{overflow-y:auto;flex:1;padding:16px 0}
.cart-item{display:flex;align-items:center;gap:14px;padding:12px 24px}
.ci-img{width:64px;height:64px;border-radius:var(--r-sm);background:var(--bg);overflow:hidden;flex-shrink:0}
.ci-img img{width:100%;height:100%;object-fit:cover}
.ci-info{flex:1;min-width:0}
.ci-name{font-size:14px;font-weight:700;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ci-price{font-size:14px;font-weight:800;color:var(--orange)}
.ci-qty{display:flex;align-items:center;gap:4px;flex-shrink:0}
.ci-qty button{width:32px;height:32px;border-radius:50%;background:var(--bg);font-size:12px;display:flex;align-items:center;justify-content:center;transition:.15s}
.ci-qty button:hover{background:var(--border)}
.ci-qty span{font-size:15px;font-weight:800;min-width:22px;text-align:center}
.cart-popup-footer{border-top:1px solid var(--border);padding:20px 24px}
.cart-row{display:flex;justify-content:space-between;font-size:14px;color:var(--gray);margin-bottom:8px}
.cart-row-total{font-size:20px;font-weight:900;color:var(--black);margin:12px 0 16px;padding-top:12px;border-top:1px solid var(--border)}
.cart-min-warn{text-align:center;color:var(--red);font-size:13px;margin-bottom:12px}
.cart-clear-btn{display:block;margin:12px auto 0;font-size:13px;color:var(--gray-light);padding:6px;transition:.2s}
.cart-clear-btn:hover{color:var(--red)}

/* BTN SUBMIT BIG */
.btn-submit-big{width:100%;padding:16px;border-radius:var(--r-sm);background:var(--orange);color:#fff;font-size:16px;font-weight:800;text-align:center;transition:.2s;cursor:pointer}
.btn-submit-big:hover{background:var(--orange-hover)}
.btn-submit-big:disabled{background:var(--gray-light);cursor:not-allowed}

/* Checkout */
.checkout-popup{background:var(--white);border-radius:var(--r);width:560px;max-width:calc(100vw - 32px);max-height:92vh;overflow-y:auto;padding:32px;position:relative;transform:scale(.95) translateY(10px);transition:.25s}
.checkout-title{font-size:24px;font-weight:900;margin-bottom:24px}
.co-section{margin-bottom:20px}
.co-label{display:block;font-size:13px;font-weight:800;color:var(--gray);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}
.co-input{width:100%;padding:14px 18px;border:2px solid var(--border);border-radius:var(--r-sm);font-size:15px;transition:.2s;background:var(--white);margin-bottom:8px}
.co-input:focus{border-color:var(--orange);box-shadow:0 0 0 4px var(--orange-bg)}
.co-input:last-child{margin-bottom:0}
textarea.co-input{resize:none}
.pay-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.pay-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px;border:2px solid var(--border);border-radius:var(--r-sm);font-size:13px;font-weight:700;cursor:pointer;transition:.2s;text-align:center}
.pay-card input{display:none}
.pay-card i{font-size:20px;color:var(--gray)}
.pay-card.active{border-color:var(--orange);background:var(--orange-light)}
.pay-card.active i{color:var(--orange)}
.promo-row{display:flex;gap:8px}
.promo-row .co-input{flex:1;margin-bottom:0}
.btn-promo{padding:14px 20px;border-radius:var(--r-sm);font-size:13px;font-weight:800;background:var(--bg);border:2px solid var(--border);transition:.2s;white-space:nowrap}
.btn-promo:hover{border-color:var(--orange);color:var(--orange)}
.promo-msg{font-size:13px;font-weight:700;margin-top:6px}
.promo-msg.ok{color:var(--green)}.promo-msg.err{color:var(--red)}
.co-summary{background:var(--bg);border-radius:var(--r-sm);padding:18px;margin:24px 0 20px}
.co-sum-row{display:flex;justify-content:space-between;font-size:14px;color:var(--gray);margin-bottom:6px}
.co-sum-total{font-size:20px;font-weight:900;color:var(--black);margin:10px 0 0;padding-top:10px;border-top:1px solid var(--border)}
.green{color:var(--green)}
.co-disclaimer{font-size:11px;color:var(--gray-light);text-align:center;margin-top:12px}
.co-disclaimer a{text-decoration:underline}

/* Login popup */
.login-popup{background:var(--white);border-radius:var(--r);width:400px;max-width:calc(100vw - 32px);padding:32px;text-align:center;position:relative;transform:scale(.95) translateY(10px);transition:.25s}
.login-popup h2{font-size:22px;font-weight:900;margin-bottom:4px}
.login-sub{color:var(--gray);font-size:13px;margin-bottom:20px}
/* OAuth row */
.login-oauth{display:flex;gap:10px;margin-bottom:4px}
.btn-oauth{flex:1;padding:13px 10px;border-radius:var(--r-sm);color:#fff;font-size:14px;font-weight:800;display:flex;align-items:center;justify-content:center;gap:8px;transition:.15s}
.btn-oauth:hover{filter:brightness(1.1)}
.btn-vk{background:#0077ff}
.btn-ya{background:#fc3f1d}
/* Divider */
.login-divider{display:flex;align-items:center;gap:12px;margin:18px 0 16px;color:var(--gray-light);font-size:12px}
.login-divider::before,.login-divider::after{content:'';flex:1;height:1px;background:var(--border)}
/* Flash call */
.login-call-info{font-size:14px;color:var(--gray);margin-bottom:12px;line-height:1.5}
.login-call-info i{color:var(--orange);margin-right:4px}
.co-input-code{font-size:28px;font-weight:900;text-align:center;letter-spacing:12px}
.login-resend{display:block;width:100%;margin-top:12px;padding:10px;color:var(--orange);font-size:13px;font-weight:700;text-align:center;background:none;border:none;cursor:pointer}
.login-resend:hover{text-decoration:underline}

/* Success */
.success-popup{background:var(--white);border-radius:var(--r);width:400px;max-width:calc(100vw - 32px);padding:40px;text-align:center;transform:scale(.95) translateY(10px);transition:.25s}
.success-check{width:72px;height:72px;border-radius:50%;background:var(--green);color:#fff;font-size:36px;font-weight:900;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.success-popup h2{font-size:24px;font-weight:900;margin-bottom:8px}
.success-id{font-size:16px;color:var(--gray);margin-bottom:4px}
.success-sub{font-size:14px;color:var(--gray-light);margin-bottom:24px}

/* ===== CART FAB (mobile) ===== */
.cart-fab{position:fixed;bottom:20px;left:16px;right:16px;background:var(--orange);color:#fff;border-radius:var(--r-sm);padding:16px 24px;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 24px rgba(255,103,35,.4);z-index:80;font-size:15px;font-weight:800}
.cart-fab i{font-size:18px}
.cart-fab-count{background:rgba(255,255,255,.25);border-radius:6px;padding:2px 8px}

/* ===== FOOTER ===== */
.footer{background:#1e1e1e;color:#fff;padding:48px 0 0}
.footer-inner{max-width:var(--max-w);margin:0 auto;padding:0 32px;display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px}
.footer-logo{font-size:20px;font-weight:900;display:block;margin-bottom:8px}
.footer-brand p{font-size:13px;color:#888;line-height:1.5}
.footer-col h4{font-size:13px;font-weight:800;color:#aaa;margin-bottom:14px;text-transform:uppercase;letter-spacing:.5px}
.footer-col a{display:flex;align-items:center;gap:8px;font-size:14px;color:#999;padding:5px 0;transition:.2s}
.footer-col a:hover{color:var(--orange)}
.footer-col a i{width:16px;text-align:center}
.footer-bottom{text-align:center;font-size:12px;color:#555;padding:24px;margin-top:40px;border-top:1px solid #333}

/* ===== CART PAGE ===== */
.cart-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.cart-page-header h2{font-size:24px;font-weight:900;display:flex;align-items:center;gap:10px}
.cart-page-header h2 i{color:var(--orange)}
.cart-page-items{background:var(--white);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden;margin-bottom:24px}
.cart-page-item{display:flex;align-items:center;gap:14px;padding:16px 20px;border-bottom:1px solid var(--border)}
.cart-page-item:last-child{border-bottom:none}
.cpi-img{width:64px;height:64px;border-radius:var(--r-sm);background:linear-gradient(135deg,#fef3ec,#fde8d8);overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.cpi-img img{width:100%;height:100%;object-fit:contain}
.cpi-img .pc-no-img{font-size:24px;opacity:.3;color:var(--orange)}
.cpi-info{flex:1;min-width:0}
.cpi-name{font-size:14px;font-weight:700;margin-bottom:2px}
.cpi-weight{font-size:12px;color:var(--gray-light)}
.cpi-price{font-size:15px;font-weight:800;color:var(--orange);margin-top:2px}
.cpi-qty{display:flex;align-items:center;gap:6px;flex-shrink:0}
.cpi-qty button{width:32px;height:32px;border-radius:50%;background:var(--bg);font-size:12px;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;transition:.15s}
.cpi-qty button:hover{background:var(--border)}
.cpi-qty span{font-size:15px;font-weight:800;min-width:22px;text-align:center}

/* Recommendations */
.recs-title{font-size:18px;font-weight:800;margin-bottom:12px}
.recs-scroll{display:flex;gap:12px;overflow-x:auto;scrollbar-width:none;padding-bottom:4px}
.recs-scroll::-webkit-scrollbar{display:none}
.rec-card{min-width:120px;background:var(--white);border-radius:var(--r-sm);box-shadow:var(--shadow);cursor:pointer;overflow:hidden;flex-shrink:0;transition:.2s}
.rec-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}
.rec-img{width:120px;height:90px;background:linear-gradient(135deg,#fef3ec,#fde8d8);overflow:hidden}
.rec-img img{width:100%;height:100%;object-fit:contain}
.rec-name{font-size:12px;font-weight:700;padding:8px 10px 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rec-price{font-size:13px;font-weight:800;color:var(--orange);padding:0 10px 8px}
.cart-recs{margin-bottom:24px}

/* Cart summary */
.cart-page-summary{background:var(--white);border-radius:var(--r);box-shadow:var(--shadow);padding:20px 24px}
.cps-row{display:flex;justify-content:space-between;font-size:14px;color:var(--gray);margin-bottom:8px}
.cps-total{font-size:20px;font-weight:900;color:var(--black);margin:12px 0 16px;padding-top:12px;border-top:1px solid var(--border)}

/* ===== ORDER TRACKING ===== */
.order-header{display:flex;align-items:center;gap:12px;margin-bottom:24px;flex-wrap:wrap}
.order-header h2{font-size:24px;font-weight:900}
.order-id{color:var(--orange)}
.order-badge{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:800;color:#fff}
.order-badge.done{background:var(--green)}
.order-badge.cancelled{background:var(--red)}
.order-progress{display:flex;align-items:center;gap:0;margin-bottom:8px;overflow-x:auto;padding:8px 0}
.op-step{display:flex;flex-direction:column;align-items:center;gap:6px;min-width:60px;flex-shrink:0}
.op-dot{width:36px;height:36px;border-radius:50%;background:var(--border);color:var(--gray-light);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;transition:.3s}
.op-step.done .op-dot{background:var(--green);color:#fff}
.op-step.active .op-dot{background:var(--orange);color:#fff;box-shadow:0 0 0 4px rgba(255,103,35,.2)}
.op-label{font-size:11px;font-weight:700;color:var(--gray-light);text-align:center;white-space:nowrap}
.op-step.done .op-label,.op-step.active .op-label{color:var(--black)}
.op-line{flex:1;height:3px;background:var(--border);min-width:20px;border-radius:2px}
.op-line.done{background:var(--green)}
.order-status-msg{font-size:18px;font-weight:800;text-align:center;padding:16px 0 24px}
.order-items{background:var(--white);border-radius:var(--r);box-shadow:var(--shadow);padding:20px;margin-bottom:16px}
.order-items h3{font-size:16px;font-weight:800;margin-bottom:12px}
.order-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border);font-size:14px;gap:8px}
.order-item:last-child{border-bottom:none}
.oi-name{flex:1}
.oi-qty{color:var(--gray);min-width:30px;text-align:center}
.oi-price{font-weight:700;min-width:60px;text-align:right}
.order-total{font-weight:900;font-size:16px;margin-top:8px;padding-top:8px}
.order-info{background:var(--white);border-radius:var(--r);box-shadow:var(--shadow);padding:16px 20px;margin-bottom:24px;font-size:14px;color:var(--gray)}
.order-info div{padding:4px 0;display:flex;align-items:center;gap:8px}
.order-info i{color:var(--orange);width:16px;text-align:center}

/* ===== PROFILE ===== */
.profile-card{display:flex;align-items:center;gap:16px;background:var(--white);border-radius:var(--r);box-shadow:var(--shadow);padding:20px;margin-bottom:16px}
.profile-ava{font-size:48px;color:var(--orange);flex-shrink:0}
.profile-name{font-size:18px;font-weight:800}
.profile-phone{font-size:14px;color:var(--gray);margin-top:2px}
.profile-phone.no-phone{color:var(--gray-light)}
.profile-stars{display:inline-flex;align-items:center;gap:6px;background:var(--orange-light);color:var(--orange);padding:6px 14px;border-radius:20px;font-size:14px;font-weight:800;margin-bottom:20px}
/* Баннер добавления телефона */
.profile-phone-banner{background:var(--white);border-radius:var(--r);box-shadow:var(--shadow);padding:20px;margin-bottom:20px;border-left:4px solid var(--orange)}
.ppb-icon{font-size:28px;color:var(--orange);margin-bottom:8px}
.ppb-text b{font-size:15px;font-weight:800}
.ppb-text p{font-size:13px;color:var(--gray);margin:2px 0 14px}
.profile-section-title{font-size:18px;font-weight:800;margin:24px 0 12px}
.profile-order{background:var(--white);border-radius:var(--r-sm);box-shadow:var(--shadow);padding:16px;margin-bottom:10px;cursor:pointer;transition:.2s}
.profile-order:hover{box-shadow:var(--shadow-hover)}
.po-top{display:flex;justify-content:space-between;margin-bottom:4px}
.po-id{font-weight:800;color:var(--orange)}
.po-date{font-size:13px;color:var(--gray)}
.po-items{font-size:13px;color:var(--gray);margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.po-bottom{display:flex;justify-content:space-between}
.po-status{font-size:13px;font-weight:700;color:var(--green)}
.po-total{font-size:15px;font-weight:800}

/* ===== EMPTY STATE ===== */
.empty-state{text-align:center;padding:60px 20px}
.empty-state .empty-icon{font-size:64px;margin-bottom:16px;opacity:.4}
.empty-state h3{font-size:22px;font-weight:900;margin-bottom:8px}
.empty-state p{color:var(--gray);margin-bottom:20px}

/* ===== RESPONSIVE ===== */
@media(max-width:1280px){
  .product-grid{grid-template-columns:repeat(5,1fr)}
}
@media(max-width:1100px){
  .product-grid{grid-template-columns:repeat(4,1fr)}
}
@media(max-width:860px){
  .header-nav{display:none}
  .cat-nav-mobile{display:block}
  .cat-section{scroll-margin-top:calc(var(--header-h) + var(--mobile-cat-h) + 16px)}
  .product-grid{grid-template-columns:repeat(3,1fr);gap:12px}
  .promo-slide{min-width:calc(100% - 16px)}
  .product-popup,.cart-popup{width:100%;max-width:100%;border-radius:var(--r) var(--r) 0 0;max-height:92vh;position:fixed;bottom:0;left:0;right:0;transform:translateY(100%)}
  .overlay.open .product-popup,.overlay.open .cart-popup{transform:translateY(0)}
  .checkout-popup{width:100%;border-radius:var(--r) var(--r) 0 0;position:fixed;bottom:0;left:0;right:0;transform:translateY(100%)}
  .overlay.open .checkout-popup{transform:translateY(0)}
}
@media(max-width:640px){
  :root{--header-h:56px}
  .topbar{display:none}
  .header-inner{padding:0 12px;gap:12px}
  .logo-icon{font-size:26px}
  .logo-text{font-size:15px}
  .btn-login .btn-login-text{display:none}
  .btn-login{padding:8px}
  .btn-cart{padding:8px 14px;font-size:13px}
  .delivery-bar-inner{padding:10px 16px}
  .dt-btn{padding:8px 16px;font-size:13px}
  .dt-btn i{display:none}
  .promo-slider-inner{padding:0 16px}
  .promo-slide{min-width:100%;padding:24px;height:140px}
  .promo-slide-text h2{font-size:18px}
  .promo-slide-img{font-size:48px}
  .main-inner{padding:0 12px}
  .main{padding:20px 0 40px}
  .cat-section{margin-bottom:28px}
  .cat-section-title{font-size:20px;margin-bottom:12px}
  .product-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .pc-body{padding:9px 10px 10px}
  .pc-name{font-size:13px}
  .pc-desc{display:none}
  .pc-weight{font-size:10px;margin-bottom:4px}
  .pc-price{font-size:14px}
  .btn-choose{padding:7px 10px;font-size:11px}
  .pc-img .pc-no-img{font-size:32px}
  .pc-img{padding:8px}
  .footer-inner{grid-template-columns:1fr;gap:24px;padding:0 16px}
  .checkout-popup{padding:24px 16px 32px}
  .pay-grid{grid-template-columns:1fr}
  .product-popup-body{padding:20px 16px}
  .product-popup-footer{padding:14px 16px}
}

@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.cat-section{animation:fadeUp .35s ease both}
.cart-item{animation:fadeUp .2s ease both}
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
