/* =====================================================================
   Bespoke identity: Schreinerei Stutz (St. Gallen)
   Character: crafted, warm, heritage. Sturdy slab-serif headlines, the
   squared corners of good joinery, a fine wood-grain in the hero.
   Built on the Lokaldigital engine, themed far beyond colour.
   ===================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Bitter:wght@500;600;700;800&display=swap');

:root{
  --brand:#A8682C;
  --brand-2:#5A3A18;
  --brand-ink:#ffffff;
  --brand-tint:#f5ece0;
  --grain:#caa06a;             /* lighter oak highlight */
  --font-display:"Bitter", Georgia, serif;
  --radius:10px;               /* sturdy, like a clean joint */
  --shadow:0 2px 4px rgba(60,38,12,.08), 0 24px 48px -26px rgba(90,58,24,.55);
}

/* =====================================================================
   BESPOKE LAYOUT - Schreinerei Stutz
   Direction: warm craft portfolio, gallery-first, editorial serif.
   Distinct from the standard hero+grid template:
     centered serif cover -> work mosaic FIRST -> materials band ->
     services as prose notes (rules, not cards) -> reasons w/ serif
     numerals -> flow line -> ONE framed quote -> inline region ->
     warm left-aligned contact. New class names; chrome reused.
   ===================================================================== */
h1,h2,h3,h4{font-weight:700;letter-spacing:-.01em}
.logo .mark{border-radius:9px}
.btn{border-radius:8px}

/* warm paper + the faintest vertical wood-grain wash down the page */
body{background:var(--paper-2);
  background-image:repeating-linear-gradient(90deg, rgba(90,58,24,.016) 0 3px, transparent 3px 9px)}

/* small-caps eyebrow with a short rule, like a workshop label */
.eyebrow{letter-spacing:.18em;display:inline-flex;align-items:center;gap:.6em;color:var(--brand-2)}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--brand)}

/* shared serif heading treatment for bespoke sections */
.serif-h{font-family:var(--font-display);font-weight:800;letter-spacing:-.02em;
  font-size:clamp(2rem,4.2vw,3rem);line-height:1.05;color:var(--brand-2);margin-top:.55rem}

