/* =============================================================================
   HOMLINY — тематическая страница про хомлинов Калининграда
   Scoped к .homliny-page / body.homliny-tpl. Не влияет на остальной сайт.
   Палитра: «сцена вечернего Кёнигсберга» — мёд, бронза, патина, кёниг-зелёный.
   Шрифты: Cormorant Garamond (display) + Inter (sans) — бренд KEDO.
   ========================================================================== */

/* ---------- Шрифты (локальные woff2, только нужные подмножества) ---------- */
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/homliny/inter-cyrillic-400-normal.woff2') format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116;}
@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/homliny/inter-latin-400-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/homliny/inter-cyrillic-500-normal.woff2') format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116;}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/homliny/inter-latin-500-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122;}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/homliny/inter-cyrillic-600-normal.woff2') format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116;}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/homliny/inter-latin-600-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122;}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/homliny/inter-cyrillic-700-normal.woff2') format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116;}
@font-face{font-family:'Inter';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/homliny/inter-latin-700-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122;}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/homliny/cormorant-garamond-cyrillic-600-normal.woff2') format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116;}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/homliny/cormorant-garamond-latin-600-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122;}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/homliny/cormorant-garamond-cyrillic-700-normal.woff2') format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116;}
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/homliny/cormorant-garamond-latin-700-normal.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122;}
@font-face{font-family:'Cormorant Garamond';font-style:italic;font-weight:600;font-display:swap;src:url('../fonts/homliny/cormorant-garamond-cyrillic-600-italic.woff2') format('woff2');unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116;}
@font-face{font-family:'Cormorant Garamond';font-style:italic;font-weight:600;font-display:swap;src:url('../fonts/homliny/cormorant-garamond-latin-600-italic.woff2') format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2074,U+20AC,U+2122;}

/* ---------- Токены ---------- */
.homliny-page{
  --bg-night:#2A2018; --bg-deep:#1C1611; --bg-panel:#3A2C20;
  --honey:#E8A33D; --honey-bright:#F6C667; --amber-deep:#C4762A;
  --bronze:#8C6A3F; --bronze-light:#B89366; --patina:#5E7A6B; --patina-light:#7FA890;
  --konig-green:#21372C; --konig-green-2:#2C4A3A;
  --cream:#F5EAD7; --cream-dim:#C9B79A; --white-soft:#FBF6EC; --parchment:#EFE2C6;
  --ink:#2A2018; --ink-soft:#4A3B2C;
  --font-display:"Cormorant Garamond",Georgia,"Times New Roman",serif;
  --font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  --maxw:1120px; --maxw-narrow:760px;
  --radius:18px; --radius-lg:26px;
  --shadow:0 18px 50px rgba(0,0,0,.35);
  font-family:var(--font-sans);
  color:var(--cream);
  -webkit-font-smoothing:antialiased;
}

/* ---------- Full-width: освобождаем контейнеры GeneratePress ---------- */
body.homliny-tpl #content,
body.homliny-tpl .site-content,
body.homliny-tpl .content-area{max-width:100%;width:100%;padding:0;margin:0;}
body.homliny-tpl #primary.homliny-page{max-width:100%;width:100%;float:none;padding:0;margin:0;}
body.homliny-tpl .inside-article{padding:0;}
body.homliny-tpl{background:var(--bg-deep);}

.homliny-page *,.homliny-page *::before,.homliny-page *::after{box-sizing:border-box;}
.homliny-page .hp{display:block;overflow:hidden;}
.homliny-page img,.homliny-page video{max-width:100%;display:block;}

