/* =========================================================
   RISLAN — sections.css
   ========================================================= */

/* ================= HERO ================= */
.hero {
  position: relative;
  min-height: 100svh;
  display: grid;
  align-items: end;
  padding: var(--gutter);
  padding-bottom: clamp(2rem, 4vw, 4rem);
  overflow: hidden;
}
.hero__canvas { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; }
html.no-js .hero__canvas, html.reduced-motion .hero__canvas { display: none; }
.hero__grain {
  position: absolute; inset: 0; z-index: 1; pointer-events: none; opacity: 0.4;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  mix-blend-mode: multiply;
}
/* fallback paint when no webgl */
html.no-js .hero, html.reduced-motion .hero {
  background:
    radial-gradient(120% 90% at 80% 10%, color-mix(in oklab, var(--ochre) 40%, transparent), transparent 60%),
    radial-gradient(100% 80% at 10% 90%, color-mix(in oklab, var(--cinnabar) 45%, transparent), transparent 55%),
    var(--canvas);
}
.hero__content { position: relative; z-index: 2; max-width: 56rem; }
.hero__eyebrow {
  display: inline-flex; align-items: center; gap: 0.7em;
  font-size: var(--step--1); letter-spacing: 0.16em; text-transform: uppercase;
  font-weight: 600; color: var(--ink-2); margin-bottom: clamp(1rem, 3vw, 2rem);
}
.hero__eyebrow-dot { width: 0.6em; height: 0.6em; border-radius: 50%; background: var(--cinnabar); animation: pulse 2.6s var(--ease) infinite; }
@keyframes pulse { 0%,100%{ transform: scale(1); opacity: 1;} 50%{ transform: scale(1.5); opacity: .5;} }
.hero__title { font-family: var(--f-display); font-weight: 320; font-size: var(--step-5); line-height: 0.82; letter-spacing: -0.04em; font-optical-sizing: auto; margin-bottom: clamp(1.2rem, 3vw, 2.4rem); }
.hero__title .hero__line { display: inline-block; }
.hero__tag { font-family: var(--f-display); font-weight: 360; font-size: var(--step-2); line-height: 1.1; max-width: 24ch; margin-bottom: 0.8rem; }
.hero__sub { color: var(--ink-2); max-width: 44ch; font-size: var(--step-0); margin-bottom: clamp(1.6rem, 3vw, 2.6rem); }
.hero__actions { display: flex; flex-wrap: wrap; gap: 0.8rem; }
.hero__hint { position: absolute; right: var(--gutter); bottom: clamp(2rem, 4vw, 4rem); z-index: 2; display: flex; align-items: center; gap: 0.8em; font-size: var(--step--1); color: var(--ink-2); letter-spacing: 0.05em; }
.hero__hint-line { width: 3rem; height: 1px; background: var(--ink-2); position: relative; overflow: hidden; }
.hero__hint-line::after { content: ""; position: absolute; inset: 0; background: var(--cinnabar); transform: translateX(-100%); animation: sweep 2.4s var(--ease) infinite; }
@keyframes sweep { 0%{ transform: translateX(-100%);} 60%,100%{ transform: translateX(100%);} }
@media (max-width: 680px){ .hero__hint { display: none; } }

/* ================= STATEMENT ================= */
.statement { padding: var(--section-y) var(--gutter); max-width: var(--maxw); margin-inline: auto; }
.statement__eyebrow { font-size: var(--step--1); letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-2); font-weight: 600; margin-bottom: clamp(1.4rem, 3vw, 2.4rem); }
.statement__text { font-family: var(--f-display); font-weight: 340; font-size: var(--step-3); line-height: 1.18; letter-spacing: -0.015em; max-width: 22ch; }
.statement__text [data-words] span.word { display: inline-block; }
.statement__meta { display: flex; flex-wrap: wrap; gap: clamp(1rem, 4vw, 3rem); margin-top: clamp(2.5rem, 5vw, 4rem); padding-top: 1.4rem; border-top: 1px solid var(--line); }
.statement__meta span { position: relative; padding-left: 1.4em; font-size: var(--step--1); color: var(--ink-2); letter-spacing: 0.02em; }
.statement__meta span::before { content: "✦"; position: absolute; left: 0; color: var(--cinnabar); }

