/* ════════════════════════════════════════════════
   LACKNER ATELIER · shared.css
   ════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400&family=Cinzel:wght@400;600&family=Raleway:wght@300;400;500&display=swap');

:root {
  --bg:    #F5F0E8;
  --bg2:   #EDE7DA;
  --bg3:   #E2DAC8;
  --white: #FDFAF5;
  --ink:   #1A1610;
  --ink2:  #FDFAF5;
  --muted: #8C806E;
  --line:  #CFC5B2;
  --line2: #DDD5C4;
  --gold:  #9C7422;
  --gold2: #B58C3A;
  --gold3: #C8A658;
  --fd:    'Cinzel', serif;
  --fb:    'Cormorant Garamond', serif;
  --fu:    'Raleway', sans-serif;
  --ease:  cubic-bezier(0.16,1,0.3,1);
  --ease2: cubic-bezier(0.76,0,0.24,1);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  background:var(--bg); color:var(--ink);
  font-family:var(--fb); font-size:20px;
  line-height:1.85; overflow-x:hidden;
}
a { text-decoration:none; color:var(--gold); }
img { display:block; }
::-webkit-scrollbar { width:3px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:var(--line); }

/* ─────────────────────────────────────────────
   HEADER
   ───────────────────────────────────────────── */
.hd {
  position:fixed; inset:0 0 auto; z-index:900;
  display:flex; justify-content:space-between; align-items:center;
  padding:28px 64px;
  transition:background .45s, padding .35s, box-shadow .45s;
}
.hd.s {
  background:rgba(245,240,232,.97);
  padding:17px 64px;
  box-shadow:0 1px 0 var(--ink);
  backdrop-filter:blur(18px);
}
.hd-logo { text-decoration:none; }
.hd-name {
  font-family:var(--fd); font-size:21px; font-weight:300;
  letter-spacing:.18em; color:var(--gold3); display:block;
}
.hd-sub {
  font-family:var(--fu); font-size:8.5px; font-weight:300;
  letter-spacing:.44em; color:var(--gold);
  text-transform:uppercase; display:block; margin-top:3px;
}

/* Navigation — original schlichte Variante mit Goldlinie */
.hd-nav { display:flex; gap:36px; align-items:center; }
.hd-nav a {
  font-family:var(--fu); font-size:14px; font-weight:500;
  letter-spacing:.32em; text-transform:uppercase;
  color:var(--gold3); opacity:.62;
  transition:opacity .3s, color .3s;
  position:relative; padding-bottom:5px;
}
.hd-nav a::after {
  content:''; position:absolute;
  bottom:0; left:0; width:0; height:1px;
  background:var(--gold);
  transition:width .38s var(--ease);
}
.hd-nav a:hover        { opacity:1; color:var(--gold3); }
.hd-nav a:hover::after { width:100%; }
.hd-nav a.on           { opacity:1; color:var(--gold); }
.hd-nav a.on::after    { width:100%; }

/* Mobile */
.burger {
  display:none; flex-direction:column; gap:6px;
  cursor:pointer; padding:4px; background:none; border:none;
}
.burger span { display:block; width:24px; height:1px; background:var(--gold); transition:.3s; }
.mob {
  display:none; position:fixed; inset:0; z-index:850;
  background:var(--white); flex-direction:column;
  align-items:center; justify-content:center; gap:36px;
}
.mob.open { display:flex; }
.mob a {
  font-family:var(--fd); font-size:21px; font-weight:400;
  letter-spacing:.12em; color:var(--ink); transition:color .3s;
}
.mob a:hover { color:var(--gold); }
.mob-x {
  position:absolute; top:26px; right:32px;
  font-family:var(--fu); font-size:10px; letter-spacing:.3em;
  color:var(--muted); cursor:pointer; text-transform:uppercase;
  background:none; border:none;
}

/* ─────────────────────────────────────────────
   SLIDER
   ───────────────────────────────────────────── */
.sl { position:relative; overflow:hidden; }
.sl-track {
  display:flex; height:100%;
  transition:transform .75s var(--ease2);
  will-change:transform;
}
.sl-slide  { min-width:100%; position:relative; overflow:hidden; flex-shrink:0; }
.sl-img    { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; filter:saturate(.72) brightness(.97); }


.sl-pips {
  position:absolute; bottom:22px; left:50%; transform:translateX(-50%);
  display:flex; gap:8px; z-index:10;
}
.sl-pip { width:28px; height:2px; background:rgba(156,116,34,.18); cursor:pointer; transition:.3s; }
.sl-pip.on { background:var(--gold); width:42px; }

/* ─────────────────────────────────────────────
   LAYOUT
   ───────────────────────────────────────────── */
.w    { max-width:1200px; margin:0 auto; padding:0 64px; }
.sec  { padding:108px 0; }
.sec-hd {
  display:flex; flex-direction:column; align-items:center;
  gap:20px; text-align:center; margin-bottom:72px;
}

/* ─────────────────────────────────────────────
   TYPOGRAFIE
   ───────────────────────────────────────────── */
