/* Shared page headings */
.jn-h{ font-family: Playfair, serif; font-size: clamp(26px,3.2vw,38px); }
.jn-lead{ color: var(--muted); margin-top: 10px; max-width: 62ch; }

/* ===== SECTION 1: Field Notes (3 photos, kinetic header, horizontal collage) ===== */
.field{ max-width: 1200px; margin: 92px auto 0; padding: 28px 16px; position: relative; }
.ticker{
  margin-top: 12px; border: 1px solid var(--line); border-radius: 14px; overflow: hidden;
  background: #14161b;
}
.ticker .roll{
  display: inline-flex; gap: 28px; padding: 10px 14px; white-space: nowrap;
  animation: tickerMove 26s linear infinite;
}
.ticker .roll span{ color: var(--muted); text-transform: lowercase; letter-spacing: .4px; }
@keyframes tickerMove{ to{ transform: translateX(-50%); } }

.field-strip{
  margin-top: 18px; display: grid; grid-auto-flow: column; gap: 16px;
  overflow-x: auto; overscroll-behavior-x: contain; scroll-snap-type: x mandatory;
}
.f-card{
  scroll-snap-align: start;
  min-width: min(84vw, 360px);
  background: var(--card); border: 1px solid var(--line); border-radius: 18px; padding: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,.26);
  transition: transform .25s cubic-bezier(.2,.8,.2,1), border-color .25s ease;
}
.f-card:hover{ transform: translateY(-6px); border-color: color-mix(in srgb, var(--brand) 30%, var(--line)); }
.f-card figcaption{ margin-top: 8px; color: var(--muted); font-size: 14px; }