/* ================= WERKE / GALLERY ================= */
.works { min-height: 100svh; display: flex; flex-direction: column; justify-content: center; gap: clamp(1.6rem, 3vw, 2.6rem); padding-block: clamp(4rem, 6vw, 7rem); overflow: hidden; }
.works__head { display: grid; gap: 0.6rem; padding-inline: var(--gutter); max-width: var(--maxw); width: 100%; margin: 0 auto; position: relative; }
.works__sub { max-width: 46ch; color: var(--ink-2); font-size: var(--step-0); margin-top: 0.3rem; }
.works__hint { justify-self: start; font-size: var(--step--1); letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); }
@media (min-width: 760px){ .works__hint { position: absolute; right: var(--gutter); bottom: 0; } }
.works__viewport { width: 100%; }
.works__track { display: flex; gap: clamp(1.2rem, 2.5vw, 2.4rem); padding-inline: var(--gutter); width: max-content; }
.tile { width: clamp(15rem, 21vw, 20rem); flex: 0 0 auto; }
.tile--wide { width: clamp(20rem, 32vw, 30rem); }
.tile__frame {
  position: relative; aspect-ratio: 1/1; overflow: hidden;
  background: var(--canvas-2);
  border: 1px solid var(--line);
  box-shadow: 0 1px 0 color-mix(in oklab, var(--ink) 6%, transparent);
}
.tile--wide .tile__frame { aspect-ratio: 16/10; }
.tile__art { width: 100%; height: 100%; }
.tile__frame::after { content: ""; position: absolute; inset: 0; box-shadow: inset 0 0 60px color-mix(in oklab, var(--ink) 14%, transparent); pointer-events: none; }
.tile__meta { display: flex; align-items: baseline; justify-content: space-between; gap: 1rem; padding-top: 0.9rem; }
.tile__meta h3 { font-family: var(--f-display); font-weight: 440; font-size: var(--step-1); letter-spacing: -0.01em; }
.tile__meta p { display: flex; gap: 0.8em; font-size: var(--step--1); color: var(--ink-3); white-space: nowrap; }
.tile__meta p span + span::before { content: "·"; margin-right: 0.8em; color: var(--cinnabar); }
.works__note { max-width: 40ch; margin: clamp(2rem, 4vw, 3.5rem) auto 0; padding-inline: var(--gutter); text-align: center; color: var(--ink-2); font-style: italic; font-family: var(--f-italic); font-size: var(--step-1); }

/* ================= LEISTUNGEN ================= */
.services { padding: var(--section-y) var(--gutter); max-width: var(--maxw); margin-inline: auto; }
.services__head { display: grid; gap: 1rem; margin-bottom: clamp(2.5rem, 5vw, 4rem); }
.services__list { border-top: 1px solid var(--line); }
.service {
  position: relative; display: grid; gap: 0.5rem;
  grid-template-columns: auto 1fr; align-items: start;
  column-gap: clamp(1rem, 3vw, 3rem);
  padding-block: clamp(1.6rem, 3vw, 2.6rem);
  border-bottom: 1px solid var(--line);
  transition: padding-left .5s var(--ease);
}
.service__no { grid-row: span 2; font-family: var(--f-display); font-style: italic; font-size: var(--step-1); color: var(--cinnabar); }
.service__name { font-family: var(--f-display); font-weight: 400; font-size: clamp(1.6rem, 1.1rem + 2.2vw, 3rem); line-height: 1; letter-spacing: -0.02em; transition: transform .5s var(--ease); }
.service__desc { max-width: 52ch; color: var(--ink-2); grid-column: 2; }
.service__tags { grid-column: 2; font-size: var(--step--1); letter-spacing: 0.04em; color: var(--ink-3); text-transform: uppercase; }
.service::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 0; background: color-mix(in oklab, var(--ochre) 22%, transparent); z-index: -1; transition: width .5s var(--ease-expo); }
@media (hover:hover){
  .service:hover { padding-left: clamp(0.8rem, 2vw, 2rem); }
  .service:hover::before { width: 100%; }
  .service:hover .service__name { color: var(--cinnabar-d); }
}

