/* =========================================================
   ZOKI FLACHDACH GmbH — Stylesheet
   Palette: warm off-white / ink black / charcoal / stone gray
   Signature accent: "Torch line" — ember gradient, references
   the torch-applied membrane work shown in the logo.
   ========================================================= */

:root{
  --bg:        #F5F3EF;
  --bg-warm:   #EFEBE3;
  --ink:       #141412;
  --charcoal:  #1B1A18;
  --stone:     #8C897F;
  --stone-lt:  #C9C5BA;
  --line:      #DEDAD0;
  --paper:     #FFFFFF;
  --ember:     #C1440E;
  --ember-lt:  #E86A2E;

  --display: 'Oswald', 'Arial Narrow', sans-serif;
  --body:    'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  --maxw: 1180px;
  --pad: clamp(20px, 5vw, 64px);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *{ animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; }
}

body{
  font-family:var(--body);
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }

h1,h2,h3,h4{
  font-family:var(--display);
  font-weight:600;
  letter-spacing:0.01em;
  text-transform:uppercase;
  line-height:1.12;
}

.container{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--pad); }

:focus-visible{
  outline:3px solid var(--ember);
  outline-offset:3px;
}

/* ---------- Torch line signature ---------- */
.torch-line{
  position:relative;
  height:3px;
  width:64px;
  background:var(--line);
  overflow:hidden;
  margin-block:18px 28px;
}
.torch-line::after{
  content:"";
  position:absolute;
  inset:0;
  width:0%;
  background:linear-gradient(90deg, var(--ember), var(--ember-lt));
  transition:width 1.1s cubic-bezier(.16,.84,.44,1);
}
.reveal.is-visible .torch-line::after{ width:100%; }

/* ---------- Reveal on scroll ---------- */
.reveal{
  opacity:0;
  transform:translateY(28px);
  transition:opacity .8s ease, transform .8s cubic-bezier(.16,.84,.44,1);
}
.reveal.is-visible{ opacity:1; transform:translateY(0); }
.reveal-delay-1.is-visible{ transition-delay:.12s; }
.reveal-delay-2.is-visible{ transition-delay:.24s; }

/* ---------- Header ---------- */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:100;
  padding:18px 0;
  color:var(--paper);
  text-shadow:0 1px 6px rgba(0,0,0,.6);
  transition:background .35s ease, padding .35s ease, box-shadow .35s ease, color .35s ease;
}
.site-header .container{
  display:flex; align-items:center; justify-content:space-between;
}
.nav-wrap{ display:flex; align-items:center; gap:30px; }
.nav-cta{ display:none; }
@media (min-width:720px){ .nav-cta{ display:inline-flex; } }
.site-header.scrolled{
  background:rgba(245,243,239,0.94);
  backdrop-filter:blur(8px);
  padding:10px 0;
  box-shadow:0 1px 0 var(--line);
  color:var(--ink);
  text-shadow:none;
}
.brand{
  display:flex; align-items:center; gap:12px;
  font-family:var(--display); font-size:1.05rem; letter-spacing:.04em;
  text-transform:uppercase;
}
.brand img{ height:38px; width:auto; filter:drop-shadow(0 1px 5px rgba(0,0,0,.4)); }
.site-header.scrolled .brand img{ filter:none; }
.brand span{ display:none; }
@media (min-width:520px){ .brand span{ display:inline; } }

.nav-desktop{ display:none; align-items:center; gap:34px; }
.nav-desktop > a{
  font-size:.86rem; text-transform:uppercase; letter-spacing:.08em;
  position:relative; padding-block:4px;
}
.nav-desktop > a::after{
  content:""; position:absolute; left:0; bottom:0; height:2px; width:0;
  background:var(--ember); transition:width .3s ease;
}
.nav-desktop > a:hover::after{ width:100%; }
.nav-desktop > a.current::after{ width:100%; }
@media (min-width:920px){ .nav-desktop{ display:flex; } }

