/* ===== SECTION 1: Embers & Smoke Hero ===== */
.hero-embers{
  position:relative;
  padding:30px 0 72px;  /* только внутренний отступ: высота хедера добавляет body */
  background:
    radial-gradient(1000px 420px at 20% -10%, rgba(255,106,40,.12), transparent 60%),
    radial-gradient(900px 420px at 120% -20%, rgba(240,58,23,.10), transparent 60%),
    var(--bg);
  overflow:hidden;
  overflow-x:clip; /* защита от субпиксельного оверфлоу */
}
.hero-embers__shimmer{
  position:absolute; inset:-10% -10% auto -10%; height:55%;
  background:repeating-linear-gradient(to bottom, rgba(255,255,255,.02) 0 4px, rgba(255,255,255,0) 4px 10px);
  animation:shimmer 6s linear infinite; pointer-events:none; mix-blend-mode:screen; filter:blur(1px) contrast(110%); top:0;
}
@keyframes shimmer{ 0%{transform:translateY(0)} 100%{transform:translateY(-30px)} }
.hero-embers__canvas{position:absolute; inset:0; width:100%; height:100%; display:block; pointer-events:none}

.hero-embers__grid{position:relative; z-index:2; display:grid; grid-template-columns:1.2fr 1fr; gap:36px; align-items:center}
.hero-embers__copy .eyebrow{letter-spacing:.12em; text-transform:uppercase; color:var(--accent); margin:0 0 6px; font-size:.9rem}
.hero-embers__copy .title{font-family:"Oswald",sans-serif; font-size:clamp(1.8rem, 2.6vw, 3rem); margin:.2rem 0 .6rem}
.hero-embers__copy .title span{color:var(--brand)}
.hero-embers__copy .lead{color:var(--muted); margin:0 0 14px}
.hero-embers__highlights{display:grid; gap:6px; margin:0 0 18px; padding-left:18px}
.hero-embers__highlights li{list-style:"🔥  "; padding-inline-start:6px}

.cta-row{display:flex; gap:12px; flex-wrap:wrap}
.btn{display:inline-block; text-decoration:none; font-weight:700; letter-spacing:.3px; padding:12px 16px; border-radius:14px; transition:transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease}
.btn--primary{background:linear-gradient(90deg, var(--brand), var(--brand-2)); color:#0b0806; box-shadow:var(--shadow)}
.btn--primary:hover{transform:translateY(-1px)}
.btn--ghost{border:1px solid rgba(255,255,255,.25); color:var(--ink)}
.btn--ghost:hover{background:rgba(255,255,255,.06)}

.hero-embers__mosaic{display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:14px}
.mosaic-card{margin:0; background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.03)); border-radius:16px; padding:10px; box-shadow:0 12px 28px rgba(0,0,0,.25)}
.mosaic-card figcaption{font-size:.9rem; color:var(--muted); margin-top:6px}
.tilt{transform:perspective(800px) rotateX(0) rotateY(0); transition:transform .25s ease}
.tilt:hover{transform:perspective(800px) rotateX(3deg) rotateY(-4deg) translateY(-2px)}

