/* ============================================================
   Mario Kainz · Tischlerei — Design System
   Leitmotiv: "Aus Holz. Für immer."
   Palette: Nussbraun / Ahorn-Creme / Tiefcharcoal / Warmgold
   Fonts: Playfair Display (Display) + Inter (Body)
   ============================================================ */

:root{
  /* Wood palette */
  --nut:        #7B4F2E;   /* dark wood — headings, accents on light */
  --nut-deep:   #5E3A1F;
  --cream:      #F5EBD7;   /* maple cream — light text on dark */
  --paper:      #FBF6EC;   /* page background */
  --paper-2:    #F3E9D6;   /* alt light section */
  --charcoal:   #1E1A17;   /* dark sections / hero */
  --charcoal-2: #2A2420;
  --gold:       #C9862A;   /* brass / warm gold — CTA, glow on dark */
  --gold-light: #E0A646;
  --gold-soft:  rgba(201,134,42,.55);
  --ink:        #221C18;   /* body text on light */
  --ink-soft:   #5A4A3C;   /* secondary text on light */
  --line:       rgba(123,79,46,.20);
  --line-dark:  rgba(245,235,215,.16);

  --shadow-sm:  0 4px 14px rgba(30,26,23,.10);
  --shadow-md:  0 14px 34px rgba(30,26,23,.16);
  --shadow-lg:  0 28px 60px rgba(30,26,23,.28);

  --radius:     14px;
  --radius-lg:  22px;
  --container:  1200px;
  --ease:       cubic-bezier(.22,.61,.36,1);

  /* Subtle wood-grain texture (procedural, very faint) */
  --grain: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.012 0.16' numOctaves='3' seed='7'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.7;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;font-weight:600;line-height:1.12;margin:0 0 .4em;color:var(--nut-deep)}
h1{font-size:clamp(2.5rem,6vw,4.6rem);letter-spacing:-.01em}
h2{font-size:clamp(1.9rem,4vw,3rem)}
h3{font-size:clamp(1.25rem,2.2vw,1.6rem)}
p{margin:0 0 1rem}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.container{max-width:var(--container);margin:0 auto;padding:0 clamp(1.1rem,4vw,2.2rem)}
section{position:relative}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:'Inter';font-weight:600;font-size:1rem;
  padding:.92rem 1.7rem;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;position:relative;overflow:hidden;
  transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s,color .25s;
  white-space:nowrap;
}
.btn svg{width:18px;height:18px;flex:0 0 auto}
.btn--gold{background:var(--gold);color:#fff;box-shadow:0 10px 26px rgba(201,134,42,.34)}
.btn--gold:hover{transform:translateY(-3px);box-shadow:0 16px 34px rgba(201,134,42,.46)}
.btn--ghost{background:transparent;color:var(--cream);border-color:var(--line-dark)}
.btn--ghost:hover{border-color:var(--gold);color:#fff;transform:translateY(-3px)}
.btn--outline{background:transparent;color:var(--nut-deep);border-color:var(--nut)}
.btn--outline:hover{background:var(--nut);color:#fff;transform:translateY(-3px)}
/* Shine sweep */
.btn--gold::after,.btn--outline::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.45) 50%,transparent 70%);
  transform:translateX(-130%);transition:transform .65s var(--ease);
}
.btn--gold:hover::after,.btn--outline:hover::after{transform:translateX(130%)}