/* ================= ABLAUF / PROCESS ================= */
.process { padding: var(--section-y) var(--gutter); background: var(--ink); color: var(--canvas); }
.process__head { max-width: var(--maxw); margin: 0 auto clamp(2.5rem, 5vw, 4.5rem); display: grid; gap: 1.2rem; }
.process .section-eyebrow { color: color-mix(in oklab, var(--canvas) 65%, transparent); }
.process .section-eyebrow__num { border-color: color-mix(in oklab, var(--canvas) 25%, transparent); color: var(--ochre); }
.process .section-title { color: var(--canvas); }
.process .section-title em { color: var(--ochre); }
.process__lead { max-width: 46ch; color: color-mix(in oklab, var(--canvas) 72%, transparent); font-size: var(--step-1); }
.process__steps { max-width: var(--maxw); margin-inline: auto; display: grid; gap: 0; }
.pstep { display: grid; grid-template-columns: clamp(3.5rem, 10vw, 8rem) 1fr; gap: clamp(1rem, 3vw, 3rem); align-items: baseline; padding-block: clamp(1.8rem, 3.5vw, 3rem); border-top: 1px solid color-mix(in oklab, var(--canvas) 18%, transparent); }
.pstep:last-child { border-bottom: 1px solid color-mix(in oklab, var(--canvas) 18%, transparent); }
.pstep__num { font-family: var(--f-display); font-size: clamp(2rem, 1rem + 4vw, 4.5rem); font-weight: 300; color: var(--ochre); line-height: 1; }
.pstep__body h3 { font-family: var(--f-display); font-weight: 400; font-size: var(--step-2); margin-bottom: 0.5rem; letter-spacing: -0.01em; }
.pstep__body p { max-width: 52ch; color: color-mix(in oklab, var(--canvas) 78%, transparent); }

/* ================= ÜBER ================= */
.about { padding: var(--section-y) var(--gutter); max-width: var(--maxw); margin-inline: auto; display: grid; gap: clamp(2.5rem, 5vw, 5rem); grid-template-columns: 1fr; align-items: center; }
@media (min-width: 900px){ .about { grid-template-columns: 0.85fr 1fr; } }
.about__visual { position: relative; }
.about__portrait { position: relative; aspect-ratio: 4/5; border: 1px solid var(--line); background: var(--canvas-3); overflow: hidden; display: grid; place-items: center; box-shadow: 0 30px 60px -40px color-mix(in oklab, var(--ink) 60%, transparent); }
.about__art { position: absolute; inset: 0; width: 100%; height: 100%; opacity: 0.92; }
.about__portrait-note { position: relative; z-index: 2; font-family: var(--f-italic); font-style: italic; font-size: var(--step-1); color: color-mix(in oklab, var(--ink) 55%, transparent); background: color-mix(in oklab, var(--canvas) 75%, transparent); padding: 0.4em 1em; border-radius: 100px; backdrop-filter: blur(2px); }
.about__signature { position: absolute; right: -0.5rem; bottom: -1.6rem; width: clamp(9rem, 22vw, 14rem); color: var(--cinnabar); }
.about__signature path { stroke-dasharray: 1; stroke-dashoffset: 1; }
.about__head { font-family: var(--f-display); font-weight: 360; font-size: var(--step-3); line-height: 1; letter-spacing: -0.02em; margin-block: 0.8rem 1.4rem; }
.about__text p { color: var(--ink-2); max-width: 54ch; margin-bottom: 1rem; }
.about__facts { display: flex; flex-wrap: wrap; gap: clamp(1.4rem, 4vw, 3rem); margin-top: 2rem; padding-top: 1.6rem; border-top: 1px solid var(--line); }
.about__facts li { display: grid; gap: 0.2rem; }
.about__facts strong { font-family: var(--f-display); font-weight: 500; font-size: var(--step-2); color: var(--cinnabar); }
.about__facts span { font-size: var(--step--1); color: var(--ink-3); }

/* ================= MITMACHEN / PLAY ================= */
.play { padding: var(--section-y) var(--gutter); max-width: var(--maxw); margin-inline: auto; display: grid; gap: clamp(2rem, 4vw, 4rem); grid-template-columns: 1fr; align-items: center; }
@media (min-width: 900px){ .play { grid-template-columns: 0.9fr 1.1fr; } }
.play__intro p { color: var(--ink-2); max-width: 40ch; margin-block: 1rem 1.6rem; }
.play .section-title { margin-top: 0.6rem; }
.play__tools { display: flex; flex-wrap: wrap; align-items: center; gap: 1.2rem; }
.play__swatches { display: flex; gap: 0.5rem; }
.swatch { width: 1.9rem; height: 1.9rem; border-radius: 50%; border: 2px solid transparent; box-shadow: inset 0 0 0 2px var(--canvas); transition: transform .3s var(--ease); }
.swatch[aria-pressed="true"] { border-color: var(--ink); transform: scale(1.12); }
.swatch:hover { transform: scale(1.12); }
.play__wall { position: relative; aspect-ratio: 4/3; border: 1px solid var(--line); background: var(--canvas-2); overflow: hidden; box-shadow: inset 0 0 80px color-mix(in oklab, var(--ink) 8%, transparent); }
#play-canvas { position: absolute; inset: 0; width: 100%; height: 100%; touch-action: none; cursor: none; }
.play__hint { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); font-family: var(--f-italic); font-style: italic; font-size: var(--step-2); color: color-mix(in oklab, var(--ink) 30%, transparent); pointer-events: none; transition: opacity .4s ease; }
.play__hint.is-gone { opacity: 0; }

