/* ВИНО·ВЕЧЕР — изумрудная тёмная система (редизайн по хендоффу Claude Design).
   Правило: НИКАКИХ обводок/дивайдеров — разделение плашкой + тенью + свечением + воздухом.
   Токены сняты 1:1 с бандла (Manrope, #0A0E0D/#141B1C, зелёный #33C57A, оранжевый #FF6803). */
:root{
  --bg:#0A0E0D; --deep:#060908; --panel:#141B1C; --inset:#0A0E0D; --btn:#1c2626;
  --text:#F1F5F2; --muted:#A7BCB6; --faint:#6E827A;
  --green:#33C57A; --glow:#67E01C; --mint:#8EFEEE; --emerald:#006A4F;
  --orange:#FF6803; --ink:#08110D;
  --r:16px; --maxw:1120px;
  --shadow-card:0 16px 50px rgba(0,0,0,.5); --inset-hi:inset 0 1px 0 rgba(255,255,255,.05);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;color:var(--text);padding-bottom:60px;
  background:radial-gradient(120% 60% at 50% -10%, #0d1a17 0%, var(--bg) 45%, var(--deep) 100%) fixed;
  font:400 16px/1.5 'Manrope',system-ui,-apple-system,Segoe UI,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
::selection{background:rgba(51,197,122,.3)}
a{color:var(--text);text-decoration:none}
h1,h2,h3,h4{margin:0}
button{font-family:inherit;cursor:pointer}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px;display:flex;flex-direction:column}

/* ---------- sticky glass header ---------- */
.site-head{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  gap:14px;padding:12px 20px;background:rgba(10,14,13,.55);backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px);box-shadow:0 8px 30px rgba(0,0,0,.35)}
.brand{font-weight:800;font-size:17px;letter-spacing:-.01em;line-height:1;white-space:nowrap}
.brand .dot{color:var(--green)}
/* store switcher — pill group; active = orange */
.shop{display:flex;padding:3px;border-radius:999px;background:var(--panel);
  box-shadow:var(--inset-hi),0 6px 20px rgba(0,0,0,.4)}
.srctab{border-radius:999px;font-weight:500;font-size:13px;line-height:1;color:var(--muted);
  padding:9px 16px;white-space:nowrap;transition:color .15s}
.srctab:hover{color:var(--text)}
.srctab.active{font-weight:700;color:var(--ink);background:var(--orange);
  box-shadow:0 4px 16px rgba(255,104,3,.4)}

/* ---------- hero (photo + copy, 2 col on desktop) ---------- */
.hero{padding:24px 0 8px}
.hero-in{display:flex;flex-wrap:wrap;gap:36px;align-items:center}
.hero-photo{flex:1 1 440px;min-width:280px;position:relative;border-radius:26px;overflow:hidden;
  aspect-ratio:16/12;max-height:420px;box-shadow:0 24px 70px rgba(0,0,0,.6),0 0 60px rgba(51,197,122,.10)}
.hero-photo img{width:100%;height:100%;object-fit:cover;display:block}
.hero-photo::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(6,9,8,0) 40%,rgba(6,9,8,.85) 100%)}
.hero-cap{position:absolute;left:18px;bottom:16px;z-index:1;display:inline-flex;align-items:center;gap:8px;
  font-size:11px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.hero-cap::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 10px var(--glow)}
.hero-copy{flex:1 1 360px;min-width:280px}
.hero-copy h1{font-weight:700;font-size:clamp(32px,8vw,46px);line-height:1.05;letter-spacing:-.02em}
.hero-copy .sub{margin:16px 0 0;font-size:16px;line-height:1.5;color:var(--muted);max-width:480px}
.hero-cta{margin-top:22px;display:inline-flex;align-items:center;gap:10px;padding:15px 24px;border:0;
  border-radius:15px;background:var(--green);color:var(--ink);font-weight:800;font-size:16px;
  box-shadow:0 12px 34px rgba(51,197,122,.32)}
