:root{
  --bg:#0f1115; --bg-2:#161a22; --panel:#1b202b; --panel-2:#212735;
  --border:#2a3140; --text:#e7ecf3; --muted:#8b95a7;
  --primary:#5b8cff; --primary-2:#3f6fe0; --green:#28c76f; --red:#ff5b6e; --amber:#ffb547;
  --radius:14px; --shadow:0 10px 30px rgba(0,0,0,.4);
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:'Inter',system-ui,Segoe UI,Roboto,Arial,sans-serif;background:radial-gradient(1100px 500px at 50% -10%,#1a2030,#0f1115) no-repeat,var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh}
button{font-family:inherit;cursor:pointer;color:inherit}
a{color:inherit;text-decoration:none}
[hidden]{display:none !important}
.wrap{max-width:1180px;margin:0 auto;padding:0 18px}
img{max-width:100%}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--panel-2);color:var(--text);border:1px solid var(--border);padding:12px 18px;border-radius:12px;font-size:15px;font-weight:600;transition:.15s}
.btn:hover{border-color:var(--muted)}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-2));border:none;color:#fff;box-shadow:0 6px 18px rgba(91,140,255,.4)}
.btn-primary:hover{filter:brightness(1.08)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed}
.btn-ghost{background:transparent}
.btn-block{width:100%}

