/* „Колко струва?" — visual spec from the approved design board (docs/plan.md → Visual spec).
   Tokens: Sofia Sans + the Realistimo brand triad; teal reserved for frozen days. */
:root {
  --green: #1d7d5a;
  --orange: #c08a3a;   /* refined: warm ochre (was #f6a64c) — editorial, not alert */
  --red: #b0544b;      /* refined: muted terracotta (was #f55147) */
  --teal: #59bab8;
  --ink: #1b1a18;      /* refined: warm near-black (was #222) */
  --ink-soft: #555;
  --surface: #f3f1ec;  /* refined: warm surface (was #f4f5f7) */
  --line: #e7e2da;     /* refined: warm line (was #e3e5e8) */
  --white: #fff;
  --cream: #faf8f4;    /* warm off-white page/card background — premium editorial */
}
* { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; }
body {
  font-family: 'Sofia Sans', sans-serif;
  color: var(--ink);
  background: var(--cream);
  min-height: 100dvh;
}
/* Mobile-first: the phone layout IS the design; desktop is a centered column. */
main { max-width: 480px; margin: 0 auto; padding-bottom: 48px; }
a { color: var(--ink); }

/* ── Header ─────────────────────────────────────────── */
.hd {
  max-width: 480px; margin: 0 auto;
  display: flex; align-items: baseline; justify-content: space-between;
  padding: 14px 16px 10px;
}
.wordmark { font-weight: 800; font-size: 24px; letter-spacing: -0.01em; text-decoration: none; line-height: 1; }
.wordmark .num { color: var(--ink-soft); font-weight: 600; font-size: 15px; margin-left: 6px; }
.wordmark .by { display: block; font-size: 10px; font-weight: 600; letter-spacing: .02em; opacity: .82; margin-top: 1px; }
.hd-right { display: flex; gap: 14px; align-items: center; }
.hd-lb { background: none; border: 0; padding: 0; color: inherit; cursor: pointer; display: flex; align-items: center; }
.hd-lb .ic { width: 22px; height: 22px; }
.lb-by { font-size: 12px; font-weight: 600; color: var(--ink-soft); }
.hd-link { font-size: 14px; font-weight: 700; color: var(--ink-soft); text-decoration: none; }
.streak { font-weight: 700; font-size: 17px; color: var(--orange); }

