/* ════════════════════════════════════════════════════════════
   HERO — Ткань Памяти
   Подключается через <link rel="stylesheet" href="/static/css/landing-hero.css">
   ════════════════════════════════════════════════════════════ */

.hero-tp{
  position:relative;
  padding:5.5rem 2rem 0;
  background:#0a0a0a;
  overflow:hidden;
  color:#fff;
}

/* Декоративный фон. Если положишь /static/img/hero-bg.jpg —
   он подмешается сверху градиентов. Если нет — просто градиенты. */
.hero-tp-bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse 60% 75% at 72% 50%, rgba(212,170,90,.22), transparent 65%),
    radial-gradient(ellipse 50% 60% at 28% 70%, rgba(184,145,58,.12), transparent 70%),
    #0a0a0a;
}
.hero-tp-bg::before{
  content:'';position:absolute;inset:0;
  background:url('/static/img/hero-bg.jpg') center/cover no-repeat;
  opacity:.9;mix-blend-mode:screen;
}
/* SVG-нити как fallback фон поверх градиентов (рисуем при отсутствии hero-bg.jpg) */
.hero-tp-bg::after{
  content:'';position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 700' preserveAspectRatio='none'><defs><linearGradient id='g' x1='0' x2='1'><stop offset='0' stop-color='%23b8913a' stop-opacity='0'/><stop offset='.5' stop-color='%23d4aa5a' stop-opacity='.7'/><stop offset='1' stop-color='%23b8913a' stop-opacity='0'/></linearGradient></defs><g fill='none' stroke='url(%23g)' stroke-width='.8'><path d='M0,220 C300,140 600,360 900,220 C1050,150 1200,300 1200,300'/><path d='M0,300 C200,260 500,420 800,310 C1000,240 1200,380 1200,380'/><path d='M0,380 C250,320 550,500 850,400 C1050,340 1200,450 1200,450'/><path d='M0,460 C300,400 600,560 900,470 C1050,420 1200,520 1200,520'/><path d='M0,180 C400,100 700,300 1000,180 C1100,140 1200,240 1200,240'/></g></svg>");
  background-size:cover;background-position:center;
  opacity:0;
}

.hero-tp-wrap{
  position:relative;z-index:2;
  max-width:1320px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;
  gap:3rem;align-items:center;
  padding-bottom:3rem;
}