.hero-embers__badges{position:absolute; inset:auto 0 10px 0; display:flex; justify-content:center; gap:10px; list-style:none; padding:0; margin:0; z-index:2}
.badge{font-size:.85rem; color:#0b0806; background:linear-gradient(90deg,#ffd166,#fffdc2); padding:8px 12px; border-radius:999px; box-shadow:var(--shadow); transform:translateY(14px); animation:badgeFloat 6s ease-in-out infinite}
.badge:nth-child(2){animation-delay:.8s}
.badge:nth-child(3){animation-delay:1.6s}
@keyframes badgeFloat{0%,100%{transform:translateY(14px)} 50%{transform:translateY(0)}}

@media (max-width:1024px){ .hero-embers__grid{grid-template-columns:1fr; gap:22px} }
@media (max-width:720px){
  .hero-embers{padding:20px 0 64px}
  .cta-row .btn{flex:1 1 auto; text-align:center}
}
@media (max-width:420px){ .hero-embers__badges{flex-wrap:wrap} }
@media (prefers-reduced-motion:reduce){ .hero-embers__shimmer,.badge,.tilt,[data-reveal]{animation:none!important; transition:none!important} }

/* ===== SECTION 2: Heat Ladder ===== */
.heat-ladder{
  position:relative; padding:56px 0 72px; overflow-x:clip;
  background:
    radial-gradient(800px 340px at 15% -10%, rgba(255,106,40,.10), transparent 60%),
    radial-gradient(700px 320px at 110% -20%, rgba(240,58,23,.08), transparent 60%),
    var(--bg-2);
}
.hl-grid{display:grid; grid-template-columns:1.15fr .85fr; gap:28px; align-items:start}
.hl-title{font-family:"Oswald",sans-serif; margin:0 0 8px; font-size:clamp(1.4rem,2.2vw,2rem)}
.hl-lead{color:var(--muted); margin:0 0 14px}
.hl-points{margin:12px 0 0; padding-left:18px}
.hl-points li{list-style:"🔥  "; padding-inline-start:6px}
.ladder{position:relative; margin:10px 0 8px; padding:0; list-style:none}
.ladder::before{content:""; position:absolute; left:10px; top:0; bottom:0; width:2px; background:linear-gradient(#ffd166,#ff6a28); filter:blur(.2px)}
.rung{position:relative; padding:10px 12px 10px 28px; border-radius:12px; margin:8px 0; background:rgba(255,255,255,.04); box-shadow:0 8px 18px rgba(0,0,0,.25); overflow:hidden}
.rung span{font-weight:800; letter-spacing:.04em}
.rung small{display:block; color:var(--muted)}
.rung::after{content:""; position:absolute; inset:0; background:linear-gradient(90deg, rgba(255,209,102,.18), rgba(255,106,40,.18)); mix-blend-mode:soft-light; opacity:0; animation:rungGlow 6s ease-in-out infinite}
@keyframes rungGlow{0%,100%{opacity:.04} 50%{opacity:.45}}
.r1::after{animation-delay:0s} .r2::after{animation-delay:.8s} .r3::after{animation-delay:1.6s} .r4::after{animation-delay:2.4s}
.hl-gallery{display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px}
.hl-gallery figure{margin:0; background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.03)); padding:10px; border-radius:16px; box-shadow:0 10px 24px rgba(0,0,0,.25)}
.hl-gallery figcaption{font-size:.9rem; color:var(--muted); margin-top:6px}
@media (max-width:960px){ .hl-grid{grid-template-columns:1fr; gap:20px} }

/* ===== SECTION 3: Cutaway Heat Map ===== */
.cutaway-heatmap{
  position:relative; padding:56px 0 72px; overflow-x:clip;
  background: radial-gradient(720px 300px at -10% 10%, rgba(240,58,23,.07), transparent 60%), var(--bg);
}
.ch-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:28px; align-items:center}
.ch-title{font-family:"Oswald",sans-serif; margin:0 0 8px}
.ch-lead{color:var(--muted); margin:0 0 12px}
.ch-tabs{display:flex; gap:10px; flex-wrap:wrap; margin:4px 0 10px}
.ch-tab{border:1px solid rgba(255,255,255,.22); background:rgba(255,255,255,.04); color:var(--ink); border-radius:12px; padding:8px 12px; cursor:pointer; font-weight:700; letter-spacing:.3px; transition:transform .15s ease, background .2s ease, border-color .2s ease; transform:translateZ(0)}
.ch-tab:hover{transform:translateY(-1px)}
.ch-tab.is-active{background:linear-gradient(90deg,var(--brand),var(--brand-2)); color:#0b0806; border-color:transparent}

.ch-stage{
  position:relative; width:100%; max-width:560px; margin-inline:auto; aspect-ratio:1/1;
  border-radius:18px; overflow:hidden; box-shadow:0 14px 32px rgba(0,0,0,.28); background:#140f0c
}
.ch-base,.ch-view{position:absolute; inset:0; width:100%; height:100%; object-fit:cover}
.ch-view{opacity:0; transition:opacity .35s ease}
.ch-wash{position:absolute; inset:0; pointer-events:none; opacity:0; mix-blend-mode:screen; transition:opacity .35s ease}
.ch-wash--sear {background:radial-gradient(280px 180px at 75% 70%, rgba(255,80,20,.55), transparent 70%)}
.ch-wash--roast{background:radial-gradient(420px 240px at 50% 60%, rgba(255,140,30,.45), transparent 70%)}
.ch-wash--smoke{background:radial-gradient(520px 300px at 40% 65%, rgba(255,209,102,.35), transparent 70%)}
/* state mapping */
.ch-stage[data-state="sear"]  .ch-sear{opacity:1}
.ch-stage[data-state="roast"] .ch-roast{opacity:1}
.ch-stage[data-state="smoke"] .ch-smoke{opacity:1}
.ch-stage[data-state="sear"]  .ch-wash--sear{opacity:1}
.ch-stage[data-state="roast"] .ch-wash--roast{opacity:1}
.ch-stage[data-state="smoke"] .ch-wash--smoke{opacity:1}
@media (max-width:980px){ .ch-grid{grid-template-columns:1fr; gap:22px} }

/* ===== SECTION 4: Balcony BBQ Playbook (scroll-snap) ===== */
.playbook{
  position:relative; padding:56px 0 84px; overflow-x:clip;
  background: radial-gradient(820px 320px at 100% -5%, rgba(255,106,40,.08), transparent 60%), var(--bg-2);
}
.pb-title{font-family:"Oswald",sans-serif; margin:0 0 8px}
.pb-lead{color:var(--muted); margin:0 0 14px}
.pb-track{
  display:flex; gap:14px; overflow-x:auto; padding:6px 2px 2px; max-width:100%;
  scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch;
  border-top:1px solid rgba(255,255,255,.06); border-bottom:1px solid rgba(255,255,255,.06);
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.03)); border-radius:14px;
}
.pb-card{scroll-snap-align:center; flex:0 0 260px; background:rgba(255,255,255,.03); border-radius:14px; padding:10px; box-shadow:0 10px 24px rgba(0,0,0,.25)}
.pb-card figure{margin:0}
.pb-card figcaption{font-size:.9rem; color:var(--muted); margin-top:6px}
.pb-card p{font-size:.92rem; margin:.5rem 0 0}
.pb-track::-webkit-scrollbar{height:8px}
.pb-track::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18); border-radius:99px}
/* ===== SECTION 5: Monsoon Coating Lab ===== */
.monsoon-lab{
  position:relative; padding:56px 0 72px; overflow-x:clip;
  background: radial-gradient(780px 300px at 5% 0%, rgba(255,106,40,.08), transparent 60%), var(--bg);
}
.mlab-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:28px; align-items:start}
.mlab-title{font-family:"Oswald",sans-serif; margin:0 0 8px}
.mlab-lead{color:var(--muted); margin:0 0 12px}

