/* ============================================================
   OnlyPets — дизайн-система
   Тёплый pet-tech: крафтовая бумага, терракота, реальные фото
   ============================================================ */

:root{
  /* палитра */
  --paper:#faf6ef;
  --paper-2:#f3ecdf;
  --card:#ffffff;
  --ink:#27201a;
  --ink-soft:#6e6052;   /* вторичный текст — контрастнее для читабельности */
  --ink-faint:#988a7b;
  --line:#e9e0d2;
  --terra:#e45a25;
  --terra-deep:#c44715;
  --terra-soft:#fbe9e0;
  --sage:#5b7b5e;
  --sage-soft:#e7efe6;
  --sun:#f2b63c;
  --sun-soft:#fdf3dd;
  --blue-soft:#e4ecf4;

  /* типографика: Manrope — заголовки/цифры, Inter — текст и интерфейс */
  --font-display:'Manrope','Inter','Segoe UI',system-ui,sans-serif;
  --font-ui:'Inter','Segoe UI',system-ui,sans-serif;

  /* геометрия */
  --r-lg:26px;
  --r-md:18px;
  --r-sm:12px;
  --shadow-1:0 2px 10px rgba(66,48,32,.06);
  --shadow-2:0 14px 40px rgba(66,48,32,.12);
  --sidebar-w:248px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
/* мобильное «как приложение»: без серой вспышки при тапе и без резинового дёргания фона */
*{-webkit-tap-highlight-color:transparent}
html,body{overscroll-behavior-y:contain}
button,.btn,.nav-item,.m-tab{-webkit-user-select:none;user-select:none}
body{
  font-family:var(--font-ui);
  background:var(--paper);
  color:var(--ink);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
button{font-family:inherit;border:none;background:none;color:inherit;cursor:pointer}
input,textarea,select{font-family:inherit;color:inherit}
a{color:inherit;text-decoration:none}
.hidden{display:none!important}

h1,h2,h3,.display{font-family:var(--font-display)}

/* ---------- иконки ---------- */
.ic{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.ic-s{width:16px;height:16px}
.ic-l{width:24px;height:24px}
.ic-fill{fill:currentColor;stroke:none}

/* ---------- каркас ---------- */
.shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}
.main{min-width:0;padding:28px 40px 120px;max-width:1240px;width:100%;margin:0 auto}

/* ---------- сайдбар ---------- */
.sidebar{
  position:sticky;top:0;height:100vh;
  border-right:1px solid var(--line);
  padding:26px 18px;
  display:flex;flex-direction:column;gap:6px;
  background:var(--paper);
  z-index:40;
}
.brand{display:flex;align-items:center;gap:10px;padding:4px 10px 22px}
.brand-mark{
  width:40px;height:40px;border-radius:14px;
  background:var(--terra);color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 16px rgba(228,90,37,.35);
}
.brand-mark .ic{width:22px;height:22px;stroke-width:2}
.brand-name{font-family:var(--font-display);font-weight:800;font-size:21px;letter-spacing:-.4px}
.brand-name b{color:var(--terra)}
.nav-item{
  display:flex;align-items:center;gap:12px;
  padding:12px;border-radius:14px;
  font-weight:600;font-size:15.5px;color:var(--ink-soft);
  transition:all .15s;position:relative;width:100%;text-align:left;
}
.nav-item:hover{background:var(--paper-2);color:var(--ink)}
.nav-item.active{background:var(--ink);color:var(--paper)}
.nav-item .nav-dot{
  position:absolute;right:12px;top:50%;transform:translateY(-50%);
  min-width:18px;height:18px;padding:0 5px;border-radius:99px;
  background:var(--terra);color:#fff;font-size:10.5px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
}
.sidebar-spacer{flex:1}
.side-wallet{
  border:1px solid var(--line);border-radius:var(--r-md);
  padding:14px;background:var(--card);
}
.side-wallet .sw-label{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint)}
.side-wallet .sw-amount{font-family:var(--font-display);font-weight:800;font-size:22px;margin:2px 0 10px}
.side-foot{padding:12px 10px 0;font-size:11.5px;color:var(--ink-faint);line-height:1.5}
.side-foot button{color:var(--ink-soft);font-weight:600;font-size:11.5px}
.side-foot button:hover{color:var(--terra)}

/* ---------- мобильная навигация ---------- */
.m-topbar{display:none}
.m-tabbar{display:none}

/* ---------- кнопки ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-weight:700;font-size:15px;border-radius:99px;
  padding:11px 20px;transition:all .15s;white-space:nowrap;
}
.btn-primary{background:var(--terra);color:#fff;box-shadow:0 6px 16px rgba(228,90,37,.3)}
.btn-primary:hover{background:var(--terra-deep);transform:translateY(-1px)}
.btn-dark{background:var(--ink);color:var(--paper)}
.btn-dark:hover{background:#000;transform:translateY(-1px)}
.btn-outline{border:1.5px solid var(--ink);color:var(--ink);background:transparent}
.btn-outline:hover{background:var(--ink);color:var(--paper)}
.btn-soft{background:var(--paper-2);color:var(--ink)}
.btn-soft:hover{background:var(--line)}
.btn-sm{padding:8px 14px;font-size:13.5px}
.btn-lg{padding:15px 28px;font-size:15.5px}
.btn-block{width:100%}
.btn-subscribed{background:var(--sage-soft);color:var(--sage);box-shadow:none}
.btn-subscribed:hover{background:#dbe8da;transform:none}
.btn:active{transform:scale(.98)}

/* ---------- бейджи и чипы ---------- */
.vbadge{
  display:inline-flex;align-items:center;justify-content:center;
  width:17px;height:17px;border-radius:50%;
  background:var(--terra);color:#fff;flex-shrink:0;
  vertical-align:-3px;
}
.vbadge .ic{width:10px;height:10px;stroke-width:3}
.chip{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12.5px;font-weight:700;
  padding:5px 11px;border-radius:99px;
  background:var(--paper-2);color:var(--ink-soft);
}
.chip-champ{background:var(--sun-soft);color:#9a6b08}
.chip-live{background:var(--sage-soft);color:var(--sage)}
.chip-live::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--sage)}
.chip-premium{background:var(--ink);color:var(--paper)}

/* ---------- секции ---------- */
.section-head{display:flex;align-items:baseline;gap:14px;margin:34px 0 18px}
.section-head h2{font-size:26px;font-weight:800;letter-spacing:-.5px}
.section-head .sh-note{font-size:14px;color:var(--ink-faint);font-weight:600}
.section-head .sh-link{margin-left:auto;font-size:13.5px;font-weight:700;color:var(--terra);display:flex;align-items:center;gap:4px}
.section-head .sh-link:hover{gap:8px}
.section-head .sh-link{transition:gap .2s}

