/* ===== Journal page styles ===== */

/* 1) Journal Hero */
.j-hero { position: relative; padding-block: clamp(64px, 10vw, 120px); overflow: clip; }
.jh-inner { display: grid; gap: clamp(14px, 3vw, 24px); }
.jh-marquee {
  position: relative; background:#fff; border-radius:18px; border:1px solid rgba(0,0,0,.06);
  box-shadow:0 12px 28px rgba(0,0,0,.08); overflow:hidden; padding:10px 0;
}
.jh-line { display:inline-block; white-space:nowrap; padding:6px 0;
  animation: jh-roll 24s linear infinite;
}
.jh-line.clone { animation-delay: -12s; }
@keyframes jh-roll { from { transform: translateX(0); } to { transform: translateX(-50%); } }

.jh-gallery { display:grid; grid-template-columns: repeat(2, 1fr); gap:12px; }
.jh-fig { margin:0; background:#fff; border-radius:16px; padding:10px; box-shadow:0 12px 28px rgba(0,0,0,.08); }
.jh-fig img{ border-radius:10px; }
.jh-fig figcaption{ font-size:.9rem; color:#355d48; margin-top:6px; }

@media (max-width: 820px){
  .jh-gallery{ grid-template-columns: 1fr; }
}

/* 2) Field Diary */
.field-diary { padding-block: clamp(56px, 8vw, 96px); }
.fd-head .eyebrow { letter-spacing:.14em; text-transform:uppercase; color:#2d6a4f; font-weight:800; margin:0 0 8px; }

.fd-rail {
  position:relative;
  display:grid; gap:12px;
  padding-left: 24px;
}
.fd-rail::before{
  content:""; position:absolute; left:12px; top:0; bottom:0; width:3px; border-radius:3px;
  background: linear-gradient(180deg, rgba(45,106,79,.25), rgba(45,106,79,.45));
}
.fd-card{
  position:relative; background:#fff; border-radius:16px; border:1px solid rgba(0,0,0,.06);
  padding:14px 14px 14px 16px; box-shadow:0 12px 28px rgba(0,0,0,.08);
}
.fd-date{
  position:absolute; left:-88px; top:12px;
  background:#2d6a4f; color:#fff; font-weight:800; padding:6px 10px; border-radius:10px;
  box-shadow:0 4px 10px rgba(0,0,0,.18);
}
@media (max-width: 680px){
  .fd-date{ position:static; display:inline-block; margin-bottom:6px; }
  .fd-rail{ padding-left: 0; }
  .fd-rail::before{ display:none; }
}

.fd-photos{ display:grid; grid-template-columns: repeat(2, 1fr); gap:12px; margin-top:12px; }
.fd-fig{ margin:0; background:#fff; border-radius:16px; padding:10px; box-shadow:0 12px 28px rgba(0,0,0,.08); }
.fd-fig img{ border-radius:10px; }
.fd-fig figcaption{ font-size:.9rem; color:#355d48; margin-top:6px; }

@media (max-width: 820px){
  .fd-photos{ grid-template-columns: 1fr; }
}

/* 3) Monsoon Letters */
.monsoon-letters{ padding-block: clamp(56px, 8vw, 100px); }
.ml-grid{
  display:grid; grid-template-columns: 1.1fr .9fr; gap: clamp(12px, 2.5vw, 24px); align-items:start;
}
.ml-head .eyebrow{ letter-spacing:.14em; text-transform:uppercase; color:#2d6a4f; font-weight:800; margin:0 0 8px; }

.ml-note{
  background:#fff; border:1px solid rgba(0,0,0,.06); border-radius:16px; padding:14px;
  box-shadow:0 12px 28px rgba(0,0,0,.08); margin-bottom:10px;
}
.ml-photos{ display:grid; gap:12px; }
.ml-fig{ margin:0; background:#fff; border-radius:16px; padding:10px; box-shadow:0 12px 28px rgba(0,0,0,.08); }
.ml-fig img{ border-radius:10px; }
.ml-fig figcaption{ font-size:.9rem; color:#355d48; margin-top:6px; }

@media (max-width: 980px){
  .ml-grid{ grid-template-columns: 1fr; }
}
/* --- FIX: Journal Hero marquee --- */
.jh-marquee{
  --gap: 48px;        /* расстояние между копиями текста */
  --speed: 90;        /* px/сек — можно менять, больше = быстрее */
  position: relative;
  overflow: hidden;
  background:#fff;
  border-radius:18px;
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 12px 28px rgba(0,0,0,.08);
  padding: 8px 0;
}

/* исходные <p> прячем — контент возьмём из первого */
.jh-marquee .jh-line{ display:none; }

.jh-track{
  display:flex;
  gap: var(--gap);
  white-space: nowrap;
  will-change: transform;
  animation: jh-scroll linear infinite var(--dur, 18s);
}
.jh-item{ padding: 6px 0; font-weight: 600; }

@keyframes jh-scroll{
  from { transform: translateX(0); }
  to   { transform: translateX(calc(-1 * var(--track-w, 100%))); }
}
/* ===== 4) Pinboard Notes ===== */
.pinboard-notes{ padding-block: clamp(56px, 8vw, 96px); }
.pb-head .eyebrow{ letter-spacing:.14em; text-transform:uppercase; color:#2d6a4f; font-weight:800; margin:0 0 8px; }

.pb-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(12px, 2.5vw, 20px);
  margin-top: 8px;
}
.pb-note{
  background:#fffbe8; border:1px solid rgba(0,0,0,.06);
  border-radius: 12px; padding:14px;
  box-shadow: 0 12px 28px rgba(0,0,0,.08);
  transform: rotate(var(--r, 0deg));
  transition: transform .2s, box-shadow .2s;
}
.pb-note h3{ margin:0 0 6px; font-size:1.05rem; }
.pb-note:hover{ transform: rotate(0deg) translateY(-2px); box-shadow:0 16px 36px rgba(0,0,0,.12); }

/* лёгкая «разбросанность» по колонкам */
.pb-note:nth-child(3n+1){ --r: -1.8deg; }
.pb-note:nth-child(3n+2){ --r: 1.8deg; }
.pb-note:nth-child(3n+3){ --r: -0.8deg; }

.pb-photos{
  display:grid; grid-template-columns: repeat(2, 1fr);
  gap: 12px; margin-top: 12px;
}
.pb-fig{ margin:0; background:#fff; border-radius:16px; padding:10px; box-shadow:0 12px 28px rgba(0,0,0,.08); }
.pb-fig img{ border-radius:10px; }
.pb-fig figcaption{ font-size:.9rem; color:#355d48; margin-top:6px; }

@media (max-width: 900px){
  .pb-grid{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 620px){
  .pb-grid{ grid-template-columns: 1fr; }
  .pb-photos{ grid-template-columns: 1fr; }
}

/* ===== 5) Weather Windows ===== */
.weather-windows{ padding-block: clamp(56px, 8vw, 96px); }
.ww-head .eyebrow{ letter-spacing:.14em; text-transform:uppercase; color:#2d6a4f; font-weight:800; margin:0 0 8px; }

.ww-grid{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap: clamp(12px, 2.5vw, 20px);
}
.ww-card{
  background:#fff; border-radius:16px; border:1px solid rgba(0,0,0,.06);
  padding:14px; box-shadow:0 12px 28px rgba(0,0,0,.08);
  transition: transform .2s, box-shadow .2s;
}
.ww-card:hover{ transform: translateY(-2px); box-shadow:0 16px 36px rgba(0,0,0,.12); }

.ww-badges{ display:flex; flex-wrap:wrap; gap:8px; padding:0; margin:6px 0 8px; list-style:none; }
.ww-badges li{
  background:#f3faf6; border:1px solid rgba(0,0,0,.06); border-radius:999px; padding:6px 10px; font-weight:700;
  box-shadow:0 6px 16px rgba(0,0,0,.06);
}

.ww-photos{
  display:grid; grid-template-columns: repeat(2, 1fr);
  gap: 12px; margin-top: 12px;
}
.ww-fig{ margin:0; background:#fff; border-radius:16px; padding:10px; box-shadow:0 12px 28px rgba(0,0,0,.08); }
.ww-fig img{ border-radius:10px; }
.ww-fig figcaption{ font-size:.9rem; color:#355d48; margin-top:6px; }

@media (max-width: 980px){
  .ww-grid{ grid-template-columns: 1fr; }
  .ww-photos{ grid-template-columns: 1fr; }
}

/* ===== 6) Story Path ===== */
.story-path{ padding-block: clamp(56px, 8vw, 100px); position: relative; }
.sp2-head .eyebrow{ letter-spacing:.14em; text-transform:uppercase; color:#2d6a4f; font-weight:800; margin:0 0 8px; }

.sp2-canvas{
  position:relative; height: 140px; border-radius: 16px;
  background: linear-gradient(180deg, #e9f4ee, #dcefe4);
  box-shadow:0 12px 28px rgba(0,0,0,.08);
  overflow:hidden; margin-bottom: 12px;
}
.sp2-line{
  position:absolute; left:6%; right:6%; top: 50%; height: 6px; border-radius: 4px;
  background: linear-gradient(90deg, rgba(45,106,79,.22), rgba(45,106,79,.42));
  transform: translateY(-50%) skewY(-4deg);
}
.sp2-dot{
  position:absolute; width:14px; height:14px; border-radius:50%; background:#2d6a4f; box-shadow:0 2px 8px rgba(0,0,0,.18);
  top: calc(50% - 7px);
}
.sp2-dot.d1{ left: 8%; }
.sp2-dot.d2{ left: 32%; }
.sp2-dot.d3{ left: 64%; }
.sp2-dot.d4{ left: 88%; }

/* шаги зигзагом */
.sp2-steps{
  display:grid; grid-template-columns: repeat(2, 1fr); gap: 12px;
}
.sp2-step{
  background:#fff; border:1px solid rgba(0,0,0,.06); border-radius:16px; padding:14px;
  box-shadow:0 12px 28px rgba(0,0,0,.08);
  position:relative;
}
.sp2-step:nth-child(odd){ transform: translateY(0); }
.sp2-step:nth-child(even){ transform: translateY(12px); }
.sp2-step h3{ margin:0 0 6px; font-size:1.05rem; }

.sp2-photos{
  display:grid; grid-template-columns: repeat(2, 1fr); gap:12px; margin-top: 12px;
}
.sp2-fig{ margin:0; background:#fff; border-radius:16px; padding:10px; box-shadow:0 12px 28px rgba(0,0,0,.08); }
.sp2-fig img{ border-radius:10px; }
.sp2-fig figcaption{ font-size:.9rem; color:#355d48; margin-top:6px; }

@media (max-width: 820px){
  .sp2-steps{ grid-template-columns: 1fr; }
  .sp2-step:nth-child(even){ transform: none; }
  .sp2-photos{ grid-template-columns: 1fr; }
}
/* --- FIX: ровные номера в Story Path --- */
.sp2-steps{
  counter-reset: sp2;             /* общий счётчик 1..4 */
  list-style: none;               /* убираем нативные маркеры */
  padding: 0;
}

.sp2-step{
  position: relative;
  padding-left: 56px;             /* одинаковый отступ под номер */
}

/* единый стиль номера-бейджа */
.sp2-step::before{
  counter-increment: sp2;
  content: counter(sp2) ".";
  position: absolute;
  left: 16px;                     /* фиксированная колонка для цифры */
  top: 14px;
  width: 28px;                    /* одинаковая ширина под 1..9 */
  text-align: right;              /* выравнивание по правому краю */
  font-weight: 800;
  color: #1a1a1a;
}

/* на узких — всё остаётся ровным в одной колонке */
@media (max-width: 820px){
  .sp2-step{ padding-left: 56px; }
}
/* ===== 7) Herd Sketches ===== */
.herd-sketches{ padding-block: clamp(56px, 8vw, 96px); }
.hs-head .eyebrow{ letter-spacing:.14em; text-transform:uppercase; color:#2d6a4f; font-weight:800; margin:0 0 8px; }

.hs-triptych{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap: clamp(12px, 2.5vw, 20px);
}
.hs-polaroid{
  margin:0; background:#fff; border-radius:14px;
  padding:10px; box-shadow:0 16px 36px rgba(0,0,0,.10);
  transform: rotate(var(--r, 0deg));
  transition: transform .25s ease, box-shadow .25s ease;
}
.hs-polaroid:hover{ transform: rotate(0deg) translateY(-2px); box-shadow:0 20px 44px rgba(0,0,0,.14); }
.hs-polaroid img{ border-radius:10px; }
.hs-polaroid figcaption{ font-size:.9rem; color:#355d48; margin-top:6px; text-align:center; }
.hs-polaroid.a{ --r: -1.6deg; }
.hs-polaroid.b{ --r: 1.4deg; }
.hs-polaroid.c{ --r: -.8deg; }

@media (max-width: 880px){
  .hs-triptych{ grid-template-columns: 1fr; }
  .hs-polaroid{ transform:none; }
}

/* ===== 8) Tool Bench Checklist ===== */
.tool-bench{ padding-block: clamp(56px, 8vw, 96px); }
.tb-head .eyebrow{ letter-spacing:.14em; text-transform:uppercase; color:#2d6a4f; font-weight:800; margin:0 0 8px; }

.tb-wrap{ display:grid; grid-template-columns: 1.1fr .9fr; gap: clamp(12px, 2.5vw, 24px); align-items:start; }
.tb-list{ display:grid; gap:10px; }
.tb-item{
  background:#fff; border:1px solid rgba(0,0,0,.06); border-radius:14px; padding:12px 14px;
  box-shadow:0 12px 28px rgba(0,0,0,.08);
}
.tb-item > summary{ cursor:pointer; font-weight:800; list-style:none; }
.tb-item > summary::-webkit-details-marker{ display:none; }
.tb-item[open]{ border-color: rgba(45,106,79,.3); }

.tb-side{ display:grid; gap:12px; }
.tb-fig{ margin:0; background:#fff; border-radius:14px; padding:10px; box-shadow:0 12px 28px rgba(0,0,0,.08); }
.tb-fig img{ border-radius:10px; }
.tb-fig figcaption{ font-size:.9rem; color:#355d48; margin-top:6px; }

@media (max-width: 980px){
  .tb-wrap{ grid-template-columns: 1fr; }
}

/* ===== 9) Milk Tests ===== */
.milk-tests{ padding-block: clamp(56px, 8vw, 96px); }
.mt-head .eyebrow{ letter-spacing:.14em; text-transform:uppercase; color:#2d6a4f; font-weight:800; margin:0 0 8px; }

.mt-grid{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap: clamp(12px, 2.5vw, 20px);
}
.mt-card{
  background:#fff; border:1px solid rgba(0,0,0,.06); border-radius:16px; padding:14px;
  box-shadow:0 12px 28px rgba(0,0,0,.08);
  transition: transform .2s, box-shadow .2s;
}
.mt-card:hover{ transform: translateY(-2px); box-shadow:0 16px 36px rgba(0,0,0,.12); }

.mt-photos{
  display:grid; grid-template-columns: repeat(3, 1fr);
  gap: 12px; margin-top: 12px;
}
.mt-fig{ margin:0; background:#fff; border-radius:16px; padding:10px; box-shadow:0 12px 28px rgba(0,0,0,.08); }
.mt-fig img{ border-radius:10px; }
.mt-fig figcaption{ font-size:.9rem; color:#355d48; margin-top:6px; }

@media (max-width: 980px){
  .mt-grid{ grid-template-columns: 1fr; }
  .mt-photos{ grid-template-columns: 1fr; }
}
/* ===== 10) Route Log ===== */
.route-log{ padding-block: clamp(56px, 8vw, 96px); }
.rl-head .eyebrow{ letter-spacing:.14em; text-transform:uppercase; color:#2d6a4f; font-weight:800; margin:0 0 8px; }

.rl-map{
  position:relative; border-radius:18px; overflow:hidden;
  background: linear-gradient(180deg, #e9f4ee, #dcefe4);
  box-shadow:0 12px 28px rgba(0,0,0,.08);
  padding: 18px;
}
.rl-fold{ position:absolute; inset:auto 0 0 0; height: 48px; background:
  linear-gradient(90deg, rgba(255,255,255,.18) 0 4%, transparent 4% 8%, rgba(255,255,255,.18) 8% 12%, transparent 12% 16%, rgba(255,255,255,.18) 16% 20%, transparent 20% 24%, rgba(255,255,255,.18) 24% 28%, transparent 28% 100%);
  opacity:.35; filter: blur(.6px);
}
.rl-fold.b{ top: 0; bottom: auto; }

.rl-stops{
  counter-reset: rl; list-style:none; margin:0; padding:0;
  display:grid; grid-template-columns: repeat(2,1fr); gap:12px;
}
.rl-stop{
  background:#fff; border:1px solid rgba(0,0,0,.06); border-radius:16px; padding:14px 14px 14px 54px;
  box-shadow:0 12px 28px rgba(0,0,0,.08); position:relative;
}
.rl-stop::before{
  counter-increment: rl; content: counter(rl);
  position:absolute; left:12px; top:12px; width:28px; height:28px; border-radius:10px;
  display:grid; place-items:center; background:#2d6a4f; color:#fff; font-weight:800;
  box-shadow:0 4px 10px rgba(0,0,0,.15);
}
@media (max-width: 900px){ .rl-stops{ grid-template-columns: 1fr; } }

.rl-photos{
  display:grid; grid-template-columns: repeat(2,1fr);
  gap:12px; margin-top:12px;
}
.rl-fig{ margin:0; background:#fff; border-radius:16px; padding:10px; box-shadow:0 12px 28px rgba(0,0,0,.08); }
.rl-fig img{ border-radius:10px; }
.rl-fig figcaption{ font-size:.9rem; color:#355d48; margin-top:6px; }
@media (max-width: 820px){ .rl-photos{ grid-template-columns: 1fr; } }

/* ===== 11) Neighbour Letters ===== */
.neighbour-letters{ padding-block: clamp(56px, 8vw, 96px); }
.nl-head .eyebrow{ letter-spacing:.14em; text-transform:uppercase; color:#2d6a4f; font-weight:800; margin:0 0 8px; }

.nl-wall{
  display:grid; grid-template-columns: repeat(4, 1fr);
  gap: clamp(10px, 2vw, 16px); list-style:none; margin:0; padding:0;
}
.nl-note{
  background:#fffdf5; border:1px solid rgba(0,0,0,.06);
  border-radius:14px; padding:12px; box-shadow:0 10px 24px rgba(0,0,0,.08);
  transform: rotate(var(--r, 0deg));
}
.nl-note:nth-child(4n+1){ --r: 1.2deg; }
.nl-note:nth-child(4n+2){ --r: -1.4deg; }
.nl-note:nth-child(4n+3){ --r: .8deg; }
.nl-note:nth-child(4n+4){ --r: -1.0deg; }
.nl-note blockquote{ margin:0 0 6px; font-weight:700; }
.nl-note cite{ font-style: normal; color:#355d48; font-weight:600; }

.nl-photos{
  display:grid; grid-template-columns: repeat(2, 1fr);
  gap:12px; margin-top:12px;
}
.nl-fig{ margin:0; background:#fff; border-radius:16px; padding:10px; box-shadow:0 12px 28px rgba(0,0,0,.08); }
.nl-fig img{ border-radius:10px; }
.nl-fig figcaption{ font-size:.9rem; color:#355d48; margin-top:6px; }

@media (max-width: 1000px){
  .nl-wall{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 620px){
  .nl-wall{ grid-template-columns: 1fr; }
  .nl-photos{ grid-template-columns: 1fr; }
}

/* ===== 12) Night Checks ===== */
.night-checks{ padding-block: clamp(56px, 8vw, 96px); position:relative; }
.nc-head .eyebrow{ letter-spacing:.14em; text-transform:uppercase; color:#2d6a4f; font-weight:800; margin:0 0 8px; }

.nc-sky{
  position:relative; height: 140px; border-radius:16px; overflow:hidden;
  background: radial-gradient(80% 120% at 50% 110%, #0e1c17, #132a22);
  box-shadow:0 12px 28px rgba(0,0,0,.12);
  margin-bottom: 12px;
}
.star{
  position:absolute; width:3px; height:3px; border-radius:50%;
  background:#d7fff0; opacity:.9;
  animation: twinkle 2.6s ease-in-out infinite;
}
@keyframes twinkle{
  0%,100%{ transform: scale(1); opacity:.7; }
  50%{ transform: scale(1.6); opacity:1; }
}
.s1{ left:18%; top:22%; animation-delay: .1s; }
.s2{ left:32%; top:54%; animation-delay: .6s; }
.s3{ left:64%; top:34%; animation-delay: 1.0s; }
.s4{ left:72%; top:18%; animation-delay: 1.4s; }
.s5{ left:44%; top:12%; animation-delay: 1.8s; }
.s6{ left:10%; top:68%; animation-delay: 2.1s; }

.nc-grid{
  display:grid; grid-template-columns: repeat(3,1fr); gap:12px;
}
.nc-card{
  background:#fff; border:1px solid rgba(0,0,0,.06); border-radius:16px; padding:14px;
  box-shadow:0 12px 28px rgba(0,0,0,.08);
}
@media (max-width: 980px){ .nc-grid{ grid-template-columns: 1fr; } }

.nc-photos{
  display:grid; grid-template-columns: repeat(3,1fr);
  gap:12px; margin-top:12px;
}
.nc-fig{ margin:0; background:#fff; border-radius:16px; padding:10px; box-shadow:0 12px 28px rgba(0,0,0,.08); }
.nc-fig img{ border-radius:10px; }
.nc-fig figcaption{ font-size:.9rem; color:#355d48; margin-top:6px; }

@media (max-width: 980px){ .nc-photos{ grid-template-columns: 1fr; } }
/* ===== 13) Hay Days ===== */
.hay-days{ padding-block: clamp(56px, 8vw, 96px); }
.hd-head .eyebrow{ letter-spacing:.14em; text-transform:uppercase; color:#2d6a4f; font-weight:800; margin:0 0 8px; }

.hd-rail{
  display:grid; grid-auto-flow: column;
  grid-auto-columns: min(86vw, 680px);
  gap: clamp(12px, 2.5vw, 20px);
  overflow-x: auto; scroll-snap-type: x mandatory; padding: 6px;
}
.hd-card, .hd-fig{ scroll-snap-align: start; }
.hd-card{
  background:#fff; border:1px solid rgba(0,0,0,.06); border-radius:16px; padding:14px;
  box-shadow:0 12px 28px rgba(0,0,0,.08);
}
.hd-fig{ margin:0; background:#fff; border-radius:16px; padding:10px; box-shadow:0 12px 28px rgba(0,0,0,.08); }
.hd-fig img{ border-radius:10px; }
.hd-fig figcaption{ font-size:.9rem; color:#355d48; margin-top:6px; }

.hd-controls{ display:flex; gap:10px; justify-content:flex-end; margin-top:10px; }
.hd-btn{
  width:40px; height:36px; border:1px solid rgba(0,0,0,.12); background:#fff; border-radius:10px;
  font-size:20px; line-height:1; cursor:pointer; transition:transform .2s, box-shadow .2s;
}
.hd-btn:hover{ transform:translateY(-2px); box-shadow:0 8px 18px rgba(0,0,0,.10); }

/* ===== 14) Kitchen Trials ===== */
.kitchen-trials{ padding-block: clamp(56px, 8vw, 96px); }
.kt-head .eyebrow{ letter-spacing:.14em; text-transform:uppercase; color:#2d6a4f; font-weight:800; margin:0 0 8px; }

.kt-tabs{ position:relative; }
.kt-dot{ position:absolute; opacity:0; pointer-events:none; }

.kt-panels{
  position:relative; overflow:hidden; border-radius:18px; background:#fff; box-shadow:0 12px 28px rgba(0,0,0,.08);
}
.kt-panel{
  display:grid; grid-template-columns: 1fr auto; gap:12px; align-items:start;
  padding:14px; min-height: 180px;
}
.kt-fig{ margin:0; background:#fff; border-radius:12px; padding:10px; box-shadow:0 10px 24px rgba(0,0,0,.08); }
.kt-fig img{ border-radius:8px; }
.kt-fig figcaption{ font-size:.9rem; color:#355d48; margin-top:6px; }

#kt1:checked ~ .kt-panels{ transform: translateX(0%);   transition: transform .45s ease; }
#kt2:checked ~ .kt-panels{ transform: translateX(-100%); transition: transform .45s ease; }
#kt3:checked ~ .kt-panels{ transform: translateX(-200%); transition: transform .45s ease; }
/* чтобы сработали сдвиги — сделаем «ленту» из панелей */
.kt-panels{ display:grid; grid-auto-flow: column; grid-auto-columns: 100%; }

.kt-controls{
  display:flex; gap:10px; justify-content:center; margin-top:10px;
}
.kt-controls label{
  width:34px; height:34px; border-radius:10px; display:grid; place-items:center; cursor:pointer;
  background:#f1f6f3; border:1px solid rgba(0,0,0,.06); transition:transform .2s, box-shadow .2s;
}
.kt-controls label:hover{ transform: translateY(-2px); box-shadow:0 8px 18px rgba(0,0,0,.10); }
#kt1:checked ~ .kt-controls label[for="kt1"],
#kt2:checked ~ .kt-controls label[for="kt2"],
#kt3:checked ~ .kt-controls label[for="kt3"]{ background:#2d6a4f; color:#fff; }

@media (max-width: 780px){
  .kt-panel{ grid-template-columns: 1fr; }
}

/* ===== 15) Green Edges ===== */
.green-edges{ padding-block: clamp(56px, 8vw, 96px); }
.ge-head .eyebrow{ letter-spacing:.14em; text-transform:uppercase; color:#2d6a4f; font-weight:800; margin:0 0 8px; }

.ge-mosaic{
  display:grid; grid-template-columns: repeat(6, 1fr);
  gap:12px; align-items:start;
}
.ge-chip{
  grid-column: span 3;
  background:#fff; border:1px solid rgba(0,0,0,.06); border-radius:16px; padding:14px;
  box-shadow:0 12px 28px rgba(0,0,0,.08);
}
.ge-fig{
  margin:0; grid-column: span 3;
  background:#fff; border-radius:16px; padding:10px; box-shadow:0 12px 28px rgba(0,0,0,.08);
}
.ge-fig img{ border-radius:10px; }
.ge-fig figcaption{ font-size:.9rem; color:#355d48; margin-top:6px; }

/* каскад по рядам */
.ge-chip:nth-of-type(1){ grid-row:1; }
.ge-fig:nth-of-type(1){ grid-row:1; }
.ge-chip:nth-of-type(2){ grid-row:2; }
.ge-fig:nth-of-type(2){ grid-row:2; }
.ge-chip:nth-of-type(3){ grid-row:3; }
.ge-fig:nth-of-type(3){ grid-row:3; }

@media (max-width: 980px){
  .ge-mosaic{ grid-template-columns: repeat(2, 1fr); }
  .ge-chip, .ge-fig{ grid-column: auto; }
}

/* ===== 16) Closing Lines ===== */
.closing-lines{ padding-block: clamp(56px, 8vw, 96px); text-align:center; }
.cl-head .eyebrow{ letter-spacing:.14em; text-transform:uppercase; color:#2d6a4f; font-weight:800; margin:0 0 8px; }

.cl-quote{
  margin: 6px auto 12px; max-width: 60ch; font-weight:800; color:#355d48;
  background:#f3faf6; border:1px solid rgba(0,0,0,.06); border-radius:16px; padding:14px;
}
.cl-photos{
  display:flex; justify-content:center; gap:12px; flex-wrap:wrap;
}
.cl-fig{ margin:0; background:#fff; border-radius:16px; padding:10px; box-shadow:0 12px 28px rgba(0,0,0,.08); }
.cl-fig img{ border-radius:10px; }
.cl-fig figcaption{ font-size:.9rem; color:#355d48; margin-top:6px; }

.cl-actions{ margin-top:12px; }
.cl-actions .backtop{
  display:inline-block; padding:10px 14px; border-radius:12px; border:1px solid rgba(0,0,0,.12);
  background:#2d6a4f; color:#fff; font-weight:800; text-decoration:none;
  box-shadow:0 12px 24px rgba(45,106,79,.22);
  transition: transform .15s, box-shadow .15s, background .15s;
}
.cl-actions .backtop:hover{ transform: translateY(-2px); box-shadow:0 16px 32px rgba(45,106,79,.28); }
/* --- FIX: Kitchen Trials tabs show active panel (fade stack) --- */

/* контейнер-вьюпорт */
.kitchen-trials .kt-panels{
  position: relative;
  overflow: hidden;
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 12px 28px rgba(0,0,0,.08);
  /* сбрасываем предыдущую "ленту" */
  display: block;
  transform: none !important;
}

/* панели кладём друг на друга */
.kitchen-trials .kt-panel{
  position: absolute;
  inset: 0;
  opacity: 0;
  pointer-events: none;
  transition: opacity .35s ease;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px;
  align-items: start;
  padding: 14px;
  min-height: 200px;
}

/* активируем нужную панель */
#kt1:checked ~ .kt-panels .kt-panel:nth-of-type(1),
#kt2:checked ~ .kt-panels .kt-panel:nth-of-type(2),
#kt3:checked ~ .kt-panels .kt-panel:nth-of-type(3){
  opacity: 1;
  pointer-events: auto;
  position: relative;   /* вытесняет высоту */
}

@media (max-width: 780px){
  .kitchen-trials .kt-panel{ grid-template-columns: 1fr; }
}

/* визуальная индикация активной кнопки уже есть ниже — оставляем */
/* ===== Lane Journal (long-form) ===== */
.lane-journal{
  position: relative;
  padding-block: clamp(64px, 10vw, 120px);
  background: radial-gradient(120% 80% at 50% 120%, #e9f4ee 0%, #f8fcfa 70%);
  overflow: clip;
}
.lj-head .eyebrow{ letter-spacing:.14em; text-transform:uppercase; color:#2d6a4f; font-weight:800; margin:0 0 8px; }

.lj-grid{
  display:grid; grid-template-columns: 1.1fr .9fr;
  gap: clamp(14px, 2.8vw, 28px); align-items:start; margin-top:10px;
}
.lj-text{
  background:#fff; border:1px solid rgba(0,0,0,.06); border-radius:16px;
  padding: clamp(14px, 2.4vw, 18px);
  box-shadow:0 12px 28px rgba(0,0,0,.08);
  line-height:1.65;
}
.lj-text p + p{ margin-top:10px; }

.lj-fig{
  margin:0; background:#fff; border-radius:16px; padding:10px;
  box-shadow:0 12px 28px rgba(0,0,0,.08);
  position: sticky; top: calc(var(--hdr-h, 64px) + 14px);
}
.lj-fig img{ display:block; width:100%; height:auto; max-width:350px; border-radius:10px; }
.lj-fig figcaption{ font-size:.9rem; color:#355d48; margin-top:6px; text-align:center; }

.lj-wave{
  position:absolute; left:0; right:0; bottom:-20px; height:70px;
  background: radial-gradient(120% 70px at 50% 0, rgba(45,106,79,.16), transparent 70%);
  filter: blur(.6px);
}

@media (max-width: 980px){
  .lj-grid{ grid-template-columns: 1fr; }
  .lj-fig{ position: relative; top: 0; }
}