.mlab-tabs{display:flex; gap:10px; flex-wrap:wrap; margin:6px 0 10px}
.mlab-tab{
  border:1px solid rgba(255,255,255,.22); background:rgba(255,255,255,.04);
  color:var(--ink); border-radius:12px; padding:8px 12px; cursor:pointer; font-weight:700;
  transition:transform .15s ease, background .2s ease, border-color .2s ease; transform:translateZ(0)
}
.mlab-tab:hover{transform:translateY(-1px)}
.mlab-tab.is-active{background:linear-gradient(90deg,var(--brand),var(--brand-2)); color:#0b0806; border-color:transparent}

.mlab-points{margin:8px 0 0; padding-left:18px}
.mlab-points li{list-style:"🔥  "; padding-inline-start:6px}

.mlab-stage{
  position:relative; border-radius:18px; overflow:hidden; box-shadow:0 14px 32px rgba(0,0,0,.28);
  background:#140f0c; padding:12px;
}
.mlab-base{margin:0}
.mlab-cards{display:grid; gap:12px; grid-template-columns:repeat(2,minmax(0,1fr)); margin-top:10px}
.mlab-card{margin:0; background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.03)); padding:8px; border-radius:14px; box-shadow:0 8px 18px rgba(0,0,0,.22)}
.mlab-card figcaption{font-size:.9rem; color:var(--muted); margin-top:6px}