/* ---------- HERO COVER: centered editorial serif over warm wood ---------- */
.cover{position:relative;overflow:hidden;color:#fff;
  background:linear-gradient(168deg,#3a2410 0%,var(--brand-2) 44%,#8a531f 100%)}
.cover-grain{position:absolute;inset:0;pointer-events:none;opacity:.6;
  background:
    repeating-linear-gradient(91deg, rgba(0,0,0,.10) 0 1px, transparent 1px 6px),
    repeating-linear-gradient(90deg, rgba(255,220,160,.05) 0 2px, transparent 2px 13px),
    radial-gradient(900px 460px at 70% -8%, rgba(255,221,165,.30), transparent 62%),
    radial-gradient(720px 480px at 8% 116%, rgba(0,0,0,.42), transparent 55%)}
.cover-in{position:relative;z-index:1;text-align:center;max-width:880px;
  padding:clamp(72px,12vw,150px) clamp(18px,5vw,40px) clamp(64px,10vw,130px)}
.cover-cap{font-family:var(--font-body);font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  font-size:.74rem;color:var(--grain);margin-bottom:1.4rem}
.cover-title{font-family:var(--font-display);font-weight:800;color:#fff;letter-spacing:-.02em;
  font-size:clamp(2.7rem,7.2vw,5.4rem);line-height:1.02}
.cover-sub{margin:1.5rem auto 0;max-width:46ch;font-size:clamp(1.04rem,2vw,1.25rem);
  color:rgba(255,255,255,.86);line-height:1.55}
.cover-cta{margin-top:2.3rem;display:flex;justify-content:center;align-items:center;gap:1.4rem;flex-wrap:wrap}
.cover .btn-call{background:#fff;color:var(--brand-2);padding:.9em 1.9em;font-size:1.05rem}
.cover .btn-call:hover{transform:translateY(-2px);box-shadow:0 16px 30px -16px rgba(0,0,0,.6)}
.cover-tel{display:inline-flex;align-items:center;gap:.5em;font-family:var(--font-display);
  font-weight:700;font-size:1.05rem;color:#fff;border-bottom:1px solid rgba(255,255,255,.4);padding-bottom:2px}
.cover-tel svg{width:1.05em;height:1.05em}
.cover-tel:hover{border-color:#fff}

/* ---------- WORK MOSAIC: gallery-first, varied tile sizes ---------- */
.work{padding:clamp(56px,8vw,104px) 0 clamp(48px,7vw,88px)}
.work-head{max-width:60ch;margin-bottom:2.4rem}
.work-intro{color:var(--ink-2);margin-top:.9rem;font-size:1.1rem;max-width:52ch}
.mosaic{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:200px;gap:1rem}
.piece{position:relative;overflow:hidden;border-radius:var(--radius);color:#fff;margin:0;
  display:flex;align-items:flex-end;box-shadow:var(--shadow);transition:transform .2s}
.piece-wide{grid-column:span 2}
.piece-tall{grid-row:span 2}
.piece:hover{transform:translateY(-3px)}
.piece:nth-child(1){background:linear-gradient(155deg,#a8682c,#5a3a18)}
.piece:nth-child(2){background:linear-gradient(155deg,#caa06a,#7a4f22)}
.piece:nth-child(3){background:linear-gradient(155deg,#6f4a26,#3a2410)}
.piece:nth-child(4){background:linear-gradient(155deg,#9c7a4a,#5a3a18)}
.piece:nth-child(5){background:linear-gradient(155deg,#b98a4e,#6f4a26)}
.piece:nth-child(6){background:linear-gradient(155deg,#7a4f22,#2e1d0c)}
.piece::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(30,18,6,.62),transparent 58%);
  background-image:linear-gradient(to top,rgba(30,18,6,.62),transparent 58%),
    repeating-linear-gradient(90deg,rgba(0,0,0,.07) 0 1px,transparent 1px 7px)}
.piece-no{position:absolute;top:.9rem;left:1rem;z-index:2;font-family:var(--font-display);
  font-weight:700;font-size:.82rem;letter-spacing:.1em;color:rgba(255,255,255,.78)}
.piece figcaption{position:relative;z-index:2;padding:1.1rem 1.2rem}
.piece figcaption strong{display:block;font-family:var(--font-display);font-size:1.12rem;text-shadow:0 1px 8px rgba(0,0,0,.45)}
.piece figcaption span{display:block;font-size:.86rem;color:rgba(255,255,255,.85);margin-top:.15rem}
.work-note{color:var(--ink-2);font-size:.86rem;margin-top:1.2rem}

/* ---------- MATERIALS BAND: unique horizontal Holzarten strip ---------- */
.woods{background:var(--brand-2);color:#fff;
  background-image:repeating-linear-gradient(90deg,rgba(0,0,0,.12) 0 1px,transparent 1px 8px)}
.woods-in{padding:clamp(28px,4vw,46px) clamp(18px,5vw,40px)}
.woods-label{display:block;font-family:var(--font-body);font-weight:600;text-transform:uppercase;
  letter-spacing:.2em;font-size:.72rem;color:var(--grain);margin-bottom:1.3rem}
.woods-strip{list-style:none;display:grid;grid-template-columns:repeat(5,1fr)}
.woods-strip li{padding:0 1.4rem;border-left:1px solid rgba(255,255,255,.18)}
.woods-strip li:first-child{padding-left:0;border-left:0}
.woods-strip b{display:block;font-family:var(--font-display);font-weight:800;font-size:1.5rem;letter-spacing:-.01em}
.woods-strip span{display:block;font-size:.85rem;color:rgba(255,255,255,.7);margin-top:.2rem}

/* ---------- SERVICES as craftsman's prose notes, thin-rule ledger ---------- */
.notes{padding:clamp(56px,8vw,104px) 0}
.notes-head{max-width:60ch;margin-bottom:2.6rem}
.ledger{border-top:1px solid var(--line)}
.note{display:grid;grid-template-columns:64px 1fr;gap:clamp(1rem,4vw,3rem);
  padding:1.8rem 0;border-bottom:1px solid var(--line);align-items:baseline}
.note-ix{font-family:var(--font-display);font-weight:700;font-size:1.05rem;letter-spacing:.08em;
  color:var(--brand);padding-top:.15rem}
.note-body h3{font-family:var(--font-display);font-weight:800;font-size:1.45rem;color:var(--brand-2);margin-bottom:.45rem}
.note-body p{color:var(--ink-2);font-size:1.05rem;max-width:62ch;line-height:1.65}
.note:hover .note-body h3{color:var(--brand)}

/* ---------- WARUM: inline rows with large serif numerals ---------- */
.reasons{background:var(--brand-tint);padding:clamp(56px,8vw,100px) 0}
.reason-rows{list-style:none;border-top:1px solid rgba(90,58,24,.16)}
.reason-rows li{display:flex;align-items:baseline;gap:clamp(1rem,3vw,2.4rem);
  padding:1.5rem 0;border-bottom:1px solid rgba(90,58,24,.16)}
.reason-num{font-family:var(--font-display);font-weight:800;font-size:clamp(2.4rem,6vw,3.6rem);
  line-height:1;color:var(--brand);opacity:.85;flex:0 0 auto;min-width:1.8em}
.reason-rows h4{font-family:var(--font-display);font-weight:700;font-size:1.25rem;color:var(--brand-2);margin-bottom:.2rem}
.reason-rows p{color:var(--ink-2);font-size:1rem;max-width:58ch}

/* ---------- ABLAUF: numbered flow line ---------- */
.flow{padding:clamp(56px,8vw,100px) 0}
.flow-track{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.4rem,4vw,3rem);
  counter-reset:none;position:relative}
.flow-step{position:relative;padding-top:1.6rem;border-top:3px solid var(--brand)}
.flow-n{position:absolute;top:-.9rem;right:0;font-family:var(--font-display);font-weight:800;
  font-size:3.4rem;line-height:1;color:var(--grain);opacity:.5}
.flow-step h4{font-family:var(--font-display);font-weight:800;font-size:1.3rem;color:var(--brand-2);margin-bottom:.4rem}
.flow-step p{color:var(--ink-2);font-size:1rem;max-width:34ch}

/* ---------- KUNDENSTIMMEN: one large framed centered quote ---------- */
.testimony{background:var(--brand-2);color:#fff;padding:clamp(60px,9vw,120px) 0;
  background-image:repeating-linear-gradient(90deg,rgba(0,0,0,.10) 0 1px,transparent 1px 9px)}
.big-quote{max-width:780px;margin:0 auto;text-align:center;position:relative;
  border:1px solid rgba(255,255,255,.22);border-radius:var(--radius);
  padding:clamp(2.4rem,6vw,4rem) clamp(1.4rem,5vw,3.4rem)}
.big-mark{position:absolute;top:-.35em;left:50%;transform:translateX(-50%);
  font-family:var(--font-display);font-size:6rem;line-height:1;color:var(--grain);opacity:.5}
.big-quote blockquote{font-family:var(--font-display);font-weight:600;font-style:italic;
  font-size:clamp(1.4rem,3.4vw,2.1rem);line-height:1.4;color:#fff;letter-spacing:-.01em}
.big-quote figcaption{margin-top:1.8rem;display:flex;flex-direction:column;align-items:center;gap:.25rem}
.qt-stars{color:var(--grain);letter-spacing:.14em}
.big-quote figcaption strong{font-family:var(--font-display);font-size:1.05rem}
.qt-place{color:rgba(255,255,255,.7);font-size:.9rem}
.testimony-note{text-align:center;color:rgba(255,255,255,.55);font-size:.84rem;margin-top:1.4rem}

/* ---------- EINZUGSGEBIET: quiet inline line ---------- */
.region{padding:clamp(40px,6vw,72px) 0;border-bottom:1px solid var(--line)}
.region-in{display:flex;flex-direction:column;gap:.7rem;max-width:62ch}
.region-line{font-family:var(--font-display);font-size:clamp(1.15rem,2.4vw,1.55rem);
  line-height:1.5;color:var(--brand-2);font-weight:500}
.region-line b{color:var(--brand);font-weight:800}

/* ---------- KONTAKT: warm, left-aligned, with working form ---------- */
.reach{padding:clamp(56px,8vw,104px) 0}
.reach-in{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.reach-lead{color:var(--ink-2);font-size:1.12rem;margin:1rem 0 2rem;max-width:42ch;line-height:1.6}
.reach-info{display:grid;gap:1.3rem}
.reach-info div{display:grid;grid-template-columns:90px 1fr;align-items:baseline;gap:1rem;
  padding-bottom:1.2rem;border-bottom:1px solid var(--line)}
.reach-info dt{font-family:var(--font-body);font-weight:700;text-transform:uppercase;
  letter-spacing:.14em;font-size:.72rem;color:var(--brand);padding-top:.2rem}
.reach-info dd{font-family:var(--font-display);font-weight:700;font-size:1.1rem;color:var(--brand-2)}
.reach-info dd a:hover{color:var(--brand)}
.reach-info small{display:block;font-family:var(--font-body);font-weight:400;
  font-size:.85rem;color:var(--ink-2);margin-top:.2rem}
.reach-form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:1.8rem}
.reach-form h3{font-family:var(--font-display);font-weight:800;font-size:1.35rem;color:var(--brand-2);margin-bottom:1rem}
.reach-form .field input,.reach-form .field textarea{background:var(--brand-tint);border-color:rgba(90,58,24,.18)}
.reach-form .btn-call{width:100%;justify-content:center;margin-top:.4rem}
.reach-alt{text-align:center;margin-top:.8rem;font-size:.88rem;color:var(--ink-2)}
.reach-alt a{color:var(--brand);font-weight:700}

/* ---------- responsive ---------- */
@media(max-width:820px){
  .reach-in{grid-template-columns:1fr;gap:2.2rem}
  .woods-strip{grid-template-columns:repeat(2,1fr);gap:1.4rem 0}
  .woods-strip li{padding:0 1rem;border-left:1px solid rgba(255,255,255,.18)}
  .woods-strip li:nth-child(odd){padding-left:0;border-left:0}
  .flow-track{grid-template-columns:1fr;gap:1.6rem}
  .flow-step{padding-top:1.2rem}
  .flow-n{font-size:2.6rem;top:-.6rem}
}
@media(max-width:680px){
  .mosaic{grid-template-columns:1fr 1fr;grid-auto-rows:170px}
  .piece-tall{grid-row:span 1}
}
@media(max-width:520px){
  .mosaic{grid-template-columns:1fr;grid-auto-rows:180px}
  .piece-wide{grid-column:span 1}
  .woods-strip{grid-template-columns:1fr}
  .woods-strip li{padding-left:0;border-left:0;border-top:1px solid rgba(255,255,255,.14);padding-top:1rem}
  .woods-strip li:first-child{border-top:0;padding-top:0}
  .note{grid-template-columns:1fr;gap:.4rem}
  .reach-info div{grid-template-columns:1fr}
}