/* ---------- Контейнеры/секции ---------- */
.hp-wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 20px;}
.hp-wrap--narrow{max-width:var(--maxw-narrow);}
.hp-section{position:relative;padding:clamp(48px,9vw,104px) 0;}
.hp-section--light{background:linear-gradient(180deg,#FBF6EC,#F3E7CF);color:var(--ink);}
.hp-section--dark{background:radial-gradient(120% 90% at 50% -10%,var(--konig-green-2),var(--bg-night) 55%,var(--bg-deep));color:var(--cream);}
.hp-section--stage{background:radial-gradient(130% 100% at 50% 0%,#33271C,var(--bg-night) 50%,var(--bg-deep));color:var(--cream);}
.hp-section--cta{background:linear-gradient(180deg,var(--konig-green),var(--bg-deep));color:var(--cream);text-align:center;}

/* мягкая зернистость/виньетка на тёмных сценах */
.hp-section--dark::after,.hp-section--stage::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(120% 80% at 50% 30%,transparent 55%,rgba(0,0,0,.45));mix-blend-mode:multiply;}

/* ---------- Типографика ---------- */
.hp-h2{font-family:var(--font-display);font-weight:700;font-size:clamp(28px,4.6vw,46px);line-height:1.08;margin:0 0 .5em;letter-spacing:.2px;}
.hp-h2--light{color:var(--white-soft);}
.hp-h3{font-family:var(--font-display);font-weight:600;font-size:clamp(21px,3vw,28px);margin:1.4em 0 .4em;}
.hp-lede{font-size:clamp(16px,2.1vw,19px);line-height:1.55;max-width:62ch;color:var(--cream-dim);margin:0 0 2em;}
.hp-section--light .hp-lede{color:var(--ink-soft);}
.hp-prose{font-size:clamp(16px,2vw,18px);line-height:1.65;max-width:68ch;}
.hp-prose p{margin:0 0 1.1em;}
.hp-prose strong{color:var(--amber-deep);font-weight:600;}
.hp-section--dark .hp-prose strong,.hp-section--stage .hp-prose strong{color:var(--honey-bright);}

/* ---------- Кнопки ---------- */
.hp-btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--font-sans);font-weight:600;font-size:15px;
  padding:13px 22px;border-radius:999px;text-decoration:none;cursor:pointer;border:1.5px solid transparent;
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease,color .18s ease;line-height:1;}
.hp-btn--primary{background:linear-gradient(135deg,var(--honey),var(--amber-deep));color:#2A1C0C;box-shadow:0 8px 24px rgba(232,163,61,.32);}
.hp-btn--primary:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(232,163,61,.45);color:#2A1C0C;}
.hp-btn--ghost{background:transparent;border-color:rgba(245,234,215,.45);color:var(--cream);}
.hp-btn--ghost:hover{border-color:var(--honey);color:var(--honey-bright);}
.hp-section--light .hp-btn--ghost{border-color:rgba(42,32,24,.3);color:var(--ink);}
.hp-section--light .hp-btn--ghost:hover{border-color:var(--amber-deep);color:var(--amber-deep);}
.hp-btn--map{background:var(--patina);color:#fff;}
.hp-btn--map:hover{background:var(--patina-light);color:#1C1611;transform:translateY(-2px);}
.hp-btn--link{background:transparent;color:var(--amber-deep);padding-left:0;padding-right:0;}
.hp-btn--link:hover{color:var(--honey);}
.hp-section--stage .hp-btn--link,.hp-section--dark .hp-btn--link{color:var(--honey-bright);}

/* =================== 1. HERO =================== */
.hp-hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden;
  background:radial-gradient(100% 70% at 50% 0%,#3A2C20,var(--bg-night) 45%,var(--bg-deep));
  padding:90px 0 60px;}
.hp-hero__inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 20px;
  display:grid;grid-template-columns:1fr;gap:32px;align-items:center;}
.hp-hero__media{position:relative;justify-self:center;max-width:460px;width:100%;}
.hp-hero__media::before{content:"";position:absolute;inset:-12% -6% -6%;z-index:-1;border-radius:50%;
  background:radial-gradient(circle at 50% 45%,rgba(246,198,103,.45),rgba(232,163,61,.12) 45%,transparent 70%);filter:blur(6px);}
.hp-hero__media img,.hp-hero__media video{width:100%;height:auto;display:block;aspect-ratio:324 / 576;border-radius:var(--radius-lg);
  border:1px solid rgba(184,147,102,.35);box-shadow:0 24px 60px rgba(0,0,0,.5);}
/* «постамент света» под семьёй */
.hp-hero__media::after{content:"";position:absolute;left:50%;bottom:-18px;transform:translateX(-50%);
  width:78%;height:34px;border-radius:50%;background:radial-gradient(closest-side,rgba(246,198,103,.5),transparent);filter:blur(7px);}
.hp-hero__eyebrow{font-weight:600;letter-spacing:.16em;text-transform:uppercase;font-size:12.5px;color:var(--honey);margin:0 0 14px;}
.hp-hero__title{font-family:var(--font-display);font-weight:700;color:var(--white-soft);
  font-size:clamp(34px,7.4vw,62px);line-height:1.03;margin:0 0 18px;letter-spacing:.3px;text-wrap:balance;}
.hp-hero__lead{font-size:clamp(16px,2.2vw,19px);line-height:1.55;color:var(--cream);max-width:46ch;margin:0 0 26px;}
.hp-hero__cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:22px;}
.hp-hero__meta{font-size:13px;color:var(--cream-dim);margin:0;}
.hp-hero__scroll{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);width:26px;height:42px;
  border:2px solid rgba(245,234,215,.4);border-radius:14px;z-index:2;}
.hp-hero__scroll span{position:absolute;left:50%;top:8px;width:4px;height:8px;border-radius:2px;background:var(--honey);transform:translateX(-50%);
  animation:hp-scroll 1.6s ease-in-out infinite;}
@keyframes hp-scroll{0%{opacity:0;transform:translate(-50%,0)}30%{opacity:1}60%{opacity:1;transform:translate(-50%,12px)}100%{opacity:0;transform:translate(-50%,16px)}}

/* плавающие фонарики (bokeh) */
.hp-hero__lanterns{position:absolute;inset:0;z-index:1;pointer-events:none;}
.hp-hero__lanterns span{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(246,198,103,.9),rgba(232,163,61,.12) 60%,transparent 70%);
  filter:blur(1px);opacity:.0;animation:hp-float linear infinite;}