/* layered rain */
.rain{position:absolute; inset:0; pointer-events:none; opacity:.0}
.rain--a{
  background-image:
    repeating-linear-gradient(120deg, rgba(255,255,255,.22) 0 2px, transparent 2px 22px);
  background-size: 18px 36px; animation: rainShiftA 6s linear infinite;
}
.rain--b{
  background-image:
    repeating-linear-gradient(120deg, rgba(255,255,255,.15) 0 1px, transparent 1px 16px);
  background-size: 12px 28px; animation: rainShiftB 5s linear infinite;
}
.rain--c{
  background-image:
    repeating-linear-gradient(120deg, rgba(255,255,255,.10) 0 1px, transparent 1px 12px);
  background-size: 8px 18px; animation: rainShiftC 4s linear infinite;
}
@keyframes rainShiftA{to{background-position: 120px 260px}}
@keyframes rainShiftB{to{background-position: 90px 200px}}
@keyframes rainShiftC{to{background-position: 70px 150px}}

/* intensity states (только непрозрачности) */
.mlab-stage.int-drizzle .rain--a{opacity:.25}
.mlab-stage.int-drizzle .rain--b,
.mlab-stage.int-drizzle .rain--c{opacity:0}

.mlab-stage.int-monsoon .rain--a{opacity:.35}
.mlab-stage.int-monsoon .rain--b{opacity:.18}
.mlab-stage.int-monsoon .rain--c{opacity:0}

.mlab-stage.int-storm .rain--a{opacity:.45}
.mlab-stage.int-storm .rain--b{opacity:.30}
.mlab-stage.int-storm .rain--c{opacity:.20}

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

/* ===== SECTION 6: Fuel Economics ===== */
.fuel-economics{
  position:relative; padding:56px 0 72px; overflow-x:clip;
  background: radial-gradient(760px 300px at 100% 0%, rgba(240,58,23,.07), transparent 60%), var(--bg-2);
}
.fe-grid{display:grid; grid-template-columns: .9fr 1.1fr; gap:28px; align-items:center}
.fe-title{font-family:"Oswald",sans-serif; margin:0 0 8px}
.fe-lead{color:var(--muted); margin:0 0 10px}
.fe-note{color:var(--muted); font-size:.92rem}

.fe-chart{display:grid; gap:12px}
.fe-row{display:grid; grid-template-columns: 1.2fr 1fr auto; gap:10px; align-items:end}
.fe-label{white-space:nowrap}
.fe-minutes{color:var(--accent); font-weight:700}

.fe-bar{
  --v: .5;               /* default */
  height: 140px; border-radius:12px; background:rgba(255,255,255,.06); position:relative; overflow:hidden;
}
.fe-bar::after{
  content:""; position:absolute; left:0; bottom:0; right:0;
  height: calc(var(--v) * 100%); border-radius:12px 12px 0 0;
  background:linear-gradient(180deg, var(--brand), var(--brand-2));
  transform-origin: bottom; transform: scaleY(0);
  transition: transform .9s cubic-bezier(.2,.8,.2,1);
}
[data-reveal].is-in .fe-bar::after{ transform: scaleY(1); }

/* discrete value classes (без инлайна) */
.fe-bar.v80{ --v:.80 }
.fe-bar.v70{ --v:.70 }
.fe-bar.v60{ --v:.60 }
.fe-bar.v35{ --v:.35 }

@media (max-width:960px){
  .fe-grid{grid-template-columns:1fr; gap:18px}
  .fe-row{grid-template-columns: 1fr; align-items:center}
  .fe-bar{height:120px}
}

/* ===== SECTION 7: Weekend Menu Builder ===== */
.menu-builder{
  position:relative; padding:56px 0 84px; overflow-x:clip;
  background: radial-gradient(800px 320px at -10% 5%, rgba(255,106,40,.08), transparent 60%), var(--bg);
}
.mb-title{font-family:"Oswald",sans-serif; margin:0 0 8px}
.mb-lead{color:var(--muted); margin:0 0 14px}