/* ---------- подиум (featured) ---------- */
.podium{
  display:flex;gap:16px;overflow-x:auto;padding:4px 4px 14px;
  scroll-snap-type:x mandatory;scrollbar-width:none;
}
.podium::-webkit-scrollbar{display:none}
.podium-card{
  position:relative;flex:0 0 200px;height:270px;border-radius:var(--r-lg);
  overflow:hidden;cursor:pointer;scroll-snap-align:start;
  box-shadow:var(--shadow-1);
}
.podium-card img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.podium-card:hover img{transform:scale(1.06)}
.podium-card::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 45%,rgba(20,12,6,.78));
}
.podium-card .pc-rank{
  position:absolute;top:12px;left:12px;z-index:2;
  font-family:var(--font-display);font-weight:800;font-size:13px;
  background:rgba(250,246,239,.92);color:var(--ink);
  padding:4px 10px;border-radius:99px;
}
.podium-card .pc-info{position:absolute;left:14px;right:14px;bottom:12px;z-index:2;color:#fff}
.podium-card .pc-name{font-family:var(--font-display);font-weight:800;font-size:18px;display:flex;align-items:center;gap:6px}
.podium-card .pc-species{font-size:11.5px;opacity:.85;font-weight:500;margin-top:1px}

/* ---------- лента ---------- */
.feed-layout{display:grid;grid-template-columns:minmax(0,640px) 308px;gap:32px;align-items:start}
.feed-col{display:flex;flex-direction:column;gap:18px}
.post-card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);
  overflow:hidden;
}
.post-head{display:flex;align-items:center;gap:12px;padding:14px 16px}
.ava{border-radius:34%;overflow:hidden;flex-shrink:0;background:var(--paper-2);cursor:pointer}
.ava img{width:100%;height:100%;object-fit:cover}
.ava-44{width:44px;height:44px}
.ava-36{width:36px;height:36px}
.ava-56{width:56px;height:56px}
.post-who{flex:1;min-width:0;cursor:pointer}
.post-name{font-weight:700;font-size:15.5px;display:flex;align-items:center;gap:6px}
.post-handle{font-size:13.5px;color:var(--ink-soft);font-weight:500}
.post-media{position:relative;background:var(--paper-2);overflow:hidden}
.post-media>img{width:100%;max-height:560px;object-fit:cover}
.post-media>video{width:100%;max-height:560px;background:#111;display:block}
.post-media .dbl-heart{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) scale(.4);
  color:#fff;opacity:0;pointer-events:none;filter:drop-shadow(0 6px 20px rgba(0,0,0,.4));
}
.post-media .dbl-heart .ic{width:84px;height:84px;fill:currentColor;stroke:none}
.post-media .dbl-heart.pop{animation:heartPop .75s ease forwards}
@keyframes heartPop{
  0%{opacity:0;transform:translate(-50%,-50%) scale(.4)}
  30%{opacity:1;transform:translate(-50%,-50%) scale(1.12)}
  65%{opacity:1;transform:translate(-50%,-50%) scale(1)}
  100%{opacity:0;transform:translate(-50%,-62%) scale(1)}
}

/* пейволл */
.locked .post-blur{filter:blur(26px) saturate(1.1) brightness(.92);transform:scale(1.12)}
.paywall{
  position:absolute;inset:0;z-index:3;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;
  background:linear-gradient(180deg,rgba(42,33,26,.25),rgba(42,33,26,.55));
  color:#fff;text-align:center;padding:24px;
}
.paywall-badge{
  width:52px;height:52px;border-radius:18px;
  background:rgba(250,246,239,.16);backdrop-filter:blur(6px);
  border:1px solid rgba(250,246,239,.4);
  display:flex;align-items:center;justify-content:center;
}
.paywall-title{font-family:var(--font-display);font-weight:800;font-size:17px;text-shadow:0 2px 14px rgba(0,0,0,.35)}
.paywall-sub{font-size:13px;opacity:.92;max-width:300px;text-shadow:0 1px 8px rgba(0,0,0,.35)}
.paywall-actions{display:flex;gap:10px;margin-top:4px;flex-wrap:wrap;justify-content:center}
.paywall .btn-ghostlight{
  background:rgba(250,246,239,.14);border:1px solid rgba(250,246,239,.5);color:#fff;backdrop-filter:blur(6px);
}
.paywall .btn-ghostlight:hover{background:rgba(250,246,239,.28)}

.post-actions{display:flex;align-items:center;gap:2px;padding:8px 10px 0}
.act{
  display:flex;align-items:center;gap:7px;
  font-size:14.5px;font-weight:700;color:var(--ink-soft);
  padding:8px 12px;border-radius:12px;transition:all .15s;
}
.act:hover{background:var(--paper-2);color:var(--ink)}
.act.liked{color:var(--terra)}
.act.liked .ic{fill:var(--terra);stroke:var(--terra)}
.act-right{margin-left:auto}
.post-body{padding:8px 18px 16px}
.post-text{font-size:15.5px;line-height:1.65}
.post-text b{font-weight:700}
.post-meta{font-size:12px;color:var(--ink-faint);margin-top:8px;font-weight:500}
.post-cpeek{
  padding:0 18px 14px;font-size:14px;color:var(--ink-soft);font-weight:600;cursor:pointer;
}
.post-cpeek:hover{color:var(--terra)}

/* правая колонка */
.rail{position:sticky;top:28px;display:flex;flex-direction:column;gap:18px}
.rail-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:18px}
.rail-card h3{font-size:15.5px;font-weight:800;margin-bottom:12px}
.rail-row{display:flex;align-items:center;gap:11px;padding:7px 0;cursor:pointer;border-radius:12px}
.rail-row:hover .rr-name{color:var(--terra)}
.rail-row .rr-info{flex:1;min-width:0}
.rail-row .rr-name{font-weight:700;font-size:14.5px;display:flex;gap:5px;align-items:center;transition:color .15s}
.rail-row .rr-sub{font-size:12.5px;color:var(--ink-faint)}
.rail-row .rr-stat{font-size:12px;font-weight:700;color:var(--ink-soft)}
.rail-promo{
  background:var(--ink);color:var(--paper);border:none;
  border-radius:var(--r-lg);padding:22px;position:relative;overflow:hidden;
}
.rail-promo::before{
  content:"";position:absolute;right:-30px;top:-30px;width:120px;height:120px;border-radius:50%;
  background:var(--terra);opacity:.25;
}
.rail-promo h3{font-family:var(--font-display);font-size:19px;font-weight:800;line-height:1.25;margin-bottom:6px}
.rail-promo p{font-size:13px;opacity:.75;margin-bottom:14px}

/* ---------- каталог ---------- */
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:20px}
.fchip{
  padding:9px 16px;border-radius:99px;border:1.5px solid var(--line);
  font-size:14px;font-weight:700;color:var(--ink-soft);background:var(--card);transition:all .15s;
}
.fchip:hover{border-color:var(--ink-soft)}
.fchip.active{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.filter-bar select{
  margin-left:auto;padding:9px 14px;border-radius:12px;border:1.5px solid var(--line);
  background:var(--card);font-size:13px;font-weight:600;outline:none;
}
.search-input{
  width:100%;padding:13px 18px 13px 46px;border-radius:16px;border:1.5px solid var(--line);
  background:var(--card);font-size:15.5px;font-weight:500;outline:none;transition:border .15s;
}
.search-input:focus{border-color:var(--terra)}
.search-wrap{position:relative;margin-bottom:16px}
.search-wrap .ic{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--ink-faint)}

.catalog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.creator-card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);
  overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s;
}
.creator-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-2)}
.creator-card .cc-photo{position:relative;aspect-ratio:4/3.4;overflow:hidden}
.creator-card .cc-photo img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.creator-card:hover .cc-photo img{transform:scale(1.05)}
.creator-card .cc-chips{position:absolute;top:12px;left:12px;display:flex;gap:6px}
.creator-card .cc-body{padding:14px 16px 16px}
.creator-card .cc-name{font-family:var(--font-display);font-weight:800;font-size:17px;display:flex;align-items:center;gap:6px}
.creator-card .cc-species{font-size:13.5px;color:var(--ink-faint);font-weight:500;margin:2px 0 10px}
.creator-card .cc-foot{display:flex;align-items:center;justify-content:space-between}
.creator-card .cc-followers{font-size:13.5px;font-weight:700;color:var(--ink-soft)}
.creator-card .cc-price{font-size:13px;font-weight:800;color:var(--terra)}