/* ---------- Header ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  transition:background .35s,box-shadow .35s,padding .35s;
  padding:.55rem 0;
}
.site-header::before{content:"";position:absolute;inset:0;background:rgba(30,26,23,.0);transition:.35s;backdrop-filter:blur(0)}
.site-header.scrolled{box-shadow:0 6px 24px rgba(30,26,23,.16)}
.site-header.scrolled::before{background:rgba(27,23,20,.92);backdrop-filter:blur(10px)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;position:relative;z-index:1}
.brand{display:flex;align-items:center;gap:.7rem;color:var(--cream)}
.brand .mark{
  width:42px;height:42px;border-radius:11px;flex:0 0 auto;
  display:grid;place-items:center;font-family:'Playfair Display';font-weight:700;
  font-size:1.18rem;color:#fff;letter-spacing:.02em;
  background:linear-gradient(150deg,var(--nut) 0%,var(--nut-deep) 60%,#3c2412 100%);
  border:1px solid rgba(224,166,70,.45);box-shadow:inset 0 1px 0 rgba(255,255,255,.18)
}
.brand .wm{display:flex;flex-direction:column;line-height:1.05}
.brand .wm b{font-family:'Playfair Display';font-weight:600;font-size:1.12rem;letter-spacing:.01em}
.brand .wm span{font-size:.66rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold-light);font-weight:600}
.nav-links{display:flex;gap:1.7rem;list-style:none;margin:0;padding:0}
.nav-links a{color:var(--cream);font-weight:500;font-size:.97rem;position:relative;padding:.2rem 0;opacity:.86;transition:.25s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-3px;height:2px;width:0;background:var(--gold);transition:width .3s var(--ease)}
.nav-links a:hover,.nav-links a.active{opacity:1}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:.7rem}
.nav-phone{display:inline-flex;align-items:center;gap:.5rem;color:var(--cream);font-weight:600;font-size:.95rem;padding:.5rem .9rem;border:1.5px solid var(--line-dark);border-radius:999px;transition:.25s}
.nav-phone svg{width:17px;height:17px}
.nav-phone:hover{border-color:var(--gold);color:#fff;background:rgba(201,134,42,.12)}
.nav-toggle{display:none;background:none;border:0;width:42px;height:42px;cursor:pointer;flex-direction:column;justify-content:center;gap:5px;padding:0}
.nav-toggle span{display:block;height:2px;width:24px;margin:0 auto;background:var(--cream);border-radius:2px;transition:.3s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ---------- Hero ---------- */
.hero{min-height:100svh;display:flex;align-items:center;color:var(--cream);overflow:hidden;padding:7rem 0 4rem}
.hero__photo{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.08);z-index:0;will-change:transform}
.hero__scrim{position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg,rgba(20,16,13,.62) 0%,rgba(20,16,13,.40) 38%,rgba(20,16,13,.74) 100%),
    radial-gradient(120% 90% at 18% 30%,rgba(20,16,13,.30),rgba(20,16,13,.85))}
.hero__grain{position:absolute;inset:0;z-index:2;background-image:var(--grain);background-size:340px;opacity:.10;mix-blend-mode:overlay;pointer-events:none}
.hero .container{position:relative;z-index:3;width:100%}
.hero__inner{max-width:760px}
.hero-chip{display:inline-flex;align-items:center;gap:.55rem;font-size:.8rem;font-weight:600;letter-spacing:.04em;
  text-transform:uppercase;color:var(--cream);background:rgba(245,235,215,.10);border:1px solid var(--line-dark);
  padding:.45rem 1rem;border-radius:999px;margin-bottom:1.6rem;backdrop-filter:blur(4px)}