.mb-rail{
  position:relative; display:grid; gap:14px;
  grid-template-columns: repeat(auto-fit, minmax(220px,1fr));
  padding:14px; border-radius:16px;
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.03));
  box-shadow:0 12px 28px rgba(0,0,0,.24);
}
.flow-line{
  position:absolute; left:14px; right:14px; top:30px; height:4px; border-radius:99px; overflow:hidden;
  background:rgba(255,255,255,.06);
}
[data-reveal].is-in .flow-line{
  background:
    linear-gradient(90deg, var(--brand), var(--brand-2));
  mask: linear-gradient(90deg, #000 0 0) 0/0% 100% no-repeat, linear-gradient(#000 0 0);
  -webkit-mask: linear-gradient(90deg, #000 0 0) 0/0% 100% no-repeat, linear-gradient(#000 0 0);
  animation: flowGrow 3s ease forwards;
}
@keyframes flowGrow{ to{ mask-size:100% 100%; -webkit-mask-size:100% 100%; } }

.step{background:rgba(255,255,255,.03); border-radius:14px; padding:10px}
.step figure{margin:0}
.step figcaption{font-size:.9rem; color:var(--muted); margin-top:6px}
.step p{font-size:.92rem; margin:.5rem 0 0}

@media (max-width:560px){
  .flow-line{display:none} /* на очень узких экранах линия не нужна */
}
/* было:
.flow-line{
  position:absolute; left:14px; right:14px; top:30px; height:4px; ...
}
*/

.flow-line{
  position:absolute;
  left:14px;
  right:14px;
  top:12px;                 /* линия в пределах верхнего padding, выше карточек */
  height:3px;               /* чуть тоньше, чтобы не спорила с закруглениями */
  border-radius:99px;
  overflow:hidden;
  background:rgba(255,255,255,.06);
  z-index:0;                /* ниже карточек */
}

.step{
  position:relative;        /* создаём свой слой для карточек */
  z-index:1;                /* гарантированно выше линии */
}
/* ===== SECTION 8: Smoke Signals ===== */
.smoke-signals{
  position:relative; padding:56px 0 72px; overflow-x:clip;
  background: radial-gradient(800px 300px at 85% -10%, rgba(255,106,40,.08), transparent 60%), var(--bg-2);
}
.ss-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:28px; align-items:center}
.ss-title{font-family:"Oswald",sans-serif; margin:0 0 8px}
.ss-lead{color:var(--muted); margin:0 0 12px}
.ss-list{margin:8px 0 0; padding-left:18px}
.ss-list li{list-style:"🔥  "; padding-inline-start:6px}

.ss-stage{
  position:relative; aspect-ratio:1/1; max-width:560px; margin-inline:auto;
  border-radius:18px; overflow:hidden; background:#120e0c; box-shadow:0 14px 32px rgba(0,0,0,.28);
  display:grid; place-items:center;
}
.ring{
  position:absolute; width:120px; height:120px; border-radius:50%;
  box-shadow:0 0 60px 10px rgba(200,200,200,.06) inset, 0 0 60px rgba(255,255,255,.05);
  animation: ringExpand 7s linear infinite; opacity:0.35; filter:blur(.3px);
}
@keyframes ringExpand{
  0%{transform:scale(.4); opacity:.0}
  10%{opacity:.35}
  100%{transform:scale(3); opacity:0}
}
.r1{animation-delay:0s} .r2{animation-delay:.8s} .r3{animation-delay:1.6s}
.r4{animation-delay:2.4s} .r5{animation-delay:3.2s} .r6{animation-delay:4.0s}

/* wood tags around the stage */
.wood-tag{position:absolute; width:120px; text-align:center; margin:0}
.wood-tag figcaption{font-size:.85rem; color:var(--muted); margin-top:6px}
.wood-a{top:8%; left:8%}
.wood-b{bottom:10%; right:12%}
.wood-c{top:12%; right:8%}

@media (max-width:980px){ .ss-grid{grid-template-columns:1fr; gap:22px} }
@media (max-width:520px){ .wood-tag{width:100px} }

/* ===== SECTION 9: Grate Geometry Test ===== */
.grate-geometry{
  position:relative; padding:56px 0 72px; overflow-x:clip;
  background: radial-gradient(760px 300px at -10% 10%, rgba(240,58,23,.07), transparent 60%), var(--bg);
}
.gg-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:28px; align-items:start}
.gg-title{font-family:"Oswald",sans-serif; margin:0 0 8px}
.gg-lead{color:var(--muted); margin:0 0 12px}
.gg-points{margin:8px 0 0; padding-left:18px}
.gg-points li{list-style:"🔥  "; padding-inline-start:6px}