/* Dropdown */
.nav-item{ position:relative; }
.nav-item-trigger{
  display:flex; align-items:center; gap:6px; background:none; border:none; cursor:pointer;
  font-family:var(--body); font-size:.86rem; text-transform:uppercase; letter-spacing:.08em; color:inherit;
  text-shadow:inherit;
  padding-block:4px;
}
.nav-item-trigger svg{ width:9px; height:9px; transition:transform .3s ease; }
.nav-item-trigger svg path{ stroke:currentColor; }
.nav-item-trigger.current{ color:var(--ember); text-shadow:none; }
.nav-item.open .nav-item-trigger svg{ transform:rotate(180deg); }
.dropdown-panel{
  position:absolute; top:100%; left:50%; transform:translate(-50%,8px);
  min-width:280px; background:var(--paper); border:1px solid var(--line); box-shadow:0 18px 40px rgba(20,20,18,.16);
  padding:10px; opacity:0; pointer-events:none; transition:opacity .25s ease, transform .25s ease;
  color:var(--ink); text-shadow:none;
}
.dropdown-panel a, .dropdown-panel a b{ color:var(--ink); text-shadow:none; }
.nav-item.open .dropdown-panel{ opacity:1; pointer-events:auto; transform:translate(-50%,14px); }
.dropdown-panel a{
  display:flex; flex-direction:column; gap:2px; padding:12px 14px; font-size:.9rem; text-transform:none; letter-spacing:0;
}
.dropdown-panel a:hover{ background:var(--bg); }
.dropdown-panel a b{ font-family:var(--display); font-size:.86rem; text-transform:uppercase; letter-spacing:.03em; font-weight:500; }
.dropdown-panel a span{ color:var(--stone); font-size:.82rem; }
.dropdown-panel a + a{ border-top:1px solid var(--line); }

.mobile-menu .sub-list{ display:flex; flex-direction:column; gap:16px; align-items:center; }
.mobile-menu .sub-list a{ font-size:1rem; color:var(--stone-lt); }

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:var(--display); text-transform:uppercase; letter-spacing:.06em;
  font-size:.82rem; padding:14px 28px;
  border:1.5px solid var(--ink); cursor:pointer;
  transition:background .3s ease, color .3s ease, border-color .3s ease, transform .2s ease;
}
.btn-solid{ background:var(--ink); color:var(--paper); }
.btn-solid:hover{ background:var(--ember); border-color:var(--ember); transform:translateY(-2px); }
.btn-ghost{ background:transparent; color:var(--ink); }
.btn-ghost:hover{ background:var(--ink); color:var(--paper); transform:translateY(-2px); }
.btn-on-dark.btn-ghost{ color:var(--paper); border-color:rgba(255,255,255,.6); }
.btn-on-dark.btn-ghost:hover{ background:var(--paper); color:var(--ink); }

.nav-toggle{
  display:flex; flex-direction:column; gap:5px; width:30px; background:none; border:none; cursor:pointer; z-index:110;
}
.nav-toggle span{ height:2px; background:var(--paper); width:100%; transition:transform .3s ease, opacity .3s ease, background .35s ease; box-shadow:0 1px 3px rgba(0,0,0,.4); }
.site-header.scrolled .nav-toggle span{ background:var(--ink); box-shadow:none; }
.nav-toggle.open span{ background:var(--paper) !important; box-shadow:none; }
.nav-toggle.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2){ opacity:0; }
.nav-toggle.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
@media (min-width:920px){ .nav-toggle{ display:none; } }

.mobile-menu{
  position:fixed; inset:0; background:var(--ink); z-index:105;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:34px;
  transform:translateY(-100%); transition:transform .45s cubic-bezier(.76,0,.24,1);
}
.mobile-menu.open{ transform:translateY(0); }
.mobile-menu a{
  color:var(--paper); font-family:var(--display); text-transform:uppercase;
  font-size:1.5rem; letter-spacing:.04em;
}