.hero-cta:hover{background:#2fb972}

/* ---------- steps (три шага) ---------- */
/* номер шага вместо иконки */
.step-n{font-weight:800;font-size:22px;color:var(--mint);line-height:1}
.perks{margin-top:28px;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px;
  list-style:none;padding:0}
.perk{display:flex;align-items:center;gap:16px;padding:16px 18px;border-radius:20px;background:var(--panel);
  box-shadow:var(--inset-hi),0 10px 30px rgba(0,0,0,.4)}
.perk .ic{flex:none;width:46px;height:46px;border-radius:14px;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(80% 80% at 50% 30%,rgba(142,254,238,.14),rgba(20,27,28,0));
  box-shadow:0 0 22px rgba(142,254,238,.14)}
.perk .ic svg{width:22px;height:22px;stroke:var(--mint);stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round}
.perk .tt{font-weight:700;font-size:16px;line-height:1.2}
.perk .st{font-size:13px;color:var(--faint);margin-top:2px;line-height:1.35}

/* ---------- feed heading + format segment + filter toggle ---------- */
.feedbar{margin:44px 0 0;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.feed-head{flex-basis:100%}
.feed-head h2{font-weight:700;font-size:clamp(24px,4vw,30px);letter-spacing:-.01em}
.feed-head h2 .q{color:var(--muted)}
.feed-head .cnt{margin-left:10px;font-size:13px;color:var(--faint);font-weight:500}
.fmtsw{display:inline-flex;padding:4px;border-radius:999px;background:var(--panel);gap:2px;margin-top:16px;
  box-shadow:var(--inset-hi),0 8px 24px rgba(0,0,0,.4)}
.fmtbtn{border:0;border-radius:999px;padding:9px 16px;font-weight:500;font-size:13px;white-space:nowrap;
  background:transparent;color:var(--muted)}
.fmtbtn:hover{color:var(--text)}
.fmtbtn.active{font-weight:700;color:var(--ink);background:var(--orange);box-shadow:0 4px 16px rgba(255,104,3,.4)}
.filter-toggle{display:none;align-items:center;gap:7px;flex:none;margin-top:16px;border:0;
  background:var(--panel);color:var(--muted);border-radius:999px;padding:9px 15px;font-weight:600;font-size:13px;
  line-height:1;box-shadow:var(--inset-hi)}
.filter-toggle:hover{color:var(--text)}
.filter-toggle[aria-expanded="true"]{color:var(--mint)}
.ft-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;
  border-radius:9px;background:var(--orange);color:var(--ink);font-weight:700;font-size:11px}
.ft-count[hidden]{display:none}

/* ---------- filter panel ---------- */
.panel{margin:22px 0 0;padding:22px;border-radius:22px;background:var(--panel);
  box-shadow:var(--inset-hi),0 12px 40px rgba(0,0,0,.4)}
.panel h2{font-weight:700;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin:0}
/* шапка панели: «Фильтры» + «Сбросить всё» (только при активных фильтрах) */
.panel-top{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 0 16px}
/* грабер и ✕ — только в мобильном шите */
.sheet-grab{display:none;justify-content:center;padding:0 0 12px}
.sheet-grab i{width:40px;height:4px;border-radius:999px;background:#2a3634;display:block}
.ft-close{display:none;border:0;background:transparent;color:var(--faint);font-size:17px;
  padding:4px 6px;cursor:pointer;line-height:1}
.ft-close:hover{color:var(--text)}
/* подложка шита фильтров */
.ft-backdrop{position:fixed;inset:0;z-index:110;background:rgba(0,0,0,.62);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.ft-backdrop[hidden]{display:none}
.clear-pill{display:inline-flex;align-items:center;gap:6px;border:0;border-radius:999px;background:#1c2626;
  color:var(--mint);font-weight:600;font-size:12px;padding:8px 14px;box-shadow:var(--inset-hi)}
.clear-pill:hover{color:var(--text)}
.clear-pill[hidden]{display:none}
.grid-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.f-wide{grid-column:1/-1}
label{display:flex;flex-direction:column;gap:8px;font-weight:600;font-size:11px;letter-spacing:.06em;
  text-transform:uppercase;color:var(--faint)}
input:not([type="checkbox"]),select{font:inherit;font-size:14px;text-transform:none;letter-spacing:normal;
  font-weight:400;border:0;border-radius:12px;background:var(--inset);color:var(--text);padding:13px 15px;
  min-height:46px;box-shadow:inset 0 1px 0 rgba(255,255,255,.04)}
input::placeholder{color:var(--faint)}
input:focus,select:focus{outline:none;box-shadow:inset 0 1px 0 rgba(255,255,255,.04),0 0 0 2px rgba(51,197,122,.35)}
select{cursor:pointer;appearance:none;-webkit-appearance:none;padding-right:38px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1.5 6 6.5 11 1.5' stroke='%236E827A' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center}
.f-check{grid-column:1/-1;flex-direction:row;align-items:center;gap:10px;font-size:14px;font-weight:400;
  letter-spacing:normal;text-transform:none;color:var(--text);align-self:end;min-height:44px}
/* чекбокс как в дизайне: мягкий квадрат, отмеченный — оранжевый с ✓ и свечением */
input[type="checkbox"]{appearance:none;-webkit-appearance:none;width:22px;height:22px;flex:0 0 auto;margin:0;
  border-radius:7px;background:var(--inset);box-shadow:var(--inset-hi);cursor:pointer;
  background-repeat:no-repeat;background-position:center;transition:background-color .15s,box-shadow .15s}
input[type="checkbox"]:checked{background-color:var(--orange);box-shadow:0 0 14px rgba(255,104,3,.5);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='10'%3E%3Cpath d='M1 5l3.5 3.5L11 1.5' stroke='%2308110D' stroke-width='2.2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E")}

/* кастомный селект панели (как в дизайне): плашка-кнопка + выпадашка с ✓ */
.csel-native{display:none}
.csel{position:relative}
.csel-btn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;border:0;
  border-radius:12px;background:var(--inset);color:var(--text);font-size:14px;font-weight:400;
  text-transform:none;letter-spacing:normal;text-align:left;padding:13px 15px;min-height:46px;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04)}
.csel-ch{color:var(--faint);font-size:11px;transition:transform .2s}
.csel.open .csel-ch{transform:rotate(180deg)}
.csel-list{position:absolute;z-index:30;top:calc(100% + 6px);left:0;right:0;background:var(--inset);
  border-radius:14px;box-shadow:0 20px 50px rgba(0,0,0,.65),inset 0 1px 0 rgba(255,255,255,.06);
  padding:6px;display:flex;flex-direction:column;gap:2px;max-height:264px;overflow:auto}
.csel-list[hidden]{display:none}
.csel-opt{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:11px 13px;
  border-radius:10px;cursor:pointer;font-size:14px;font-weight:400;text-transform:none;
  letter-spacing:normal;color:var(--muted)}
.csel-opt:hover{background:var(--panel);color:var(--text)}
.csel-opt.sel{background:#17221f;color:var(--text)}
.csel-opt.sel::after{content:"✓";color:var(--orange);font-weight:800;font-size:13px}
.more{margin-top:4px}
.more>summary{cursor:pointer;list-style:none;display:inline-flex;align-items:center;gap:9px;min-height:44px;
  font-weight:700;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--mint);user-select:none}
.more>summary::-webkit-details-marker{display:none}
.more>summary::after{content:"+";display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;
  border-radius:7px;background:#1c2626;color:var(--mint);font-size:14px}
.more[open]>summary::after{content:"–"}
.more .grid-form{margin-top:16px}
.actions{margin-top:18px;display:flex;flex-wrap:wrap;align-items:center;gap:12px}
.primary{border:0;border-radius:14px;background:var(--green);color:var(--ink);font-weight:800;font-size:15px;
  padding:14px 26px;min-height:46px;box-shadow:0 12px 30px rgba(51,197,122,.28)}
.primary:hover{background:#2fb972}
.ghost{border:0;border-radius:14px;background:#1c2626;color:var(--muted);font-weight:700;font-size:14px;
  padding:14px 22px;min-height:46px;box-shadow:var(--inset-hi)}
.ghost:hover{color:var(--text)}

/* ---------- results ---------- */
/* верхний отступ отделяет ленту от панели фильтров (padding, а не margin — не схлопывается) */
.results{padding:20px 0 20px}
.count{margin:24px 0 16px;color:var(--faint);font-weight:600;font-size:12px;letter-spacing:.08em;text-transform:uppercase}
.count strong{color:var(--text)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:18px}
.empty{margin:24px 0;padding:40px 22px;border-radius:22px;background:var(--panel);box-shadow:var(--inset-hi);
  color:var(--muted);line-height:1.5;text-align:center}
.empty p{margin:0}
.empty-hint{color:var(--faint);font-size:14px;margin-top:8px}
.empty-reset{margin-top:16px}

/* active-filter chips */
.chips{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 18px}
.chip{border:0;font-weight:500;font-size:13px;min-height:38px;display:inline-flex;align-items:center;gap:6px;
  padding:9px 15px;border-radius:999px;background:var(--panel);color:var(--muted);box-shadow:var(--inset-hi)}
.chip:hover{color:var(--text)}
.chip .x{font-size:1rem;line-height:1;color:var(--faint)}
.chip-clear{background:#1c2626;color:var(--mint)}

/* ---------- card: вино по годам ---------- */
.card{border-radius:26px;padding:22px;background:var(--panel);box-shadow:var(--inset-hi),var(--shadow-card);
  display:flex;flex-direction:column;gap:14px}
.vcard,.card.battle{cursor:pointer}   /* карточка кликабельна целиком (как в дизайне) */
.card-open{width:100%;border:0;border-radius:13px;background:#1c2626;color:var(--text);font-weight:700;
  font-size:14px;padding:12px;box-shadow:var(--inset-hi);display:flex;align-items:center;justify-content:center;gap:8px;margin-top:auto}
.card-open .ar{color:var(--green);font-size:16px}
.card-open:hover{color:var(--mint)}
.ftag{align-self:flex-start;display:inline-flex;align-items:center;padding:6px 13px;border-radius:999px;
  background:rgba(51,197,122,.16);font-weight:700;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--green)}
.card-title{font-weight:700;font-size:21px;line-height:1.15;letter-spacing:-.01em;color:var(--text)}
.cardline2{margin:0;display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:13px}
.cardline2 .country{display:inline-flex;align-items:center;gap:6px;font-weight:500;color:var(--muted)}
.cardline2 .flag{font-size:1.05rem;line-height:1}
.cardline2 .grape{font-weight:500;font-size:12px;color:var(--muted);background:var(--inset);border-radius:999px;padding:5px 11px}
.sep{color:var(--faint)}
.specs{margin:0;display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:13px;color:var(--faint)}
.specs .wcolor{display:inline-flex;align-items:center;gap:7px}
.specs .swatch{width:9px;height:9px;border-radius:50%}
/* «зачем эта дегустация» — тихая плашка */
.why{margin:0;padding:13px 15px;border-radius:15px;background:var(--inset);color:var(--muted);font-size:14px;line-height:1.45}
/* number trio */
.stats3{display:grid;grid-template-columns:1fr 1fr 1.15fr;gap:8px}
.stat{padding:13px 8px;border-radius:14px;background:var(--inset);text-align:center}
.stat .n{font-weight:800;font-size:21px;line-height:1;font-variant-numeric:tabular-nums;white-space:nowrap}
.stat .l{font-size:9px;color:var(--faint);text-transform:uppercase;letter-spacing:.08em;margin-top:5px;line-height:1.2}
.stat.set{background:linear-gradient(160deg,rgba(0,106,79,.4),rgba(10,14,13,.4));box-shadow:0 0 24px rgba(51,197,122,.12)}
.stat.set .n{color:var(--green)}
.stat.set .l{color:var(--mint)}
/* bottles — список винтажей с чекбоксом «куплено» */
.bottles{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}
.bottle{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:13px;background:var(--inset);
  transition:opacity .2s,background .2s}
.bought-cb{flex:0 0 auto;width:22px;height:22px;border-radius:7px}
.bottle-link{flex:1;min-width:0;display:flex;align-items:center;gap:12px;color:var(--text)}
.bottle-link .yr{font-weight:800;width:46px;font-variant-numeric:tabular-nums}
.bottle-link .pr{flex:1;color:var(--muted);font-variant-numeric:tabular-nums;font-weight:700}
.bottle-link .go{color:var(--faint);font-weight:700;transition:color .12s,transform .12s}
.bottle-link:hover .pr{color:var(--text)}
.bottle-link:hover .go{color:var(--green);transform:translateX(3px)}
.bottle.done{opacity:.55}
.bottle.done .yr,.bottle.done .pr{text-decoration:line-through}
.bottle input[type="checkbox"]:not(:checked){background-color:#1c2626}
/* подача — строкой внутри why-плашки (в оверлее) */
.serving{margin:0;color:var(--faint);font-size:12px;line-height:1.4}
.why .serving{margin-top:8px}
/* buy-all + share */
.buy-all{display:flex;flex-wrap:wrap;align-items:center;gap:10px}
/* «Открыть все N» / «Открыть обе» — зелёное действие (как в дизайне) */
.buyall{flex:1;min-width:180px;border:0;border-radius:13px;background:var(--green);color:var(--ink);
  font-weight:800;font-size:14px;padding:13px;box-shadow:0 10px 26px rgba(51,197,122,.24);
  display:inline-flex;align-items:center;justify-content:center;gap:8px}
.buyall:hover{background:#2fb972}
.buyall.done{background:#1c2626;color:var(--faint);box-shadow:var(--inset-hi)}
.buyall.done:hover{background:#1c2626}
/* CTA карточки-боя — та же тихая кнопка, что .card-open, но ссылкой рядом с шерингом */
.buy-all .card-open{flex:1;width:auto;min-width:180px}
.buy-where{color:var(--faint);font-size:11px;letter-spacing:.06em;text-transform:uppercase}
.share-btn{border:0;background:#1c2626;color:var(--mint);border-radius:12px;padding:11px 14px;font-weight:600;
  font-size:12px;line-height:1;white-space:nowrap;box-shadow:var(--inset-hi)}
.share-btn:hover{color:var(--text)}
.buy-all .share-btn{margin-left:auto}

/* ---------- card: поединок (бой) ---------- */
.card.battle{background:linear-gradient(165deg,#16211f 0%,#101615 100%)}
.card.battle .ftag{background:rgba(255,104,3,.16);color:var(--orange)}
.card.battle .card-title,.battle-title{font-weight:800;font-size:22px;line-height:1.2;letter-spacing:-.01em}
.card.battle .why{background:rgba(10,14,13,.6)}
.stats2{display:flex;gap:10px}
.stats2 .stat{flex:1}
.stats2 .stat.set{flex:1.3}
.vs-honesty{display:flex;gap:8px;flex-wrap:wrap}
.hdot{display:inline-flex;align-items:center;gap:7px;padding:7px 12px;border-radius:999px;background:rgba(10,14,13,.6);
  font-size:12px;font-weight:500;color:var(--muted)}
.hdot::before{content:"";width:7px;height:7px;border-radius:50%}
.hdot.green::before{background:var(--green);box-shadow:0 0 6px var(--glow)}
.hdot.mint::before{background:var(--mint)}
.hdot.orange::before{background:var(--orange);box-shadow:0 0 6px rgba(255,104,3,.6)}

/* «Показать ещё» — последний элемент грида, на всю ширину */
.feedmore{border:0;border-radius:16px;background:var(--panel);color:var(--text);font-weight:700;
  font-size:14px;padding:16px;box-shadow:var(--inset-hi),0 10px 30px rgba(0,0,0,.35);
  display:flex;align-items:center;justify-content:center;gap:6px}
.feedmore:hover{color:var(--mint)}
.feedmore-n{color:var(--faint);font-weight:500}
.feedmore.htmx-request{display:flex;opacity:.6;pointer-events:none}

/* ---------- skeleton ---------- */
.skel{pointer-events:none}
.skel .skel-b{display:block;border-radius:10px;background:linear-gradient(90deg,#141b1c 25%,#1c2626 37%,#141b1c 63%);
  background-size:400% 100%;animation:skel 1.4s ease infinite}
.skel .skel-tag{width:90px;height:22px;border-radius:999px}
.skel .skel-title{width:70%;height:22px;margin-top:6px}
.skel .skel-line{width:90%;height:52px;margin-top:6px}
.skel .skel-rows{height:96px;margin-top:6px}
@keyframes skel{0%{background-position:100% 0}100%{background-position:-100% 0}}

/* ---------- оверлей деталей набора (bottom-sheet / модалка, как в дизайне) ---------- */
.dt-backdrop{position:fixed;inset:0;z-index:100;display:flex;justify-content:center;align-items:flex-end;
  background:rgba(0,0,0,.62);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.dt-backdrop[hidden]{display:none}
/* без входных keyframes: в замороженной вкладке анимация зависает на from-кадре
   и шит остаётся за экраном; мгновенное появление надёжнее */
.dt-sheet{position:relative;width:100%;background:#0f1615;box-shadow:0 -20px 60px rgba(0,0,0,.6);
  overflow-y:auto;-webkit-overflow-scrolling:touch;max-height:90vh;border-radius:24px 24px 0 0}
.dt-grab{display:flex;justify-content:center;padding-top:10px}
.dt-grab i{width:40px;height:4px;border-radius:999px;background:#2a3634;display:block}
.dt-head{position:sticky;top:0;z-index:2;display:flex;align-items:center;gap:12px;padding:14px 20px;
  background:rgba(15,22,21,.92);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}
.dt-back,.dt-close{border:0;background:transparent;color:var(--faint);font-size:18px;padding:4px;cursor:pointer;flex:none}
.dt-back:hover,.dt-close:hover{color:var(--text)}
.dt-title{flex:1;min-width:0;font-weight:700;font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dt-body{padding:8px 20px 30px;display:flex;flex-direction:column;gap:14px}
.dt-label{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin:8px 0 -6px}
body.dt-lock{overflow:hidden}
@media(min-width:640px){
  .dt-backdrop{align-items:center;padding:24px}
  .dt-sheet{max-width:720px;max-height:86vh;border-radius:26px}
  .dt-grab{display:none}
}

/* ---------- toast ---------- */
.toast{position:fixed;left:50%;bottom:28px;transform:translate(-50%,20px);background:var(--text);color:var(--ink);
  font-weight:700;font-size:13px;padding:11px 18px;border-radius:14px;opacity:0;pointer-events:none;
  transition:opacity .2s,transform .2s;z-index:200;box-shadow:0 6px 24px rgba(0,0,0,.5)}
.toast.show{opacity:1;transform:translate(-50%,0)}

/* ---------- footer: блок «О проекте» в карточке ---------- */
.foot{max-width:var(--maxw);margin:56px auto 0;padding:0 20px 8px}
.about{background:var(--panel);border-radius:26px;padding:34px 36px;
  box-shadow:var(--inset-hi),0 16px 50px rgba(0,0,0,.5)}
.about-h{margin:0 0 16px;font-weight:700;font-size:clamp(22px,4vw,28px);letter-spacing:-.01em;color:var(--text)}
.about-h .q{color:var(--muted)}
.about-body{text-align:justify}
.about-body p{margin:0 0 14px;color:var(--muted);font-size:15px;line-height:1.65}
.about-body p:last-child{margin-bottom:0}
.about-body strong{color:var(--text);font-weight:700}
.about .dot{color:var(--green)}
/* мелкий дисклеймер — отделён воздухом, приглушённый (без линий-дивайдеров) */
.about-legal{margin:24px 0 0;color:var(--faint);font-size:12px;line-height:1.6;text-align:justify}

/* ---------- возрастной гейт 18+ ---------- */
/* по умолчанию оверлей виден и блокирует скролл; html.age-ok (ставится инлайн в head
   для подтвердивших) его убирает — без мигания контента */
html:not(.age-ok){overflow:hidden}
html.age-ok #agegate{display:none}
#agegate{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;
  background:radial-gradient(120% 80% at 50% 0%, #0d1a17 0%, var(--deep) 70%)}
.agegate-card{max-width:420px;width:100%;text-align:center;background:var(--panel);border-radius:26px;
  padding:36px 28px;box-shadow:var(--inset-hi),0 30px 80px rgba(0,0,0,.6)}
.agegate-brand{font-weight:800;font-size:18px;letter-spacing:-.01em;margin-bottom:22px}
.agegate-brand .dot{color:var(--green)}
.agegate-q{font-weight:800;font-size:26px;letter-spacing:-.01em}
.agegate-sub{margin:12px 0 0;color:var(--muted);font-size:14px;line-height:1.5}
.agegate-actions{display:flex;gap:12px;justify-content:center;margin-top:26px}
.agegate-yes{border:0;border-radius:14px;background:var(--green);color:var(--ink);font-weight:800;font-size:15px;
  padding:14px 30px;box-shadow:0 12px 30px rgba(51,197,122,.28)}
.agegate-yes:hover{background:#2fb972}
.agegate-no{border:0;border-radius:14px;background:#1c2626;color:var(--muted);font-weight:700;font-size:15px;
  padding:14px 30px;box-shadow:var(--inset-hi)}
.agegate-no:hover{color:var(--text)}
.agegate-blocked h2{font-weight:800;font-size:24px}
.agegate-blocked p{margin:12px 0 0;color:var(--muted);line-height:1.5}

/* ---------- versus page ---------- */
.subhead{padding:20px 0 0}
.subhead .eyebrow{font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--faint)}
.subhead h1{margin:10px 0 0;font-weight:700;font-size:clamp(28px,7vw,42px);letter-spacing:-.02em}
.subhead .sub{margin:12px 0 0;font-size:16px;color:var(--muted);max-width:520px;line-height:1.5}
.tabs{display:inline-flex;padding:4px;border-radius:999px;background:var(--panel);gap:2px;margin-top:18px;
  box-shadow:var(--inset-hi),0 8px 24px rgba(0,0,0,.4)}
.tab{border-radius:999px;padding:9px 16px;font-weight:500;font-size:13px;color:var(--muted)}
.tab.active{font-weight:700;color:var(--ink);background:var(--orange);box-shadow:0 4px 16px rgba(255,104,3,.4)}
.vs-presets{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:0 0 4px}
.vs-presets-l{flex-basis:100%;color:var(--faint);font-weight:600;font-size:11px;letter-spacing:.1em;
  text-transform:uppercase;margin-bottom:2px}
.vs-preset{border:0;background:var(--inset);color:var(--muted);border-radius:999px;padding:9px 14px;font-weight:500;
  font-size:13px;box-shadow:inset 0 1px 0 rgba(255,255,255,.04)}
.vs-preset:hover{color:var(--text)}
.vs-rand{background:#1c2626;color:var(--mint)}
.vs-check{flex-direction:row;align-items:center;gap:10px;font-size:14px;font-weight:400;letter-spacing:normal;
  text-transform:none;color:var(--text);align-self:end;min-height:46px}
.load{color:var(--green);font-size:13px;font-weight:600}
.htmx-indicator{display:none}
.htmx-request .htmx-indicator,.htmx-request.htmx-indicator{display:inline}
.error{color:#e2887f}
/* versus results */
.vs-title{font-weight:800;font-size:clamp(24px,5vw,30px);letter-spacing:-.02em;margin:24px 0 6px}
.vs-stats{display:flex;flex-wrap:wrap;gap:10px;margin:14px 0 0}
.vs-stat{padding:12px 18px;border-radius:16px;background:var(--panel);box-shadow:var(--inset-hi);
  display:flex;align-items:baseline;gap:7px}
.vs-stat-n{font-weight:800;font-size:22px;font-variant-numeric:tabular-nums}
.vs-stat:nth-child(2) .vs-stat-n{color:var(--green)}
.vs-stat:nth-child(3) .vs-stat-n{color:var(--mint)}
.vs-stat-l{font-size:11px;color:var(--faint);text-transform:uppercase;letter-spacing:.08em}
.vs-warn{margin:8px 0 0;color:var(--orange);font-size:13px}
.eyebrow.vs-eyebrow{margin:28px 0 0;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--faint)}
.vs-hint{margin:10px 0 0;color:var(--muted);font-size:13px;line-height:1.5;max-width:640px}
.vs-pairs{display:flex;flex-direction:column;gap:16px;margin-top:20px}
.vs-pair{border-radius:22px;padding:18px;background:var(--panel);box-shadow:var(--inset-hi),0 12px 40px rgba(0,0,0,.4)}
.vs-empty{color:var(--faint);text-align:center;background:var(--panel);border-radius:22px;padding:22px;box-shadow:var(--inset-hi)}
.vs-tag{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:16px}
.vs-tag-in{display:inline-flex;align-items:center;gap:10px;padding:8px 16px;border-radius:999px;background:var(--inset)}
.vs-bars{display:flex;align-items:flex-end;gap:3px;height:14px}
.vs-bars i{width:4px;border-radius:2px;display:block;background:#1c2626}
.vs-bars i:nth-child(1){height:6px}.vs-bars i:nth-child(2){height:10px}.vs-bars i:nth-child(3){height:14px}
.vs-green .vs-bars i{background:var(--green);box-shadow:0 0 8px var(--glow)}
.vs-yellow .vs-bars i:nth-child(-n+2){background:var(--mint)}
.vs-orange .vs-bars i:nth-child(1){background:var(--orange);box-shadow:0 0 8px rgba(255,104,3,.6)}
.vs-badge{font-weight:700;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--green)}
.vs-yellow .vs-badge{color:var(--mint)}.vs-orange .vs-badge{color:var(--orange)}
.vs-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.vs-num{font-weight:700;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint)}
.vs-redo{border:0;border-radius:11px;background:#1c2626;color:var(--muted);font-weight:700;font-size:13px;padding:8px 12px;box-shadow:var(--inset-hi)}
.vs-redo:hover{color:var(--text)}
.vs-row{display:flex;align-items:stretch;gap:10px}
.vs-bottle{flex:1;min-width:0;padding:16px;border-radius:18px;background:var(--inset);display:flex;flex-direction:column;gap:10px}
.vs-side-l{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--faint)}
.vs-side-l .flag{font-size:1.05rem}
.vs-side-l .swatch{width:12px;height:12px;border-radius:50%}
.vs-name{font-weight:700;font-size:15px;line-height:1.2;color:var(--text)}
.vs-pricerow{margin-top:auto}
.vs-price{font-weight:800;font-size:22px;color:var(--text);font-variant-numeric:tabular-nums}
/* тихая ссылка стороны «Открыть →» (акцент один на пару — зелёное «Открыть обе») */
.vs-open{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:4px;
  padding:10px 12px;border-radius:11px;background:#1c2626;color:var(--text);font-weight:700;
  font-size:13px;box-shadow:var(--inset-hi)}
.vs-open .go{color:var(--faint);font-weight:700;transition:color .12s,transform .12s}
.vs-open:hover .go{color:var(--green);transform:translateX(3px)}
/* строка действия пары: зелёное «Открыть обе» + домен */
.vs-buy{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-top:12px}
.vs-mid{flex:none;display:flex;align-items:center}
.vs-mid span{width:36px;height:36px;border-radius:50%;background:var(--panel);display:flex;align-items:center;
  justify-content:center;font-weight:800;font-size:12px;color:var(--faint);box-shadow:0 6px 20px rgba(0,0,0,.5)}
.buy{border:0;border-radius:11px;background:#1c2626;color:var(--text);font-weight:700;font-size:13px;padding:10px;
  text-align:center;display:inline-flex;align-items:center;justify-content:center;gap:6px}
.buy:hover{color:var(--mint)}
.vs-bottle .buy{width:100%;margin-top:4px}
.vs-why{margin:14px 0 0;padding:14px 16px;border-radius:15px;background:var(--inset);font-size:14px;line-height:1.45;color:var(--muted)}
.vs-why p{margin:0}
.buyall.vs-both{margin-top:12px;width:100%}
.ask-answer,.ai-form{display:none}

/* ---------- versus filter FORM — своя структура (НЕ .grid-form вертикали) ----------
   вертикаль = плоская сетка фильтров каталога; поединок = смысловые блоки-плашки:
   1 тема спора · 2 тип вина · 3 кто против кого. Так две дегустации не путаются. */
.vsform{display:flex;flex-direction:column;gap:16px}
.vs-store-field{max-width:340px}
.vs-blocks{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.vs-block{background:var(--inset);border-radius:18px;padding:16px 16px 18px;box-shadow:var(--inset-hi)}
.vs-block-wide{grid-column:1/-1}
.vs-block-h{display:flex;align-items:center;gap:9px;margin:0 0 13px;font-weight:700;font-size:11px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.vs-block-n{flex:none;display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;
  border-radius:7px;background:#1c2626;color:var(--mint);font-size:11px;font-weight:800}
.vs-field{gap:7px}
.vs-cap{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--faint)}
.vs-duo{display:grid;grid-template-columns:1fr 1fr;gap:12px}
/* «кто против кого»: A ⚔ B крупно по центру + узкое поле «пар» */
.vs-sides{display:grid;grid-template-columns:1fr auto 1fr auto;align-items:end;gap:14px}
.vs-side{gap:7px;min-width:0}
.vs-vs{align-self:end;margin-bottom:4px;flex:none;width:44px;height:44px;border-radius:50%;background:var(--panel);
  color:var(--orange);font-weight:800;font-size:12px;letter-spacing:.04em;display:flex;align-items:center;
  justify-content:center;box-shadow:0 8px 24px rgba(0,0,0,.5)}
.vs-npairs{width:110px}
.vs-npairs input{text-align:center}
/* тонкие уточнения — приглушённый подвал под тремя главными блоками */
.vs-fine{display:flex;flex-wrap:wrap;gap:8px 24px;padding:14px 16px;border-radius:15px;background:rgba(10,14,13,.5)}
.vs-fine .vs-check{min-height:0;color:var(--muted)}

/* панели фильтров/конструктора — ВСЕГДА во всю ширину контейнера (как грид карточек),
   на всех страницах; без зажатия в 760px и без завязки на брейкпоинт */

/* ---------- mobile ---------- */
@media(max-width:640px){
  .site-head{padding:11px 16px}
  .wrap{padding-left:16px;padding-right:16px}
  .hero-in{gap:20px}
  .stats3{grid-template-columns:1fr 1fr 1.2fr}
  .vs-row{flex-direction:column}
  .vs-mid{justify-content:center}
  /* поединок-форма: блоки и стороны в столбик, VS-кружок по центру между A и B */
  .vs-blocks{grid-template-columns:1fr}
  .vs-sides{grid-template-columns:1fr;gap:10px}
  .vs-vs{margin:2px auto;align-self:center}
  .vs-npairs{width:100%}
  .grid{grid-template-columns:1fr}
  /* результаты первым экраном; фильтры свёрнуты за кнопкой «Фильтры» */
  .feedbar{position:sticky;top:56px;z-index:6;padding-top:12px;margin-top:20px;
    background:linear-gradient(180deg,var(--bg) 70%,transparent)}
  .filter-toggle{display:inline-flex}
  .feed-head h2{font-size:22px}
  /* фильтры ленты — БОТТОМ-ШИТ (не в потоке): подложка + шит снизу; форма поединка
     (та же .panel, но без #filters) остаётся видимой — у неё нет своего переключателя */
  #filters{display:none}
  #filters.open{display:block;position:fixed;left:0;right:0;bottom:0;z-index:120;margin:0;
    max-height:88vh;overflow-y:auto;-webkit-overflow-scrolling:touch;
    border-radius:24px 24px 0 0;background:#0f1615;box-shadow:0 -20px 60px rgba(0,0,0,.6);
    padding:10px 20px 30px}
  #filters.open .sheet-grab{display:flex}
  #filters.open .ft-close{display:inline-flex}
  #feed{order:2}
  .wrap{position:relative}
}