.eyebrow {
  font-family:var(--fu); font-size:12px; font-weight:500;
  letter-spacing:.54em; text-transform:uppercase; color:var(--gold);
}
.h1 {
  font-family:var(--fd); font-weight:400;
  font-size:clamp(38px,5.5vw,68px);
  letter-spacing:.08em; color:var(--bg); line-height:1.05;
}
.h1 em { font-style:italic; color:var(--gold); }
.h2 {
  font-family:var(--fd); font-weight:400;
  font-size:clamp(32px,3.6vw,54px);
  letter-spacing:.1em; color:var(--ink); line-height:1.1;
}
.h3 {
  font-family:var(--fd); font-weight:400;
  font-size:clamp(22px,2.4vw,32px);
  letter-spacing:.08em; color:var(--ink); line-height:1.2;
}
.body-i {
  font-family:var(--fb); font-size:1.25rem; font-weight:300;
  font-style:italic; color:var(--ink); line-height:2.05;
}
.lead { max-width:620px; }

/* Ornament */
.orn { display:flex; align-items:center; gap:14px; width:160px; }
.orn-l   { flex:1; height:1px; background:linear-gradient(to right,transparent,var(--gold3)); }
.orn-l.r { background:linear-gradient(to left,transparent,var(--gold3)); }
.orn-d   { width:6px; height:6px; background:var(--gold3); transform:rotate(45deg); flex-shrink:0; }

/* ─────────────────────────────────────────────
   BUTTON
   ───────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center;
  font-family:var(--fu); font-size:10px; font-weight:500;
  letter-spacing:.46em; text-transform:uppercase;
  color:var(--gold); border:1px solid var(--gold3);
  padding:16px 40px;
  position:relative; overflow:hidden;
  transition:color .4s; cursor:pointer;
  background:rgba(255,255,255,.35);
}
.btn::before {
  content:''; position:absolute; inset:0;
  background:var(--gold); transform:translateX(-101%);
  transition:transform .42s var(--ease2);
}
.btn:hover { color:var(--white); }
.btn:hover::before { transform:translateX(0); }
.btn > span { position:relative; z-index:1; }

/* ─────────────────────────────────────────────
   FOTO-PLATZHALTER
   Foto tauschen: img src → eigene Datei,
   dann <p class="ph-note"> löschen
   ───────────────────────────────────────────── */
.ph { position:relative; overflow:hidden; background:var(--bg3); }
.ph img {
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; filter:saturate(.72) brightness(.97);
  transition:transform .88s var(--ease);
}
.ph:hover img { transform:scale(1.04); }
.ph-note {
  position:absolute; bottom:0; left:0; right:0; z-index:4;
  background:rgba(245,240,232,.92); border-top:1px solid var(--line2);
  font-family:var(--fu); font-size:7.5px; letter-spacing:.32em;
  color:var(--muted); text-transform:uppercase; text-align:center; padding:6px;
}

/* ─────────────────────────────────────────────
   FORMULAR
   ───────────────────────────────────────────── */
.form   { max-width:600px; margin:0 auto; }
.form-2 { display:grid; grid-template-columns:1fr 1fr; gap:0 28px; }
.ff input, .ff textarea {
  width:100%; padding:18px 0;
  background:transparent; border:none; border-bottom:1px solid var(--line);
  color:var(--ink); font-family:var(--fb); font-size:1.15rem;
  outline:none; transition:border-color .3s; margin-bottom:22px;
}
.ff input:focus,.ff textarea:focus { border-bottom-color:var(--gold); }
.ff input::placeholder,.ff textarea::placeholder { color:var(--muted); font-style:italic; }
.ff textarea { resize:none; height:134px; }
.form-btn {
  width:100%; padding:19px;
  background:transparent; border:1px solid var(--gold3);
  color:var(--gold); font-family:var(--fu); font-size:10px; font-weight:500;
  letter-spacing:.46em; text-transform:uppercase;
  cursor:pointer; position:relative; overflow:hidden; transition:color .4s;
}
.form-btn::before {
  content:''; position:absolute; inset:0;
  background:var(--gold); transform:translateY(101%);
  transition:transform .42s var(--ease2);
}
.form-btn:hover { color:var(--white); }
.form-btn:hover::before { transform:translateY(0); }
.form-btn > span { position:relative; z-index:1; }

/* ─────────────────────────────────────────────
   FOOTER
   ───────────────────────────────────────────── */
.ft {
  background:var(--ink); padding:56px 64px;
  display:grid; grid-template-columns:1fr 1fr 1fr; align-items:center;
}
.ft-name { font-family:var(--fd); font-size:15px; letter-spacing:.14em; color:var(--gold3); }
.ft-copy { font-family:var(--fu); font-size:9px; letter-spacing:.3em; color:var(--muted); text-transform:uppercase; text-align:center; }
.ft-tag  { font-family:var(--fb); font-size:15px; font-style:italic; color:var(--muted); text-align:right; }

/* ─────────────────────────────────────────────
   SCROLL REVEAL
   ───────────────────────────────────────────── */
.rv {
  opacity:0; transform:translateY(30px);
  transition:opacity .9s var(--ease), transform .9s var(--ease);
}
.rv.in { opacity:1; transform:translateY(0); }
.d1 { transition-delay:.12s; }
.d2 { transition-delay:.24s; }
.d3 { transition-delay:.36s; }

/* ─────────────────────────────────────────────
   RESPONSIVE
   ───────────────────────────────────────────── */
@media(max-width:880px) {
  .hd,.hd.s { padding:18px 26px; }
  .hd-nav   { display:none; }
  .burger   { display:flex; }
  .w        { padding:0 26px; }
  .sec      { padding:76px 0; }
  .ft { grid-template-columns:1fr; text-align:center; padding:40px 26px; gap:14px; }
  .ft-tag   { text-align:center; }
  .form-2   { grid-template-columns:1fr; }
}