/* ── Photo hero ─────────────────────────────────────── */
.photo-wrap { position: relative; }
.photo {
  width: 100%; aspect-ratio: 39 / 24; background: var(--surface);
  background-size: cover; background-position: center;
}
.photo.skeleton { animation: pulse 1.2s ease-in-out infinite; }
@keyframes pulse { 50% { opacity: 0.6; } }
.photo-chip {
  position: absolute; right: 10px; bottom: 8px;
  font-size: 11px; color: #fff; background: rgba(0, 0, 0, 0.45);
  padding: 3px 8px; border-radius: 99px;
}
.meta { padding: 10px 16px; font-size: 15.5px; border-bottom: 1px solid #eef0f2; }
.meta b { font-weight: 700; }

/* ── Guess ladder ───────────────────────────────────── */
.ladder { padding: 8px 16px 0; min-height: 8px; }
.g-row {
  display: flex; align-items: center; justify-content: space-between;
  border-radius: 10px; padding: 9px 12px; margin-bottom: 7px;
  font-size: 17.5px; font-weight: 600;
}
.g-row .val { font-family: 'Sofia Sans Condensed', sans-serif; font-weight: 800; font-size: 23px; color: var(--ink); }
.g-row .dir { font-weight: 800; font-size: 17.5px; }
.g-row.far { background: rgba(176, 84, 75, 0.12); color: #8a3a33; }
.g-row.close { background: rgba(192, 138, 58, 0.16); color: #79541d; }
.g-row.win { background: rgba(29, 125, 90, 0.12); color: var(--green); }
/* Motion 1/3: ladder row slides in on each guess */
.g-row.is-new { animation: row-in 0.32s cubic-bezier(0.2, 0.8, 0.3, 1); }
@keyframes row-in { from { opacity: 0; transform: translateY(8px); } }
/* unlocked photo flashes attention to the photo area */
.photo.is-new { animation: photo-in 0.45s ease; }
@keyframes photo-in { from { opacity: 0.3; } }

/* ── Input row ──────────────────────────────────────── */
.guess-form { display: flex; gap: 8px; padding: 10px 16px 6px; }
.inp {
  flex: 1; display: flex; align-items: center;
  border: 2px solid var(--ink); border-radius: 12px; padding: 0 14px; height: 52px;
}
.inp input { border: 0; outline: 0; width: 100%; font: 600 20px 'Sofia Sans', sans-serif; }
.inp input::placeholder { color: #9aa0a6; }
.inp .eur { margin-left: auto; font-weight: 800; font-size: 20px; color: var(--ink-soft); }
.inp.error { border-color: var(--red); animation: shake 0.3s; }
@keyframes shake { 25% { transform: translateX(-4px); } 75% { transform: translateX(4px); } }
.btn {
  height: 52px; border: 0; border-radius: 12px; background: var(--ink); color: #fff;
  font: 800 19px 'Sofia Sans', sans-serif; padding: 0 22px; cursor: pointer;
}
.btn:disabled { opacity: 0.5; cursor: default; }
.btn-block { display: block; width: calc(100% - 32px); margin: 10px 16px; text-align: center; text-decoration: none; line-height: 52px; }
.form-error { padding: 0 16px; color: #9c2f27; font-size: 14px; min-height: 18px; }

/* ── Progress dots ──────────────────────────────────── */
.dots { display: flex; gap: 7px; justify-content: center; padding: 10px 0 18px; }
.dot { width: 9px; height: 9px; border-radius: 99px; background: #d9dce0; }
.dot.far { background: var(--red); }
.dot.close { background: var(--orange); }
.dot.win { background: var(--green); }

/* ── Reveal ─────────────────────────────────────────── */
.verdict { padding: 18px 16px 6px; text-align: center; }
.verdict .h { font-size: 26px; font-weight: 800; }
.verdict.win .h { color: var(--green); }
.verdict .p { color: var(--ink-soft); font-size: 15px; margin-top: 2px; }
.price-block { text-align: center; padding: 6px 16px 2px; }
.price-v { font-family: 'Sofia Sans Condensed', sans-serif; font-weight: 800; font-size: 44px; letter-spacing: -0.01em; }
.price-l { font-size: 13px; color: var(--ink-soft); text-transform: uppercase; letter-spacing: 0.08em; }
.median-card { margin: 12px 16px; background: var(--surface); border-radius: 12px; padding: 12px 14px; }
.median-t { font-size: 13px; color: var(--ink-soft); margin-bottom: 8px; }
.median-bar { position: relative; height: 10px; border-radius: 99px; background: linear-gradient(90deg, #cfe7dd, #f8d8a8, #f5b9b4); }
.median-me { position: absolute; top: -5px; width: 4px; height: 20px; border-radius: 2px; background: var(--ink); }
.median-lbl { display: flex; justify-content: space-between; font-size: 11px; color: var(--ink-soft); margin-top: 6px; }
.median-note { font-size: 14px; margin-top: 8px; }
.median-note b { color: #9c2f27; }
.pct { text-align: center; font-size: 15px; padding: 6px 16px 8px; }
.pct b { color: var(--green); }

/* share block — motion 3/3: scale-pop on appear */
.share-card {
  margin: 8px 16px; background: var(--ink); border-radius: 14px; color: #fff;
  padding: 14px; text-align: center;
  animation: pop-in 0.35s cubic-bezier(0.2, 0.9, 0.3, 1.3);
}
@keyframes pop-in { from { opacity: 0; transform: scale(0.92); } }
.share-cap { font-size: 13px; color: #cfd3d8; }
/* Motion 2/3: the win tile-flip — tiles flip over one by one */
.share-grid { font-size: 22px; letter-spacing: 3px; margin: 6px 0 2px; display: inline-flex; gap: 6px; }
.share-grid .tile { display: inline-block; }
.share-grid .tile.flip { animation: flip 0.5s ease backwards; }
@keyframes flip { from { transform: rotateX(90deg); opacity: 0; } }
.sharebtn {
  display: block; margin: 10px 16px; background: var(--green); color: #fff;
  border: 0; border-radius: 12px; height: 52px; width: calc(100% - 32px);
  font: 800 17px 'Sofia Sans', sans-serif; cursor: pointer;
}
.sharebtn.ink { background: var(--ink); }
.reveal-links { display: flex; gap: 10px; padding: 4px 16px 8px; }
.reveal-links a, .reveal-links button {
  flex: 1; text-align: center; border: 1.5px solid #d9dce0; border-radius: 12px;
  padding: 12px 6px; font: 700 14px 'Sofia Sans', sans-serif; color: var(--ink);
  text-decoration: none; background: none; cursor: pointer;
}
.reveal-links .locked { color: var(--ink-soft); }
.claim-banner {
  margin: 8px 16px; padding: 12px 14px; border-radius: 12px;
  background: rgba(246, 166, 76, 0.16); font-size: 14.5px;
}
.claim-banner b { display: block; margin-bottom: 2px; }
.claim-banner button { margin-top: 8px; }
.btn-sm {
  border: 0; border-radius: 10px; background: var(--ink); color: #fff;
  font: 700 14px 'Sofia Sans', sans-serif; padding: 9px 16px; cursor: pointer;
}

/* ── How-to + empty states ──────────────────────────── */
.howto { padding: 12px 16px; color: var(--ink-soft); font-size: 14px; }
.empty-state { max-width: 480px; margin: 0 auto; text-align: center; padding: 64px 24px; }
.empty-emoji { font-size: 56px; }
.empty-state h1 { font-size: 27px; margin: 12px 0 8px; }
.empty-state p { color: var(--ink-soft); }

/* ── Modal (registration triggers) ──────────────────── */
.modal { position: fixed; inset: 0; background: rgba(0, 0, 0, 0.5); display: flex; align-items: flex-end; justify-content: center; z-index: 10; }
.modal[hidden] { display: none; }
.modal-card {
  background: #fff; border-radius: 20px 20px 0 0; padding: 24px 20px 28px;
  width: 100%; max-width: 480px; position: relative;
  animation: sheet-up 0.3s cubic-bezier(0.2, 0.8, 0.3, 1);
}
@keyframes sheet-up { from { transform: translateY(40px); opacity: 0.5; } }
@media (min-width: 540px) { .modal { align-items: center; } .modal-card { border-radius: 20px; } }
.modal-x { position: absolute; top: 10px; right: 14px; border: 0; background: none; font-size: 26px; color: var(--ink-soft); cursor: pointer; }
.modal-card h2 { font-size: 20px; margin-bottom: 6px; }
.modal-card p { font-size: 14.5px; color: var(--ink-soft); margin-bottom: 12px; }
.modal-card .badge-line { font-size: 38px; text-align: center; margin: 8px 0; }
.modal-card input[type='email'] {
  width: 100%; height: 48px; border: 2px solid var(--ink); border-radius: 12px;
  padding: 0 12px; font: 600 16px 'Sofia Sans', sans-serif; margin-bottom: 10px;
}
.optin { display: flex; gap: 8px; align-items: flex-start; font-size: 13px; color: var(--ink-soft); margin-bottom: 12px; }
.optin input { margin-top: 2px; }
.modal-ok { text-align: center; padding: 12px 0; font-size: 15px; }

/* ── Archive ────────────────────────────────────────── */
.arhiv { padding: 0 16px; }
.arhiv h1 { font-size: 24px; margin: 12px 0; }
.arhiv-list { list-style: none; }
.arhiv-row { display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid var(--line); padding: 11px 0; gap: 8px; }
.arhiv-main { display: flex; gap: 10px; align-items: baseline; text-decoration: none; min-width: 0; }
.arhiv-no { font-weight: 800; color: var(--ink-soft); font-size: 14px; }
.arhiv-title { font-weight: 600; font-size: 15px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.arhiv-right { display: flex; gap: 8px; align-items: center; flex-shrink: 0; }
.price-sm { font-family: 'Sofia Sans Condensed', sans-serif; font-weight: 800; font-size: 15px; }
.tag { font-size: 12px; font-weight: 700; padding: 3px 9px; border-radius: 99px; text-decoration: none; }
.tag-live { background: rgba(29, 125, 90, 0.12); color: var(--green); }
.tag-play { background: var(--ink); color: #fff; }
.tag-lock { background: var(--surface); }
.arhiv-empty { color: var(--ink-soft); padding: 24px 0; }
.arhiv-detail { padding: 0 16px; }
.arhiv-detail h1 { font-size: 22px; margin: 12px 0; }
.arhiv-photo { width: 100%; border-radius: 12px; }
.dist { color: var(--ink-soft); font-size: 14px; padding: 8px 0; }
.listing-link { display: block; font-weight: 700; padding: 8px 0; }
.gate-note { background: var(--surface); border-radius: 12px; padding: 12px 14px; font-size: 14.5px; margin: 10px 0; }

/* ── Admin ──────────────────────────────────────────── */
.admin { max-width: 900px; padding: 0 16px; }
.admin h1 { font-size: 22px; margin: 14px 0; }
.admin h2 { font-size: 17px; margin: 18px 0 8px; }
.admin-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.admin-table th, .admin-table td { text-align: left; padding: 6px 8px; border-bottom: 1px solid var(--line); }
.admin-table.small { font-size: 12.5px; }
.admin .warn { background: rgba(245, 81, 71, 0.12); color: #9c2f27; font-weight: 700; padding: 10px 14px; border-radius: 10px; margin: 8px 0; }
.admin .hint { font-size: 13px; color: var(--ink-soft); margin-top: 8px; }

/* ── Accessibility: reduced motion kills all three motions ── */
@media (prefers-reduced-motion: reduce) {
  .g-row.is-new, .photo.is-new, .share-card, .share-grid .tile.flip, .modal-card, .inp.error { animation: none; }
}

/* ── TikTok-like feed (2026-06-05 pivot) ─────────────────── */
.feedbody { background: #000; }
.feedbody .hd-overlay {
  position: fixed; top: 0; left: 50%; transform: translateX(-50%);
  width: 100%; max-width: 480px; z-index: 5; padding: 14px 16px 10px;
}
.feedbody .hd-overlay .wordmark, .feedbody .hd-overlay .streak, .feedbody .hd-overlay .score {
  color: #fff; text-shadow: 0 1px 6px rgba(0,0,0,.5);
}
.score { font-weight: 700; font-size: 17px; color: var(--green); }
.feed {
  /* No native scroll (overflow:hidden) → no rubber-band flicker, and a flick can never skip
     past an unfinished estate. feed.js intercepts swipe/wheel and moves exactly one estate
     (forward only when the estate in view is finished); scrollIntoView still works here. */
  height: 100dvh; overflow: hidden; scroll-snap-type: y mandatory;
  max-width: 480px; margin: 0 auto; padding-bottom: 0;
  overscroll-behavior-y: contain; scrollbar-width: none;
}
.feed::-webkit-scrollbar { display: none; }
.card {
  height: 100dvh; scroll-snap-align: start;
  position: relative; overflow: hidden; background: #111;
}
.card-photo {
  position: absolute; inset: 0; background-size: cover; background-position: center;
  transition: background-image 0.15s ease;
}
.photo-dots {
  position: absolute; top: 58px; left: 0; right: 0;
  display: flex; gap: 5px; justify-content: center; z-index: 3;
}
.pdot { width: 18px; height: 3px; border-radius: 2px; background: rgba(255,255,255,.35); }
.pdot.on { background: rgba(255,255,255,.95); }
/* Visible photo controls — grandma-friendly, big touch targets */
.photo-nav {
  position: absolute; top: 38%; transform: translateY(-50%); z-index: 3;
  width: 52px; height: 52px; border-radius: 99px; border: 0;
  background: rgba(0,0,0,.42); color: #fff; font-size: 30px; line-height: 1;
  display: flex; align-items: center; justify-content: center; cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.photo-nav.prev { left: 10px; } .photo-nav.next { right: 10px; }
.photo-zoom {
  position: absolute; right: 10px; top: 50px; z-index: 4;
  display: flex; align-items: center; gap: 6px;
  background: rgba(0,0,0,.5); color: #fff; border: 0; border-radius: 99px;
  padding: 9px 14px 9px 11px; font: 700 14px 'Sofia Sans', sans-serif; cursor: pointer;
}
.photo-zoom svg { display: block; }

/* Fullscreen zoomable photo viewer */
.lightbox {
  position: fixed; inset: 0; z-index: 50; background: #000;
  display: flex; align-items: center; justify-content: center; overflow: hidden;
  touch-action: none;
}
.lightbox[hidden] { display: none; }
.lb-stage { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; }
.lb-img { max-width: 100%; max-height: 100%; transform-origin: center center; will-change: transform; user-select: none; }
.lightbox.zoomed .lb-img { cursor: grab; }
.lb-close {
  position: absolute; top: 14px; right: 14px; z-index: 2;
  background: rgba(255,255,255,.16); color: #fff; border: 0; border-radius: 99px;
  padding: 11px 18px; font: 800 15px 'Sofia Sans', sans-serif; cursor: pointer;
}
.lb-counter {
  position: absolute; top: 18px; left: 50%; transform: translateX(-50%);
  color: #fff; font: 600 15px 'Sofia Sans', sans-serif; opacity: .85;
}
.lb-arrow {
  position: absolute; top: 50%; transform: translateY(-50%); z-index: 2;
  width: 56px; height: 56px; border-radius: 99px; border: 0;
  background: rgba(255,255,255,.16); color: #fff; font-size: 34px; cursor: pointer;
}
.lb-arrow.prev { left: 12px; } .lb-arrow.next { right: 12px; }
.lb-zoom {
  position: absolute; bottom: 70px; left: 50%; transform: translateX(-50%); z-index: 2;
  display: flex; gap: 14px;
}
.lb-zoom button {
  width: 60px; height: 60px; border-radius: 99px; border: 0;
  background: rgba(255,255,255,.92); color: #111; font-size: 32px; font-weight: 700; cursor: pointer;
}
.lb-hint {
  position: absolute; bottom: 22px; left: 0; right: 0; text-align: center;
  color: rgba(255,255,255,.7); font-size: 13px; pointer-events: none;
}
.lightbox.zoomed .lb-hint { opacity: 0; }
.card-grad {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(180deg, rgba(0,0,0,.34) 0%, rgba(0,0,0,0) 20%, rgba(0,0,0,0) 36%, rgba(12,9,6,.88) 84%);
}
.card-ui {
  position: absolute; left: 0; right: 0; bottom: 0; z-index: 4;
  padding: 0 14px calc(14px + env(safe-area-inset-bottom));
  color: #fff;
}
.daily-badge {
  display: inline-block; background: linear-gradient(90deg, #c08a3a, #b0544b); color: #fff;
  font: 800 12px 'Sofia Sans', sans-serif; letter-spacing: .02em;
  padding: 4px 11px; border-radius: 99px; margin-bottom: 7px; box-shadow: 0 2px 8px rgba(0,0,0,.35);
}
.card-meta { font-size: 21px; margin-bottom: 4px; text-shadow: 0 1px 4px rgba(0,0,0,.6); min-height: 1.2em; }
.card-attrs { font-size: 17px; color: #d8dadd; margin-bottom: 6px; text-shadow: 0 1px 4px rgba(0,0,0,.6); }
.reveal-more { align-self: flex-start; margin-bottom: 2px; padding: 6px 13px; font: inherit; font-size: 14.5px; font-weight: 700;
  color: #eaf6f0; background: rgba(29,125,90,.34); border: 1px solid rgba(91,224,164,.5); border-radius: 99px; cursor: pointer; font-size: 16.5px; }
.reveal-more:active { transform: scale(.97); }
.reveal-cost { margin: 0 0 8px; font-size: 15.5px; color: #cfd3d8; text-shadow: 0 1px 4px rgba(0,0,0,.6); }
.card-ladder .g-row { padding: 7px 11px; margin-bottom: 6px; backdrop-filter: blur(6px); }
.card-ladder .g-row.far { background: rgba(176, 84, 75, 0.40); color: #f4d7d2; }
.card-ladder .g-row.close { background: rgba(192, 138, 58, 0.38); color: #f6e6cd; }
.card-ladder .g-row.win { background: rgba(29, 125, 90, 0.4); color: #d3f3e6; }
.card-ladder .g-row .val { color: #fff; }
.card-form { display: flex; gap: 8px; padding: 4px 0 8px; }
.card-form .inp { background: rgba(255,255,255,.96); border-color: transparent; height: 48px; border-radius: 12px; }
.card-form .btn { height: 48px; background: var(--green); }
.card-dots { display: flex; gap: 7px; justify-content: center; padding: 2px 0 6px; }
.card-dots .dot { background: rgba(255,255,255,.3); }
.card-dots .dot.far { background: var(--red); }
.card-dots .dot.close { background: var(--orange); }
.card-dots .dot.win { background: var(--green); }
/* in-card reveal */
/* Photo-first editorial reveal: verdict = small-caps eyebrow, price = hero caption on the photo. */
.card-reveal { padding: 2px 0 6px; text-align: center; }
.rv-verdict { font-size: 14.5px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; color: rgba(255,255,255,.82); }
.rv-verdict.win { color: #9be9c4; }
.rv-price { font-family: 'Sofia Sans Condensed', sans-serif; font-weight: 800; font-size: 58px; line-height: 1; letter-spacing: -.01em; margin-top: 3px; text-shadow: 0 2px 14px rgba(0,0,0,.55); }
.rv-cap { font-size: 13.5px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.72); margin-top: 9px; text-shadow: 0 1px 4px rgba(0,0,0,.6); }
.rv-median, .rv-pct { font-size: 15px; color: #e3e5e8; margin-top: 2px; }
.rv-actions { display: flex; gap: 8px; justify-content: center; margin: 6px 0; }
.sharebtn-sm {
  border: 0; border-radius: 11px; background: var(--green); color: #fff;
  font: 800 16px 'Sofia Sans', sans-serif; padding: 11px 16px; cursor: pointer;
}
.rv-listing {
  border: 1.5px solid rgba(255,255,255,.4); border-radius: 11px; padding: 10px 14px;
  font: 700 16px 'Sofia Sans', sans-serif; color: #fff; text-decoration: none;
  background: none; cursor: pointer;
}
.rv-next {
  display: block; width: 100%; margin: 12px 0 2px; border: 0; border-radius: 12px;
  background: rgba(255,255,255,.16); color: #fff; padding: 14px;
  font: 800 18px 'Sofia Sans', sans-serif; cursor: pointer;
}
.rv-next:hover { background: rgba(255,255,255,.24); }
.rv-next:active { background: rgba(255,255,255,.3); }
.card-empty { display: flex; align-items: center; justify-content: center; }
.card-empty .empty-state { color: #fff; }
.card-empty .empty-state p { color: #c8ccd1; }
/* how-to overlay + toast */
.howto-overlay {
  position: fixed; inset: 0; z-index: 8; background: rgba(0,0,0,.6);
  display: flex; align-items: center; justify-content: center; padding: 24px;
}
.howto-overlay[hidden] { display: none; }
.howto-card { background: var(--cream); border-radius: 18px; padding: 22px 20px; max-width: 420px; }
.howto-card h2 { font-size: 21px; margin-bottom: 8px; }
.howto-card p { font-size: 17px; color: var(--ink-soft); margin-bottom: 14px; line-height: 1.5; }
.howto-card .btn { width: 100%; }
.toast {
  position: fixed; top: 16px; left: 50%; transform: translateX(-50%); z-index: 9;
  background: var(--green); color: #fff; font: 700 14px 'Sofia Sans', sans-serif;
  padding: 10px 18px; border-radius: 99px;
}
@media (prefers-reduced-motion: reduce) { .rv-next { animation: none; } }


/* ── Custom SVG icon set (replaces emoji) ──────────────── */
.ic { width: 1em; height: 1em; vertical-align: -0.13em; display: inline-block; }
.rv-verdict .ic { width: 15px; height: 15px; vertical-align: -2px; }
.rv-verdict.win .ic { color: var(--green); }
.streak .ic { color: var(--orange); width: 17px; height: 17px; vertical-align: -3px; }
.score .ic { color: var(--green); width: 17px; height: 17px; vertical-align: -3px; }
.rv-pct .ic { width: 15px; height: 15px; vertical-align: -2px; color: var(--green); }
.sharebtn-sm .ic { width: 17px; height: 17px; vertical-align: -3px; }
.badge-line .ic { width: 40px; height: 40px; color: var(--green); }

/* Wave A: share-at-moment pulse + recipient head-to-head strip */
.sharebtn-sm.pulse { animation: share-pulse 1.1s ease-in-out 2; }
@keyframes share-pulse { 0%,100% { transform: scale(1); } 50% { transform: scale(1.06); box-shadow: 0 0 0 6px rgba(29,125,90,.22); } }
.rv-versus { font-size: 15.5px; color: #f4e3c8; background: rgba(192,138,58,.18); border-radius: 10px; padding: 7px 10px; margin: 6px 16px; }
@media (prefers-reduced-motion: reduce) { .sharebtn-sm.pulse { animation: none; } }

/* B1: end-of-session save card */
.session-card { background: linear-gradient(170deg, #1d7d5a 0%, #14624a 100%); color: #fff;
  display: flex; align-items: center; justify-content: center; text-align: center; }
.session-inner { padding: 0 26px; max-width: 360px; }
.session-inner h2 { font-size: 24px; margin-bottom: 18px; }
.session-stats { display: flex; gap: 14px; justify-content: center; margin-bottom: 18px; }
.session-stats div { background: rgba(255,255,255,.14); border-radius: 14px; padding: 14px 10px; flex: 1; }
.session-stats b { display: block; font: 800 28px 'Sofia Sans Condensed', sans-serif; }
.session-stats span { font-size: 12.5px; opacity: .85; }
.session-copy { font-size: 14.5px; opacity: .92; margin-bottom: 14px; line-height: 1.45; }
.session-form input { width: 100%; height: 50px; border: 0; border-radius: 12px; padding: 0 14px;
  font: 600 16px 'Sofia Sans', sans-serif; margin-bottom: 10px; }
.session-form .btn { width: 100%; background: #fff; color: var(--green); }
.session-skip { background: none; border: 0; color: rgba(255,255,255,.8); font: 600 14px 'Sofia Sans', sans-serif;
  margin-top: 12px; cursor: pointer; }
/* B2: push prompt strip inside the reveal */
/* Push opt-in modal reuses .howto-overlay/.howto-card; this is the secondary dismiss.
   Extra top margin sets it well apart from „Включи" so it can be tapped calmly. */
.push-later { display: block; width: 100%; margin-top: 24px; background: none; border: 0;
  color: var(--ink-soft); font: 600 15px 'Sofia Sans', sans-serif; padding: 10px; cursor: pointer; }

/* C3: points line */
.rv-points { font-size: 19px; color: #ffe9cd; margin-top: 6px; font-weight: 700; }
.rv-breakdown { display: block; font-size: 13px; font-weight: 600; color: #c9cdd2; margin-top: 1px; }
.rv-points .lb-open { background: none; border: 0; color: var(--teal); font: 700 14px 'Sofia Sans', sans-serif; cursor: pointer; }
/* C2: leaderboard sheet */
.sheet { position: fixed; inset: 0; z-index: 40; background: rgba(0,0,0,.5); display: flex; align-items: flex-end; justify-content: center; }
.sheet[hidden] { display: none; }
.sheet-card { background: var(--cream); color: var(--ink); border-radius: 20px 20px 0 0; padding: 22px 18px 28px;
  width: 100%; max-width: 480px; position: relative; max-height: 80dvh; overflow-y: auto;
  animation: sheet-up .3s cubic-bezier(.2,.8,.3,1); }
@media (min-width: 540px) { .sheet { align-items: center; } .sheet-card { border-radius: 20px; } }
.sheet-card h2 { font-size: 20px; margin-bottom: 12px; }
.lb-list { display: flex; flex-direction: column; }
.lb-row { display: flex; align-items: center; gap: 12px; padding: 9px 6px; border-bottom: 1px solid var(--line); }
.lb-rank { font-family: 'Sofia Sans Condensed', sans-serif; font-weight: 800; color: var(--ink-soft); width: 28px; }
.lb-name { flex: 1; font-weight: 600; }
.lb-pts { font-family: 'Sofia Sans Condensed', sans-serif; font-weight: 800; }
.lb-me { margin-top: 12px; background: rgba(29,125,90,.1); color: var(--green); border-radius: 10px; padding: 10px 12px; font-weight: 700; }
.lb-empty, .lb-loading { color: var(--ink-soft); padding: 20px 0; text-align: center; }
.lb-nick { margin-top: 16px; }
.lb-nick-lbl { display: block; font-size: 13px; font-weight: 700; color: var(--ink-soft); margin-bottom: 6px; }
.lb-nick-row { display: flex; gap: 8px; }
.lb-nick input { flex: 1; height: 44px; border: 2px solid var(--ink); border-radius: 10px; padding: 0 12px; font: 600 15px 'Sofia Sans', sans-serif; }
.lb-nick button { border: 0; border-radius: 10px; background: var(--ink); color: #fff; font: 800 14px 'Sofia Sans', sans-serif; padding: 0 18px; cursor: pointer; }
.lb-nick button:disabled { opacity: .5; cursor: default; }
.lb-notify { margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--line); }
.lb-notify-btn { width: 100%; height: 46px; border: 0; border-radius: 10px; background: var(--green); color: #fff; font: 800 15px 'Sofia Sans', sans-serif; cursor: pointer; }
.lb-notify-hint { font-size: 13px; color: var(--ink-soft); margin-top: 8px; text-align: center; }
.lb-notify-on { font-size: 15px; font-weight: 700; color: var(--green); text-align: center; padding: 6px 0; }

/* ── Desktop: frame the mobile column on a branded backdrop ─────────────────
   The feed stays a phone-width column (the design is mobile-first), but on a wide
   screen the dead black is replaced by a green-glow backdrop, the column floats as
   a defined panel, and the brand fills the left gutter. */
@media (min-width: 900px) {
  .feedbody {
    background:
      radial-gradient(1100px 680px at 50% -8%, rgba(29,125,90,.26), transparent 62%),
      radial-gradient(900px 820px at 94% 110%, rgba(29,125,90,.13), transparent 55%),
      #0a0e0c;
  }
  /* float the column as a panel; full-height so the fixed header stays aligned */
  .feed { box-shadow: 0 0 0 1px rgba(255,255,255,.07), 0 28px 90px rgba(0,0,0,.55); }
}
/* Wider desktop: brand + tagline in the left gutter (room only past ~1180px). */
@media (min-width: 1180px) {
  .feedbody::before {
    content: 'Колко струва?';
    position: fixed; left: max(28px, 7vw); top: 39%; transform: translateY(-50%);
    z-index: 1; max-width: 4.6em; letter-spacing: -.01em;
    font: 800 clamp(34px, 3.4vw, 54px)/1.04 'Sofia Sans Condensed', sans-serif;
    color: #fff; text-shadow: 0 3px 30px rgba(0,0,0,.5);
  }
  .feedbody::after {
    content: 'Истински имоти, истински цени. Имаш 3 опита да познаеш.';
    position: fixed; left: max(28px, 7vw); top: 53%; transform: translateY(-50%);
    z-index: 1; max-width: 12.5em;
    font: 600 16.5px/1.42 'Sofia Sans', sans-serif; color: rgba(255,255,255,.62);
  }
}