/* ================= STIMMEN ================= */
.voices { padding: var(--section-y) var(--gutter); max-width: var(--maxw); margin-inline: auto; }
.voices .section-eyebrow { margin-bottom: clamp(2rem, 4vw, 3rem); }
.voices__grid { display: grid; gap: clamp(1rem, 2vw, 1.6rem); grid-template-columns: 1fr; }
@media (min-width: 800px){ .voices__grid { grid-template-columns: repeat(3, 1fr); } }
.voice { padding: clamp(1.6rem, 3vw, 2.4rem); border: 1px solid var(--line); background: var(--canvas); display: grid; gap: 1.4rem; align-content: space-between; }
.voice p { font-family: var(--f-display); font-weight: 360; font-size: var(--step-1); line-height: 1.32; letter-spacing: -0.01em; }
.voice p::first-letter { color: var(--cinnabar); }
.voice--accent { background: var(--ink); color: var(--canvas); }
.voice--accent p em { color: var(--ochre); font-family: var(--f-italic); }
.voice footer { display: grid; gap: 0.1rem; font-size: var(--step--1); }
.voice footer span:first-child { font-weight: 600; }
.voice footer span:last-child { color: var(--ink-3); }
.voice--accent footer span:last-child { color: color-mix(in oklab, var(--canvas) 60%, transparent); }
@media (min-width: 800px){ .voice:nth-child(2){ transform: translateY(2rem); } }

/* ================= ANFRAGE / WIZARD ================= */
.booking { padding: var(--section-y) var(--gutter); background: var(--canvas-2); border-top: 1px solid var(--line); }
.booking { display: grid; gap: clamp(2.5rem, 5vw, 5rem); grid-template-columns: 1fr; max-width: var(--maxw); margin-inline: auto; }
@media (min-width: 980px){ .booking { grid-template-columns: 0.8fr 1fr; align-items: start; } .booking__intro { position: sticky; top: 6rem; } }
.booking__intro p { color: var(--ink-2); max-width: 38ch; margin-block: 1rem 1.6rem; }
.booking__assure { display: grid; gap: 0.6rem; }
.booking__assure li { position: relative; padding-left: 1.6em; color: var(--ink-2); font-size: var(--step--1); }
.booking__assure li::before { content: "✓"; position: absolute; left: 0; color: var(--viridian); font-weight: 700; }

.wizard { position: relative; background: var(--canvas); border: 1px solid var(--line); padding: clamp(1.4rem, 3vw, 2.6rem); box-shadow: 0 40px 80px -60px color-mix(in oklab, var(--ink) 70%, transparent); }
.wizard__progress { display: flex; align-items: center; gap: 1rem; margin-bottom: clamp(1.6rem, 3vw, 2.4rem); }
.wizard__bar { flex: 1; height: 3px; background: var(--line); border-radius: 4px; overflow: hidden; }
.wizard__bar i { display: block; height: 100%; width: 20%; background: var(--cinnabar); border-radius: 4px; transition: width .55s var(--ease-expo); }
.wizard__count { font-size: var(--step--1); color: var(--ink-3); font-variant-numeric: tabular-nums; }
.wizard__count b { color: var(--ink); }

.wizard__step { border: none; padding: 0; display: none; }
.wizard__step.is-active { display: block; animation: stepin .5s var(--ease) both; }
@keyframes stepin { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }
.wizard__q { font-family: var(--f-display); font-weight: 400; font-size: var(--step-2); line-height: 1.05; letter-spacing: -0.01em; margin-bottom: 1.2rem; padding: 0; }
.wizard__hint { font-size: var(--step--1); color: var(--ink-3); margin-top: -0.6rem; margin-bottom: 1rem; }