.gg-stage{background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.03)); border-radius:18px; padding:14px; box-shadow:0 12px 28px rgba(0,0,0,.26)}
.heat-grid{
  display:grid; grid-template-columns:repeat(6, 1fr); grid-template-rows:repeat(6, 48px); gap:8px;
}
.cell{
  border-radius:10px; background:rgba(255,255,255,.04);
  position:relative; overflow:hidden; transition:background .2s ease, transform .2s ease;
}
.cell::after{
  content:""; position:absolute; inset:auto 0 0 0; height:0%;
  background:linear-gradient(180deg, rgba(255,209,102,.4), rgba(255,106,40,.4));
  transition:height .35s ease;
}
.cell:hover{ transform:translateY(-1px); background:rgba(255,255,255,.06); }
.cell:hover::after{ height:100%; }

/* aside gallery */
.gg-aside{display:grid; gap:12px; align-content:start}
.gg-card{margin:0; background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.03)); padding:10px; border-radius:16px; box-shadow:0 10px 24px rgba(0,0,0,.25)}
.gg-card figcaption{font-size:.9rem; color:var(--muted); margin-top:6px}

@media (max-width:980px){ .gg-grid{grid-template-columns:1fr; gap:22px} }
@media (max-width:520px){ .heat-grid{grid-template-rows:repeat(6, 40px)} }

/* ===== SECTION 10: Street Grill Collab ===== */
.street-collab{
  position:relative; padding:56px 0 84px; overflow-x:clip;
  background: radial-gradient(820px 320px at 100% -5%, rgba(255,106,40,.08), transparent 60%), var(--bg-2);
}
.sc-title{font-family:"Oswald",sans-serif; margin:0 0 8px}
.sc-lead{color:var(--muted); margin:0 0 14px}

.sc-timeline{
  position:relative; list-style:none; padding:0; margin:0;
}
.sc-timeline::before{
  content:""; position:absolute; left:50%; top:0; bottom:0; width:3px; border-radius:99px;
  background:rgba(255,255,255,.08);
}
.sc-item{
  position:relative; width:calc(50% - 18px); margin:0 0 18px;
  background:rgba(255,255,255,.03); border-radius:14px; padding:10px;
  box-shadow:0 10px 24px rgba(0,0,0,.25);
}
.sc-item:nth-child(odd){ margin-left:0; transform:translateX(0); }
.sc-item:nth-child(even){ margin-left:auto; transform:translateX(0); }
.sc-item::after{
  content:""; position:absolute; top:18px; width:12px; height:12px; border-radius:999px; background:var(--accent);
}
.sc-item:nth-child(odd)::after{ right:-24px; }
.sc-item:nth-child(even)::after{ left:-24px; }

.sc-item figure{margin:0}
.sc-item figcaption{font-size:.9rem; color:var(--muted); margin-top:6px}
.sc-item p{font-size:.92rem; margin:.5rem 0 0}

@media (max-width:900px){
  .sc-timeline::before{ left:14px; }
  .sc-item{ width:auto; margin-left:0; margin-right:0; padding-left:26px; }
  .sc-item::after{ left:8px; right:auto; }
}
/* ===== SECTION 11: Lexicon (no images) ===== */
.lexicon{
  position:relative; padding:56px 0 72px; overflow-x:clip;
  background: radial-gradient(760px 300px at -10% 0%, rgba(255,106,40,.08), transparent 60%), var(--bg);
}
.lex-title{font-family:"Oswald",sans-serif; margin:0 0 8px}
.lex-lead{color:var(--muted); margin:0 0 14px}

.lex-grid{
  display:grid; gap:12px;
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.03));
  border-radius:16px; padding:12px; box-shadow:0 12px 28px rgba(0,0,0,.24);
}
.lex-row{
  display:grid; grid-template-columns: 220px 1fr; gap:14px;
  align-items:start; padding:10px; border-radius:12px; background:rgba(255,255,255,.03);
  position:relative; overflow:hidden;
}
.lex-row::after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:2px;
  background:linear-gradient(90deg, var(--brand), var(--brand-2));
  transform:scaleX(0); transform-origin:left; transition:transform .4s ease;
}
.lex-row:hover::after{ transform:scaleX(1); }
.lex-row dt{
  font-weight:800; letter-spacing:.04em; text-transform:uppercase; color:var(--accent);
  position:sticky; top:calc(var(--header-h) + 8px); /* приятный эффект «прилипания» термина */
}
.lex-row dd{ margin:0; color:var(--ink) }
@media (max-width: 760px){
  .lex-row{ grid-template-columns:1fr; }
  .lex-row dt{ position:static; }
}