/* ---------- профиль ---------- */
.profile-hero{position:relative;border-radius:var(--r-lg);overflow:hidden;height:300px;box-shadow:var(--shadow-1)}
.profile-hero img{width:100%;height:100%;object-fit:cover}
.profile-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(22,14,8,.72))}
.profile-hero .ph-back{
  position:absolute;top:16px;left:16px;z-index:3;
  width:40px;height:40px;border-radius:14px;
  background:rgba(250,246,239,.9);display:flex;align-items:center;justify-content:center;
}
.profile-hero .ph-back:hover{background:#fff}
.profile-hero .ph-info{position:absolute;left:28px;right:28px;bottom:22px;z-index:2;color:#fff;display:flex;align-items:flex-end;gap:18px;flex-wrap:wrap}
.profile-hero .ph-name{font-family:var(--font-display);font-weight:900;font-size:40px;letter-spacing:-1px;display:flex;align-items:center;gap:10px;line-height:1}
.profile-hero .ph-species{font-size:13.5px;opacity:.9;font-weight:500;margin-top:6px}
.profile-hero .ph-chips{margin-left:auto;display:flex;gap:8px}
.profile-bar{
  display:flex;align-items:center;gap:26px;flex-wrap:wrap;
  padding:18px 8px;border-bottom:1px solid var(--line);margin-bottom:22px;
}
.pstat{display:flex;flex-direction:column}
.pstat b{font-family:var(--font-display);font-weight:800;font-size:19px}
.pstat span{font-size:11.5px;color:var(--ink-faint);font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.profile-bar .pb-actions{margin-left:auto;display:flex;gap:10px}
.profile-bio{font-size:15.5px;line-height:1.7;max-width:640px;color:var(--ink);margin-bottom:6px}
.profile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:20px}
.pg-item{position:relative;aspect-ratio:1;border-radius:var(--r-md);overflow:hidden;cursor:pointer;background:var(--paper-2)}
.pg-item img,.pg-item video{width:100%;height:100%;object-fit:cover;transition:transform .3s;display:block}
.pg-item:hover img{transform:scale(1.04)}
.pg-item.locked img,.pg-item.locked video{filter:blur(18px) brightness(.85);transform:scale(1.12)}
.pg-video{ /* плитка видео-поста: кадр (если прогрузился) поверх тёмного градиента + значок ▶ */
  position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#241c14,#3a2c1e);color:#fff;
}
.pg-video video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.pgv-badge{
  position:relative;z-index:2;width:38%;max-width:46px;aspect-ratio:1;border-radius:50%;
  background:rgba(20,14,8,.55);border:1.5px solid rgba(255,255,255,.55);
  display:flex;align-items:center;justify-content:center;backdrop-filter:blur(3px);
}
.pgv-badge .ic{width:46%;height:46%;margin-left:8%}
.pg-lock{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;
  background:rgba(42,33,26,.32);
}

/* тарифы */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:18px 0 8px}
.plan-card{
  border:1.5px solid var(--line);border-radius:var(--r-md);padding:18px;
  background:var(--card);cursor:pointer;transition:all .15s;position:relative;
}
.plan-card:hover{border-color:var(--terra);transform:translateY(-2px)}
.plan-card.popular{border-color:var(--terra)}
.plan-card .pl-tag{
  position:absolute;top:-10px;left:14px;background:var(--terra);color:#fff;
  font-size:10.5px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  padding:3px 10px;border-radius:99px;
}
.plan-card .pl-name{font-weight:800;font-size:15px}
.plan-card .pl-price{font-family:var(--font-display);font-weight:800;font-size:24px;margin:6px 0 8px}
.plan-card .pl-price small{font-size:12px;color:var(--ink-faint);font-weight:600}
.plan-card .pl-desc{font-size:12.5px;color:var(--ink-soft);line-height:1.5}

/* ---------- студия ---------- */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.kpi{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);padding:16px 18px;
}
.kpi .k-label{font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-faint)}
.kpi .k-value{font-family:var(--font-display);font-weight:800;font-size:26px;margin-top:4px;letter-spacing:-.5px}
.kpi .k-delta{font-size:12px;font-weight:700;margin-top:3px;display:flex;align-items:center;gap:4px}
.kpi .k-delta.up{color:var(--sage)}
.kpi .k-delta.down{color:#c0392b}
.chart-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px 22px;margin-bottom:18px}
.chart-card .ch-head{display:flex;align-items:baseline;gap:12px;margin-bottom:8px}
.chart-card h3{font-size:16px;font-weight:800}
.chart-card .ch-note{font-size:12.5px;color:var(--ink-faint);font-weight:600}
.chart-wrap{width:100%}
.chart-wrap svg{width:100%;height:auto;display:block}
.table{width:100%;border-collapse:collapse;font-size:14.5px}
.table th{
  text-align:left;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  color:var(--ink-faint);padding:10px 12px;border-bottom:1px solid var(--line);
}
.table td{padding:11px 12px;border-bottom:1px solid var(--paper-2);font-weight:500}
.table td.amt{font-weight:700;font-variant-numeric:tabular-nums;text-align:right}
.table td.amt.plus{color:var(--sage)}
.table td.amt.minus{color:#c0392b}
.table tr:last-child td{border-bottom:none}

/* ---------- кошелёк ---------- */
.wallet-hero{
  background:var(--ink);color:var(--paper);border-radius:var(--r-lg);
  padding:28px;display:flex;align-items:center;gap:24px;flex-wrap:wrap;
  position:relative;overflow:hidden;margin-bottom:22px;
}
.wallet-hero::before{
  content:"";position:absolute;right:-40px;bottom:-60px;width:200px;height:200px;border-radius:50%;
  background:var(--terra);opacity:.22;
}
.wallet-hero .wh-label{font-size:11.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;opacity:.6}
.wallet-hero .wh-amount{font-family:var(--font-display);font-weight:900;font-size:44px;letter-spacing:-1px;line-height:1.1}
.wallet-hero .wh-actions{margin-left:auto;display:flex;gap:10px;z-index:2}
.amount-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:14px}
.amount-opt{
  border:1.5px solid var(--line);border-radius:var(--r-sm);padding:14px 8px;text-align:center;
  font-weight:800;font-size:15px;font-family:var(--font-display);transition:all .15s;background:var(--card);
}
.amount-opt small{display:block;font-family:var(--font-ui);font-size:11px;color:var(--ink-faint);font-weight:600;margin-top:2px}
.amount-opt:hover{border-color:var(--ink-soft)}
.amount-opt.selected{border-color:var(--terra);background:var(--terra-soft)}
.pay-row{display:flex;gap:10px;margin-bottom:16px}
.pay-opt{
  flex:1;border:1.5px solid var(--line);border-radius:var(--r-sm);padding:12px 8px;
  text-align:center;font-weight:700;font-size:12.5px;transition:all .15s;background:var(--card);
  display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--ink-soft);
}
.pay-opt:hover{border-color:var(--ink-soft)}
.pay-opt.selected{border-color:var(--terra);background:var(--terra-soft);color:var(--ink)}