.hp-hero__lanterns span:nth-child(1){left:8%;bottom:-40px;width:14px;height:14px;animation-duration:15s;animation-delay:0s;}
.hp-hero__lanterns span:nth-child(2){left:24%;bottom:-60px;width:9px;height:9px;animation-duration:19s;animation-delay:3s;}
.hp-hero__lanterns span:nth-child(3){left:52%;bottom:-50px;width:18px;height:18px;animation-duration:22s;animation-delay:6s;}
.hp-hero__lanterns span:nth-child(4){left:70%;bottom:-40px;width:11px;height:11px;animation-duration:17s;animation-delay:2s;}
.hp-hero__lanterns span:nth-child(5){left:84%;bottom:-70px;width:16px;height:16px;animation-duration:24s;animation-delay:8s;}
.hp-hero__lanterns span:nth-child(6){left:40%;bottom:-30px;width:7px;height:7px;animation-duration:13s;animation-delay:5s;}
@keyframes hp-float{0%{opacity:0;transform:translateY(0) scale(.7)}12%{opacity:.85}88%{opacity:.7}100%{opacity:0;transform:translateY(-90vh) scale(1.1)}}

@media(min-width:860px){
  .hp-hero__inner{grid-template-columns:1.05fr .95fr;gap:48px;}
  .hp-hero__media{order:2;justify-self:end;}
  .hp-hero__text{order:1;}
}

/* =================== 2. КТО ТАКИЕ =================== */
.hp-family-tree{margin-top:36px;display:grid;gap:14px;grid-template-columns:1fr;}
.hp-family-tree__gen{background:rgba(255,255,255,.55);border:1px solid rgba(140,106,63,.25);border-radius:var(--radius);
  padding:16px 20px;backdrop-filter:saturate(1.1);}
.hp-family-tree__role{display:block;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--amber-deep);font-weight:600;margin-bottom:4px;}
.hp-family-tree__gen p{margin:0;font-family:var(--font-display);font-size:22px;font-weight:600;color:var(--ink);}
@media(min-width:760px){.hp-family-tree{grid-template-columns:repeat(3,1fr);}}