.field-orb{
  position: absolute; border-radius: 999px; filter: blur(24px);
  mix-blend-mode: screen; pointer-events: none; opacity: .35; animation: ffloat 24s linear infinite;
}
.field-orb.a{ width: 220px; height: 220px; left: -40px; top: -40px; background: radial-gradient(circle at 50% 50%, #ffdcb5, transparent 60%); }
.field-orb.b{ width: 180px; height: 180px; right: -30px; top: 20px; background: radial-gradient(circle at 50% 50%, #cfe4d8, transparent 60%); animation-duration: 30s; }
@keyframes ffloat{ 50%{ transform: translateY(-6px); } }

/* ===== SECTION 2: Makers’ Voices (2 photos, quote lanes) ===== */
.voices{ max-width: 1100px; margin: 20px auto 0; padding: 0 16px 16px; }
.v-lanes{
  margin-top: 16px; display: grid; gap: 16px;
  grid-template-columns: repeat(2, minmax(0,1fr));
}
.v-lane{
  background: var(--card); border: 1px solid var(--line); border-radius: 18px; padding: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,.26);
}
.v-fig figcaption{ margin-top: 8px; color: var(--muted); font-size: 14px; }
.v-quote{ margin: 10px 0 6px; line-height: 1.6; }
.v-cite{ color: var(--muted); font-style: normal; font-size: 14px; }

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

/* ===== SECTION 3: Ritual Recipes (2 photos, flip steps) ===== */
.rituals{ max-width: 1100px; margin: 20px auto 40px; padding: 0 16px 16px; }
.r-grid{
  margin-top: 16px; display: grid; gap: 16px;
  grid-template-columns: repeat(2, minmax(0,1fr));
  perspective: 1000px;
}
.r-card{
  position: relative; height: 280px;
  transform-style: preserve-3d;
  transition: transform .45s cubic-bezier(.2,.8,.2,1);
}
.r-card:hover{ transform: rotateY(180deg); }

.r-face{
  position: absolute; inset: 0;
  background: var(--card); border: 1px solid var(--line); border-radius: 18px; padding: 14px;
  box-shadow: 0 10px 30px rgba(0,0,0,.26);
  backface-visibility: hidden; display: grid; align-content: center;
}
.r-face.front h3{ margin: 0 0 8px; font-size: 18px; }
.r-face.front .r-steps{ margin: 0; padding-left: 18px; color: var(--muted); line-height: 1.6; }
.r-face.back{ transform: rotateY(180deg); }
.r-face figcaption{ margin-top: 8px; color: var(--muted); font-size: 14px; }

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

/* Responsive helpers */
@media (max-width: 560px){
  .f-card{ min-width: 82vw; }
}
html, body{ overflow-x: hidden; }
/* ===== SECTION 4: Light Diary (3 photos + hour badges) ===== */
.ldiary{ max-width: 1100px; margin: 20px auto 0; padding: 0 16px 16px; }
.ld-grid{
  margin-top: 16px; display: grid; gap: 16px;
  grid-template-columns: repeat(3, minmax(0,1fr));
}
.ld-card{
  position: relative;
  background: var(--card); border: 1px solid var(--line); border-radius: 18px; padding: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,.26);
}
.ld-copy{ color: var(--muted); margin-top: 8px; }
.d-badge{
  position: absolute; left: 12px; top: 12px;
  display: inline-grid; place-items: center;
  width: 54px; height: 30px; border-radius: 10px;
  background: linear-gradient(120deg, var(--brand), var(--brand-2));
  color: #111; font-weight: 700; font-size: 12px;
  box-shadow: var(--shadow);
}
@media (max-width: 980px){ .ld-grid{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px){ .ld-grid{ grid-template-columns: 1fr; } }

/* ===== SECTION 5: Care Ledger (2 photos + accordions) ===== */
.cledger{ max-width: 1100px; margin: 20px auto 0; padding: 0 16px 16px; }
.cl-grid{
  margin-top: 16px; display: grid; gap: 12px;
  grid-template-columns: repeat(2, minmax(0,1fr));
}
.cl-item{
  border: 1px solid var(--line); background: var(--card); border-radius: 16px;
  box-shadow: 0 8px 24px rgba(0,0,0,.22); overflow: hidden;
}
.cl-q{
  width: 100%; text-align: left;
  padding: 14px 44px 14px 14px; color: var(--ink); background: transparent;
  transition: background .2s ease;
}
.cl-q:hover, .cl-q:focus-visible{ background: #1b1e24; }
.cl-q::after{
  content:""; position:absolute; right: 14px; transform: translateY(2px) rotate(0deg);
  width: 14px; height: 14px; border-right: 2px solid var(--ink); border-bottom: 2px solid var(--ink);
  opacity: .8; transition: transform .2s ease, opacity .2s ease;
}
.cl-item{ position: relative; }
.cl-q[aria-expanded="true"]::after{ transform: translateY(2px) rotate(45deg); opacity: 1; }
.cl-a{ padding: 0 14px 14px 14px; color: var(--muted); border-top: 1px solid var(--line); animation: cfade .25s ease; }
@keyframes cfade{ from{ opacity:.6; transform: translateY(-2px);} to{ opacity:1; transform:none;} }
.cl-fig{ margin-top: 8px; }
.cl-fig figcaption{ color: var(--muted); margin-top: 6px; font-size: 14px; }
@media (max-width: 980px){ .cl-grid{ grid-template-columns: 1fr; } }

/* ===== SECTION 6: Palette Walk (3 photos + glow chips) ===== */
.pwalk{ max-width: 1100px; margin: 20px auto 40px; padding: 0 16px 16px; }
.pw-chips{ margin-top: 12px; display: flex; flex-wrap: wrap; gap: 8px; }
.pw-chip{
  height: 40px; padding: 0 14px; border-radius: 12px; border: 1px solid var(--line);
  background: #171a20; color: var(--ink);
  transition: transform .2s ease, background .2s ease, border-color .2s ease;
}
.pw-chip:hover, .pw-chip:focus-visible{ transform: translateY(-1px); background:#1d2026; border-color: color-mix(in srgb, var(--brand) 30%, var(--line)); }
.pw-chip[data-active="true"]{ outline: 2px solid var(--brand); }

.pw-grid{
  margin-top: 16px; display: grid; gap: 16px;
  grid-template-columns: repeat(3, minmax(0,1fr));
}
.pw-card{
  position: relative; overflow: hidden;
  background: var(--card); border: 1px solid var(--line); border-radius: 18px; padding: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,.26);
  transition: transform .25s cubic-bezier(.2,.8,.2,1), border-color .25s ease;
}
.pw-card:hover{ transform: translateY(-6px); border-color: color-mix(in srgb, var(--brand) 30%, var(--line)); }
.pw-card figcaption{ margin-top: 8px; color: var(--muted); font-size: 14px; }

/* glow overlay driven by vars */
:root{
  --pw-a: rgba(155,182,167,.20);
  --pw-b: rgba(27,30,35,.40);
}
.pw-glow{
  position: absolute; inset: -20% -10%;
  background:
    radial-gradient(40% 60% at 30% 50%, var(--pw-a), transparent 60%),
    radial-gradient(60% 40% at 70% 60%, var(--pw-b), transparent 60%);
  mix-blend-mode: screen; filter: blur(18px); opacity: .45; pointer-events: none;
  transition: opacity .35s ease, transform .35s ease, background .35s ease;
}
.pw-card:hover .pw-glow{ transform: translateY(-4px); opacity: .65; }

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

/* Safety */
html, body{ overflow-x: hidden; }
/* ===== SECTION 7: Room Sound (2 photos + wave overlay) ===== */
.rsound{ max-width: 1100px; margin: 20px auto 0; padding: 0 16px 16px; }
.rs-grid{
  margin-top: 16px; display: grid; gap: 16px;
  grid-template-columns: repeat(2, minmax(0,1fr));
}
.rs-card{
  position: relative; overflow: hidden;
  background: var(--card); border: 1px solid var(--line); border-radius: 18px; padding: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,.26);
  transition: transform .25s cubic-bezier(.2,.8,.2,1), border-color .25s ease;
}
.rs-card:hover{ transform: translateY(-6px); border-color: color-mix(in srgb, var(--brand) 30%, var(--line)); }
.rs-card figcaption{ margin-top: 8px; color: var(--muted); font-size: 14px; }
.rs-wave{
  position: absolute; inset: -20% -10%;
  background: radial-gradient(40% 60% at 30% 50%, rgba(155,182,167,.22), transparent 60%),
              radial-gradient(60% 40% at 70% 60%, rgba(214,169,123,.18), transparent 60%);
  mix-blend-mode: screen; filter: blur(18px); opacity: .4; pointer-events: none;
  animation: rsPulse 16s ease-in-out infinite;
}
@keyframes rsPulse{ 50%{ opacity: .55; transform: translateY(-4px); } }
@media (max-width: 980px){ .rs-grid{ grid-template-columns: 1fr; } }

/* ===== SECTION 8: Mend Notebook (3 photos, flip cards) ===== */
.mend{ max-width: 1100px; margin: 20px auto 0; padding: 0 16px 16px; }
.md-grid{
  margin-top: 16px; display: grid; gap: 16px;
  grid-template-columns: repeat(3, minmax(0,1fr));
  perspective: 1000px;
}
.md-card{
  position: relative; height: 260px;
  transform-style: preserve-3d;
  transition: transform .45s cubic-bezier(.2,.8,.2,1);
}
.md-card:hover{ transform: rotateY(180deg); }
.md-face{
  position: absolute; inset: 0;
  background: var(--card); border: 1px solid var(--line); border-radius: 18px; padding: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,.26);
  backface-visibility: hidden; display: grid; align-content: center; text-align: left;
}
.md-face.front h3{ margin: 0 0 6px; font-size: 18px; }
.md-face.front p{ margin: 0; color: var(--muted); }
.md-face.back{ transform: rotateY(180deg); }
.md-face figcaption{ margin-top: 8px; color: var(--muted); font-size: 14px; }
@media (max-width: 980px){ .md-grid{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px){ .md-grid{ grid-template-columns: 1fr; } }

/* ===== SECTION 9: Evening Recipes (2 photos + glow toggle) ===== */
.erecipes{ max-width: 1100px; margin: 20px auto 40px; padding: 0 16px 16px; }
.er-modes{ margin-top: 12px; display: flex; flex-wrap: wrap; gap: 8px; }
.er-btn{
  height: 40px; padding: 0 14px; border-radius: 12px; border: 1px solid var(--line);
  background: #171a20; color: var(--ink);
  transition: transform .2s ease, background .2s ease, border-color .2s ease;
}
.er-btn:hover, .er-btn:focus-visible{ transform: translateY(-1px); background:#1d2026; border-color: color-mix(in srgb, var(--brand) 30%, var(--line)); }
.er-btn[data-active="true"]{ outline: 2px solid var(--brand); }

.er-grid{
  margin-top: 16px; display: grid; gap: 16px;
  grid-template-columns: repeat(2, minmax(0,1fr));
}
.er-card{
  position: relative; overflow: hidden;
  background: var(--card); border: 1px solid var(--line); border-radius: 18px; padding: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,.26);
}
.er-card figcaption{ margin-top: 8px; color: var(--muted); font-size: 14px; }

/* glow overlay via vars */
:root{
  --er-a: rgba(214,169,123,.14); /* Dim default */
  --er-b: rgba(155,182,167,.18);
}
.er-glow{
  position: absolute; inset: -20% -10%;
  background:
    radial-gradient(40% 60% at 30% 50%, var(--er-a), transparent 60%),
    radial-gradient(60% 40% at 70% 60%, var(--er-b), transparent 60%);
  mix-blend-mode: screen; filter: blur(18px); opacity: .5; pointer-events: none;
  transition: opacity .35s ease, transform .35s ease, background .35s ease;
}
.er-card:hover .er-glow{ transform: translateY(-4px); opacity: .7; }

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

/* Safety */
html, body{ overflow-x: hidden; }
/* ===== SECTION 10: Bench Stories (2 photos + expandable notes) ===== */
.bstories{ max-width: 1100px; margin: 20px auto 0; padding: 0 16px 16px; }
.bs-grid{
  margin-top: 16px; display: grid; gap: 16px;
  grid-template-columns: repeat(2, minmax(0,1fr));
}
.bs-card{
  position: relative; overflow: hidden;
  background: var(--card); border: 1px solid var(--line); border-radius: 18px; padding: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,.26);
}
.bs-card figcaption{ margin-top: 8px; color: var(--muted); font-size: 14px; }
.bs-teaser{ color: var(--muted); margin: 8px 0; }

.bs-more{
  height: 38px; padding: 0 12px; border-radius: 12px; border: 1px solid var(--line);
  background: #171a20; color: var(--ink);
  transition: transform .2s ease, background .2s ease, border-color .2s ease;
}
.bs-more:hover, .bs-more:focus-visible{ transform: translateY(-1px); background:#1d2026; border-color: color-mix(in srgb, var(--brand) 30%, var(--line)); }
.bs-note{ margin-top: 8px; color: var(--muted); border-top: 1px solid var(--line); padding-top: 8px; animation: bsFade .25s ease both; }
@keyframes bsFade{ from{ opacity:.6; transform: translateY(-2px);} to{ opacity:1; transform:none;} }

/* decorative silk line */
.bs-silk{ position: absolute; left: -12px; right: -12px; top: -6px; height: 60px; pointer-events: none; }
.bs-line{ width: 100%; height: 60px; display: block; }
.bs-line path{
  fill: none; stroke: color-mix(in srgb, var(--brand) 55%, var(--brand-2) 45%);
  stroke-width: 1.2; opacity: .5; filter: drop-shadow(0 6px 12px rgba(0,0,0,.25));
  stroke-dasharray: 6 10; animation: bsGlide 9s linear infinite;
}
@keyframes bsGlide{ to{ stroke-dashoffset: -320; } }

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

/* ===== SECTION 11: Balcony Notes (2 photos + mood glow) ===== */
.balcony{ max-width: 1100px; margin: 20px auto 0; padding: 0 16px 16px; }
.bn-modes{ margin-top: 12px; display: flex; flex-wrap: wrap; gap: 8px; }
.bn-btn{
  height: 40px; padding: 0 14px; border-radius: 12px; border: 1px solid var(--line);
  background: #171a20; color: var(--ink);
  transition: transform .2s ease, background .2s ease, border-color .2s ease;
}
.bn-btn:hover, .bn-btn:focus-visible{ transform: translateY(-1px); background:#1d2026; border-color: color-mix(in srgb, var(--brand) 30%, var(--line)); }
.bn-btn[data-active="true"]{ outline: 2px solid var(--brand); }

.bn-grid{
  margin-top: 16px; display: grid; gap: 16px;
  grid-template-columns: repeat(2, minmax(0,1fr));
}
.bn-card{
  position: relative; overflow: hidden;
  background: var(--card); border: 1px solid var(--line); border-radius: 18px; padding: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,.26);
}
.bn-card figcaption{ margin-top: 8px; color: var(--muted); font-size: 14px; }

/* mood glow via vars */
:root{
  --bn-a: rgba(155,182,167,.18); /* Breeze default */
  --bn-b: rgba(214,169,123,.16);
}
.bn-glow{
  position: absolute; inset: -20% -10%;
  background:
    radial-gradient(40% 60% at 30% 50%, var(--bn-a), transparent 60%),
    radial-gradient(60% 40% at 70% 60%, var(--bn-b), transparent 60%);
  mix-blend-mode: screen; filter: blur(18px); opacity: .5; pointer-events: none;
  transition: opacity .35s ease, transform .35s ease, background .35s ease;
}
.bn-card:hover .bn-glow{ transform: translateY(-4px); opacity: .7; }

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

/* ===== SECTION 12: Toolkit Trio (3 photos + dashed highlight & tags) ===== */
.toolkit{ max-width: 1100px; margin: 20px auto 40px; padding: 0 16px 16px; }
.tk-tags{ margin-top: 12px; display: flex; flex-wrap: wrap; gap: 8px; }
.tk-tag{
  height: 40px; padding: 0 14px; border-radius: 12px; border: 1px solid var(--line);
  background: #171a20; color: var(--ink);
  transition: transform .2s ease, background .2s ease, border-color .2s ease;
}
.tk-tag:hover, .tk-tag:focus-visible{ transform: translateY(-1px); background:#1d2026; border-color: color-mix(in srgb, var(--brand) 30%, var(--line)); }
.tk-tag[data-active="true"]{ outline: 2px solid var(--brand); }

.tk-grid{
  margin-top: 16px; display: grid; gap: 16px;
  grid-template-columns: repeat(3, minmax(0,1fr));
}
.tk-card{
  position: relative; overflow: hidden;
  background: var(--card); border: 1px solid var(--line); border-radius: 18px; padding: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,.26);
  transition: transform .25s cubic-bezier(.2,.8,.2,1), border-color .25s ease;
}
.tk-card:hover{ transform: translateY(-6px); border-color: color-mix(in srgb, var(--brand) 30%, var(--line)); }
.tk-card figcaption{ margin-top: 8px; color: var(--muted); font-size: 14px; }

/* dashed animated border highlight */
.tk-dash{
  position: absolute; inset: 8px; border-radius: 14px;
  border: 1.6px dashed color-mix(in srgb, var(--brand) 55%, var(--brand-2) 45%);
  opacity: 0; pointer-events: none;
  mask: linear-gradient(#000 0 0) padding-box, linear-gradient(#0000 0 0);
  animation: dashMove 14s linear infinite;
}
@keyframes dashMove{ to{ transform: translateX(8px); } }
.tk-card[data-focus="on"] .tk-dash{ opacity: .9; }

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

/* Safety */
html, body{ overflow-x: hidden; }
/* ===== SECTION 13: Room Sketches (2 photos + SVG flow) ===== */
.rsketch{ max-width: 1100px; margin: 20px auto 0; padding: 0 16px 16px; }
.rk-grid{
  margin-top: 16px; display: grid; gap: 16px;
  grid-template-columns: repeat(2, minmax(0,1fr));
}
.rk-card{
  position: relative; overflow: hidden;
  background: var(--card); border: 1px solid var(--line); border-radius: 18px; padding: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,.26);
}
.rk-card figcaption{ margin-top: 8px; color: var(--muted); font-size: 14px; }
.rk-svg{ position: absolute; inset: -6px -6px auto -6px; height: 60px; pointer-events: none; }
.rk-path path{
  fill: none; stroke: color-mix(in srgb, var(--brand) 55%, var(--brand-2) 45%);
  stroke-width: 1.4; opacity: .55; filter: drop-shadow(0 6px 12px rgba(0,0,0,.25));
  stroke-dasharray: 6 12; animation: rkRun 9s linear infinite;
}
@keyframes rkRun{ to{ stroke-dashoffset: -360; } }
@media (max-width: 980px){ .rk-grid{ grid-template-columns: 1fr; } }

/* ===== SECTION 14: Market Finds (rail with arrows) ===== */
.mfinds{ max-width: 1100px; margin: 20px auto 0; padding: 0 16px 16px; }
.mf-track{
  margin-top: 16px; display: grid; grid-auto-flow: column; gap: 16px;
  overflow-x: auto; overscroll-behavior-x: contain; scroll-snap-type: x mandatory; padding-bottom: 8px;
}
.mf-card{
  scroll-snap-align: start;
  min-width: min(84vw, 360px);
  background: var(--card); border: 1px solid var(--line); border-radius: 18px; padding: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,.26);
  transition: transform .25s cubic-bezier(.2,.8,.2,1), border-color .25s ease;
}
.mf-card:hover{ transform: translateY(-6px); border-color: color-mix(in srgb, var(--brand) 30%, var(--line)); }
.mf-card figcaption{ margin-top: 8px; color: var(--muted); font-size: 14px; }

.mf-controls{ display: flex; justify-content: center; gap: 10px; margin-top: 10px; }
.mf-nav{
  width: 42px; height: 42px; border-radius: 12px;
  background: linear-gradient(120deg, var(--brand), var(--brand-2));
  color: #111; font-weight: 700; box-shadow: var(--shadow); transition: transform .2s ease;
}
.mf-nav:hover{ transform: translateY(-1px); }
@media (max-width: 560px){ .mf-card{ min-width: 82vw; } }

/* ===== SECTION 15: Seasonal Switch (2 photos + mood glow) ===== */
.season{ max-width: 1100px; margin: 20px auto 60px; padding: 0 16px 16px; }
.ss-modes{ margin-top: 12px; display: flex; flex-wrap: wrap; gap: 8px; }
.ss-btn{
  height: 40px; padding: 0 14px; border-radius: 12px; border: 1px solid var(--line);
  background: #171a20; color: var(--ink);
  transition: transform .2s ease, background .2s ease, border-color .2s ease;
}
.ss-btn:hover, .ss-btn:focus-visible{ transform: translateY(-1px); background:#1d2026; border-color: color-mix(in srgb, var(--brand) 30%, var(--line)); }
.ss-btn[data-active="true"]{ outline: 2px solid var(--brand); }

.ss-grid{
  margin-top: 16px; display: grid; gap: 16px;
  grid-template-columns: repeat(2, minmax(0,1fr));
}
.ss-card{
  position: relative; overflow: hidden;
  background: var(--card); border: 1px solid var(--line); border-radius: 18px; padding: 12px;
  box-shadow: 0 10px 30px rgba(0,0,0,.26);
}
.ss-card figcaption{ margin-top: 8px; color: var(--muted); font-size: 14px; }

/* glow overlay via vars */
:root{ --ss-a: rgba(155,182,167,.22); --ss-b: rgba(214,169,123,.16); } /* monsoon default */
.ss-glow{
  position: absolute; inset: -20% -10%;
  background:
    radial-gradient(40% 60% at 30% 50%, var(--ss-a), transparent 60%),
    radial-gradient(60% 40% at 70% 60%, var(--ss-b), transparent 60%);
  mix-blend-mode: screen; filter: blur(18px); opacity: .5; pointer-events: none;
  transition: opacity .35s ease, transform .35s ease, background .35s ease;
}
.ss-card:hover .ss-glow{ transform: translateY(-4px); opacity: .7; }

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

/* Safety */
html, body{ overflow-x: hidden; }
/* ==== Journal: mobile overflow guard for images (sec. 2) ==== */

/* 0) Глобальная защита для всех картинок на странице журнала */
main#main img.cap-img{
  display:block;
  width:100%;
  height:auto;
  max-width:350px;        /* по требованию проекта */
}

/* 1) Makers’ Voices — центрируем карточки и ограничиваем фигуры */
.voices .v-lanes{ justify-items:center; } /* чтобы в колонках стояли по центру */

.voices .v-fig{
  width:100%;
  max-width:350px;        /* жёсткий лимит */
  margin:0 auto;
  border-radius:14px;
  overflow:hidden;        /* чтобы скругления не «резались» */
  box-sizing:border-box;
}

.voices .v-fig > img{
  width:100% !important;  /* перекрываем старые правила, если были */
  height:auto !important;
  object-fit:cover;
  object-position:center;
}

/* 2) На узких — одна колонка и безопасная ширина карточки */
@media (max-width: 640px){
  .v-lanes{ grid-template-columns: 1fr !important; }
  .voices .v-lane{ width:100%; max-width:min(350px,92vw); margin-inline:auto; }
}