/* ───── Правая колонка — описание платформы (вместо коллажа) ───── */
.hero-tp-desc{position:relative}
.htd-lead{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(1.3rem,2vw,1.75rem);font-weight:300;line-height:1.45;
  color:#fff;margin-bottom:1.5rem;
  text-shadow:0 2px 18px rgba(0,0,0,.5);
}
.htd-lead::first-letter{color:#d4aa5a}
.htd-card{
  background:rgba(20,18,14,.55);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(184,145,58,.32);
  border-radius:16px;padding:1.4rem 1.6rem;margin-bottom:1.4rem;
  box-shadow:0 0 28px rgba(184,145,58,.08), 0 20px 48px rgba(0,0,0,.45);
}
.htd-card-title{
  font-size:.74rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:#e7c98b;margin-bottom:.9rem;
}
.htd-list{list-style:none}
.htd-list li{
  position:relative;padding:.5rem 0 .5rem 1.7rem;
  font-size:.95rem;color:rgba(255,255,255,.86);line-height:1.4;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.htd-list li:last-child{border-bottom:none}
.htd-list li::before{
  content:'';position:absolute;left:.15rem;top:.95rem;
  width:7px;height:7px;border-radius:50%;
  background:#d4aa5a;box-shadow:0 0 0 3px rgba(212,170,90,.18);
}
.htd-note{
  font-size:.92rem;line-height:1.6;color:rgba(255,255,255,.62);font-weight:300;
  border-left:2px solid rgba(212,170,90,.5);padding-left:1rem;
}

/* ───── Левая колонка ───── */
.hero-tp-left .ht-eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-size:.86rem;letter-spacing:.04em;
  color:#e7c98b;font-weight:500;line-height:1.3;
  padding:.55rem 1.1rem;
  background:rgba(212,170,90,.1);
  border:1px solid rgba(212,170,90,.4);
  border-radius:30px;
  margin-bottom:1.9rem;
  text-align:left;max-width:100%;
  box-shadow:0 0 24px rgba(212,170,90,.08);
}
.hero-tp-left .ht-eyebrow svg{flex-shrink:0;color:#d4aa5a}
.hero-tp-left h1{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.4rem, 4.5vw, 4.4rem);
  font-weight:300;line-height:1.05;letter-spacing:-.01em;
  margin-bottom:1.3rem;
  color:#fff;
  text-shadow:0 2px 24px rgba(0,0,0,.55);
}
.hero-tp-left h1 em{font-style:italic;color:#d4aa5a}
.hero-tp-left p.ht-sub{
  font-size:1rem;line-height:1.75;
  color:rgba(255,255,255,.82);font-weight:400;
  text-shadow:0 2px 16px rgba(0,0,0,.6);
  max-width:480px;margin-bottom:2.5rem;
}
.hero-tp-cta{display:flex;gap:.9rem;flex-wrap:wrap}
.hero-tp-cta .btn{padding:1rem 2rem;font-size:.78rem}
.btn-tp-play{
  background:rgba(255,255,255,.06);
  color:rgba(255,255,255,.85);
  border:1px solid rgba(255,255,255,.14);
}
.btn-tp-play:hover{background:rgba(255,255,255,.12);color:#fff}

/* ───── Правая колонка — коллаж карточек ───── */
.hero-tp-right{
  position:relative;
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:.75rem;
  min-height:460px;
}

.htcard{
  position:relative;border-radius:18px;overflow:hidden;
  background:#1a1a1a;
  border:1px solid rgba(184,145,58,.35);
  box-shadow:
    0 0 0 1px rgba(184,145,58,.1),
    0 0 24px rgba(184,145,58,.08),
    0 20px 48px rgba(0,0,0,.55);
  transition:transform .25s, box-shadow .25s;
}
.htcard:hover{
  transform:translateY(-3px);
  box-shadow:
    0 0 0 1px rgba(212,170,90,.45),
    0 0 32px rgba(212,170,90,.18),
    0 28px 64px rgba(0,0,0,.65);
}
.htcard img{
  width:100%;height:100%;object-fit:cover;display:block;
  position:absolute;inset:0;
  z-index:1;
}
/* fallback за картинкой — показывается если img не загрузилась */
.htcard-fallback{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(ellipse at 50% 40%, rgba(212,170,90,.13) 0%, transparent 65%),
    linear-gradient(135deg,#2a2520 0%,#1a1812 60%,#0d0c0a 100%);
  color:rgba(212,170,90,.55);
  font-size:2.4rem;
  z-index:0;
}
.htcard-fallback svg{
  filter:drop-shadow(0 0 12px rgba(212,170,90,.2));
}
.htcard .ht-label{
  position:absolute;left:50%;bottom:.85rem;transform:translateX(-50%);
  z-index:2;
  background:rgba(10,10,10,.78);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(184,145,58,.28);
  padding:.42rem 1rem;border-radius:24px;
  font-size:.72rem;color:#fff;letter-spacing:.03em;
  display:inline-flex;align-items:center;gap:.45rem;
  white-space:nowrap;
}
.htcard .ht-label svg{flex-shrink:0;color:#d4aa5a}

/* Сетка карточек — компактная раскладка в 3 ряда.
   --y хранит финальное смещение для эффекта плавающих блоков (используется в анимации появления) */
.htc-people  { grid-column: 1 / 5;   grid-row: 1;     aspect-ratio: 1/1; --y:.5rem; }
.htc-tree    { grid-column: 9 / 13;  grid-row: 1 / 3; aspect-ratio: 3/4; margin-top:1rem; --y:0rem; }
.htc-company { grid-column: 4 / 9;   grid-row: 2;     aspect-ratio: 4/3; --y:.8rem; }
.htc-archive { grid-column: 1 / 5;   grid-row: 3;     aspect-ratio: 5/4; --y:.5rem; }
.htc-qr      { grid-column: 5 / 9;   grid-row: 3;     align-self:center; --y:.3rem; }
.htc-events  { grid-column: 9 / 13;  grid-row: 3;     aspect-ratio: 5/4; --y:-.3rem; }

/* ═══════════════ АНИМАЦИИ ПОЯВЛЕНИЯ ═══════════════ */
@keyframes heroFadeUp {
  from { opacity:0; transform:translateY(28px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes heroCardIn {
  from { opacity:0; transform:translateY(calc(var(--y, 0px) + 40px)) scale(.96); }
  to   { opacity:1; transform:translateY(var(--y, 0px)) scale(1); }
}

/* Текст слева — поэтапное появление */
.hero-tp-left .ht-eyebrow,
.hero-tp-left h1,
.hero-tp-left p.ht-sub,
.hero-tp-cta {
  opacity:0;
  animation:heroFadeUp .85s cubic-bezier(.2,.7,.2,1) forwards;
}
.hero-tp-left .ht-eyebrow { animation-delay:0s; }
.hero-tp-left h1       { animation-delay:.05s; }
.hero-tp-left p.ht-sub { animation-delay:.2s;  }
.hero-tp-cta           { animation-delay:.35s; }

/* Карточки — с задержкой друг за другом */
.htcard, .htc-qr {
  opacity:0;
  animation:heroCardIn .95s cubic-bezier(.2,.7,.2,1) forwards;
}
.htc-people  { animation-delay:.4s;  }
.htc-tree    { animation-delay:.55s; }
.htc-company { animation-delay:.7s;  }
.htc-archive { animation-delay:.85s; }
.htc-qr      { animation-delay:1s;   }
.htc-events  { animation-delay:1.15s;}

/* Описание справа — плавное появление */
.hero-tp-desc{
  opacity:0;
  animation:heroFadeUp .9s cubic-bezier(.2,.7,.2,1) .45s forwards;
}

/* Полоса статистики тоже плавно появляется */
.hero-tp-stats {
  opacity:0;
  animation:heroFadeUp .9s cubic-bezier(.2,.7,.2,1) 1.3s forwards;
}

/* Уважаем настройку пользователя «уменьшить анимацию» */
@media (prefers-reduced-motion: reduce) {
  .hero-tp-left .ht-eyebrow,
  .hero-tp-left h1,
  .hero-tp-left p.ht-sub,
  .hero-tp-cta,
  .htcard,
  .htc-qr,
  .hero-tp-stats {
    opacity:1;
    animation:none;
    transform:translateY(var(--y, 0));
  }
}

/* QR-блок */
.ht-qr-block{
  background:rgba(20,20,20,.7);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(184,145,58,.25);
  border-radius:14px;
  padding:.85rem 1rem;
  display:flex;align-items:center;gap:.85rem;
}
.ht-qr-text{
  flex:1;font-size:.72rem;color:rgba(255,255,255,.7);
  line-height:1.4;
}
.ht-qr-img{
  width:54px;height:54px;background:#fff;border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}

/* ───── Полоса статистики ───── */
.hero-tp-stats{
  position:relative;z-index:2;
  background:rgba(0,0,0,.4);
  border-top:1px solid rgba(184,145,58,.16);
  border-bottom:1px solid rgba(184,145,58,.16);
  padding:1.5rem 2rem;
  display:flex;justify-content:space-around;align-items:center;
  flex-wrap:wrap;gap:1.5rem 2rem;
}
.ht-stat{
  display:flex;align-items:center;gap:.7rem;
  color:#fff;
}
.ht-stat>svg{color:#d4aa5a;opacity:.8;flex-shrink:0}
.ht-stat-num{
  font-family:'Cormorant Garamond',serif;
  font-size:1.6rem;font-weight:400;line-height:1;color:#fff;
}
.ht-stat-lbl{
  font-size:.66rem;color:rgba(255,255,255,.45);
  letter-spacing:.04em;margin-top:.2rem;
}

/* ═══════════════ MOBILE ═══════════════ */
@media (max-width: 900px){
  .hero-tp{padding:6.75rem 1.75rem 0}
  .hero-tp-wrap{
    grid-template-columns:1fr;
    gap:2rem;
    text-align:center;
    padding-bottom:2rem;
  }
  .hero-tp-left p.ht-sub{margin-left:auto;margin-right:auto}
  .hero-tp-cta{justify-content:center}
  .hero-tp-desc{text-align:left;max-width:560px;margin:0 auto}
  .htd-lead{text-align:center}
  .hero-tp-left h1{
    letter-spacing:0;
    text-shadow:0 2px 16px rgba(0,0,0,.55);
  }

  /* Коллаж — асимметричная компактная раскладка */
  .hero-tp-right{
    grid-template-columns:repeat(6,1fr);
    min-height:auto;
    gap:.55rem;
    padding:.3rem;
  }
  .htcard, .htc-qr{margin-top:0!important}

  /* Карточки разной высоты — эффект плавающих блоков. --y используется в анимации появления */
  .htc-people  { grid-column: 1/4; grid-row: 1/3; aspect-ratio: 3/4; --y:.7rem; }
  .htc-tree    { grid-column: 4/7; grid-row: 1;   aspect-ratio: 1/1; --y:0; }
  .htc-company { grid-column: 4/7; grid-row: 2;   aspect-ratio: 4/3; --y:0; }
  .htc-events  { grid-column: 1/4; grid-row: 3;   aspect-ratio: 1/1; --y:0; }
  .htc-archive { grid-column: 4/7; grid-row: 3;   aspect-ratio: 1/1; --y:-.4rem; }
  .htc-qr      { grid-column: 1/7; grid-row: 4;   margin-top:.5rem;  --y:0; }

  /* Иконки в карточках на мобиле — поменьше */
  .htcard-fallback svg{width:38px!important;height:38px!important}

  /* Лейблы поменьше */
  .htcard .ht-label{
    bottom:.5rem;font-size:.62rem;padding:.3rem .7rem;
  }

  .hero-tp-stats{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:1.1rem 1.5rem;
    align-items:center;
    padding:1.75rem 1.25rem 1.5rem;
    margin-top:1.5rem;
  }
  .ht-stat{width:auto}
}

@media (max-width: 500px){
  .hero-tp{padding:6.5rem 1.5rem 0}
  .hero-tp-left h1{font-size:2rem;line-height:1.1}
  .hero-tp-left .ht-eyebrow{margin-bottom:1.25rem;font-size:.72rem;letter-spacing:.02em;padding:.5rem .9rem;gap:.45rem}
  .hero-tp-left p.ht-sub{font-size:.88rem;margin-bottom:1.6rem;line-height:1.6}
  .hero-tp-cta{gap:.5rem}
  .hero-tp-cta .btn{padding:.78rem 1.2rem;font-size:.68rem;flex:1;min-width:0;letter-spacing:.04em}

  /* На очень узких экранах — карточки ещё меньше */
  .hero-tp-right{gap:.4rem}
  .htcard-fallback svg{width:30px!important;height:30px!important}
  .htcard .ht-label{
    font-size:.56rem;padding:.25rem .55rem;
    border-radius:18px;
  }
  .htcard .ht-label svg{width:9px;height:9px}

  .ht-qr-block{padding:.65rem .8rem}
  .ht-qr-text{font-size:.68rem}
  .ht-qr-img{width:46px;height:46px}
  .ht-qr-img svg{width:30px;height:30px}
}

/* ════════════════════════════════════════════════════════════
   ОПИСАНИЕ ПЛАТФОРМЫ
   ════════════════════════════════════════════════════════════ */
.tp-about{background:var(--cream);padding:5.5rem 2rem 4rem}
.tp-about-in{max-width:1080px;margin:0 auto}
.tp-about .slabel{margin-bottom:.7rem}
.tp-about .stitle{margin-bottom:1rem}
.tp-lead{
  text-align:center;max-width:720px;margin:0 auto 3rem;
  font-size:1.12rem;line-height:1.7;color:#3a352c;font-weight:300;
}
.tp-about-grid{
  display:grid;grid-template-columns:1.5fr 1fr;gap:2.5rem;align-items:start;
}
.tp-about-text p{
  font-size:.95rem;line-height:1.85;color:#4a4438;margin-bottom:1.1rem;font-weight:300;
}
.tp-about-text p b{font-weight:600;color:var(--ink)}
.tp-about-final{
  border-left:3px solid var(--gold);padding-left:1.1rem;
  color:var(--ink)!important;font-style:italic;
}
.tp-about-card{
  background:var(--white);border:1px solid var(--border);border-radius:10px;
  padding:1.75rem 1.6rem;box-shadow:0 14px 40px rgba(0,0,0,.05);
  position:sticky;top:96px;
}
.tp-about-card-title{
  font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-weight:600;
  line-height:1.35;margin-bottom:1.1rem;
}
.tp-about-list{list-style:none}
.tp-about-list li{
  position:relative;padding:.55rem 0 .55rem 1.7rem;
  font-size:.9rem;color:#4a4438;border-bottom:1px solid var(--warm);
}
.tp-about-list li:last-child{border-bottom:none}
.tp-about-list li::before{
  content:'';position:absolute;left:.2rem;top:.95rem;
  width:7px;height:7px;border-radius:50%;
  background:var(--gold);box-shadow:0 0 0 3px var(--goldpale);
}

/* ════════════════════════════════════════════════════════════
   5 БЛОКОВ-КАТЕГОРИЙ
   ════════════════════════════════════════════════════════════ */
.tp-cats{background:var(--warm);padding:5rem 2rem 6rem}
.tp-cats-in{max-width:1180px;margin:0 auto}
.tp-cats .slabel{margin-bottom:.7rem}
.tp-cats .ssub{margin-bottom:3rem}
.cat-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;
}
.cat-grid .cat-card:first-child{grid-column:span 1}
.cat-card{
  display:flex;flex-direction:column;text-align:left;
  background:var(--white);border:1px solid var(--border);border-radius:12px;
  overflow:hidden;cursor:pointer;padding:0;font-family:'Jost',sans-serif;
  transition:transform .22s, box-shadow .22s, border-color .22s;
}
.cat-card:hover{
  transform:translateY(-4px);
  box-shadow:0 20px 48px rgba(0,0,0,.12);
  border-color:var(--gold);
}
.cat-img{
  position:relative;height:178px;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  background:
    radial-gradient(ellipse at 50% 35%, rgba(212,170,90,.14), transparent 65%),
    linear-gradient(135deg,#2a2520,#181612);
  color:rgba(212,170,90,.6);
}
.cat-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.cat-img .cat-ph{filter:drop-shadow(0 0 12px rgba(212,170,90,.25))}
.cat-body{padding:1.3rem 1.4rem 1.5rem;display:flex;flex-direction:column;flex:1}
.cat-body h3{
  font-family:'Cormorant Garamond',serif;font-size:1.32rem;font-weight:600;
  margin-bottom:.45rem;color:var(--ink);
}
.cat-body p{font-size:.84rem;line-height:1.6;color:var(--muted);flex:1}
.cat-go{
  margin-top:1rem;font-size:.74rem;font-weight:600;letter-spacing:.06em;
  text-transform:uppercase;color:var(--gold);
}
.cat-card:hover .cat-go{color:var(--gold2)}

@media(max-width:900px){
  .tp-about-grid{grid-template-columns:1fr;gap:1.5rem}
  .tp-about-card{position:static}
  .cat-grid{grid-template-columns:1fr 1fr;gap:1rem}
}
@media(max-width:560px){
  .tp-about{padding:4rem 1.4rem 3rem}
  .tp-cats{padding:3.5rem 1.4rem 4.5rem}
  .cat-grid{grid-template-columns:1fr}
  .tp-lead{font-size:1rem}
}

/* ── Описание-секция в одну центрированную колонку ── */
.tp-about-narrow{max-width:780px}
.tp-about-narrow .stitle{margin-bottom:1.4rem}
.tp-about-narrow .tp-about-text{text-align:left}

/* ── Акцентный блок «не социальная сеть» ── */
.tp-callout{
  display:flex;align-items:center;gap:1.2rem;text-align:left;
  background:linear-gradient(135deg,#1a1714 0%,#241f17 100%);
  border:1px solid rgba(184,145,58,.4);
  border-left:4px solid var(--gold);
  border-radius:12px;padding:1.5rem 1.8rem;margin:0 auto 2.2rem;
  box-shadow:0 16px 40px rgba(0,0,0,.14);
}
.tp-callout-mark{
  flex-shrink:0;font-family:'Cormorant Garamond',serif;
  font-size:1.05rem;font-weight:600;color:var(--gold2);
  line-height:1.2;max-width:120px;
  padding-right:1.2rem;border-right:1px solid rgba(184,145,58,.3);
}
.tp-callout p{
  margin:0;font-size:1.02rem;line-height:1.6;color:rgba(255,255,255,.85);font-weight:300;
}
.tp-callout p b{color:#fff;font-weight:600}

/* ── Карточки «в разработке» ── */
.cat-soon{cursor:pointer}
.cat-soon .cat-img{filter:grayscale(.35) brightness(.85)}
.cat-soon:hover{border-color:var(--border)}
.cat-soon:hover .cat-img{filter:grayscale(0) brightness(1)}
.cat-soon .cat-go{color:var(--muted)}
.cat-soon-badge{
  position:absolute;top:.6rem;right:.6rem;z-index:2;
  background:rgba(10,10,10,.78);backdrop-filter:blur(6px);
  border:1px solid rgba(184,145,58,.4);
  color:#e7c98b;font-size:.6rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  padding:3px 9px;border-radius:10px;
}

@media(max-width:560px){
  .tp-callout{flex-direction:column;align-items:flex-start;gap:.7rem;padding:1.2rem 1.3rem}
  .tp-callout-mark{border-right:none;border-bottom:1px solid rgba(184,145,58,.3);padding:0 0 .6rem;max-width:none}
}

/* ── Ряд из 5 блоков-категорий (фото из hero) ── */
.cat-grid-5{grid-template-columns:repeat(5,1fr);gap:1rem}
/* высота фото = от ширины карточки (не фиксируем — иначе сплющивает) */
.cat-grid-5 .cat-img{height:auto;aspect-ratio:16/11}
.cat-grid-5 .cat-img img{object-position:center 35%}
.cat-grid-5 .cat-body{padding:1.05rem 1.1rem 1.25rem}
.cat-grid-5 .cat-body h3{font-size:1.18rem;margin-bottom:.35rem}
.cat-grid-5 .cat-body p{font-size:.79rem}
.cat-grid-5 .cat-go{margin-top:.8rem}
@media(max-width:1080px){.cat-grid-5{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){.cat-grid-5{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){
  .cat-grid-5{grid-template-columns:1fr;gap:1.1rem}
  .cat-grid-5 .cat-img{aspect-ratio:4/3}
}