/* =================== 3. КАРТА + ТАБЛИЦА =================== */
.hp-map{position:relative;margin:8px 0 36px;border-radius:var(--radius-lg);overflow:hidden;
  background:
    radial-gradient(80% 60% at 30% 20%,rgba(127,168,144,.12),transparent),
    linear-gradient(160deg,#efe2c6,#e3d2ac);
  border:1px solid rgba(140,106,63,.4);box-shadow:var(--shadow);padding:18px;}
.hp-map__svg{display:block;width:100%;height:auto;}
.hp-map__route{stroke:var(--amber-deep);stroke-width:3;stroke-dasharray:2 12;stroke-linecap:round;opacity:.75;}
.hp-map__point{cursor:pointer;}
.hp-map__dot{fill:var(--amber-deep);stroke:#fff;stroke-width:2.5;transition:fill .2s ease;}
.hp-map__point:hover .hp-map__dot,.hp-map__point:focus .hp-map__dot{fill:var(--konig-green);}
.hp-map__num{fill:#fff;font:700 12px var(--font-sans);pointer-events:none;}
.hp-map__label{fill:var(--ink);font:600 15px var(--font-display);pointer-events:none;paint-order:stroke;stroke:rgba(239,226,198,.9);stroke-width:3px;}
.hp-map__pulse{fill:var(--honey);opacity:.5;transform-origin:center;transform-box:fill-box;animation:hp-pulse 2.6s ease-out infinite;}
.hp-map__point:nth-child(3) .hp-map__pulse{animation-delay:.4s}
.hp-map__point:nth-child(4) .hp-map__pulse{animation-delay:.8s}
.hp-map__point:nth-child(5) .hp-map__pulse{animation-delay:1.2s}
.hp-map__point:nth-child(6) .hp-map__pulse{animation-delay:1.6s}
.hp-map__point:nth-child(7) .hp-map__pulse{animation-delay:2s}
@keyframes hp-pulse{0%{transform:scale(.5);opacity:.6}80%,100%{transform:scale(1.7);opacity:0}}
.hp-map__hint{margin:12px 4px 2px;font-size:13.5px;color:var(--ink-soft);}
/* Иллюстрированная карта-картинка вместо SVG-схемы: своя рамка у картинки, без двойного багета */
.hp-map--photo{padding:0;background:none;border:none;box-shadow:none;overflow:visible;margin:8px auto 30px;max-width:1080px;}
.hp-map__img{display:block;width:100%;height:auto;border-radius:16px;box-shadow:var(--shadow);}
.hp-map--photo .hp-map__hint{color:var(--cream-dim);text-align:center;}

.hp-table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid rgba(245,234,215,.14);}
.hp-table{width:100%;border-collapse:collapse;min-width:560px;font-size:15px;background:rgba(28,22,17,.4);}
.hp-table th,.hp-table td{padding:13px 16px;text-align:left;border-bottom:1px solid rgba(245,234,215,.1);}
.hp-table th{background:rgba(33,55,44,.55);color:var(--honey-bright);font-weight:600;font-size:13px;letter-spacing:.04em;text-transform:uppercase;}
.hp-table td{color:var(--cream);}
.hp-table tr:last-child td{border-bottom:none;}
.hp-table a{color:var(--honey-bright);text-decoration:none;border-bottom:1px dotted rgba(246,198,103,.5);}
.hp-table a:hover{color:#fff;}

/* =================== 4. ЛЕНТА-ПРОГУЛКА =================== */
.hp-faces{display:flex;gap:14px;overflow-x:auto;padding:8px 2px 18px;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;}
.hp-faces__chip{flex:0 0 auto;width:88px;text-align:center;text-decoration:none;scroll-snap-align:start;}
.hp-faces__chip img{width:72px;height:72px;border-radius:50%;object-fit:cover;margin:0 auto 6px;
  border:2px solid var(--bronze);box-shadow:0 6px 16px rgba(0,0,0,.35);transition:transform .2s ease,border-color .2s ease;}
.hp-faces__chip:hover img{transform:translateY(-3px) scale(1.05);border-color:var(--honey);}
.hp-faces__chip span{display:block;font-size:12.5px;color:var(--cream-dim);line-height:1.2;}

.hp-walk{max-width:var(--maxw);margin:30px auto 0;padding:0 20px;display:flex;flex-direction:column;gap:clamp(56px,9vw,110px);}
.hp-stop{display:grid;grid-template-columns:1fr;gap:24px;align-items:center;scroll-margin-top:80px;}
.hp-stop__role{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--patina-light);font-weight:600;margin:0 0 4px;}
.hp-stop__name{font-family:var(--font-display);font-weight:700;font-size:clamp(26px,5vw,40px);color:var(--white-soft);margin:0 0 10px;line-height:1.05;}
.hp-stop__lead{font-size:18px;color:var(--honey-bright);font-weight:500;margin:0 0 12px;line-height:1.4;}
.hp-stop__story{font-size:16px;line-height:1.65;color:var(--cream);margin:0 0 14px;}
.hp-stop__fact{font-size:14.5px;line-height:1.55;color:var(--cream-dim);background:rgba(94,122,107,.16);
  border-left:3px solid var(--patina-light);border-radius:0 12px 12px 0;padding:10px 14px;margin:0 0 16px;}
.hp-stop__fact span{color:var(--honey-bright);font-weight:600;}
.hp-stop__meta{display:grid;grid-template-columns:1fr 1fr;gap:10px 18px;margin:0 0 18px;}
.hp-stop__meta div{min-width:0;}
.hp-stop__meta dt{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--bronze-light);margin:0 0 2px;}
.hp-stop__meta dd{margin:0;font-size:14px;color:var(--cream);}
.hp-stop__actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center;}

