
:root{
  --bg:#ffffff;
  --surface:#f7f7f8;
  --muted:#6b7280;
  --accent:#4f46e5;
  --card:#ffffff;
}
/* page load animation */
body{opacity:0;transform:translateY(6px);transition:opacity .45s ease, transform .45s cubic-bezier(.2,.9,.2,1)}
body.visible{opacity:1;transform:none}

/* card entrance */
@keyframes cardIn{0%{opacity:0;transform:translateY(12px) scale(.995)}100%{opacity:1;transform:translateY(0) scale(1)}}
.animate-card{opacity:0;animation:cardIn .42s forwards cubic-bezier(.2,.9,.2,1)}

/* cart button bump */
.cart-btn{transition:transform .22s cubic-bezier(.2,.9,.2,1)}
.cart-btn.bump{transform:translateY(-6px) scale(1.04)}
*{box-sizing:border-box}
body{font-family:Inter,system-ui,Arial,Helvetica,sans-serif;margin:0;background:linear-gradient(180deg,var(--surface),var(--bg));color:#0f172a}
.top{display:flex;justify-content:space-between;align-items:center;padding:18px 20px;height:84px;background:linear-gradient(90deg,var(--accent),#7c3aed);color:#fff}
.header-right{display:flex;align-items:center}
.top h1{margin:0;font-size:1.25rem;margin-left:8px}
.main-catalog-wrap{}
main{padding:14px 6px 14px 14px;display:grid;grid-template-columns:1fr;gap:14px}
.card{background:var(--card);border-radius:12px;box-shadow:0 6px 18px rgba(15,23,42,0.06);overflow:hidden;border:1px solid rgba(15,23,42,0.06)}
.card img{width:100%;height:180px;object-fit:cover}
.card .body{padding:12px}
.card .title{font-weight:700;margin-bottom:6px;color:#0f172a}
.card .price{color:var(--muted);font-weight:600}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;justify-content:start}

/* category chips */
.chips{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.chip{background:transparent;border:1px solid rgba(15,23,42,0.06);color:var(--muted);padding:6px 10px;border-radius:999px;cursor:pointer;transition:all .12s ease}
.chip:hover{filter:brightness(1.06);transform:translateY(-2px)}
.chip.active{background:linear-gradient(90deg,var(--accent),#00e5ff);color:#fff;border-color:transparent;box-shadow:0 8px 30px rgba(79,70,229,0.08)}

.card{transition:transform .25s ease, box-shadow .25s ease}
.card:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 12px 40px rgba(124,58,237,0.25)}
.card .title{position:relative}
.card .title:after{content:'';position:absolute;left:0;bottom:-6px;width:40px;height:3px;background:linear-gradient(90deg,var(--accent),#00e5ff);border-radius:2px;box-shadow:0 6px 30px rgba(124,58,237,0.4)}
.actions{margin-top:8px}
.add{background:linear-gradient(90deg,var(--accent),#00e5ff);border:none;padding:8px 12px;border-radius:8px;color:#05060a;font-weight:700;cursor:pointer}
.add:hover{filter:brightness(1.05);transform:translateY(-2px)}
.stock{color:var(--muted);margin-top:6px}

/* controls */
.controls{display:flex;gap:8px;padding:12px}
.controls input{flex:1;padding:10px;border-radius:10px;border:1px solid rgba(15,23,42,0.06);background:#fff;color:#0f172a}
.controls button{background:transparent;border:1px solid rgba(15,23,42,0.06);color:#0f172a;padding:8px 12px;border-radius:10px}
.cart-btn{display:inline-flex;align-items:center;gap:8px}
.cart-icon{width:20px;height:20px;display:inline-block}

/* cart badge (count) — absolute so it doesn't affect layout */
/* removed badge styles — restored original counter markup */

/* cart */
.cart{position:fixed;right:12px;top:100px;width:320px;max-width:95%;background:linear-gradient(180deg,rgba(255,255,255,0.02),rgba(0,0,0,0.6));border-radius:12px;box-shadow:0 12px 40px rgba(2,6,23,.7);padding:12px;border:1px solid rgba(124,58,237,0.12);visibility:hidden;opacity:0;transform:translateY(12px) scale(.98);transition:opacity .32s ease, transform .36s cubic-bezier(.2,.9,.2,1), box-shadow .36s ease}
.cart.open{visibility:visible;opacity:1;transform:translateY(0) scale(1);box-shadow:0 20px 60px rgba(124,58,237,0.18);border:2px solid rgba(124,58,237,0.85);}
.cart-footer{display:flex;justify-content:space-between;align-items:center;margin-top:8px}

/* subtle pulsing accent */
@keyframes neonPulse{0%{box-shadow:0 0 0 rgba(124,58,237,0)}50%{box-shadow:0 0 30px rgba(124,58,237,0.12)}100%{box-shadow:0 0 0 rgba(124,58,237,0)}}
top{animation:neonPulse 3s infinite ease-in-out}

/* cart neon glow animation on open */
@keyframes cartGlow{0%{box-shadow:0 6px 20px rgba(124,58,237,0.08)}50%{box-shadow:0 18px 60px rgba(124,58,237,0.22)}100%{box-shadow:0 6px 20px rgba(124,58,237,0.08)}}
.cart.open{animation:cartGlow 1.2s ease both}

/* flavor chooser modal */
.flavor-select{display:none}

/* bottom-sheet style for flavor chooser */
.flavor-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.28);display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .28s ease}
.flavor-modal-overlay.open{opacity:1;pointer-events:auto}
.flavor-modal{background:var(--card);width:100%;max-width:720px;border-radius:12px 12px 0 0;padding:12px 12px 20px;box-shadow:0 -12px 40px rgba(2,6,23,0.12);transform:translateY(100%);opacity:1;transition:transform .32s cubic-bezier(.2,.9,.2,1)}
.flavor-modal-overlay.open .flavor-modal{transform:translateY(0)}
.flavor-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.flavor-item{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-radius:10px;border:1px solid rgba(15,23,42,0.06);background:#ffffff;color:#0f172a;cursor:pointer}
.flavor-item:hover{box-shadow:0 8px 24px rgba(15,23,42,0.06);transform:translateY(-2px)}
.flavor-item:disabled{opacity:0.5;cursor:not-allowed}
.flavor-item .meta{color:var(--muted);font-size:13px}

/* small handle indicator */
.flavor-modal .handle{width:48px;height:6px;background:#e6eef6;border-radius:6px;margin:6px auto 8px;opacity:0.9}

/* product detail modal (reuses overlay) */
.product-modal{background:var(--card);width:100%;max-width:720px;border-radius:12px 12px 0 0;padding:12px 16px 20px;box-shadow:0 -12px 40px rgba(2,6,23,0.12);transform:translateY(100%);transition:transform .32s cubic-bezier(.2,.9,.2,1)}
.flavor-modal-overlay.open .product-modal{transform:translateY(0)}
/* make modal content scrollable on small screens and allow smooth touch scrolling */
.product-modal{max-height:90vh;overflow:auto;-webkit-overflow-scrolling:touch}
.product-modal .product-close{position:absolute;right:12px;top:8px;background:transparent;border:none;color:var(--muted);font-size:18px;padding:8px;border-radius:8px;cursor:pointer}
.product-modal h3{margin:8px 0;color:#0f172a}
.product-cat{color:var(--muted);font-size:13px}
.product-desc{color:#0f172a}
.product-modal .flavor-item{background:transparent;border:1px solid rgba(15,23,42,0.04);padding:10px}

/* fullscreen image viewer */
.img-fullscreen-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.9);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .26s ease}
.img-fullscreen-overlay.open{opacity:1;pointer-events:auto}
.img-fullscreen-img{max-width:98%;max-height:98%;object-fit:contain;border-radius:6px}

/* ensure fullscreen viewer overlays other UI */
.img-fullscreen-overlay{z-index:100050}

/* global button styling (dark) */
button, .add, .controls button{
  background:linear-gradient(90deg,var(--accent),#7c3aed);
  border:1px solid rgba(0,0,0,0.04);
  color:#fff;
  padding:8px 10px;
  border-radius:8px;
  cursor:pointer;
  transition:transform .12s ease, box-shadow .12s ease, filter .12s ease;
}
button:hover{transform:translateY(-2px);filter:brightness(1.06)}
button:active{transform:translateY(0)}

/* logo */
.logo{height:56px}
.logo-wrap{display:inline-flex;align-items:center;margin-right:12px}

/* small responsive tweaks */
@media (max-width:520px){
  .controls{flex-direction:column}
  .grid{grid-template-columns:1fr}
}

/* toast */
#toasts{display:flex;flex-direction:column;gap:8px}
.toast{background:linear-gradient(90deg,var(--accent),#00e5ff);color:#05060a;padding:10px 12px;border-radius:10px;box-shadow:0 6px 24px rgba(15,23,42,0.06);transform:translateX(12px);opacity:0;transition:all .25s ease}
.toast.visible{transform:translateX(0);opacity:1}

/* cart summary (compact lines showing quantity × name) */
.cart-summary{padding:8px 6px;border-bottom:1px solid rgba(15,23,42,0.04);max-height:160px;overflow:auto}
.cart-summary-line{padding:6px 8px;border-radius:8px;background:linear-gradient(90deg,rgba(79,70,229,0.04),rgba(0,229,255,0.02));margin-bottom:6px;font-weight:600;color:#0f172a}
.cart-empty{color:var(--muted);padding:8px}

.cart-flavor{color:var(--muted);font-size:13px;margin-top:4px}
.cart-summary-flavor{color:var(--muted);font-size:13px;margin-top:6px}

/* small circular badge for qty */
.qty-badge{min-width:30px;height:30px;border-radius:999px;background:linear-gradient(90deg,var(--accent),#00e5ff);color:#05060a;display:inline-flex;align-items:center;justify-content:center;font-weight:700;margin:0 8px}

/* header small badge */
.header-qty-badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;border-radius:999px;background:linear-gradient(90deg,var(--accent),#00e5ff);color:#05060a;font-weight:800;margin-left:8px;font-size:12px}
.header-qty-badge.hidden{display:none}

/* Telegram avatar in header: show full image with minimal cropping */
.tg-avatar{width:44px;height:44px;border-radius:8px;overflow:hidden;display:inline-block;margin-right:10px;border:2px solid rgba(255,255,255,0.12);background:linear-gradient(90deg,var(--accent),#00e5ff)}
.tg-avatar img{width:100%;height:100%;object-fit:contain;display:block}

/* cart styles when positioned absolutely */
.cart{background:var(--card);border:1px solid rgba(255,255,255,0.03);}
.cart .cart-line-left{display:flex;flex-direction:column}
.cart .cart-line-right{display:flex;align-items:center;gap:6px}
.qty-input{background:#0b0f14;border:1px solid rgba(255,255,255,0.04);color:#e6eef6;padding:6px;border-radius:6px}

/* fullscreen cart styling */
.cart.fullscreen{position:fixed;inset:0;right:0;top:0;width:100%;height:100vh;max-width:none;border-radius:0;padding:18px;overflow:auto;z-index:100200}
.cart.fullscreen { position: fixed; inset: 0; right: 0; top: 0; width: 100%; height: 100vh; max-width: none; border-radius: 0; padding: 18px; overflow: auto; z-index: 100200; transform: translateY(12px) scale(.99); opacity: 0; transition: transform .34s cubic-bezier(.2,.9,.2,1), opacity .34s ease; }
.cart.fullscreen.opened { transform: translateY(0) scale(1); opacity: 1; }
.cart.fullscreen .cart-footer{position:sticky;bottom:18px;background:transparent;padding-top:12px}
body.cart-fullscreen-open{overflow:hidden}
.cart-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:100150}
.clear-btn{background:#ef4444;border:none;color:#fff;padding:10px 12px;border-radius:8px;cursor:pointer;font-weight:700}
.clear-btn:hover{filter:brightness(0.95)}
.cart .file-button{background:rgba(255,255,255,0.06);color:#fff;border:1px solid rgba(255,255,255,0.06)}
.cart .file-button:hover{filter:brightness(1.05)}

/* top close button style */
.cart-close-top svg{display:block;width:16px;height:16px}
.cart-close-top{background:rgba(0,0,0,0.32);border:none;padding:6px;display:inline-flex;align-items:center;justify-content:center;color:#fff;z-index:100210}
.cart-close-top:hover{background:rgba(0,0,0,0.42)}

/* fullscreen toggle icon styling */
.fs-toggle{display:inline-flex;align-items:center;justify-content:center;padding:6px;border-radius:8px}
.fs-icon{width:16px;height:16px;display:block}
.fs-toggle.collapsed .fs-icon{transform:rotate(180deg)}
.cart-controls{display:inline-flex;gap:8px;align-items:center}

/* delivery controls in cart */
.delivery-options label{font-size:13px;color:var(--muted);cursor:pointer}
#metro-input{min-width:140px}

/* ensure catalog fills available vertical space */
main{min-height:calc(100vh - 200px)}

/* custom file button */
.file-button{background:linear-gradient(90deg,var(--accent),#00e5ff);color:#05060a;padding:8px 12px;border-radius:8px;cursor:pointer;border:1px solid rgba(0,0,0,0.2)}
.file-button:hover{filter:brightness(1.06)}

/* cart positioning tweaks when shown near button */
/* removed absolute override to keep cart fixed and stable when counts update */

@media (min-width:700px){
  main{grid-template-columns:repeat(3,1fr)}
}

/* card description inside catalog */
.card-desc{color:var(--muted);font-size:13px;margin-top:8px;max-height:64px;overflow:hidden}

/* footer */
.site-footer{padding:12px 14px;text-align:center;color:#9ca3af;font-size:8px}

form input, form button{display:block;width:100%;padding:8px;margin:6px 0;background:var(--surface);border:1px solid rgba(255,255,255,0.03);color:#e6eef6}

/* Admin-specific overrides: ensure inputs and buttons are white and readable on white background */
.admin form input,
.admin form button,
.admin .file-button,
.admin input[type="color"]{
  background:#ffffff;
  color:#0f172a;
  border:1px solid rgba(15,23,42,0.06);
}
.admin form input::placeholder{color:#6b7280}
.admin .file-button{background:linear-gradient(180deg,#ffffff,#f6f6f8);border:1px solid rgba(15,23,42,0.06)}
.admin form button{box-shadow:none}