.hero-chip .dot{width:8px;height:8px;border-radius:50%;background:var(--gold-light);box-shadow:0 0 0 4px rgba(224,166,70,.25)}
.hero h1{color:#fff;margin-bottom:.5rem;text-shadow:0 2px 30px rgba(0,0,0,.35)}
.hero h1 em{font-style:italic;color:var(--gold-light)}
.hero__lead{font-size:clamp(1.05rem,2vw,1.3rem);color:rgba(245,235,215,.92);max-width:56ch;margin-bottom:2rem}
.hero__cta{display:flex;flex-wrap:wrap;gap:.9rem;align-items:center}
.hero__meta{display:flex;flex-wrap:wrap;gap:1.6rem;margin-top:2.6rem;padding-top:1.6rem;border-top:1px solid var(--line-dark)}
.hero__meta div{display:flex;flex-direction:column}
.hero__meta b{font-family:'Playfair Display';font-size:1.5rem;color:#fff;font-weight:600}
.hero__meta span{font-size:.82rem;letter-spacing:.02em;color:rgba(245,235,215,.72)}
.scroll-hint{position:absolute;left:50%;bottom:1.4rem;transform:translateX(-50%);z-index:3;color:rgba(245,235,215,.6);font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:.5rem}
.scroll-hint .line{width:1px;height:34px;background:linear-gradient(var(--gold-light),transparent);animation:scrollpulse 2s var(--ease) infinite}
@keyframes scrollpulse{0%{transform:scaleY(.2);transform-origin:top;opacity:0}40%{opacity:1}100%{transform:scaleY(1);transform-origin:top;opacity:0}}

/* ---------- Section frame ---------- */
.sec{padding:clamp(4rem,9vw,7rem) 0}
.sec--paper2{background:var(--paper-2)}
.sec--dark{background:var(--charcoal);color:var(--cream)}
.sec--dark h2{color:#fff}
.eyebrow{display:inline-flex;align-items:center;gap:.6rem;font-size:.78rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--nut);margin-bottom:1rem}
.sec--dark .eyebrow{color:var(--gold-light)}
.eyebrow::before{content:"";width:26px;height:1.5px;background:currentColor;opacity:.7}
.sec-head{max-width:680px;margin-bottom:3rem}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head.center .eyebrow::before{display:none}
.sec-head p{color:var(--ink-soft);font-size:1.08rem}
.sec--dark .sec-head p{color:rgba(245,235,215,.8)}

/* ---------- Wavy wood divider ---------- */
.divider{display:block;width:100%;height:60px;line-height:0}
.divider svg{width:100%;height:100%;display:block}

/* ---------- Stats band ---------- */
.stats{background:linear-gradient(140deg,var(--charcoal) 0%,#241d18 100%);color:var(--cream);position:relative;overflow:hidden}
.stats::before{content:"";position:absolute;inset:0;background-image:var(--grain);background-size:300px;opacity:.08;mix-blend-mode:overlay}
.stats .container{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;padding-top:3rem;padding-bottom:3rem}
.stat{text-align:center;padding:.4rem;position:relative}
.stat:not(:last-child)::after{content:"";position:absolute;right:-.75rem;top:14%;height:72%;width:1px;background:var(--line-dark)}
.stat b{display:block;font-family:'Playfair Display';font-size:clamp(2rem,4vw,3.1rem);color:#fff;font-weight:600;line-height:1}
.stat .suffix{color:var(--gold-light)}
.stat span{display:block;margin-top:.5rem;font-size:.82rem;letter-spacing:.04em;color:rgba(245,235,215,.74)}

/* ---------- Service cards (3D tilt) ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.svc-grid .svc:first-child{grid-column:span 2}
@media(max-width:900px){.svc-grid{grid-template-columns:1fr 1fr}.svc-grid .svc:first-child{grid-column:span 2}}
.svc{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;min-height:340px;
  display:flex;flex-direction:column;justify-content:flex-end;color:#fff;
  transform-style:preserve-3d;transition:transform .4s var(--ease),box-shadow .4s var(--ease);
  box-shadow:var(--shadow-sm);background:#2a2018;cursor:pointer;
}
.svc:hover{box-shadow:var(--shadow-lg)}
.svc__img{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .6s var(--ease);transform:translateZ(0)}
.svc:hover .svc__img{transform:scale(1.07)}
.svc__veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,15,11,.05) 30%,rgba(20,15,11,.55) 62%,rgba(18,13,9,.9) 100%);transition:.4s}
.svc:hover .svc__veil{background:linear-gradient(180deg,rgba(20,15,11,.12) 22%,rgba(20,15,11,.6) 55%,rgba(15,10,7,.94) 100%)}
.svc__ring{position:absolute;inset:0;border-radius:inherit;border:1.5px solid transparent;transition:.4s;pointer-events:none}
.svc:hover .svc__ring{border-color:var(--gold-soft);box-shadow:inset 0 0 0 1px rgba(201,134,42,.25)}
.svc__body{position:relative;padding:1.6rem 1.7rem 1.7rem;transform:translateZ(40px)}
.svc__ico{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;background:rgba(201,134,42,.22);border:1px solid var(--gold-soft);margin-bottom:.9rem;backdrop-filter:blur(3px)}
.svc__ico svg{width:24px;height:24px;stroke:var(--gold-light);fill:none;stroke-width:1.7}
.svc h3{color:#fff;margin-bottom:.35rem}
.svc p{color:rgba(245,235,215,.86);font-size:.96rem;margin-bottom:.9rem}
.svc__more{display:inline-flex;align-items:center;gap:.45rem;font-weight:600;font-size:.9rem;color:var(--gold-light);transition:gap .25s}
.svc__more svg{width:16px;height:16px}
.svc:hover .svc__more{gap:.8rem}
.svc__price{position:absolute;top:1.1rem;right:1.1rem;z-index:2;font-size:.74rem;font-weight:600;letter-spacing:.02em;
  background:rgba(27,22,18,.62);border:1px solid var(--line-dark);color:var(--cream);padding:.35rem .7rem;border-radius:999px;backdrop-filter:blur(4px)}

/* ---------- Manifesto band ---------- */
.manifesto{background:var(--charcoal);color:var(--cream);position:relative;overflow:hidden;text-align:center}
.manifesto__bg{position:absolute;inset:0;background-size:cover;background-position:center 40%;opacity:.16;filter:saturate(1.1)}
.manifesto::after{content:"";position:absolute;inset:0;background-image:var(--grain);background-size:320px;opacity:.07;mix-blend-mode:overlay}
.manifesto .container{position:relative;z-index:2;padding-top:clamp(4.5rem,9vw,7rem);padding-bottom:clamp(4.5rem,9vw,7rem);max-width:860px}
.manifesto .quote-mark{font-family:'Playfair Display';font-size:5rem;line-height:0;color:var(--gold);opacity:.5;display:block;height:2.2rem}
.manifesto h2{font-size:clamp(2rem,4.5vw,3.4rem);color:#fff;margin-bottom:1rem}
.manifesto h2 em{font-style:italic;color:var(--gold-light)}
.manifesto p{font-size:1.12rem;color:rgba(245,235,215,.86);max-width:62ch;margin:0 auto}

/* ---------- Split (Über den Meister) ---------- */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.split__media{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);aspect-ratio:4/5}
.split__media img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.split__media:hover img{transform:scale(1.05)}
.split__badge{position:absolute;left:1.1rem;bottom:1.1rem;background:rgba(27,22,18,.78);backdrop-filter:blur(6px);
  border:1px solid var(--line-dark);border-radius:14px;padding:.8rem 1.1rem;color:var(--cream);display:flex;align-items:center;gap:.7rem}
.split__badge b{font-family:'Playfair Display';font-size:1.5rem;color:var(--gold-light)}
.split__badge span{font-size:.78rem;line-height:1.3;color:rgba(245,235,215,.85)}
.split__sig{font-family:'Playfair Display';font-style:italic;font-size:1.55rem;color:var(--nut);margin-top:.4rem}
.feature-list{list-style:none;padding:0;margin:1.4rem 0 0;display:grid;gap:.7rem}
.feature-list li{display:flex;gap:.7rem;align-items:flex-start;font-size:1rem;color:var(--ink-soft)}
.feature-list svg{width:20px;height:20px;flex:0 0 auto;margin-top:3px;stroke:var(--gold);fill:none;stroke-width:2}

/* ---------- Gallery preview / grid ---------- */
.gal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:1rem}
.gal__item{position:relative;overflow:hidden;border-radius:var(--radius);cursor:pointer;background:#2a2018;box-shadow:var(--shadow-sm)}
.gal__item img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.gal__item:hover img{transform:scale(1.08)}
.gal__item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(18,13,9,.66));opacity:0;transition:.35s}
.gal__item:hover::after{opacity:1}
.gal__cap{position:absolute;left:0;right:0;bottom:0;padding:.9rem 1rem;color:#fff;font-weight:600;font-size:.92rem;
  transform:translateY(8px);opacity:0;transition:.35s;z-index:2;display:flex;align-items:center;gap:.5rem}
.gal__cap svg{width:16px;height:16px;stroke:var(--gold-light)}
.gal__item:hover .gal__cap{transform:none;opacity:1}
.gal__item.tall{grid-row:span 2}
.gal__item.wide{grid-column:span 2}
@media(max-width:820px){.gal{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}.gal__item.wide{grid-column:span 2}.gal__item.tall{grid-row:span 1}}

/* ---------- Reviews / social proof ---------- */
.proof{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(1.5rem,4vw,3rem);align-items:center}
.proof__score{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:2rem;text-align:center;box-shadow:var(--shadow-sm)}
.sec--dark .proof__score{background:var(--charcoal-2);border-color:var(--line-dark)}
.proof__score .num{font-family:'Playfair Display';font-size:3.6rem;font-weight:600;color:var(--nut);line-height:1}
.sec--dark .proof__score .num{color:var(--gold-light)}
.stars{color:var(--gold);font-size:1.3rem;letter-spacing:.12em;margin:.4rem 0}
.proof__score small{display:block;color:var(--ink-soft);font-size:.88rem;margin-top:.3rem}
.sec--dark .proof__score small{color:rgba(245,235,215,.72)}
.proof__lead h2{margin-bottom:.6rem}
.proof__lead p{color:var(--ink-soft)}
.sec--dark .proof__lead p{color:rgba(245,235,215,.82)}

/* Marquee */
.marquee-wrap{margin-top:2.5rem;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.marquee{display:flex;gap:1.2rem;width:max-content;animation:marquee 40s linear infinite}
.marquee-wrap:has(.review-card:hover) .marquee{animation-play-state:paused}
.review-card{flex:0 0 360px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem 1.5rem;
  transition:border-color .25s,box-shadow .25s,transform .25s}
.sec--dark .review-card{background:var(--charcoal-2);border-color:var(--line-dark)}
.review-card:hover{border-color:var(--gold-soft);box-shadow:0 0 0 2px var(--gold-soft);transform:translateY(-3px)}
.review-card .rc-stars{color:var(--gold);font-size:.95rem;letter-spacing:.1em;margin-bottom:.5rem}
.review-card p{font-size:.96rem;color:var(--ink);margin-bottom:.8rem;font-style:italic}
.sec--dark .review-card p{color:var(--cream)}
.review-card .rc-by{font-size:.84rem;font-weight:600;color:var(--ink-soft);display:flex;align-items:center;gap:.5rem}
.sec--dark .review-card .rc-by{color:rgba(245,235,215,.74)}
.review-card .rc-by .ph{font-weight:500;font-style:normal;opacity:.7}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---------- Contact / form ---------- */
.contact{background:linear-gradient(160deg,var(--charcoal) 0%,#26201b 100%);color:var(--cream);position:relative;overflow:hidden}
.contact::before{content:"";position:absolute;inset:0;background-image:var(--grain);background-size:300px;opacity:.07;mix-blend-mode:overlay}
.contact .container{position:relative;display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,4rem)}
.contact__aside h2{color:#fff}
.contact__aside p{color:rgba(245,235,215,.82)}
.contact-lines{list-style:none;padding:0;margin:1.8rem 0 0;display:grid;gap:1.1rem}
.contact-lines li{display:flex;gap:.9rem;align-items:flex-start}
.contact-lines .ci{width:44px;height:44px;flex:0 0 auto;border-radius:12px;display:grid;place-items:center;background:rgba(201,134,42,.16);border:1px solid var(--gold-soft)}
.contact-lines .ci svg{width:20px;height:20px;stroke:var(--gold-light);fill:none;stroke-width:1.8}
.contact-lines b{display:block;color:#fff;font-size:.95rem}
.contact-lines a,.contact-lines span{color:rgba(245,235,215,.82);font-size:.95rem}
.contact-lines a:hover{color:var(--gold-light)}

.form{background:rgba(245,235,215,.05);border:1px solid var(--line-dark);border-radius:var(--radius-lg);padding:clamp(1.5rem,3vw,2.2rem);backdrop-filter:blur(6px)}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field{margin-bottom:1.1rem;display:flex;flex-direction:column}
.field label{font-size:.85rem;font-weight:600;color:var(--cream);margin-bottom:.4rem}
.field label .req{color:var(--gold-light)}
.field input,.field select,.field textarea{
  font-family:inherit;font-size:.98rem;color:#fff;background:rgba(27,22,18,.5);
  border:1.5px solid var(--line-dark);border-radius:11px;padding:.8rem .95rem;transition:.25s;width:100%}
.field textarea{resize:vertical;min-height:120px}
.field input::placeholder,.field textarea::placeholder{color:rgba(245,235,215,.45)}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%23E0A646' stroke-width='2'%3E%3Cpath d='M3 5l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.4rem}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,134,42,.22);background:rgba(27,22,18,.75)}
.consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.82rem;color:rgba(245,235,215,.74);margin-bottom:1.2rem}
.consent input{width:18px;height:18px;margin-top:2px;accent-color:var(--gold);flex:0 0 auto}
.consent a{color:var(--gold-light);text-decoration:underline}
.form .btn{width:100%;justify-content:center}
.form__note{font-size:.78rem;color:rgba(245,235,215,.55);margin-top:.9rem;text-align:center}

/* ---------- Leistungen detail page ---------- */
.page-hero{background:linear-gradient(160deg,var(--charcoal),#231c17);color:var(--cream);padding:9rem 0 4rem;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;background-image:var(--grain);background-size:300px;opacity:.08;mix-blend-mode:overlay}
.page-hero .container{position:relative}
.page-hero h1{color:#fff;max-width:16ch}
.page-hero h1 em{font-style:italic;color:var(--gold-light)}
.page-hero p{color:rgba(245,235,215,.84);max-width:60ch;font-size:1.1rem}
.crumb{font-size:.82rem;letter-spacing:.04em;color:rgba(245,235,215,.6);margin-bottom:1rem}
.crumb a:hover{color:var(--gold-light)}

.svc-list{display:grid;gap:1.5rem}
.svc-row{display:grid;grid-template-columns:300px 1fr auto;gap:1.8rem;align-items:center;background:var(--paper);
  border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.2rem;box-shadow:var(--shadow-sm);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s}
.svc-row:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--gold-soft)}
.svc-row__img{width:100%;height:200px;border-radius:var(--radius);overflow:hidden;background:#2a2018}
.svc-row__img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.svc-row:hover .svc-row__img img{transform:scale(1.07)}
.svc-row__body h3{margin-bottom:.4rem}
.svc-row__body p{color:var(--ink-soft);font-size:.98rem;margin:0}
.svc-row__price{text-align:right;min-width:150px}
.svc-row__price .amount{font-family:'Playfair Display';font-size:1.5rem;color:var(--nut);font-weight:600;display:block}
.price-badge{display:inline-flex;align-items:center;gap:.4rem;font-size:.7rem;font-weight:600;letter-spacing:.02em;
  color:var(--nut);background:rgba(123,79,46,.10);border:1px solid var(--line);padding:.3rem .6rem;border-radius:999px;margin-top:.5rem}
.price-badge svg{width:13px;height:13px;stroke:var(--nut);fill:none;stroke-width:2}
@media(max-width:780px){.svc-row{grid-template-columns:1fr}.svc-row__price{text-align:left}}

.price-disclaimer{display:flex;gap:.8rem;align-items:flex-start;background:var(--paper-2);border:1px dashed var(--line);
  border-radius:var(--radius);padding:1.1rem 1.3rem;margin-bottom:2.5rem;color:var(--ink-soft);font-size:.92rem}
.price-disclaimer svg{width:22px;height:22px;flex:0 0 auto;stroke:var(--nut);fill:none;stroke-width:1.8;margin-top:1px}

/* ---------- Lightbox ---------- */
.lb{position:fixed;inset:0;z-index:1000;background:rgba(15,11,8,.92);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;padding:3vw;opacity:0;visibility:hidden;transition:.3s}
.lb.open{opacity:1;visibility:visible}
.lb img{max-width:92vw;max-height:86vh;border-radius:10px;box-shadow:var(--shadow-lg);transform:scale(.96);transition:.3s}
.lb.open img{transform:scale(1)}
.lb__cap{position:absolute;bottom:max(1.2rem,3vh);left:0;right:0;text-align:center;color:var(--cream);font-size:.95rem}
.lb__close,.lb__nav{position:absolute;background:rgba(245,235,215,.10);border:1px solid var(--line-dark);color:#fff;
  width:50px;height:50px;border-radius:50%;cursor:pointer;display:grid;place-items:center;transition:.25s}
.lb__close{top:max(1.2rem,3vh);right:max(1.2rem,3vw)}
.lb__close svg,.lb__nav svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:2}
.lb__nav{top:50%;transform:translateY(-50%)}
.lb__nav.prev{left:max(.8rem,2vw)}
.lb__nav.next{right:max(.8rem,2vw)}
.lb__close:hover,.lb__nav:hover{background:var(--gold);border-color:var(--gold)}

/* ---------- Anleitung ---------- */
.guide{max-width:820px}
.guide-step{display:flex;gap:1.2rem;padding:1.4rem 0;border-bottom:1px solid var(--line)}
.guide-step:last-child{border-bottom:0}
.guide-step .n{width:42px;height:42px;flex:0 0 auto;border-radius:50%;display:grid;place-items:center;font-family:'Playfair Display';
  font-weight:700;color:#fff;background:linear-gradient(150deg,var(--nut),var(--nut-deep));font-size:1.1rem}
.guide-step h3{margin-bottom:.3rem;font-size:1.2rem}
.guide-step p{color:var(--ink-soft);margin:0}
.guide-step code{background:var(--paper-2);border:1px solid var(--line);border-radius:6px;padding:.1rem .45rem;font-size:.88em;color:var(--nut-deep)}
.callout{background:linear-gradient(140deg,rgba(201,134,42,.10),rgba(123,79,46,.06));border:1px solid var(--gold-soft);
  border-radius:var(--radius-lg);padding:1.5rem 1.7rem;margin:0 0 2.5rem;display:flex;gap:1rem}
.callout svg{width:26px;height:26px;flex:0 0 auto;stroke:var(--gold);fill:none;stroke-width:1.8}
.callout h3{margin:0 0 .3rem;font-size:1.15rem;color:var(--nut-deep)}
.callout p{margin:0;color:var(--ink-soft);font-size:.96rem}

/* ---------- Footer ---------- */
.footer{background:#15110e;color:rgba(245,235,215,.74);padding:3.5rem 0 2rem;font-size:.92rem}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem;padding-bottom:2.5rem;border-bottom:1px solid var(--line-dark)}
.footer .brand{margin-bottom:1rem}
.footer h4{color:var(--cream);font-family:'Inter';font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;font-weight:700;margin-bottom:1rem}
.footer a:hover{color:var(--gold-light)}
.footer ul{list-style:none;padding:0;margin:0;display:grid;gap:.55rem}
.footer__legal{font-size:.82rem;line-height:1.8;color:rgba(245,235,215,.55)}
.footer__bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding-top:1.5rem;color:rgba(245,235,215,.5);font-size:.82rem}
.footer__bottom a{text-decoration:underline}

/* ---------- Reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .split{grid-template-columns:1fr}
  .proof{grid-template-columns:1fr}
  .contact .container{grid-template-columns:1fr}
  .stats .container{grid-template-columns:1fr 1fr;gap:2rem 1rem}
  .stat:nth-child(2)::after{display:none}
}
@media(max-width:760px){
  .nav-links,.nav-phone{display:none}
  .nav-toggle{display:flex}
  .site-header{padding:.4rem 0}
  .site-header::before{background:rgba(27,23,20,.96);backdrop-filter:blur(10px)}
  .mobile-open .nav-links{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;
    background:rgba(22,18,15,.98);padding:1.2rem 1.4rem;gap:1rem;border-top:1px solid var(--line-dark);box-shadow:var(--shadow-md)}
  .svc-grid{grid-template-columns:1fr}
  .svc-grid .svc:first-child{grid-column:span 1}
  .form .row{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr;gap:1.6rem}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
  .reveal{opacity:1;transform:none}
}
