: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)}
.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}
.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}
.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}

/* 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}
.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}

.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}
}
