/* ===== Магазин (Spotlight) ===== */
.store-wrap{ --s-acc:#29a3ab; --s-acc2:#5fe3ff; --s-blue:#2b7fff; --s-card:rgba(255,255,255,.035); --s-bd:rgba(255,255,255,.06); --s-hi:rgba(41,163,171,.45); --s-head:#eafcff; --s-muted:#9fb2c0; display:block; }
.store-wrap *{ box-sizing:border-box; }

/* hero */
.store-hero{ display:flex; align-items:center; gap:18px; background:var(--s-card); border:1px solid var(--s-bd); border-radius:20px; padding:26px 30px; margin-top:14px; box-shadow:0 18px 50px rgba(0,0,0,.3); }
.store-hero-ic{ width:64px; height:64px; flex-shrink:0; border-radius:18px; display:flex; align-items:center; justify-content:center; background:linear-gradient(120deg,var(--s-acc),var(--s-blue)); box-shadow:0 10px 30px rgba(43,127,255,.35); }
.store-hero-ic svg{ width:32px; height:32px; fill:#fff; }
.store-eyebrow{ display:inline-block; font-size:13px; font-weight:800; letter-spacing:.18em; text-transform:uppercase; background:linear-gradient(120deg,var(--s-acc2),var(--s-blue)); -webkit-background-clip:text; background-clip:text; color:transparent; margin-bottom:6px; }
.store-title{ margin:0; font-family:var(--font-family-1,"Unbounded"),sans-serif; font-size:clamp(26px,3.4vw,40px); font-weight:800; color:var(--s-head); letter-spacing:-.01em; }
.store-title span{ background:linear-gradient(120deg,var(--s-acc2),var(--s-blue)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.store-sub{ margin:6px 0 0; color:var(--s-muted); font-size:15px; }

/* tabs */
.store-tabs{ display:flex; gap:8px; flex-wrap:wrap; margin:22px 0; }
.store-tab{ padding:10px 20px; border-radius:12px; background:var(--s-card); border:1px solid var(--s-bd); color:var(--s-muted); font-size:14px; font-weight:600; cursor:pointer; transition:.2s; }
.store-tab:hover{ color:var(--s-head); border-color:var(--s-hi); }
.store-tab.active{ background:linear-gradient(120deg,var(--s-acc),var(--s-blue)); color:#fff; border-color:transparent; box-shadow:0 6px 18px rgba(43,127,255,.3); }

/* grid */
.store-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:18px; }
.store-card{ position:relative; background:var(--s-card); border:1px solid var(--s-bd); border-radius:20px; padding:26px; display:flex; flex-direction:column; transition:transform .25s, border-color .25s, box-shadow .25s; animation:storeIn .4s ease; }
.store-card:hover{ transform:translateY(-5px); border-color:var(--s-hi); box-shadow:0 22px 55px rgba(0,0,0,.4); }
.store-card-feat{ }
.store-card-feat.store-card-feat{}
.store-card-feat{ } /* placeholder */
.store-card.store-card-feat{ border-color:rgba(95,227,255,.45); box-shadow:0 0 36px rgba(41,163,171,.16); }
.store-card-tag{ position:absolute; top:16px; right:16px; padding:5px 12px; border-radius:999px; font-size:11px; font-weight:800; letter-spacing:.04em; background:linear-gradient(120deg,var(--s-acc),var(--s-blue)); color:#fff; box-shadow:0 6px 16px rgba(43,127,255,.35); }
.store-card-ic{ width:56px; height:56px; border-radius:16px; display:flex; align-items:center; justify-content:center; background:rgba(41,163,171,.12); border:1px solid rgba(41,163,171,.25); margin-bottom:16px; }
.store-card-ic svg{ width:28px; height:28px; fill:var(--s-acc2); filter:drop-shadow(0 0 8px var(--s-acc)); }
.store-card-name{ font-family:var(--font-family-1,"Unbounded"),sans-serif; font-size:22px; font-weight:800; color:var(--s-head); margin-bottom:14px; }
.store-card-feat{ list-style:none; margin:0 0 18px; padding:0; display:flex; flex-direction:column; gap:9px; flex:1; }
.store-card-feat li{ display:flex; align-items:center; gap:9px; font-size:13.5px; color:var(--s-muted); }
.store-card-feat li svg{ width:15px; height:15px; flex-shrink:0; fill:var(--s-acc2); }
.store-card-bottom{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-top:auto; }
.store-card-price{ font-family:var(--font-family-1,"Unbounded"),sans-serif; font-size:22px; font-weight:800; background:linear-gradient(120deg,var(--s-acc2),var(--s-blue)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.store-card-price span{ font-family:Inter,sans-serif; font-size:12px; font-weight:500; color:var(--s-muted); -webkit-text-fill-color:var(--s-muted); margin-left:4px; }
.store-buy{ display:inline-flex; align-items:center; gap:8px; padding:11px 20px; border-radius:12px; border:none; cursor:pointer; background:linear-gradient(120deg,var(--s-acc),var(--s-blue)); color:#fff; font-weight:700; font-size:14px; box-shadow:0 6px 20px rgba(43,127,255,.3); transition:transform .2s, box-shadow .2s; }
.store-buy svg{ width:16px; height:16px; fill:#fff; }
.store-buy:hover{ transform:translateY(-2px); box-shadow:0 10px 28px rgba(43,127,255,.5); }
.store-buy-ok{ background:#3ddc84 !important; }
@keyframes storeIn{ from{ opacity:0; transform:translateY(16px); } to{ opacity:1; transform:none; } }
@media (max-width:560px){ .store-hero{ flex-direction:column; text-align:center; } .store-grid{ grid-template-columns:1fr; } }

/* ===== Редактор товаров (админ) ===== */
.store-hero{ position:relative; }
.store-edit-open{ margin-left:auto; display:inline-flex; align-items:center; gap:8px; padding:11px 18px; border-radius:12px; cursor:pointer;
  background:rgba(41,163,171,.12); border:1px solid rgba(41,163,171,.3); color:#5fe3ff; font-weight:600; font-size:14px; transition:.2s; }
.store-edit-open:hover{ background:rgba(41,163,171,.22); }
.store-edit-open svg{ width:15px; height:15px; fill:currentColor; }
.se-head{ display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; margin:18px 0 14px; }
.se-eyebrow{ font-size:12px; font-weight:800; letter-spacing:.18em; text-transform:uppercase; background:linear-gradient(120deg,#5fe3ff,#2b7fff); -webkit-background-clip:text; background-clip:text; color:transparent; }
.se-title{ font-family:var(--font-family-1,"Unbounded"),sans-serif; font-size:22px; font-weight:800; color:#eafcff; }
.se-actions{ display:flex; gap:8px; flex-wrap:wrap; }
.se-btn{ display:inline-flex; align-items:center; gap:7px; padding:10px 18px; border-radius:11px; cursor:pointer; font-weight:600; font-size:14px;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); color:#e7edf2; transition:.2s; }
.se-btn:hover{ background:rgba(255,255,255,.08); border-color:rgba(41,163,171,.35); }
.se-btn svg{ width:15px; height:15px; fill:currentColor; }
.se-btn-primary{ background:linear-gradient(120deg,#29a3ab,#2b7fff); border:none; color:#fff; box-shadow:0 6px 20px rgba(43,127,255,.3); }
.se-btn-primary:hover{ transform:translateY(-2px); }
.se-hint{ display:flex; align-items:center; gap:9px; padding:12px 16px; border-radius:12px; margin-bottom:16px; font-size:13px; color:#9fb2c0;
  background:rgba(41,163,171,.08); border:1px solid rgba(41,163,171,.25); }
.se-hint svg{ width:16px; height:16px; fill:#5fe3ff; flex-shrink:0; }
.se-list{ display:flex; flex-direction:column; gap:12px; }
.se-row{ background:rgba(255,255,255,.035); border:1px solid rgba(255,255,255,.06); border-radius:16px; padding:16px 18px; }
.se-row-head{ display:flex; align-items:center; gap:10px; margin-bottom:14px; }
.se-drag{ color:#5e7585; cursor:default; }
.se-row-title{ font-family:var(--font-family-1,"Unbounded"),sans-serif; font-weight:700; color:#eafcff; flex:1; }
.se-del{ width:34px; height:34px; border-radius:10px; cursor:pointer; display:flex; align-items:center; justify-content:center;
  background:rgba(255,80,80,.1); border:1px solid rgba(255,80,80,.3); color:#ff8585; transition:.2s; }
.se-del:hover{ background:rgba(255,80,80,.2); }
.se-del svg{ width:15px; height:15px; fill:currentColor; }
.se-grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(180px,1fr)); gap:12px; }
.se-f{ display:flex; flex-direction:column; gap:6px; font-size:12px; color:#9fb2c0; }
.se-f span{ font-weight:600; }
.se-f input[type="text"], .se-f select, .se-f textarea{ background:rgba(0,0,0,.22); border:1px solid rgba(255,255,255,.07); border-radius:10px; padding:9px 12px; color:#e7edf2; font-size:14px; outline:none; transition:border-color .2s; font-family:Inter,sans-serif; }
.se-f input:focus, .se-f select:focus, .se-f textarea:focus{ border-color:rgba(41,163,171,.5); }
.se-f textarea{ resize:vertical; line-height:1.5; }
.se-f-full{ margin-top:12px; }
.se-f-chk{ flex-direction:row; align-items:center; gap:9px; }
.se-f-chk input{ width:18px; height:18px; accent-color:#29a3ab; }
.se-f-chk span{ font-size:13px; }