/* ---------- Hero ---------- */
.hero{
  position:relative; min-height:100svh; display:flex; align-items:flex-end;
  overflow:hidden; color:var(--paper);
}
.hero-slide{
  position:absolute; inset:0; background-size:cover; background-position:center;
  opacity:0; transition:opacity 1.6s ease;
}
.hero-slide.active{ opacity:1; }
.hero-scrim{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(20,20,18,.35) 0%, rgba(20,20,18,.35) 40%, rgba(20,20,18,.92) 100%);
}
.hero-content{
  position:relative; z-index:2; padding-block:120px 88px; width:100%;
}
.hero-eyebrow{
  font-size:.8rem; letter-spacing:.18em; text-transform:uppercase; color:var(--stone-lt);
  margin-bottom:14px; display:flex; align-items:center; gap:10px;
}
.hero-eyebrow::before{ content:""; width:26px; height:1.5px; background:var(--ember-lt); }
.hero h1{
  font-size:clamp(2.4rem, 6.4vw, 4.6rem);
  max-width:15ch;
  margin-bottom:18px;
}
.hero-heading-row{ display:flex; align-items:center; flex-wrap:wrap; gap:28px; margin-bottom:18px; }
.hero-heading-row h1{ margin-bottom:0; }
.hero-logo{ height:clamp(80px,11vw,148px); width:auto; flex:0 0 auto; margin-left:auto; filter:drop-shadow(0 6px 18px rgba(0,0,0,.5)); }
@media (max-width:600px){
  .hero-logo{ margin-left:0; height:64px; }
}
.hero p{
  font-size:clamp(1rem, 1.6vw, 1.2rem); max-width:46ch; color:#EDEAE3; margin-bottom:36px;
}
.hero-actions{ display:flex; flex-wrap:wrap; gap:16px; }
@media (max-width:600px){
  .hero-content{ padding-block:104px 56px; }
  .page-hero .hero-content{ padding-block:100px 44px; }
  .hero-actions{ gap:12px; }
  .hero-actions .btn{ flex:1 1 auto; text-align:center; }
}
.scroll-cue{
  position:absolute; bottom:26px; left:50%; transform:translateX(-50%); z-index:2;
  width:1px; height:46px; background:rgba(255,255,255,.5);
}
.scroll-cue::after{
  content:""; position:absolute; top:0; left:-2.5px; width:6px; height:6px; border-radius:50%;
  background:var(--ember-lt); animation:cue 2.2s ease-in-out infinite;
}
@keyframes cue{ 0%{ top:0; opacity:1;} 90%{ top:100%; opacity:0;} 100%{ top:100%; opacity:0;} }

/* ---------- Trust strip ---------- */
.trust{
  background:var(--paper); border-bottom:1px solid var(--line);
  padding-block:40px;
}
.trust-grid{
  display:grid; gap:28px; grid-template-columns:1fr;
}
@media (min-width:720px){ .trust-grid{ grid-template-columns:repeat(3,1fr); } }
.trust-item{ border-left:2px solid var(--ember); padding-left:18px; }
.trust-item strong{
  display:block; font-family:var(--display); font-size:1.1rem; text-transform:uppercase; letter-spacing:.02em; margin-bottom:4px;
}
.trust-item span{ color:var(--stone); font-size:.92rem; }

/* ---------- Section basics ---------- */
section{ padding-block:96px; }
.section-head{ max-width:640px; margin-bottom:56px; }
.eyebrow{
  font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ember);
}
.section-head h2{ font-size:clamp(1.9rem,3.6vw,2.7rem); }
.section-head p{ color:var(--stone); margin-top:18px; font-size:1.05rem; max-width:56ch; }