/* медальон-ниша (вертикальное видео в арочной рамке) */
.hp-medallion{justify-self:center;width:min(280px,78vw);}
.hp-medallion__frame{position:relative;aspect-ratio:608/1080;border-radius:140px 140px 22px 22px;overflow:hidden;
  background:linear-gradient(160deg,#4A3826,#2A2018);
  border:3px solid var(--bronze);box-shadow:0 16px 44px rgba(0,0,0,.5),inset 0 0 0 2px rgba(184,147,102,.25);
  transition:box-shadow .5s ease,border-color .5s ease,transform .5s ease;}
.hp-medallion__video{width:100%;height:100%;object-fit:cover;display:block;}
.hp-medallion__num{position:absolute;top:12px;left:12px;z-index:3;width:30px;height:30px;border-radius:50%;
  background:var(--amber-deep);color:#fff;font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;
  box-shadow:0 4px 10px rgba(0,0,0,.4);}
.hp-medallion__play{position:absolute;inset:0;z-index:2;border:0;background:rgba(28,22,17,.25);cursor:pointer;
  display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .25s ease;}
.hp-medallion__play::after{content:"";width:0;height:0;border-style:solid;border-width:13px 0 13px 22px;border-color:transparent transparent transparent #fff;
  margin-left:5px;filter:drop-shadow(0 2px 6px rgba(0,0,0,.5));}
.hp-medallion__play.is-shown{opacity:1;}
/* «оживает» когда доскроллил */
.hp-stop.is-active .hp-medallion__frame{border-color:var(--honey);box-shadow:0 18px 50px rgba(0,0,0,.5),0 0 36px rgba(246,198,103,.4),inset 0 0 0 2px rgba(246,198,103,.4);transform:translateY(-4px);}

@media(min-width:840px){
  .hp-stop{grid-template-columns:300px 1fr;gap:48px;}
  .hp-stop--right{grid-template-columns:1fr 300px;}
  .hp-stop--right .hp-medallion{order:2;}
  .hp-stop--right .hp-stop__body{order:1;}
}

/* =================== 5. МАРШРУТ =================== */
.hp-route{counter-reset:hp-step;list-style:none;margin:1.5em 0;padding:0;}
.hp-route li{position:relative;padding:0 0 1.1em 52px;font-size:16px;line-height:1.55;color:var(--ink-soft);}
.hp-route li::before{counter-increment:hp-step;content:counter(hp-step);position:absolute;left:0;top:-2px;
  width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--honey),var(--amber-deep));
  color:#2A1C0C;font-weight:700;display:flex;align-items:center;justify-content:center;font-size:15px;}
.hp-route li:not(:last-child)::after{content:"";position:absolute;left:16px;top:34px;bottom:0;width:2px;background:rgba(196,118,42,.3);}
.hp-route strong{color:var(--ink);}