/* Age gate */
.age-gate{position:fixed;inset:0;z-index:80;display:grid;place-items:center;background:rgba(8,10,14,.92);backdrop-filter:blur(6px);padding:20px}
.age-card{background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:34px;max-width:400px;text-align:center;box-shadow:var(--shadow)}
.age-logo{width:60px;height:60px;border-radius:16px;background:linear-gradient(135deg,var(--primary),#8a5bff);display:grid;place-items:center;margin:0 auto 16px;box-shadow:0 8px 22px rgba(91,140,255,.45)}
.age-logo img{width:60%}
.age-card h1{margin:0 0 10px;font-size:26px}
.age-card p{color:var(--muted);line-height:1.6;margin:0 0 22px}
.age-actions{display:flex;flex-direction:column;gap:10px;margin-bottom:18px}
.age-card small{color:var(--muted);font-size:11.5px;line-height:1.5;display:block}

/* Topbar */
.topbar{position:sticky;top:0;z-index:20;background:rgba(15,17,21,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}
.topbar-in{display:flex;align-items:center;gap:16px;padding-top:14px;padding-bottom:14px}
.brand{display:flex;align-items:center;gap:11px;flex-shrink:0}
.brand-logo{width:40px;height:40px;border-radius:11px;background:linear-gradient(135deg,var(--primary),#8a5bff);display:grid;place-items:center;box-shadow:0 6px 16px rgba(91,140,255,.4)}
.brand-logo img{width:60%}
.brand-name{font-weight:800;font-size:20px;letter-spacing:-.01em}
.search{flex:1;background:var(--panel);border:1px solid var(--border);color:var(--text);padding:11px 16px;border-radius:12px;font-size:15px;outline:none;min-width:0}
.search:focus{border-color:var(--primary)}
.acc-btn{background:var(--panel-2);border:1px solid var(--border);border-radius:12px;padding:11px 14px;font-size:14px;font-weight:700;flex-shrink:0;color:var(--text);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.acc-btn:hover{border-color:var(--primary)}
.cart-btn{position:relative;background:var(--panel-2);border:1px solid var(--border);border-radius:12px;padding:11px 16px;font-size:16px;font-weight:700;flex-shrink:0}
.cart-btn:hover{border-color:var(--primary)}
.cart-count{display:inline-grid;place-items:center;min-width:22px;height:22px;padding:0 6px;border-radius:11px;background:var(--primary);color:#fff;font-size:12.5px;margin-left:4px}

.main{padding:22px 18px 60px}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.chip{background:var(--panel);border:1px solid var(--border);color:var(--muted);padding:8px 15px;border-radius:22px;font-size:13.5px;font-weight:600;transition:.12s;white-space:nowrap}
.chip:hover{color:var(--text);border-color:var(--muted)}
.chip.active{background:var(--primary);border-color:var(--primary);color:#fff}

/* Grid */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:16px}
.card{background:var(--panel);border:1px solid var(--border);border-radius:16px;overflow:hidden;display:flex;flex-direction:column;transition:.15s}
.card:hover{border-color:#384156;transform:translateY(-2px)}
.card-img{aspect-ratio:1/1;background:var(--bg-2);display:grid;place-items:center;overflow:hidden;position:relative}
.card-img img{width:100%;height:100%;object-fit:cover}
.card-img .noimg{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:#fff}
.card-img .ph-emoji{font-size:50px;filter:drop-shadow(0 4px 10px rgba(0,0,0,.25))}
.card-img .ph-brand{font-size:13px;font-weight:700;letter-spacing:.02em;opacity:.95;text-shadow:0 1px 4px rgba(0,0,0,.25);padding:0 10px;text-align:center}
.card-cat{position:absolute;top:10px;left:10px;background:rgba(15,17,21,.78);backdrop-filter:blur(4px);color:var(--text);font-size:11px;font-weight:600;padding:4px 9px;border-radius:20px;z-index:2}
.promo-badge{position:absolute;top:10px;right:10px;z-index:2;font-size:11px;font-weight:800;padding:4px 10px;border-radius:20px;color:#fff;box-shadow:0 4px 12px rgba(0,0,0,.35);letter-spacing:.01em}
.promo-hit{background:linear-gradient(135deg,#ff8a18,#ff3d5e)}
.promo-new{background:linear-gradient(135deg,#28c76f,#1f9d8f)}
.card.glow-hit{border-color:#ff7a3d;box-shadow:0 0 0 1px #ff7a3d,0 10px 28px rgba(255,90,60,.30)}
.card.glow-new{border-color:#28c76f;box-shadow:0 0 0 1px #28c76f,0 10px 28px rgba(40,199,111,.28)}
.card.glow-hit:hover,.card.glow-new:hover{transform:translateY(-3px)}
.badge-toggle{position:absolute;bottom:8px;left:8px;z-index:4;background:rgba(15,17,21,.82);backdrop-filter:blur(4px);border:1px solid var(--border);color:var(--text);font-size:11px;font-weight:700;padding:5px 10px;border-radius:9px;cursor:pointer}
.badge-toggle.on{background:var(--primary);border-color:var(--primary);color:#fff}
.badge-toggle:hover{border-color:var(--primary)}
.card-body{padding:13px 14px;display:flex;flex-direction:column;gap:8px;flex:1}
.card-name{font-size:13.5px;font-weight:600;line-height:1.3;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;min-height:52px}
.card-brand{font-size:11.5px;color:var(--muted)}
.card-foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:8px}
.card-price{font-size:18px;font-weight:800}
.card-add{background:linear-gradient(135deg,var(--primary),var(--primary-2));border:none;color:#fff;width:40px;height:40px;border-radius:11px;font-size:20px;font-weight:700;display:grid;place-items:center;flex-shrink:0;box-shadow:0 4px 12px rgba(91,140,255,.35)}
.card-add:hover{filter:brightness(1.1)}
.card-add:disabled{background:var(--panel-2);box-shadow:none;color:var(--muted);cursor:not-allowed}
.card.out .card-img{opacity:.5}
.out-badge{position:absolute;inset:0;display:grid;place-items:center;background:rgba(15,17,21,.5);color:#fff;font-weight:700;font-size:14px}
.transit-strip{position:absolute;left:0;right:0;bottom:0;z-index:2;background:linear-gradient(135deg,#3f6fe0,#6f5bff);color:#fff;font-size:11.5px;font-weight:700;text-align:center;padding:5px 8px}
.transit-note{font-size:11px;color:var(--amber);font-weight:600;line-height:1.3}
.card.transit{border-color:#3f6fe0}
.card-add.preorder{background:linear-gradient(135deg,#3f6fe0,#6f5bff)}
.qty-mini{display:flex;align-items:center;border:1px solid var(--border);border-radius:11px;overflow:hidden;height:40px}
.qty-mini button{background:var(--panel-2);border:none;color:var(--text);width:32px;height:40px;font-size:18px}
.qty-mini span{min-width:30px;text-align:center;font-size:14px;font-weight:700}

.loading,.empty{grid-column:1/-1;text-align:center;padding:60px 20px;color:var(--muted)}
.empty .ico{font-size:42px;margin-bottom:10px}

.footer{padding:30px 18px 50px;color:var(--muted);font-size:12.5px;text-align:center;border-top:1px solid var(--border);margin-top:20px}
.footer-links{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:16px}
.tg-link{display:inline-flex;align-items:center;gap:6px;background:var(--panel);border:1px solid var(--border);color:var(--text);padding:9px 16px;border-radius:11px;font-size:13.5px;font-weight:600;transition:.15s}
.tg-link:hover{border-color:var(--primary);transform:translateY(-1px)}
.tg-link.manager{background:linear-gradient(135deg,#2aabee,#229ed9);border:none;color:#fff;box-shadow:0 4px 14px rgba(34,158,217,.35)}
.staff-link{background:transparent;border:none;color:var(--muted);font-size:12px;text-decoration:underline;cursor:pointer;opacity:.6;margin-top:6px}
.staff-link:hover{opacity:1;color:var(--text)}

/* Баннер режима редактирования */
.admin-banner{position:sticky;top:0;z-index:30;background:linear-gradient(135deg,#3f6fe0,#6f5bff);color:#fff;font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 16px;flex-wrap:wrap}
.admin-banner .ab-right{display:flex;align-items:center;gap:12px}
.admin-banner a{color:#fff;text-decoration:underline}
.admin-banner button{background:rgba(255,255,255,.2);border:none;color:#fff;padding:5px 12px;border-radius:8px;font-weight:600}
.admin-banner button:hover{background:rgba(255,255,255,.32)}

/* Окно входа */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:70;display:grid;place-items:center;padding:20px}
.login-box{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:26px;width:100%;max-width:360px;box-shadow:var(--shadow)}
.login-box h3{margin:0 0 16px;font-size:18px}
.login-err{background:rgba(255,91,110,.14);color:var(--red);padding:9px 13px;border-radius:10px;font-size:13px;margin-bottom:12px}
.login-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}

/* Редактирование цены на карточке */
.price-edit{display:flex;align-items:center;gap:5px;border:1px solid var(--primary);border-radius:10px;padding:3px 8px;background:var(--bg-2)}
.price-edit input{width:74px;background:transparent;border:none;color:var(--text);font-size:16px;font-weight:800;outline:none}
.price-edit .cur{color:var(--muted);font-size:13px}
.card-price.editable{cursor:pointer;border-bottom:1px dashed var(--muted)}
.card-price.editable:hover{color:var(--primary)}

/* Drawer (корзина/оформление) */
.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:40}
.drawer{position:fixed;top:0;right:0;bottom:0;width:420px;max-width:92vw;background:var(--panel);border-left:1px solid var(--border);z-index:41;display:flex;flex-direction:column;box-shadow:var(--shadow);animation:slideIn .22s ease}
@keyframes slideIn{from{transform:translateX(30px);opacity:.6}to{transform:none;opacity:1}}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border)}
.drawer-head h2{margin:0;font-size:18px}
.drawer-close{background:transparent;border:none;color:var(--muted);font-size:24px;line-height:1}
.drawer-body{flex:1;overflow:auto;padding:18px 20px}
.drawer-foot{padding:16px 20px;border-top:1px solid var(--border)}

.cart-row{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}
.cart-row:last-child{border-bottom:none}
.cart-thumb{width:56px;height:56px;border-radius:10px;background:var(--bg-2);object-fit:cover;flex-shrink:0;display:grid;place-items:center;font-size:22px;opacity:.9}
.cart-info{flex:1;min-width:0}
.cart-info .cn{font-size:13px;font-weight:600;line-height:1.3}
.cart-info .cp{font-size:12.5px;color:var(--muted);margin-top:2px}
.cart-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px}
.cart-sum{font-weight:700;font-size:14px;white-space:nowrap}
.cart-total{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px}
.cart-total .lbl{color:var(--muted)}
.cart-total .val{font-size:24px;font-weight:800}

.field{display:flex;flex-direction:column;gap:6px;margin-bottom:13px}
.field label{font-size:13px;color:var(--muted);font-weight:500}
.field input,.field select,.field textarea{background:var(--bg-2);border:1px solid var(--border);color:var(--text);padding:11px 13px;border-radius:11px;font-size:14.5px;outline:none;width:100%}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--primary)}
.seg{display:flex;gap:6px;background:var(--bg-2);border:1px solid var(--border);border-radius:11px;padding:4px}
.seg button{flex:1;background:transparent;border:none;color:var(--muted);padding:9px;border-radius:8px;font-size:13.5px;font-weight:600}
.seg button.active{background:var(--primary);color:#fff}
.seg.seg-col{flex-direction:column;gap:6px}
.seg.seg-col button{text-align:left;padding:11px 13px}
.pay-note{color:var(--muted);font-size:12.5px;line-height:1.5;margin:8px 0 0}
.auth-tabs{display:flex;gap:8px;margin-bottom:14px}
.auth-tabs button{flex:1;background:var(--bg-2);border:1px solid var(--border);color:var(--muted);padding:9px;border-radius:10px;font-weight:600}
.auth-tabs button.active{background:var(--primary);border-color:var(--primary);color:#fff}
.ord-row{border:1px solid var(--border);border-radius:12px;padding:12px;margin-bottom:10px}
.ord-top{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:6px}
.ord-items{font-size:12px;color:var(--muted);line-height:1.5}
.promo-row{display:flex;gap:8px}
.promo-row input{flex:1}
.sum-line{display:flex;justify-content:space-between;font-size:13.5px;margin-top:5px}
.sum-line.disc{color:var(--green);font-weight:600}
.notice{background:rgba(255,181,71,.12);border:1px solid rgba(255,181,71,.32);color:#ffcf80;padding:10px 12px;border-radius:10px;font-size:12.5px;line-height:1.5;margin-top:10px}
.acc-profile .field{margin-bottom:11px}
.row2{display:flex;gap:10px}
.row2 .field{flex:1}

.ok-screen{text-align:center;padding:30px 10px}
.ok-screen .ico{font-size:54px;margin-bottom:10px}
.ok-screen h2{margin:0 0 8px}
.ok-screen p{color:var(--muted);line-height:1.6}

.fab-manager{position:fixed;right:18px;bottom:18px;z-index:35;display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,#2aabee,#229ed9);color:#fff;padding:13px 18px;border-radius:30px;font-weight:700;font-size:14.5px;box-shadow:0 8px 24px rgba(34,158,217,.45);transition:.15s}
.fab-manager:hover{transform:translateY(-2px);filter:brightness(1.05)}
.fab-ico{font-size:18px}
@media (max-width:560px){.fab-manager{right:14px;bottom:14px;padding:13px}.fab-text{display:none}}
.toast-wrap{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;gap:10px;z-index:100;align-items:center}
.toast{background:var(--panel-2);border:1px solid var(--border);border-left:3px solid var(--primary);padding:12px 18px;border-radius:11px;font-size:14px;box-shadow:var(--shadow)}
.toast.ok{border-left-color:var(--green)}
.toast.err{border-left-color:var(--red)}

@media (max-width:560px){
  .brand-name{display:none}
  .grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:11px}
  .card-name{min-height:46px;font-size:12.5px}
}