/* ---------- чаты ---------- */
.chat-layout{
  display:grid;grid-template-columns:320px 1fr;gap:0;
  background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);
  overflow:hidden;height:calc(100dvh - 140px);min-height:480px;
}
.chat-list{border-right:1px solid var(--line);overflow-y:auto}
.chat-list-head{padding:18px 18px 10px;font-family:var(--font-display);font-weight:800;font-size:19px}
.chat-item{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:background .12s}
.chat-item:hover{background:var(--paper)}
.chat-item.active{background:var(--terra-soft)}
.chat-item .ci-meta{flex:1;min-width:0}
.chat-item .ci-name{font-weight:700;font-size:15px;display:flex;align-items:center;gap:5px}
.chat-item .ci-last{font-size:13.5px;color:var(--ink-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.chat-item .ci-unread{
  min-width:20px;height:20px;border-radius:99px;background:var(--terra);color:#fff;
  font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;padding:0 6px;
}
.chat-pane{display:flex;flex-direction:column;min-width:0}
.chat-pane-head{
  display:flex;align-items:center;gap:12px;padding:14px 18px;
  border-bottom:1px solid var(--line);
}
.chat-pane-head .cp-name{font-weight:800;font-size:15px;display:flex;align-items:center;gap:6px}
.chat-pane-head .cp-status{font-size:12px;color:var(--ink-faint)}
.chat-pane-head .cp-status.online{color:var(--sage);font-weight:600}
.chat-pane-head .cp-actions{margin-left:auto;display:flex;gap:6px}
.icon-btn{
  width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  color:var(--ink-soft);transition:all .15s;
}
.icon-btn:hover{background:var(--paper-2);color:var(--ink)}
.chat-msgs{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:10px;background:var(--paper)}
.msg{max-width:72%;padding:11px 15px;border-radius:18px;font-size:15px;line-height:1.55;animation:msgIn .18s ease}
@keyframes msgIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}
.msg.me{align-self:flex-end;background:var(--ink);color:var(--paper);border-bottom-right-radius:6px}
.msg.them{align-self:flex-start;background:var(--card);border:1px solid var(--line);border-bottom-left-radius:6px}
.msg.sys{align-self:center;background:none;font-size:12px;color:var(--ink-faint);font-weight:600}
.typing-dots{display:inline-flex;gap:4px;padding:4px 2px}
.typing-dots i{width:6px;height:6px;border-radius:50%;background:var(--ink-faint);animation:tblink 1.2s infinite}
.typing-dots i:nth-child(2){animation-delay:.18s}
.typing-dots i:nth-child(3){animation-delay:.36s}
@keyframes tblink{0%,60%,100%{opacity:.25}30%{opacity:1;transform:translateY(-2px)}}
.chat-input{display:flex;gap:10px;padding:14px 16px;border-top:1px solid var(--line);background:var(--card)}
.chat-input input{
  flex:1;padding:12px 18px;border-radius:99px;border:1.5px solid var(--line);
  background:var(--paper);font-size:15px;outline:none;
}
.chat-input input:focus{border-color:var(--terra)}
.chat-send{
  width:44px;height:44px;border-radius:50%;background:var(--terra);color:#fff;
  display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0;
}
.chat-send:hover{background:var(--terra-deep);transform:scale(1.06)}
.chat-empty{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  color:var(--ink-faint);font-weight:600;font-size:14px;background:var(--paper);
}

/* ---------- дровер уведомлений ---------- */
.drawer-overlay{position:fixed;inset:0;background:rgba(42,33,26,.35);z-index:90;animation:fadeIn .2s ease}
.drawer{
  position:fixed;top:0;right:0;bottom:0;width:min(400px,94vw);z-index:91;
  background:var(--paper);border-left:1px solid var(--line);
  display:flex;flex-direction:column;animation:drawerIn .25s cubic-bezier(.2,.8,.3,1);
}
@keyframes drawerIn{from{transform:translateX(40%);opacity:.5}to{transform:none;opacity:1}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:20px 20px 12px}
.drawer-head h3{font-size:19px;font-weight:800}
.drawer-body{flex:1;overflow-y:auto;padding:6px 16px 24px;display:flex;flex-direction:column;gap:8px}
.notif{
  display:flex;gap:12px;background:var(--card);border:1px solid var(--line);
  border-radius:var(--r-md);padding:13px 14px;align-items:flex-start;
}
.notif.unread{border-left:3px solid var(--terra)}
.notif .n-ico{
  width:36px;height:36px;border-radius:12px;background:var(--paper-2);
  display:flex;align-items:center;justify-content:center;color:var(--ink-soft);flex-shrink:0;
}
.notif .n-body{font-size:14.5px;line-height:1.5}
.notif .n-time{font-size:11.5px;color:var(--ink-faint);font-weight:600;margin-top:2px}

/* ---------- модалки ---------- */
.modal-overlay{
  position:fixed;inset:0;background:rgba(42,33,26,.45);z-index:250; /* выше Reels (120), ниже тостов (300) */
  display:flex;align-items:center;justify-content:center;padding:20px;
  animation:fadeIn .18s ease;
}
.modal{
  width:min(520px,100%);max-height:88vh;overflow-y:auto;
  background:var(--paper);border-radius:var(--r-lg);padding:26px;
  animation:modalIn .22s cubic-bezier(.2,.8,.3,1.05);
}
@keyframes modalIn{from{transform:translateY(18px) scale(.98);opacity:0}to{transform:none;opacity:1}}
.modal h2{font-size:21px;font-weight:800;letter-spacing:-.3px;display:flex;align-items:center;gap:10px}
.modal .m-sub{font-size:14.5px;color:var(--ink-soft);margin:6px 0 18px;line-height:1.55}
.modal-x{position:sticky;float:right;top:0}
.field{margin-bottom:14px}
.field label{display:block;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:6px}
.field input[type=text],.field input[type=number],.field textarea,.field select{
  width:100%;padding:12px 15px;border-radius:var(--r-sm);border:1.5px solid var(--line);
  background:var(--card);font-size:15.5px;outline:none;transition:border .15s;
}
.field input:focus,.field textarea:focus{border-color:var(--terra)}
.field textarea{resize:vertical;min-height:80px}

/* комментарии */
.comments{display:flex;flex-direction:column;gap:12px;margin:8px 0 18px;max-height:46vh;overflow-y:auto;padding-right:4px}
.comment{display:flex;gap:10px}
.comment .cm-ava{
  width:34px;height:34px;border-radius:34%;overflow:hidden;flex-shrink:0;
  background:var(--paper-2);display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:13px;color:var(--ink-soft);
}
.comment .cm-ava img{width:100%;height:100%;object-fit:cover}
.comment .cm-body{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:10px 13px;font-size:14.5px;line-height:1.5;flex:1}
.comment .cm-author{font-weight:700;font-size:12.5px;display:flex;align-items:center;gap:5px}
.comment.from-pet .cm-body{background:var(--terra-soft);border-color:#f3d3c2}

/* чаевые */
.tip-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:14px}
.tip-opt{
  border:1.5px solid var(--line);border-radius:var(--r-sm);padding:14px 6px;text-align:center;
  background:var(--card);transition:all .15s;
}
.tip-opt b{font-family:var(--font-display);font-size:16px;font-weight:800;display:block}
.tip-opt span{font-size:11px;color:var(--ink-faint);font-weight:600}
.tip-opt:hover,.tip-opt.selected{border-color:var(--terra);background:var(--terra-soft)}

/* ---------- онбординг ---------- */
.login-page{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}
.login-grid{
  flex:1;display:grid;grid-template-columns:1.05fr 1fr;gap:40px;align-items:center;
  max-width:1200px;margin:0 auto;padding:40px 48px;width:100%;
}
.login-left .l-logo{display:flex;align-items:center;gap:12px;margin-bottom:40px}
.login-left h1{
  font-size:clamp(38px,4.6vw,60px);font-weight:900;letter-spacing:-1.5px;line-height:1.04;
  margin-bottom:18px;
}
.login-left h1 em{font-style:normal;color:var(--terra)}
.login-left .l-sub{font-size:16.5px;color:var(--ink-soft);line-height:1.6;max-width:440px;margin-bottom:28px}
.login-form{display:flex;flex-direction:column;gap:10px;max-width:380px}
.login-form input{
  padding:14px 18px;border-radius:16px;border:1.5px solid var(--line);
  background:var(--card);font-size:15px;outline:none;transition:border .15s;
}
.login-form input:focus{border-color:var(--terra)}
.login-stats{display:flex;gap:28px;margin-top:34px;flex-wrap:wrap}
.lstat b{font-family:var(--font-display);font-weight:800;font-size:22px;display:block;letter-spacing:-.5px}
.lstat span{font-size:12px;color:var(--ink-faint);font-weight:600}
.login-right{position:relative;display:flex;justify-content:center}
.hero-arch{
  width:min(400px,100%);aspect-ratio:4/5;overflow:hidden;
  border-radius:200px 200px 28px 28px;box-shadow:var(--shadow-2);position:relative;
}
.hero-arch img{width:100%;height:100%;object-fit:cover}
.hero-arch-sm{
  position:absolute;right:-12px;bottom:-26px;width:170px;aspect-ratio:1;
  border-radius:90px 90px 22px 22px;overflow:hidden;
  border:6px solid var(--paper);box-shadow:var(--shadow-2);
}
.hero-arch-sm img{width:100%;height:100%;object-fit:cover}
.hero-tag{
  position:absolute;left:-14px;top:42px;
  background:var(--card);border:1px solid var(--line);border-radius:99px;
  padding:9px 16px;font-size:13px;font-weight:700;display:flex;align-items:center;gap:8px;
  box-shadow:var(--shadow-1);
}
.login-foot{
  border-top:1px solid var(--line);
  padding:14px 48px;display:flex;gap:30px;justify-content:center;flex-wrap:wrap;
  font-size:12px;color:var(--ink-faint);font-weight:600;letter-spacing:.04em;text-transform:uppercase;
}

/* ---------- «стать криэйтором» ---------- */
.become-hero{
  background:var(--ink);color:var(--paper);border-radius:var(--r-lg);padding:36px;
  margin-bottom:24px;position:relative;overflow:hidden;
}
.become-hero::before{
  content:"";position:absolute;right:-50px;top:-70px;width:240px;height:240px;border-radius:50%;
  background:var(--terra);opacity:.22;
}
.become-hero h2{font-size:30px;font-weight:900;letter-spacing:-.6px;line-height:1.15;max-width:520px}
.become-hero p{opacity:.75;margin-top:10px;max-width:480px;font-size:14.5px}
.calc-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px}
.calc-grid{display:grid;grid-template-columns:1fr 280px;gap:30px;align-items:start}
.slider-row{margin-bottom:22px}
.slider-row .sl-head{display:flex;justify-content:space-between;font-size:13.5px;font-weight:700;margin-bottom:10px}
.slider-row .sl-head span{color:var(--terra);font-family:var(--font-display);font-weight:800}
input[type=range]{
  width:100%;height:6px;border-radius:99px;background:var(--paper-2);outline:none;
  -webkit-appearance:none;appearance:none;
}
input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;width:22px;height:22px;border-radius:50%;
  background:var(--terra);cursor:pointer;border:4px solid var(--card);box-shadow:0 2px 8px rgba(0,0,0,.2);
}
.calc-result{
  background:var(--paper-2);border-radius:var(--r-md);padding:22px;text-align:center;
}
.calc-result .cr-label{font-size:11.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-soft)}
.calc-result .cr-value{font-family:var(--font-display);font-weight:900;font-size:34px;letter-spacing:-1px;color:var(--terra);margin:6px 0 2px}
.calc-result .cr-note{font-size:11.5px;color:var(--ink-faint);font-weight:600;margin-bottom:14px}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:22px}
.step{background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);padding:18px}
.step .st-num{
  width:34px;height:34px;border-radius:12px;background:var(--terra-soft);color:var(--terra);
  font-family:var(--font-display);font-weight:800;display:flex;align-items:center;justify-content:center;margin-bottom:10px;
}
.step h4{font-size:14.5px;font-weight:800;margin-bottom:4px}
.step p{font-size:12.5px;color:var(--ink-soft);line-height:1.5}