.optgrid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.7rem; }
@media (min-width: 520px){ .optgrid { grid-template-columns: repeat(3, 1fr); } }
.opt { position: relative; cursor: pointer; }
.opt input { position: absolute; opacity: 0; }
.opt__face { display: grid; gap: 0.2rem; padding: 1rem; border: 1px solid var(--line); height: 100%; transition: border-color .3s, background .3s, transform .3s var(--ease); }
.opt__face b { font-weight: 600; }
.opt__face small { color: var(--ink-3); font-size: 0.82em; }
.opt:hover .opt__face { transform: translateY(-2px); border-color: color-mix(in oklab, var(--ink) 30%, transparent); }
.opt input:checked + .opt__face { border-color: var(--cinnabar); background: color-mix(in oklab, var(--cinnabar) 8%, transparent); box-shadow: inset 0 0 0 1px var(--cinnabar); }
.opt input:focus-visible + .opt__face { outline: 2px solid var(--cinnabar); outline-offset: 2px; }

.field { margin-bottom: 1.2rem; display: grid; gap: 0.5rem; }
.field--row { grid-template-columns: 1fr; gap: 1.2rem; }
@media (min-width: 520px){ .field--row { grid-template-columns: 1fr 1fr; } }
.field label, .field > div > label { font-size: var(--step--1); font-weight: 600; letter-spacing: 0.02em; }
.wizard input[type="text"], .wizard input[type="email"], .wizard input[type="tel"], .wizard textarea {
  width: 100%; padding: 0.85em 1em; background: var(--canvas-2);
  border: 1px solid var(--line); border-radius: var(--radius); transition: border-color .3s, background .3s;
}
.wizard input:focus, .wizard textarea:focus { outline: none; border-color: var(--cinnabar); background: var(--canvas); }
.wizard textarea { resize: vertical; min-height: 3.5em; }

.chips, .tags { display: flex; flex-wrap: wrap; gap: 0.5rem; }
.chip input, .tagopt input { position: absolute; opacity: 0; }
.chip span, .tagopt span { display: inline-block; padding: 0.55em 1em; border: 1px solid var(--line); border-radius: 100px; font-size: var(--step--1); cursor: pointer; transition: all .25s var(--ease); }
.chip span:hover, .tagopt span:hover { border-color: var(--ink); }
.chip input:checked + span, .tagopt input:checked + span { background: var(--ink); color: var(--canvas); border-color: var(--ink); }
.chip input:focus-visible + span, .tagopt input:focus-visible + span { outline: 2px solid var(--cinnabar); outline-offset: 2px; }

.consent { display: flex; gap: 0.7em; align-items: start; font-size: var(--step--1); color: var(--ink-2); margin-top: 0.5rem; cursor: pointer; }
.consent input { margin-top: 0.25em; accent-color: var(--cinnabar); width: 1.05em; height: 1.05em; flex: 0 0 auto; }
.consent a { text-decoration: underline; text-underline-offset: 2px; }

.wizard__nav { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-top: 1.8rem; }
.wizard__back { font-weight: 600; font-size: var(--step--1); color: var(--ink-2); position: relative; }
.wizard__back::before { content: "←"; margin-right: 0.5em; }
.wizard__back:hover { color: var(--ink); }
.wizard__next { margin-left: auto; }

.wizard.is-invalid .wizard__step.is-active { animation: shake .4s ease; }
@keyframes shake { 0%,100%{transform:translateX(0)} 25%{transform:translateX(-6px)} 75%{transform:translateX(6px)} }
.field--error input, .field--error textarea, .optgrid.field--error { border-color: var(--cinnabar) !important; }
.err-msg { color: var(--cinnabar-d); font-size: 0.8em; font-weight: 600; }

.wizard__done { display: grid; gap: 1rem; justify-items: start; text-align: left; animation: stepin .6s var(--ease) both; }
.wizard__done[hidden] { display: none; }
.wizard__done-mark { width: 4rem; height: 4rem; border-radius: 50%; background: color-mix(in oklab, var(--viridian) 16%, transparent); color: var(--viridian); display: grid; place-items: center; }
.wizard__done-mark svg { width: 60%; }
.wizard__done-mark path { stroke-dasharray: 1; stroke-dashoffset: 1; animation: draw 0.8s var(--ease) 0.2s forwards; }
@keyframes draw { to { stroke-dashoffset: 0; } }
.wizard__done h3 { font-family: var(--f-display); font-weight: 400; font-size: var(--step-2); letter-spacing: -0.01em; }
.wizard__done p { color: var(--ink-2); max-width: 44ch; }
.wizard__restart { font-size: var(--step--1); color: var(--ink-3); text-decoration: underline; text-underline-offset: 3px; margin-top: 0.4rem; }