/* ---------- Services ---------- */
.service{
  display:grid; gap:40px; align-items:center;
  grid-template-columns:1fr; padding-block:56px;
  border-top:1px solid var(--line);
}
.service:last-child{ border-bottom:1px solid var(--line); }
@media (min-width:860px){
  .service{ grid-template-columns:1fr 1fr; gap:64px; }
  .service.flip .service-media{ order:2; }
  .service.flip .service-text{ order:1; }
}
.service-media{
  position:relative; overflow:hidden; aspect-ratio:4/3; background:var(--stone-lt);
}
.service-media img{
  width:100%; height:100%; object-fit:cover;
  transition:transform .7s cubic-bezier(.16,.84,.44,1);
}
.service:hover .service-media img{ transform:scale(1.045); }
.service-index{
  font-family:var(--display); font-size:.78rem; color:var(--stone); letter-spacing:.14em;
}
.service-text h3{ font-size:clamp(1.5rem,2.6vw,2rem); margin-top:8px; }
.service-text p{ margin-top:16px; color:var(--stone); }
.service-list{ margin-top:20px; display:flex; flex-direction:column; gap:9px; }
.service-list li{
  display:flex; gap:10px; align-items:flex-start; font-size:.96rem;
}
.service-list li::before{
  content:""; width:6px; height:6px; margin-top:9px; flex:0 0 auto; background:var(--ember);
}

.callout{
  margin-top:64px; padding:40px var(--pad); background:var(--ink); color:var(--paper);
  display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:24px;
}
.callout p{
  font-family:var(--display); text-transform:uppercase; font-size:clamp(1.1rem,2.4vw,1.5rem);
  letter-spacing:.01em; max-width:32ch;
}

/* ---------- Gallery ---------- */
.gallery-dark{ background:var(--charcoal); color:var(--paper); }
.gallery-dark .eyebrow{ color:var(--ember-lt); }
.gallery-dark .section-head p{ color:var(--stone-lt); }
.compare-grid{ display:grid; gap:28px; grid-template-columns:1fr; }
@media (min-width:760px){ .compare-grid{ grid-template-columns:repeat(2,1fr); } }
.compare{
  position:relative; overflow:hidden; aspect-ratio:5/4;
}
.compare img{ width:100%; height:100%; object-fit:cover; }
.compare-tag{
  position:absolute; top:14px; left:14px; z-index:2;
  font-family:var(--display); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase;
  padding:6px 12px; background:var(--paper); color:var(--ink);
}
.compare-tag.after{ background:var(--ember); color:var(--paper); }

.gallery-grid{
  margin-top:56px; display:grid; gap:16px;
  grid-template-columns:repeat(2,1fr);
}
@media (min-width:720px){ .gallery-grid{ grid-template-columns:repeat(4,1fr); } }
.gallery-grid figure{ position:relative; overflow:hidden; aspect-ratio:1/1; cursor:pointer; }
.gallery-grid img{ width:100%; height:100%; object-fit:cover; transition:transform .6s ease, filter .4s ease; }
.gallery-grid figure:hover img{ transform:scale(1.08); filter:brightness(.7); }
.gallery-grid figure::after{
  content:"+"; position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-family:var(--display); font-size:2rem; color:var(--paper); opacity:0; transition:opacity .4s ease;
}
.gallery-grid figure:hover::after{ opacity:1; }

.lightbox{
  position:fixed; inset:0; background:rgba(14,13,12,.94); z-index:200;
  display:none; align-items:center; justify-content:center; padding:5vw;
}
.lightbox.open{ display:flex; }
.lightbox img{ max-width:100%; max-height:88vh; }
.lightbox-close{
  position:absolute; top:24px; right:28px; color:var(--paper); font-size:1.8rem; background:none; border:none; cursor:pointer;
}

/* ---------- About ---------- */
.about{ display:grid; gap:56px; grid-template-columns:1fr; }
@media (min-width:860px){ .about{ grid-template-columns:0.8fr 1.2fr; align-items:center; } }
.about-photo{ position:relative; }
.about-photo img{ width:100%; aspect-ratio:3/4; object-fit:cover; }
.about-photo::before{
  content:""; position:absolute; top:-16px; left:-16px; right:16px; bottom:16px;
  border:1.5px solid var(--ember); z-index:-1;
}
.about-name{ font-family:var(--display); font-size:1.5rem; text-transform:uppercase; }
.about-role{ color:var(--ember); font-size:.85rem; letter-spacing:.1em; text-transform:uppercase; margin-top:4px; }
.about-text p{ margin-top:18px; color:var(--stone); }
.qual-list{ margin-top:26px; display:flex; flex-direction:column; gap:12px; }
.qual-list li{ display:flex; gap:12px; align-items:baseline; font-size:.98rem; }
.qual-list li b{ font-family:var(--display); color:var(--ember); font-weight:500; }
.about-meta{
  margin-top:36px; padding-top:26px; border-top:1px solid var(--line);
  display:grid; gap:10px; font-size:.86rem; color:var(--stone);
}