/* =================== 6. ЧЕКЛИСТ =================== */
.hp-checklist{background:rgba(28,22,17,.45);border:1px solid rgba(245,234,215,.14);border-radius:var(--radius-lg);padding:clamp(20px,4vw,34px);}
.hp-checklist__bar{height:12px;border-radius:999px;background:rgba(245,234,215,.14);overflow:hidden;margin-bottom:10px;}
.hp-checklist__fill{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--patina-light),var(--honey));transition:width .5s cubic-bezier(.22,1,.36,1);}
.hp-checklist__count{font-size:14px;color:var(--cream-dim);margin:0 0 18px;}
.hp-checklist__count span{color:var(--honey-bright);font-weight:700;font-size:18px;}
.hp-checklist__list{list-style:none;margin:0 0 18px;padding:0;display:grid;grid-template-columns:1fr;gap:8px;}
@media(min-width:620px){.hp-checklist__list{grid-template-columns:1fr 1fr;}}
.hp-check{display:flex;align-items:center;gap:12px;cursor:pointer;padding:10px 12px;border-radius:12px;transition:background .2s ease;}
.hp-check:hover{background:rgba(245,234,215,.06);}
.hp-check input{position:absolute;opacity:0;width:0;height:0;}
.hp-check__box{flex:0 0 auto;width:24px;height:24px;border-radius:7px;border:2px solid var(--bronze-light);position:relative;transition:all .2s ease;}
.hp-check input:checked + .hp-check__box{background:var(--honey);border-color:var(--honey);}
.hp-check input:checked + .hp-check__box::after{content:"";position:absolute;left:7px;top:3px;width:6px;height:11px;border:solid #2A1C0C;border-width:0 2.5px 2.5px 0;transform:rotate(45deg);}
.hp-check input:focus-visible + .hp-check__box{outline:2px solid var(--honey-bright);outline-offset:2px;}
.hp-check__name{font-size:15.5px;color:var(--cream);}
.hp-check input:checked ~ .hp-check__name{color:var(--cream-dim);text-decoration:line-through;}
.hp-checklist.is-complete{box-shadow:0 0 0 1px var(--honey),0 0 40px rgba(246,198,103,.25);}

/* =================== 7. ФАКТЫ =================== */
.hp-facts{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr;gap:14px;}
@media(min-width:760px){.hp-facts{grid-template-columns:1fr 1fr;}}
.hp-facts li{background:#fff;border:1px solid rgba(140,106,63,.2);border-radius:var(--radius);padding:18px 20px;font-size:15.5px;line-height:1.55;color:var(--ink-soft);box-shadow:0 6px 18px rgba(140,106,63,.08);}
.hp-facts strong{color:var(--amber-deep);}

/* =================== 8. FAQ =================== */
.hp-faq{display:grid;gap:10px;}
.hp-faq__item{background:#fff;border:1px solid rgba(140,106,63,.22);border-radius:14px;overflow:hidden;}
.hp-faq__q{cursor:pointer;list-style:none;padding:16px 48px 16px 20px;font-family:var(--font-display);font-weight:600;font-size:19px;color:var(--ink);position:relative;}
.hp-faq__q::-webkit-details-marker{display:none;}
.hp-faq__q::after{content:"+";position:absolute;right:18px;top:50%;transform:translateY(-50%);font-size:24px;color:var(--amber-deep);transition:transform .2s ease;font-family:var(--font-sans);}
.hp-faq__item[open] .hp-faq__q::after{transform:translateY(-50%) rotate(45deg);}
.hp-faq__a{padding:0 20px 18px;font-size:15.5px;line-height:1.6;color:var(--ink-soft);}
.hp-faq__a p{margin:0;}

/* =================== 9. CTA =================== */
.hp-cta{padding:8px 0;}
.hp-cta__btns{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin:24px 0 18px;}
.hp-cta__app{font-size:14px;color:var(--cream-dim);max-width:50ch;margin:0 auto;}

/* =================== Прогрессивное появление (только с JS) =================== */
.hp-js .hp-reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s cubic-bezier(.22,1,.36,1);}
.hp-js .hp-reveal.is-visible{opacity:1;transform:none;}

/* =================== Reduced motion =================== */
@media(prefers-reduced-motion:reduce){
  .hp-hero__lanterns,.hp-hero__scroll{display:none;}
  .hp-map__pulse{animation:none;opacity:.35;}
  .hp-js .hp-reveal{opacity:1;transform:none;transition:none;}
  .homliny-page *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important;}
}

/* =================== Focus-доступность =================== */
.homliny-page a:focus-visible,.homliny-page button:focus-visible,.hp-map__point:focus-visible{outline:2px solid var(--honey-bright);outline-offset:3px;border-radius:4px;}

/* --- Блок «Сказки о хомлинах» (низ страницы) ----------------------------- */
.hp-section--tales{background:linear-gradient(180deg,#f9f1df 0%,#f1e2c6 100%);color:var(--ink);}
.hp-section--tales .hp-h2{color:var(--ink);}
.hp-tales{display:grid;grid-template-columns:300px 1fr;gap:46px;align-items:center;}
.hp-tales__media{justify-self:center;}
.hp-tales__media img{display:block;width:100%;max-width:300px;height:auto;border-radius:18px;
  box-shadow:0 20px 48px rgba(74,46,16,.4);border:1px solid rgba(184,147,102,.5);}
.hp-tales__body h2{margin-top:0;}
.hp-tales__body p{margin:0 0 16px;font-size:1.04rem;line-height:1.7;}
.hp-tales__body .hp-btn{margin-top:8px;}
@media (max-width:760px){
  .hp-tales{grid-template-columns:1fr;gap:26px;text-align:center;justify-items:center;}
  .hp-tales__media img{max-width:240px;}
}