/* ================= FOOTER ================= */
.foot { background: var(--ink); color: var(--canvas); padding: var(--section-y) var(--gutter) clamp(1.5rem, 3vw, 2.5rem); }
.foot__cta { max-width: var(--maxw); margin-inline: auto; padding-bottom: clamp(3rem, 6vw, 5rem); border-bottom: 1px solid color-mix(in oklab, var(--canvas) 18%, transparent); }
.foot .section-eyebrow { color: color-mix(in oklab, var(--canvas) 65%, transparent); }
.foot .section-eyebrow__num { border-color: color-mix(in oklab, var(--canvas) 25%, transparent); color: var(--ochre); }
.foot__head { font-family: var(--f-display); font-weight: 340; font-size: var(--step-4); line-height: 0.95; letter-spacing: -0.03em; margin-block: 1.2rem 2rem; }
.foot__head em { font-family: var(--f-italic); font-style: italic; color: var(--ochre); }
.foot__mail { display: inline-block; font-family: var(--f-display); font-size: var(--step-2); font-style: italic; position: relative; }
.foot__mail::after { content: ""; position: absolute; left: 0; bottom: 0.05em; width: 100%; height: 1px; background: currentColor; transform: scaleX(0); transform-origin: left; transition: transform .5s var(--ease); }
.foot__mail:hover::after { transform: scaleX(1); }
.foot__cols { max-width: var(--maxw); margin: clamp(2.5rem,5vw,4rem) auto 0; display: grid; grid-template-columns: repeat(2, 1fr); gap: 2rem; }
@media (min-width: 720px){ .foot__cols { grid-template-columns: repeat(4, 1fr); } }
.foot__col { display: grid; gap: 0.6rem; align-content: start; }
.foot__label { font-size: var(--step--1); text-transform: uppercase; letter-spacing: 0.12em; color: var(--ochre); margin-bottom: 0.3rem; }
.foot__col a, .foot__col span { color: color-mix(in oklab, var(--canvas) 78%, transparent); font-size: var(--step-0); width: max-content; }
.foot__col a { position: relative; transition: color .3s; }
.foot__col a:hover { color: var(--canvas); }
.foot__base { max-width: var(--maxw); margin: clamp(3rem, 6vw, 5rem) auto 0; }
.foot__wordmark { display: block; font-family: var(--f-display); font-weight: 300; font-size: clamp(4rem, 1rem + 18vw, 18rem); line-height: 0.8; letter-spacing: -0.04em; color: color-mix(in oklab, var(--canvas) 92%, transparent); overflow: hidden; }
.foot__fine { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 1rem; margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px solid color-mix(in oklab, var(--canvas) 18%, transparent); font-size: var(--step--1); color: color-mix(in oklab, var(--canvas) 60%, transparent); }

/* ================= LEGAL PAGES ================= */
.legal { max-width: 52rem; margin-inline: auto; padding: clamp(7rem, 12vw, 11rem) var(--gutter) var(--section-y); }
.legal h1 { font-family: var(--f-display); font-weight: 360; font-size: var(--step-4); letter-spacing: -0.02em; line-height: 1; margin-bottom: 2.5rem; }
.legal h2 { font-family: var(--f-display); font-weight: 500; font-size: var(--step-1); margin-block: 2rem 0.6rem; }
.legal p, .legal li { color: var(--ink-2); margin-bottom: 0.8rem; max-width: 64ch; }
.legal a { color: var(--cinnabar-d); text-decoration: underline; text-underline-offset: 2px; }
.legal__back { display: inline-flex; align-items: center; gap: 0.5em; margin-bottom: 3rem; font-size: var(--step--1); font-weight: 600; }
.legal__back::before { content: "←"; }
.legal__note { background: var(--canvas-2); border-left: 2px solid var(--ochre); padding: 1rem 1.2rem; font-size: var(--step--1); color: var(--ink-2); }