/* ===== SECTION 12: Heat Compass (CSS conic + needle) ===== */
.heat-compass{
  position:relative; padding:56px 0 72px; overflow-x:clip;
  background: radial-gradient(800px 320px at 100% -5%, rgba(240,58,23,.07), transparent 60%), var(--bg-2);
}
.hc-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:28px; align-items:center}
.hc-title{font-family:"Oswald",sans-serif; margin:0 0 8px}
.hc-lead{color:var(--muted); margin:0 0 12px}
.hc-points{margin:8px 0 0; padding-left:18px}
.hc-points li{list-style:"🔥  "; padding-inline-start:6px}

.hc-stage{
  position:relative; aspect-ratio:1/1; max-width:420px; margin-inline:auto;
  display:grid; place-items:center; border-radius:50%; box-shadow:0 14px 32px rgba(0,0,0,.28); background:#130f0d;
}
.wheel{
  width:80%; aspect-ratio:1/1; border-radius:50%;
  background:
    conic-gradient(from -30deg,
      rgba(255,209,102,.85) 0 120deg,        /* conduction */
      rgba(120,180,255,.75) 0 240deg,        /* convection */
      rgba(255,106,40,.85) 0 360deg          /* radiation */
    );
  filter:contrast(110%) saturate(105%);
  mask: radial-gradient(circle at 50% 50%, #000 56%, transparent 58%),
        radial-gradient(circle at 50% 50%, transparent 0 100%); /* кольцо */
}
.needle{
  position:absolute; width:4px; height:38%;
  background:#fff; border-radius:3px; top:11%; transform-origin:50% 88%;
  animation: needleSpin 24s linear infinite;
  box-shadow:0 0 12px rgba(255,255,255,.25);
}
.needle::after{
  content:""; position:absolute; bottom:-10px; left:50%; transform:translateX(-50%);
  width:14px; height:14px; border-radius:50%; background:#fff;
}
@keyframes needleSpin{ to{ rotate:360deg } }

.legend{position:absolute; bottom:10px; display:flex; gap:12px; list-style:none; margin:0; padding:0}
.legend .dot{display:inline-block; width:10px; height:10px; border-radius:50%; margin-right:6px; vertical-align:middle}
.legend .d1{background:#ffd166}
.legend .d2{background:#9dc0ff}
.legend .d3{background:#ff6a28}

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

/* ===== SECTION 13: Care & Warranty (details) ===== */
.care-warranty{
  position:relative; padding:56px 0 84px; overflow-x:clip;
  background: radial-gradient(760px 300px at 5% 0%, rgba(255,106,40,.08), transparent 60%), var(--bg);
}
.cw-title{font-family:"Oswald",sans-serif; margin:0 0 8px}
.cw-lead{color:var(--muted); margin:0 0 14px}

.cw-accord{
  display:grid; gap:10px;
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.03));
  border-radius:16px; padding:12px; box-shadow:0 12px 28px rgba(0,0,0,.24);
}
.cw-accord details{
  background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.08);
  border-radius:12px; padding:10px 12px;
}
.cw-accord summary{
  cursor:pointer; list-style:none; font-weight:800; letter-spacing:.03em;
  position:relative; padding-right:28px;
}
.cw-accord summary::-webkit-details-marker{ display:none }
.cw-accord summary::after{
  content:""; position:absolute; right:6px; top:50%; transform:translateY(-50%) rotate(0deg);
  width:10px; height:10px; border-right:2px solid var(--ink); border-bottom:2px solid var(--ink);
  border-radius:2px; transition:transform .25s ease;
}
.cw-accord details[open] summary::after{ transform:translateY(-50%) rotate(45deg); }
.cw-accord p{ margin:.6rem 0 0; color:var(--ink) }
/* ===== SECTION 14: Chef’s Radio Ticker ===== */
.chefs-radio{
  position:relative; padding:56px 0 72px; overflow-x:clip;
  background: radial-gradient(780px 300px at 5% -10%, rgba(255,106,40,.08), transparent 60%), var(--bg-2);
}
.cr-title{font-family:"Oswald",sans-serif; margin:0 0 8px}
.cr-lead{color:var(--muted); margin:0 0 12px}

.cr-track{
  position:relative; border-radius:16px;
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.03));
  box-shadow:0 12px 28px rgba(0,0,0,.24);
  overflow:hidden; padding:10px 0;
}
.cr-marquee{
  --speed: 38s;
  display:flex; gap:22px; align-items:center;
  list-style:none; margin:0; padding:8px 14px;
  white-space:nowrap; will-change: transform;
  animation: crSlide var(--speed) linear infinite;
}
.cr-marquee li{
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12);
  padding:8px 12px; border-radius:999px; font-weight:700; letter-spacing:.2px;
}
.cr-track:hover .cr-marquee{ animation-play-state: paused; }
@keyframes crSlide{
  from{ transform: translateX(0); }
  to  { transform: translateX(-50%); }  /* список длинный — цикла хватает без дубля */
}