/* ---------- тосты ---------- */
.toast-wrap{
  position:fixed;bottom:26px;left:50%;transform:translateX(-50%);z-index:300;
  display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none;width:min(440px,92vw);
}
.toast{
  background:var(--ink);color:var(--paper);font-weight:600;font-size:14.5px;
  padding:13px 20px;border-radius:16px;box-shadow:var(--shadow-2);
  animation:toastIn .25s ease;text-align:center;line-height:1.45;
}
.toast.out{opacity:0;transition:opacity .3s}
@keyframes toastIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* ---------- скелетоны/пустоты ---------- */
.empty{
  padding:34px 20px;text-align:center;color:var(--ink-faint);font-weight:600;font-size:14px;
  border:1.5px dashed var(--line);border-radius:var(--r-md);line-height:1.6;
}

/* ---------- утилиты ---------- */
.muted{color:var(--ink-faint)}
.tnum{font-variant-numeric:tabular-nums}
.screen{display:none;animation:screenIn .22s ease}
.screen.active{display:block}
@keyframes screenIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ---------- адаптив ---------- */
@media (max-width:1150px){
  .feed-layout{grid-template-columns:minmax(0,1fr)}
  .rail{display:none}
  .catalog-grid{grid-template-columns:repeat(2,1fr)}
  .kpis{grid-template-columns:repeat(2,1fr)}
  .calc-grid{grid-template-columns:1fr}
}
@media (max-width:900px){
  .shell{grid-template-columns:1fr}
  .sidebar{display:none}
  .main{padding:calc(70px + env(safe-area-inset-top)) 14px calc(96px + env(safe-area-inset-bottom))}
  /* iOS: поля ввода от 16px — иначе Safari принудительно зумит страницу при фокусе */
  input,select,textarea{font-size:16px!important}
  /* портретные фото в ленте не режем по морде: потолок зависит от ширины экрана */
  .post-media>img{max-height:130vw}
  /* формы вязки: сетки в одну колонку */
  .modal div[style*="grid-template-columns:1fr 1fr 1fr"]{grid-template-columns:1fr 1fr!important}
  .modal div[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr 1fr}
  .modal{padding:18px}
  .my-mate-bar{padding:12px}
  .filter-bar select,.filter-bar input{flex:1;min-width:120px}
  .wallet-hero .wh-amount{font-size:32px}
  .profile-bar .pb-actions{width:100%;margin-left:0}
  .become-hero{padding:24px}
  .become-hero h2{font-size:23px}
  .m-tab{padding:4px 6px}
  .m-tab .nav-dot{right:-2px}
  .post-media>video{max-height:380px}
  .tip-grid{grid-template-columns:repeat(2,1fr)}
  .amount-grid{grid-template-columns:repeat(2,1fr)}
  .m-topbar{
    display:flex;position:fixed;top:0;left:0;right:0;z-index:60;
    align-items:center;gap:10px;
    padding:calc(10px + env(safe-area-inset-top)) 16px 10px; /* iPhone: не лезем под чёлку */
    background:rgba(250,246,239,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);
  }
  .m-topbar .brand-name{font-size:18px}
  .m-topbar .mt-actions{margin-left:auto;display:flex;align-items:center;gap:4px}
  .m-tabbar{
    display:flex;position:fixed;bottom:0;left:0;right:0;z-index:60;
    background:rgba(250,246,239,.95);backdrop-filter:blur(12px);border-top:1px solid var(--line);
    justify-content:space-around;padding:8px 8px calc(8px + env(safe-area-inset-bottom));
  }
  .m-tab{
    display:flex;flex-direction:column;align-items:center;gap:3px;
    font-size:10px;font-weight:700;color:var(--ink-faint);padding:4px 10px;border-radius:12px;position:relative;
  }
  .m-tab.active{color:var(--terra)}
  .m-tab .nav-dot{
    position:absolute;top:-2px;right:2px;min-width:16px;height:16px;border-radius:99px;
    background:var(--terra);color:#fff;font-size:9.5px;font-weight:800;
    display:flex;align-items:center;justify-content:center;padding:0 4px;
  }
  .login-grid{grid-template-columns:1fr;padding:24px 20px 30px;gap:26px}
  .login-right{order:-1}
  .hero-arch{width:min(320px,80vw)}
  /* кот-миниатюра: на мобиле меньше и в самый низ-угол — НЕ закрывает морду Санни */
  .hero-arch-sm{width:96px;right:-8px;bottom:-14px;border-width:4px}
  .hero-tag{left:0;top:18px;font-size:12px;padding:7px 12px}
  .login-left h1{font-size:clamp(30px,8vw,40px)}
  .login-left .l-logo{margin-bottom:20px}
  .login-stats{gap:18px;margin-top:24px}
  .login-foot{padding:12px 16px;gap:14px}
  .catalog-grid{grid-template-columns:1fr}
  .plans{grid-template-columns:1fr}
  .kpis{grid-template-columns:repeat(2,1fr)}
  .chat-layout{grid-template-columns:1fr;height:calc(100dvh - 150px)} /* dvh: iOS-адресная строка не съедает поле ввода */
  .chat-list.pane-hidden{display:none}
  .chat-pane.pane-hidden{display:none}
  .profile-hero .ph-name{font-size:28px}
  .profile-hero{height:240px}
  .steps{grid-template-columns:1fr}
}