/* ---------- Contact ---------- */
.contact{ background:var(--bg-warm); }
.contact-grid{ display:grid; gap:56px; grid-template-columns:1fr; }
@media (min-width:900px){ .contact-grid{ grid-template-columns:1.1fr 0.9fr; } }

.field{ margin-bottom:20px; }
.field label{
  display:block; font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; color:var(--stone); margin-bottom:8px;
}
.field input, .field textarea{
  width:100%; border:none; border-bottom:1.5px solid var(--stone-lt); background:transparent;
  padding:10px 2px; font-family:var(--body); font-size:1rem; color:var(--ink);
  transition:border-color .3s ease;
}
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--ember); }
.field textarea{ resize:vertical; min-height:110px; }
.consent{ display:flex; gap:12px; align-items:flex-start; margin-block:26px 28px; font-size:.86rem; color:var(--stone); }
.consent input{ margin-top:4px; }
.consent a{ color:var(--ink); text-decoration:underline; text-underline-offset:2px; }
.form-note{ margin-top:16px; font-size:.85rem; }
.form-note.success{ color:#2E6B3E; }
.form-note.error{ color:var(--ember); }

.contact-info{ display:flex; flex-direction:column; gap:28px; }
.info-card{ background:var(--paper); padding:26px; border-left:2px solid var(--ember); }
.info-card h4{ font-size:.95rem; letter-spacing:.04em; }
.info-card p, .info-card a{ margin-top:8px; color:var(--stone); font-size:.96rem; }
.map-wrap{ position:relative; aspect-ratio:4/3; background:var(--ink); overflow:hidden; }
.map-wrap iframe{ width:100%; height:100%; border:0; }
.map-cover{
  position:absolute; inset:0; background:var(--charcoal); color:var(--paper);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:14px; text-align:center; padding:20px;
}
.map-cover span{ font-size:.86rem; color:var(--stone-lt); max-width:26ch; }

/* ---------- Footer ---------- */
footer{ background:var(--ink); color:var(--stone-lt); padding-block:56px 30px; }
.footer-brand{ display:flex; align-items:center; gap:16px; margin-bottom:14px; }
.footer-brand img{ height:58px; width:auto; }
.footer-brand span{ font-family:var(--display); font-size:1.05rem; text-transform:uppercase; color:var(--paper); letter-spacing:.04em; }
.footer-grid{
  display:grid; gap:36px; grid-template-columns:1fr; padding-bottom:36px; border-bottom:1px solid rgba(255,255,255,.12);
}
@media (min-width:760px){ .footer-grid{ grid-template-columns:1.3fr 1fr 1fr; } }
.footer-col h5{
  font-family:var(--display); text-transform:uppercase; font-size:.82rem; letter-spacing:.1em; color:var(--paper); margin-bottom:14px;
}
.footer-col a, .footer-col p{ display:block; font-size:.92rem; margin-bottom:8px; }
.footer-col a:hover{ color:var(--ember-lt); }
.footer-bottom{
  padding-top:22px; display:flex; flex-wrap:wrap; justify-content:space-between; gap:12px; font-size:.8rem; color:var(--stone);
}

/* ---------- Page hero (subpages) ---------- */
.page-hero{
  position:relative; min-height:64vh; display:flex; align-items:flex-end;
  background-size:cover; background-position:center; color:var(--paper);
}
.page-hero .hero-scrim{ background:linear-gradient(180deg, rgba(20,20,18,.45) 0%, rgba(20,20,18,.9) 100%); }
.page-hero .hero-content{ padding-block:150px 64px; }
.page-hero h1{ font-size:clamp(2.1rem,5vw,3.4rem); max-width:18ch; }
.page-hero p{ max-width:52ch; }
.breadcrumb{
  position:relative; z-index:2; display:flex; gap:8px; align-items:center;
  font-size:.78rem; letter-spacing:.06em; text-transform:uppercase; color:var(--stone-lt); margin-bottom:16px;
}
.breadcrumb a:hover{ color:var(--paper); }
.breadcrumb span{ color:var(--ember-lt); }

/* ---------- Intro row on service pages ---------- */
.service-intro{ display:grid; gap:48px; grid-template-columns:1fr; }
@media (min-width:860px){ .service-intro{ grid-template-columns:0.9fr 1.1fr; } }
.service-intro .lede{ font-size:1.15rem; color:var(--ink); }
.service-intro .support{ color:var(--stone); margin-top:16px; }

/* ---------- Overview cards (Leistungen page) ---------- */
.card-grid{ display:grid; gap:28px; grid-template-columns:1fr; }
@media (min-width:640px){ .card-grid{ grid-template-columns:repeat(2,1fr); } }
.service-card{
  display:block; background:var(--paper); border:1px solid var(--line);
  transition:transform .35s cubic-bezier(.16,.84,.44,1), box-shadow .35s ease;
}
.service-card:hover{ transform:translateY(-6px); box-shadow:0 22px 40px rgba(20,20,18,.1); }
.service-card-media{ aspect-ratio:16/10; overflow:hidden; }
.service-card-media img{ width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.service-card:hover .service-card-media img{ transform:scale(1.06); }
.service-card-body{ padding:26px; }
.service-card-body .service-index{ display:block; margin-bottom:6px; }
.service-card-body h3{ font-size:1.3rem; }
.service-card-body p{ color:var(--stone); margin-top:10px; font-size:.94rem; }
.service-card-body .more{
  margin-top:16px; display:inline-flex; align-items:center; gap:8px;
  font-size:.78rem; text-transform:uppercase; letter-spacing:.08em; color:var(--ember);
}

/* ---------- Cross links between service pages ---------- */
.cross-links{ border-top:1px solid var(--line); padding-top:56px; }
.cross-grid{ display:grid; gap:20px; grid-template-columns:1fr; }
@media (min-width:640px){ .cross-grid{ grid-template-columns:repeat(3,1fr); } }
.cross-card{
  display:flex; flex-direction:column; gap:6px; padding:22px; border:1px solid var(--line);
  transition:border-color .3s ease, background .3s ease;
}
.cross-card:hover{ border-color:var(--ink); background:var(--paper); }
.cross-card span{ font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--ember); }
.cross-card b{ font-family:var(--display); text-transform:uppercase; font-size:1.02rem; font-weight:500; }

/* ---------- Index page teasers ---------- */
.teaser-intro{ display:grid; gap:48px; grid-template-columns:1fr; align-items:center; }
@media (min-width:860px){ .teaser-intro{ grid-template-columns:1fr 1fr; } }

/* ---------- Legal pages ---------- */
.legal-hero{ padding-block:150px 60px; background:var(--ink); color:var(--paper); }
.legal-hero h1{ font-size:clamp(2rem,4vw,2.8rem); }
.legal-body{ padding-block:64px; max-width:820px; }
.legal-body h2{ text-transform:none; font-family:var(--body); font-weight:700; font-size:1.25rem; margin-top:42px; margin-bottom:14px; }
.legal-body h2:first-child{ margin-top:0; }
.legal-body p, .legal-body li{ color:var(--ink); margin-bottom:12px; font-size:.98rem; }
.legal-body ul{ list-style:disc; padding-left:22px; margin-bottom:12px; }
.legal-body a{ text-decoration:underline; text-underline-offset:2px; }
.back-link{ display:inline-flex; align-items:center; gap:8px; margin-bottom:20px; font-size:.86rem; text-transform:uppercase; letter-spacing:.06em; color:var(--stone-lt); }