/* ===== SECTION 15: Service Band (pure CSS icons) ===== */
.service-band{
  position:relative; padding:56px 0 72px; overflow-x:clip;
  background: radial-gradient(840px 320px at 100% 0%, rgba(240,58,23,.07), transparent 60%), var(--bg);
}
.sb-grid{
  display:grid; grid-template-columns: repeat(4, 1fr); gap:14px;
}
.sb-card{
  background:rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.08);
  border-radius:16px; padding:14px; text-align:left; box-shadow:0 10px 24px rgba(0,0,0,.25);
}
.sb-card h3{ margin:.4rem 0 .3rem }
.sb-card p{ margin:.2rem 0 0; color:var(--muted) }

/* CSS-only pictograms */
.sb-ico{ width:44px; height:44px; border-radius:12px; margin-bottom:8px; position:relative; background:linear-gradient(90deg, var(--brand), var(--brand-2)); box-shadow:0 6px 16px rgba(0,0,0,.25) }
.sb-ico::before, .sb-ico::after{ content:""; position:absolute; background:#0b0806; border-radius:3px }
.sb-ico--shield::before{ inset:8px 12px 14px 12px; border-radius:10px 10px 14px 14px }
.sb-ico--shield::after{ width:16px; height:16px; left:50%; top:12px; transform:translateX(-50%); background:#ffd166; border-radius:50% }

.sb-ico--truck::before{ left:8px; right:6px; top:12px; height:14px }
.sb-ico--truck::after{ left:10px; right:20px; bottom:10px; height:8px }
.sb-ico--truck::after{ border-radius:2px }
.sb-ico--truck{ position:relative }
.sb-ico--truck span{ display:none } /* на случай, если вставишь текст */

.sb-ico--wrench::before{ width:26px; height:8px; left:9px; top:18px; transform:rotate(35deg) }
.sb-ico--wrench::after{ width:10px; height:10px; left:24px; top:12px; border-radius:50% }

.sb-ico--leaf::before{ width:22px; height:28px; left:11px; top:8px; border-radius:50% 50% 50% 8px; transform:rotate(-25deg) }
.sb-ico--leaf::after{ width:2px; height:18px; left:21px; top:18px }

@media (max-width: 980px){ .sb-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px){ .sb-grid{ grid-template-columns: 1fr; } }

/* ===== SECTION 16: Community Stories (rotating quotes) ===== */
.community{
  position:relative; padding:56px 0 84px; overflow-x:clip;
  background: radial-gradient(820px 320px at -10% 5%, rgba(255,106,40,.08), transparent 60%), var(--bg-2);
}
.com-title{font-family:"Oswald",sans-serif; margin:0 0 8px}
.com-lead{color:var(--muted); margin:0 0 12px}

.com-rotator{
  position:relative; border-radius:16px; overflow:hidden;
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.03));
  box-shadow:0 12px 28px rgba(0,0,0,.24);
  min-height:132px;
}
.q{ margin:0; padding:16px 14px; opacity:0; transform:translateY(8px); position:absolute; inset:0; display:flex; align-items:center; justify-content:center; text-align:center; line-height:1.5; }
.q cite{ font-style:normal; color:var(--muted) }
.q.q1{ animation: rot 16s infinite; }
.q.q2{ animation: rot 16s infinite 4s; }
.q.q3{ animation: rot 16s infinite 8s; }
.q.q4{ animation: rot 16s infinite 12s; }
@keyframes rot{
  0%{opacity:0; transform:translateY(8px)}
  6%{opacity:1; transform:none}
  25%{opacity:1; transform:none}
  31%{opacity:0; transform:translateY(-8px)}
  100%{opacity:0; transform:translateY(-8px)}
}