/* ---------- стрик-виджет ---------- */
.streak-side{
  display:flex;align-items:center;gap:10px;width:100%;text-align:left;
  border:1px solid var(--line);border-radius:var(--r-md);padding:11px 13px;margin-bottom:8px;
  background:linear-gradient(120deg,#fff6ec,#ffe9d4);transition:transform .15s;position:relative;
}
.streak-side:hover{transform:translateY(-1px)}
.streak-side .ss-flame{font-size:24px;line-height:1;filter:saturate(1.2)}
.streak-side .ss-meta{flex:1;min-width:0}
.streak-side .ss-num{font-family:var(--font-display);font-weight:800;font-size:16px;color:var(--terra-deep)}
.streak-side .ss-label{font-size:11px;color:#9a6b08;font-weight:600}
.streak-side.claimable::after{
  content:"";position:absolute;top:9px;right:9px;width:9px;height:9px;border-radius:50%;background:var(--terra);
  box-shadow:0 0 0 0 rgba(228,90,37,.6);animation:streakPulse 1.6s infinite;
}
@keyframes streakPulse{0%{box-shadow:0 0 0 0 rgba(228,90,37,.55)}70%{box-shadow:0 0 0 8px rgba(228,90,37,0)}100%{box-shadow:0 0 0 0 rgba(228,90,37,0)}}
.streak-m{
  display:flex;align-items:center;gap:4px;background:linear-gradient(120deg,#fff6ec,#ffe1c4);
  border-radius:99px;padding:5px 11px;font-family:var(--font-display);font-weight:800;font-size:13.5px;
  color:var(--terra-deep);position:relative;
}
.streak-m.claimable::after{content:"";position:absolute;top:2px;right:2px;width:8px;height:8px;border-radius:50%;background:var(--terra);animation:streakPulse 1.6s infinite}
/* модалка стрика */
.streak-days{display:flex;gap:7px;justify-content:space-between;margin:16px 0}
.sd-day{flex:1;text-align:center;border-radius:12px;padding:9px 2px;background:var(--paper-2);position:relative}
.sd-day.done{background:linear-gradient(160deg,#ffb877,var(--terra));color:#fff}
.sd-day.today{outline:2px solid var(--terra);outline-offset:2px}
.sd-day .sd-flame{font-size:18px}
.sd-day .sd-n{font-size:10.5px;font-weight:700;margin-top:2px;opacity:.85}
.streak-stat{display:flex;gap:12px;margin:6px 0 4px}
.streak-stat .st-box{flex:1;background:var(--paper-2);border-radius:var(--r-sm);padding:12px;text-align:center}
.streak-stat .st-box b{font-family:var(--font-display);font-size:22px;display:block}
.streak-stat .st-box span{font-size:11.5px;color:var(--ink-faint);font-weight:600}
.ach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:8px}
.ach{border:1px solid var(--line);border-radius:var(--r-sm);padding:12px 8px;text-align:center;opacity:.4}
.ach.on{opacity:1;background:var(--sun-soft);border-color:#f0d9a0}
.ach .a-ic{width:34px;height:34px;border-radius:11px;background:var(--card);display:flex;align-items:center;justify-content:center;margin:0 auto 6px;color:var(--terra)}
.ach .a-t{font-size:11.5px;font-weight:800;line-height:1.2}
/* всплывашка достижения */
.ach-pop{
  position:fixed;top:84px;left:50%;transform:translateX(-50%) translateY(-20px);z-index:350;
  background:var(--ink);color:#fff;border-radius:var(--r-md);padding:14px 20px;
  display:flex;align-items:center;gap:12px;box-shadow:var(--shadow-2);opacity:0;
  animation:achPop 3.6s ease forwards;max-width:min(420px,92vw);
}
@keyframes achPop{0%{opacity:0;transform:translateX(-50%) translateY(-20px)}8%,86%{opacity:1;transform:translateX(-50%) translateY(0)}100%{opacity:0;transform:translateX(-50%) translateY(-20px)}}
.ach-pop .ap-ic{width:42px;height:42px;border-radius:13px;background:var(--terra);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ach-pop .ap-ic .ic{width:24px;height:24px;fill:#fff;stroke:#fff}
.ach-pop b{font-size:14.5px;display:block}
.ach-pop span{font-size:12.5px;opacity:.8}
.coin-burst{position:fixed;z-index:340;font-size:22px;pointer-events:none;animation:coinUp 1s ease forwards}
@keyframes coinUp{0%{opacity:0;transform:translateY(0) scale(.6)}30%{opacity:1}100%{opacity:0;transform:translateY(-70px) scale(1.1)}}

/* ---------- REELS: полноэкранная вертикальная лента ---------- */
.reels{
  position:fixed;inset:0;z-index:120;background:#000;
  scroll-snap-type:y mandatory;overflow-y:scroll;overscroll-behavior:contain;
  -webkit-overflow-scrolling:touch;scrollbar-width:none;animation:fadeIn .2s ease;
}
.reels::-webkit-scrollbar{display:none}
.reel{
  position:relative;height:100dvh;width:100%;scroll-snap-align:start;scroll-snap-stop:always;
  display:flex;align-items:center;justify-content:center;overflow:hidden;background:#000;
}
.reel-media{position:absolute;inset:0;width:100%;height:100%}
.reel-media video,.reel-media img{width:100%;height:100%;object-fit:cover;display:block;background:#000}
.reel-media.cover-contain video,.reel-media.cover-contain img{object-fit:contain}
.reel::before{ /* затемнение под текст снизу/сверху */
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,rgba(0,0,0,.35) 0%,transparent 18%,transparent 60%,rgba(0,0,0,.75) 100%);
}
.reel-locked .reel-media video,.reel-locked .reel-media img{filter:blur(28px) brightness(.7);transform:scale(1.12)}
.reel-paywall{
  position:absolute;inset:0;z-index:4;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;
  color:#fff;text-align:center;padding:30px;
}
.reel-paywall .rp-badge{width:60px;height:60px;border-radius:20px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(6px)}
.reel-paywall .rp-badge .ic{width:28px;height:28px}
.reel-paywall .rp-title{font-family:var(--font-display);font-weight:800;font-size:19px}
/* верхняя панель Reels */
.reels-top{
  position:fixed;top:0;left:0;right:0;z-index:130;display:flex;align-items:center;gap:12px;
  padding:calc(12px + env(safe-area-inset-top)) 16px 12px;
  background:linear-gradient(180deg,rgba(0,0,0,.5),transparent);
}
.reels-top .rt-title{color:#fff;font-family:var(--font-display);font-weight:800;font-size:18px;display:flex;align-items:center;gap:8px}
.reels-top .rt-close{margin-left:auto;width:40px;height:40px;border-radius:50%;background:rgba(0,0,0,.4);color:#fff;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(6px)}
/* информация и действия на риле */
.reel-info{position:absolute;left:16px;right:84px;bottom:calc(26px + env(safe-area-inset-bottom));z-index:5;color:#fff}
.reel-info .ri-author{display:flex;align-items:center;gap:10px;margin-bottom:10px;cursor:pointer}
.reel-info .ri-author .ava{width:40px;height:40px;border:2px solid #fff}
.reel-info .ri-name{font-weight:800;font-size:15px;display:flex;align-items:center;gap:5px;text-shadow:0 1px 6px rgba(0,0,0,.6)}
.reel-info .ri-sub{
  margin-left:6px;border:1.5px solid #fff;color:#fff;font-size:11.5px;font-weight:800;
  padding:3px 11px;border-radius:99px;background:rgba(255,255,255,.12);backdrop-filter:blur(4px);
}
.reel-info .ri-sub.on{border-color:var(--sage);color:#bfe9c4}
.reel-info .ri-text{font-size:14.5px;line-height:1.45;text-shadow:0 1px 8px rgba(0,0,0,.7);max-height:4.5em;overflow:hidden}
.reel-actions{
  position:absolute;right:12px;bottom:calc(40px + env(safe-area-inset-bottom));z-index:5;
  display:flex;flex-direction:column;gap:20px;align-items:center;
}
.reel-act{display:flex;flex-direction:column;align-items:center;gap:5px;color:#fff;cursor:pointer}
.reel-act .ra-ic{
  width:50px;height:50px;border-radius:50%;background:rgba(0,0,0,.35);backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;transition:transform .15s;
}
.reel-act:active .ra-ic{transform:scale(.88)}
.reel-act .ra-ic .ic{width:26px;height:26px}
.reel-act.liked .ra-ic{background:var(--terra)}
.reel-act.liked .ra-ic .ic{fill:#fff;stroke:#fff}
.reel-act .ra-num{font-size:12px;font-weight:700;text-shadow:0 1px 4px rgba(0,0,0,.7)}
.reel-dbl{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) scale(.4);z-index:6;color:#fff;opacity:0;pointer-events:none;filter:drop-shadow(0 6px 24px rgba(0,0,0,.5))}
.reel-dbl .ic{width:110px;height:110px;fill:#fff;stroke:none}
.reel-dbl.pop{animation:heartPop .8s ease forwards}
.reel-play{position:absolute;inset:0;z-index:3;display:flex;align-items:center;justify-content:center;pointer-events:none;opacity:0;transition:opacity .2s}
.reel-play.show{opacity:1}
.reel-play .ic{width:72px;height:72px;color:rgba(255,255,255,.85);fill:rgba(255,255,255,.85)}
.reel-progress{position:absolute;top:0;left:0;height:3px;background:var(--terra);z-index:6;width:0;transition:width .2s linear}
/* кнопка запуска Reels в ленте */
.reels-launch{
  display:flex;align-items:center;gap:14px;cursor:pointer;
  background:linear-gradient(120deg,#1b1b1f,#3a2218 70%,var(--terra));
  border-radius:var(--r-lg);padding:18px 20px;margin-bottom:18px;color:#fff;position:relative;overflow:hidden;
}
.reels-launch:hover{transform:translateY(-2px);box-shadow:var(--shadow-2)}
.reels-launch .rl-play{width:48px;height:48px;border-radius:16px;background:rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.reels-launch .rl-play .ic{width:26px;height:26px;fill:#fff;stroke:#fff}
.reels-launch h3{font-family:var(--font-display);font-weight:800;font-size:18px}
.reels-launch p{font-size:13px;opacity:.8}
.reels-launch .rl-go{margin-left:auto;font-weight:800;font-size:13px;white-space:nowrap;opacity:.9}
@media (min-width:560px){
  /* десктоп: рил по центру в рамке 9:16 */
  .reel{padding:0}
  .reel-media{max-width:min(440px,calc(100dvh * 0.5625));left:50%;transform:translateX(-50%)}
  .reels{background:#0a0a0c}
}

/* ---------- вложения в чате ---------- */
.msg-attach{padding:8px}
.msg-attach img{max-width:260px;max-height:280px;border-radius:12px;display:block}
.msg-file{
  display:flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);
  border-radius:12px;padding:10px 14px;font-size:13.5px;line-height:1.35;min-width:180px;
}
.msg.them .msg-file{background:var(--paper-2);border-color:var(--line);color:var(--ink)}
.msg-file:hover{opacity:.85}
.msg-file small{opacity:.7}

/* ---------- цель-краудфандинг ---------- */
.goal-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);padding:16px 18px;margin:14px 0}
.goal-head{display:flex;justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:10px}
.goal-title{font-weight:800;font-size:14.5px}
.goal-nums{font-size:13px;font-weight:700;color:var(--terra);white-space:nowrap}
.goal-bar{height:10px;border-radius:99px;background:var(--paper-2);overflow:hidden}
.goal-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--terra),#f08c5a);transition:width .6s ease}
.goal-note{font-size:12px;color:var(--ink-faint);font-weight:600;margin-top:8px}

/* ---------- PPV-сообщение в чате ---------- */
.msg-ppv{
  align-self:flex-start;max-width:76%;
  background:var(--card);border:1px solid var(--line);border-radius:18px;border-bottom-left-radius:6px;
  overflow:hidden;animation:msgIn .18s ease;
}
.msg-ppv .ppv-teaser{padding:10px 15px 8px;font-size:14px;line-height:1.5}
.msg-ppv .ppv-media{position:relative;height:170px;background:var(--paper-2);overflow:hidden}
.msg-ppv .ppv-media img{width:100%;height:100%;object-fit:cover}
.msg-ppv .ppv-media img.teaser-blur{filter:blur(22px) saturate(1.2);transform:scale(1.25)}
.msg-ppv .ppv-lockwrap{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  background:rgba(42,33,26,.35);color:#fff;
}
.msg-ppv .ppv-open{padding:10px 14px}
.msg-ppv .ppv-photo img{width:100%;max-height:280px;object-fit:cover;display:block}

/* ---------- бандлы в модале подписки ---------- */
.bundle-row{display:flex;gap:8px;margin:0 0 14px;flex-wrap:wrap}
.bundle-opt{
  flex:1;min-width:70px;border:1.5px solid var(--line);border-radius:var(--r-sm);
  padding:9px 6px;text-align:center;background:var(--card);transition:all .15s;
}
.bundle-opt b{display:block;font-size:13.5px}
.bundle-opt span{font-size:10.5px;color:var(--sage);font-weight:800}
.bundle-opt:hover{border-color:var(--ink-soft)}
.bundle-opt.selected{border-color:var(--terra);background:var(--terra-soft)}
.trial-btn{
  width:100%;margin-top:10px;padding:9px;border-radius:10px;border:1.5px dashed var(--terra);
  color:var(--terra);font-weight:800;font-size:13px;transition:all .15s;background:transparent;
}
.trial-btn:hover{background:var(--terra-soft)}

/* ---------- вязка ---------- */
.mates-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media (max-width:1150px){.mates-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:700px){.mates-grid{grid-template-columns:1fr}}
.mate-card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);
  overflow:hidden;transition:transform .2s, box-shadow .2s;position:relative;
}
.mate-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-2)}
.mate-card .mc-photo{position:relative;aspect-ratio:4/3.1;overflow:hidden;background:var(--paper-2);cursor:pointer}
.mate-card .mc-photo img{width:100%;height:100%;object-fit:cover}
.mate-card .mc-noimg{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:900;font-size:44px;color:var(--terra);background:var(--terra-soft);
}
.match-badge{
  position:absolute;top:10px;right:10px;z-index:2;
  background:var(--card);border-radius:99px;padding:5px 11px;
  font-family:var(--font-display);font-weight:800;font-size:13px;color:var(--sage);
  box-shadow:var(--shadow-1);
}
.match-badge.warn{color:#b07c10}
.boost-badge{
  position:absolute;top:10px;left:10px;z-index:2;background:var(--sun);color:#5c4200;
  border-radius:99px;padding:5px 10px;font-size:11px;font-weight:800;
}
.sex-badge{
  display:inline-flex;align-items:center;justify-content:center;
  width:20px;height:20px;border-radius:7px;font-size:12px;font-weight:900;vertical-align:-3px;
}
.sex-badge.m{background:var(--blue-soft);color:#3a6ea8}
.sex-badge.f{background:#fde4ec;color:#c2447c}
.mate-card .mc-body{padding:13px 15px 15px}
.mate-card .mc-name{font-family:var(--font-display);font-weight:800;font-size:17px;display:flex;align-items:center;gap:7px}
.mate-card .mc-breed{font-size:13.5px;color:var(--ink-soft);font-weight:600;margin:2px 0 8px}
.mate-chips{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:10px}
.mate-chips .chip{font-size:11px;padding:4px 9px}
.chip-ok{background:var(--sage-soft);color:var(--sage)}
.chip-doc{background:var(--blue-soft);color:#3a6ea8}
/* сторис-полоса: кружки криэйтеров как в инстаграме */
.stories{
  display:flex;gap:14px;overflow-x:auto;padding:2px 2px 12px;margin-bottom:10px;
  scrollbar-width:none;-webkit-overflow-scrolling:touch;
}
.stories::-webkit-scrollbar{display:none}
.story{
  display:flex;flex-direction:column;align-items:center;gap:5px;flex:0 0 auto;
  background:none;border:none;cursor:pointer;font-family:inherit;width:66px;
}
.st-ring{
  width:62px;height:62px;border-radius:50%;padding:2.5px;
  background:linear-gradient(45deg,#f06a32,#ffb56b,#e8453c);
  display:flex;align-items:center;justify-content:center;
}
.st-ring-live{background:linear-gradient(45deg,#36b864,#a6e22e)}
.st-ring-reels{background:linear-gradient(45deg,#2b2017,#6b4a2f)}
.st-ring-more{background:var(--line)}
.st-ava{
  width:100%;height:100%;border-radius:50%;overflow:hidden;border:2.5px solid var(--paper);
  background:var(--ink);display:flex;align-items:center;justify-content:center;color:#fff;
}
.st-ava img{width:100%;height:100%;object-fit:cover}
.st-ava .ic{width:22px;height:22px}
.st-more{background:var(--card);color:var(--ink-soft)}
.st-name{font-size:10.5px;font-weight:700;color:var(--ink-soft);max-width:66px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* центральная кнопка Reels в мобильном таб-баре */
.m-tab-reels{padding:0!important}
.mtr-circle{
  width:52px;height:52px;border-radius:50%;margin-top:-22px;
  background:linear-gradient(135deg,#f06a32,#d94e1f);
  display:flex;align-items:center;justify-content:center;color:#fff;
  box-shadow:0 6px 18px rgba(228,90,37,.45),0 0 0 5px var(--paper);
}
.mtr-circle .ic{width:22px;height:22px;margin-left:2px}

/* быстрые ссылки в аккаунте (Студия/Кошелёк/Добро/Каталог) */
.acc-quick{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:16px}
.aq{
  display:flex;flex-direction:column;align-items:center;gap:6px;padding:13px 6px;
  background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);
  cursor:pointer;font-family:inherit;font-size:12px;font-weight:700;color:var(--ink);
}
.aq .ic{width:21px;height:21px;color:var(--terra)}

/* нативный отклик: нажатие проминает кнопки и карточки */
.btn:active,.m-tab:active,.story:active,.aq:active,.podium-card:active,.dp:active,.share-btn:active{transform:scale(.96)}
.btn,.m-tab,.story,.aq,.podium-card,.dp,.share-btn{transition:transform .12s ease, filter .15s ease, box-shadow .2s ease}
/* появление карточек ленты */
.post-card,.shelter-card,.mate-card,.cat-card{animation:cardIn .35s ease both}
@keyframes cardIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* гостевая стена: «дальше — после регистрации» */
.guest-wall{position:relative;border-radius:var(--r-lg);overflow:hidden;margin-top:6px}
.gw-blur{display:flex;flex-direction:column;gap:14px;filter:blur(7px);opacity:.55;pointer-events:none}
.gw-fake{
  height:120px;border-radius:var(--r-lg);
  background:linear-gradient(120deg,var(--card),var(--terra-soft) 55%,var(--card));
  border:1px solid var(--line);
}
.gw-body{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:8px;text-align:center;padding:18px;
  background:linear-gradient(180deg,rgba(250,246,239,.35),rgba(250,246,239,.92) 70%);
}
.gw-body h3{font-family:var(--font-display);font-size:19px}
.gw-body .m-sub{max-width:420px}
.gw-body .btn{margin-top:6px}
.reel-gate{display:flex;align-items:center;justify-content:center;background:#0d0d10}
.rg-inner{text-align:center;color:#fff;padding:30px;max-width:420px;display:flex;flex-direction:column;gap:12px;align-items:center}
.rg-inner h2{font-family:var(--font-display);font-size:24px}
.rg-inner p{color:rgba(255,255,255,.75);font-size:14.5px;line-height:1.55}

/* ДОБРО: приюты и сборы */
.shelters-banner{
  display:flex;align-items:center;gap:14px;width:100%;cursor:pointer;font-family:inherit;
  background:linear-gradient(120deg,#fff7e8,#ffeFD6 60%,#ffe9c4);border:1px solid #f3ddb4;
  border-radius:var(--r-lg);padding:14px 18px;margin-bottom:18px;color:var(--ink);font-size:14.5px;
  transition:transform .15s ease, box-shadow .15s ease;
}
.shelters-banner:hover{transform:translateY(-1px);box-shadow:0 8px 22px rgba(180,130,40,.18)}
.shelters-banner .shb-ic{font-size:30px}
.shelters-hero{display:flex;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.shh-stat{
  flex:1;min-width:150px;background:var(--card);border:1px solid var(--line);
  border-radius:var(--r-md);padding:14px;text-align:center;
}
.shh-stat b{display:block;font-size:21px}
.shh-stat span{font-size:12.5px;color:var(--ink-soft)}
.shelter-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:16px}
.shelter-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.shc-photo{position:relative;height:160px}
.shc-photo img{width:100%;height:100%;object-fit:cover}
.shc-city{
  position:absolute;left:10px;bottom:10px;background:rgba(30,22,14,.72);color:#fff;
  font-size:12px;font-weight:700;padding:4px 10px;border-radius:99px;
}
.shc-body{padding:14px 16px 16px}
.shc-name{font-family:var(--font-display);font-weight:800;font-size:17.5px}
.shc-about{font-size:13.5px;color:var(--ink-soft);line-height:1.5;margin-bottom:12px}
.shc-goal{border-top:1px dashed var(--line);padding:10px 0 12px}
.shcg-row{display:flex;justify-content:space-between;gap:10px;font-size:13px;font-weight:600;margin-bottom:6px}
.shc-goal .goal-bar{margin-bottom:9px}
.donate-presets{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}
.dp{
  padding:12px 6px;border-radius:12px;border:1.5px solid var(--line);background:var(--card);
  font-family:inherit;font-size:14.5px;font-weight:800;cursor:pointer;color:var(--ink);
}
.dp.active{border-color:var(--terra);background:var(--terra-soft);color:var(--terra)}
.sdon-row{
  display:flex;justify-content:space-between;gap:10px;padding:8px 2px;font-size:13.5px;
  border-bottom:1px dashed var(--line);
}
.sdon-row:last-child{border-bottom:none}

/* share-sheet: Telegram / ВК / MAX / копировать */
.share-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.share-btn{
  display:flex;align-items:center;justify-content:center;gap:9px;min-width:0;
  padding:14px 10px;border-radius:14px;border:none;cursor:pointer;white-space:nowrap;
  font-family:inherit;font-size:14px;font-weight:700;color:#fff;text-decoration:none;
  transition:transform .12s ease, filter .12s ease;
}
.share-btn:hover{transform:translateY(-1px);filter:brightness(1.06)}
.share-btn .sb-glyph{
  width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.22);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  font-size:11px;font-weight:800;letter-spacing:.3px;
}
.share-btn .sb-glyph .ic{width:14px;height:14px}
.sb-tg{background:#229ED9}
.sb-vk{background:#07F}
.sb-max{background:linear-gradient(135deg,#3f6dff,#9b35ff)}
.sb-copy{background:var(--card);color:var(--ink);border:1.5px solid var(--line)}
.sb-copy .sb-glyph{background:var(--paper-warm, #f1e9dc)}
.share-refrow{display:flex;gap:8px;margin-top:10px}
.share-refrow .share-btn{flex:1;padding:11px 8px;font-size:13px}
.chip-verified{background:#e3f4e8;color:#2f7d4a;font-weight:800}
.chip-verified .ic{width:13px;height:13px}
.verified-banner{
  display:flex;align-items:center;gap:10px;background:#e9f6ee;border:1px solid #bfe3cb;
  border-radius:var(--r-md);padding:12px 14px;margin:12px 0;color:#2f7d4a;font-weight:600;font-size:13.5px;
}
.verified-banner .ic{flex-shrink:0}
.mate-card .mc-actions{display:flex;gap:8px}
.warn-list{display:flex;flex-direction:column;gap:6px;margin:10px 0}
.warn-item{
  background:var(--sun-soft);color:#7a5500;border-radius:10px;
  padding:8px 12px;font-size:12.5px;font-weight:600;line-height:1.45;
}
.my-mate-bar{
  display:flex;align-items:center;gap:14px;background:var(--card);border:1px solid var(--line);
  border-radius:var(--r-lg);padding:14px 16px;margin-bottom:18px;flex-wrap:wrap;
}
.my-mate-bar .ava{width:54px;height:54px}
.verify-banner{
  background:var(--sun-soft);border:1px solid #f0d9a0;border-radius:var(--r-md);
  padding:14px 16px;margin-bottom:16px;display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  font-size:13.5px;font-weight:600;color:#7a5500;
}
.mail-view{
  background:var(--paper-2);border-radius:var(--r-sm);padding:14px;font-size:13px;
  white-space:pre-wrap;line-height:1.6;font-family:ui-monospace,Consolas,monospace;
  max-height:40vh;overflow-y:auto;
}

/* ---------- топ-фаны ---------- */
.topfans{display:flex;flex-direction:column;gap:8px}
.topfan{display:flex;align-items:center;gap:10px;font-size:13.5px;font-weight:600}
.topfan .tf-rank{
  width:26px;height:26px;border-radius:9px;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:800;font-size:12px;background:var(--paper-2);color:var(--ink-soft);
}
.topfan:first-child .tf-rank{background:var(--sun-soft);color:#9a6b08}
.topfan .tf-sum{margin-left:auto;font-weight:800;color:var(--terra)}
