/* ===== Fonts (Playfair Display) ===== */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600;700;800&display=swap');

/* ========= Palette ========= */
:root{
  --brand:    #C99350;  /* dunkler Ocker/Gold */
  --cream:    #F2D6B5;  /* cremiger Hintergrund */
  --ink:      #121212;
  --muted:    #666A6F;
  --bg:       var(--cream);
  --card:     #ffffff;
  --ring:     rgba(0,0,0,.08);
  --brand-2:  #B07F41;  /* Hover/Accents */
}

/* ========= Reset ========= */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
img{max-width:100%;display:block}
body{
  font-family: "Playfair Display", serif;
  color: var(--ink);
  background:
    radial-gradient(1200px 800px at 20% -10%, rgba(201,147,80,.16), transparent 60%),
    radial-gradient(1200px 800px at 100% 0%, rgba(242,214,181,.24), transparent 50%),
    var(--bg);
  line-height: 1.75;
}

/* ========= Layout & Typo ========= */
.container{width:min(1180px,92%);margin-inline:auto}
.section{padding:86px 0}
.main{display:block}

h1,h2,h3,.display,.display-sm{
  font-family:"Playfair Display", serif;
  letter-spacing:.2px;
}
.h1{
  font-size:clamp(2.6rem,4vw,3.6rem);line-height:1.07;margin:0 0 20px;font-weight:800;
  background: linear-gradient(90deg,var(--ink),color-mix(in oklab,var(--ink),var(--brand) 28%));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.h2{
  font-size:clamp(2rem,2.8vw,2.4rem);margin:30px 0 14px;font-weight:700;
}
.lead{font-size:1.18rem;color:var(--muted)}
.center{text-align:center}

.kicker{
  display:inline-block; font-family:"Playfair Display",serif; font-weight:600;
  letter-spacing:.6px; color: var(--brand-2);
  border-left:5px solid var(--brand); padding-left:12px; margin:14px 0 18px;
}

/* Überschriften-Ornament */
.h1::after, .h2::after{
  content:""; display:block; width:96px; height:6px; margin-top:12px; border-radius:6px;
  background: linear-gradient(90deg, var(--brand), color-mix(in oklab, var(--brand), #000 18%));
  box-shadow: 0 4px 10px rgba(201,147,80,.25);
}

/* hr */
hr{
  border:0; height:1px; background:
    linear-gradient(90deg, transparent, rgba(0,0,0,.12), transparent);
  margin:24px 0;
}

/* ========= Header ========= */
.site-header{
  position: sticky; top:0; z-index: 100;
  background: #fff;
  backdrop-filter: saturate(160%) blur(8px);
  border-bottom: 1px solid var(--ring);
  transition: box-shadow .25s ease, transform .25s ease;
}
.site-header.scrolled{ box-shadow: 0 10px 30px rgba(0,0,0,.08); }
.nav{display:flex;align-items:center;justify-content:space-between;padding:14px 0}

/* Logo */
.logo-img{height:56px;width:auto;display:block;object-fit:contain}
@media (max-width:480px){ .logo-img{height:44px} }

/* Desktop-Nav */
.nav ul{list-style:none;display:flex;gap:18px;margin:0;padding:0}
.nav a{
  position:relative; display:inline-block;
  padding:10px 12px; text-decoration:none; color: var(--ink);
  border-radius:12px;
  transition: transform .15s ease;
}
.nav a:hover{ transform: translateY(-1px); }
.nav a::after{
  content:""; position:absolute; left:12px; right:12px; bottom:6px; height:2px;
  background: linear-gradient(90deg, var(--brand), color-mix(in oklab, var(--brand), var(--ink) 20%));
  border-radius:2px; transform:scaleX(0); transform-origin:left; transition: transform .2s ease;
}
.nav a:hover::after{ transform: scaleX(1); }
.nav a.active{
  background: linear-gradient(180deg, rgba(201,147,80,.16), rgba(201,147,80,.06));
  box-shadow: inset 0 0 0 1px rgba(201,147,80,.28);
}

/* Mobile-Nav */
.menu-toggle{
  display:none;
  border:0;
  background:transparent;
  font-size:1.6rem;
  color: var(--brand);
  cursor:pointer;
  padding:6px 10px;
  border-radius:999px;
}
#navlinks{display:flex}
@media (max-width:900px){
  .menu-toggle{display:block}
  #navlinks{
    display:none; position:absolute; right:4%; top:64px;
    background:#fff; border:1px solid var(--ring); border-radius:14px;
    padding:12px; flex-direction:column; gap:6px;
    box-shadow: 0 20px 40px rgba(0,0,0,.1);
    min-width: 230px;
  }
  #navlinks.open{display:flex}
}

/* ========= Große Bilder ========= */
.hero-top{margin:6px 0 30px}
.hero-top img{
  width:100%; height:600px; object-fit:cover; border-radius:22px;
  box-shadow:0 18px 38px rgba(0,0,0,.14);
  transform: translateZ(0); transition: transform .6s ease, filter .4s ease;
}
.hero-top img:hover{ transform: scale(1.018) }

@media (max-width:1100px){ .hero-top img{height:480px} }
@media (max-width:800px){ .hero-top img{height:340px} }
@media (max-width:560px){ .hero-top img{height:260px} }

/* Abschnittsbilder */
.section-image{
  width:100%; height:520px; object-fit:cover; border-radius:22px;
  margin:14px 0 20px; box-shadow:0 14px 32px rgba(0,0,0,.12);
  transform: translateZ(0); transition: transform .6s ease, filter .4s ease;
}
.section-image:hover{ transform: scale(1.012) }

@media (max-width:1100px){ .section-image{height:420px} }
@media (max-width:760px){ .section-image{height:300px} }

/* ========= Prose ========= */
.prose{font-size:1.06rem; line-height:1.9}
.prose p{margin:0 0 14px}
.prose p.lead{font-size:1.2rem; color:color-mix(in oklab, var(--ink), var(--muted) 22%)}
.dropcap:first-letter{
  float:left; font-family:"Playfair Display",serif; font-size:3.2rem; line-height:.9;
  padding-right:.25rem; padding-top:.15rem; color:var(--brand);
}

/* Spalten */
.split{column-count: 2; column-gap: 42px;}
@media (max-width: 980px){ .split{ column-count:1 } }

/* Akzent-Box */
.accent{
  background: #fff; border:1px solid var(--ring); border-radius:18px;
  padding:22px; box-shadow:0 10px 26px rgba(0,0,0,.06);
}

/* ZigZag Layout */
.zig{display:grid; grid-template-columns: 1.15fr 1fr; gap:26px; align-items:center; margin:38px 0 18px}
.zig .zig-media img{border-radius:22px; box-shadow:0 14px 32px rgba(0,0,0,.12)}
.zig .zig-body p{margin:0 0 12px}
.zig.reverse{ grid-template-columns: 1fr 1.15fr }
@media (max-width: 980px){ .zig, .zig.reverse{grid-template-columns:1fr} }

/* Cards */
.card{
  background: var(--card); border:1px solid var(--ring); border-radius:20px; padding:24px;
  box-shadow: 0 8px 24px rgba(0,0,0,.06);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.card:hover{ transform: translateY(-4px); box-shadow: 0 18px 38px rgba(0,0,0,.1); border-color: rgba(201,147,80,.5) }
.cards{display:grid; gap:22px; grid-template-columns:repeat(4,1fr)}
@media (max-width:1100px){ .cards{grid-template-columns:repeat(2,1fr)} }
@media (max-width:640px){ .cards{grid-template-columns:1fr} }

/* Formulare */
.form{background:var(--card);border:1px solid var(--ring);padding:22px;border-radius:20px;box-shadow:0 6px 18px rgba(0,0,0,.06)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media (max-width:760px){.grid-2{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.field label{font-weight:600}
input,textarea{padding:12px 14px;border-radius:12px;border:1px solid var(--ring);background:#fff;color:var(--ink);outline:none}
input:focus,textarea:focus{border-color: color-mix(in oklab, var(--brand), #000 10%); box-shadow: 0 0 0 4px rgba(201,147,80,.18)}
.alert.success{background:rgba(41, 167, 69, .12);border:1px solid rgba(41,167,69,.35);padding:12px 14px;border-radius:12px}

/* Breadcrumbs */
.breadcrumbs{color:var(--muted);font-size:.92rem;margin-bottom:10px}
.breadcrumbs a{color:inherit;text-decoration:none}
.breadcrumbs a:hover{text-decoration:underline}

/* Reveal */
.reveal{opacity:0; transform: translateY(14px); transition: opacity .6s ease, transform .6s ease}
.reveal.show{opacity:1; transform:none}

/* ========= FOOTER ========= */
.site-footer{background:#fff;margin-top:54px;border-top:1px solid var(--ring)}

/* CTA-Band oben im Footer */
.footer-cta{
  background: linear-gradient(135deg, rgba(201,147,80,.10), rgba(201,147,80,.04));
  border-bottom:1px solid var(--ring);
}
.footer-cta-inner{
  display:grid; grid-template-columns: 1fr auto; gap:16px; align-items:center; padding:22px 0;
}
.cta-title{
  margin:0; font-family:"Playfair Display",serif; font-size:clamp(1.4rem,2.4vw,1.9rem);
}
.cta-actions{display:flex; gap:12px; flex-wrap:wrap}
.cta-btn{min-width:250px; text-align:center}
@media (max-width:840px){
  .footer-cta-inner{grid-template-columns:1fr}
  .cta-actions{justify-content:stretch}
  .cta-btn{width:100%}
}

/* Grid-Bereich */
.footer-grid{
  display:grid; grid-template-columns: repeat(4, 1fr); gap:20px; padding:28px 0;
}
@media (max-width:1080px){ .footer-grid{grid-template-columns:repeat(2,1fr)} }
@media (max-width:620px){ .footer-grid{grid-template-columns:1fr} }

.footer-card{
  background:#fff; border:1px solid var(--ring); border-radius:16px; padding:18px;
  box-shadow:0 8px 20px rgba(0,0,0,.04);
}
.footer-h{font-family:"Playfair Display",serif; margin:0 0 10px; font-size:1.2rem}
.footer-text{margin:.2rem 0 .6rem; color:var(--muted)}
.footer-note{margin:.2rem 0; color:var(--muted); font-size:.95rem}

/* Kontakt-Liste */
.contact-list{list-style:none; padding:0; margin:8px 0 0}
.contact-list li{display:flex; align-items:center; gap:10px; margin:.35rem 0}
.contact-list a{text-decoration:none; color:var(--ink)}
.contact-list a:hover{ text-decoration:underline }
.contact-chip{
  display:inline-block; font-size:.78rem; font-weight:700; letter-spacing:.2px;
  padding:.22rem .5rem; border-radius:999px; color:#fff;
  background: linear-gradient(180deg, color-mix(in oklab, var(--brand) 88%, #fff 12%), var(--brand-2));
  box-shadow: 0 6px 12px rgba(201,147,80,.28);
}

/* Öffnungszeiten */
.hours{list-style:none; padding:0; margin:0}
.hours li{display:flex; justify-content:space-between; gap:12px; padding:.35rem 0; border-bottom:1px dashed var(--ring)}
.hours li:last-child{border-bottom:0}
.hours span:first-child{color:var(--muted)}

/* Links */
.footer-links{list-style:none; padding:0; margin:0}
.footer-links li{margin:.35rem 0}
.footer-links a{text-decoration:none; color:var(--ink)}
.footer-links a:hover{text-decoration:underline}
.footer-links .legal{margin-top:.6rem; color:var(--muted)}

/* Copyright */
.copy{text-align:center; color:var(--muted); padding:12px 0; border-top:1px solid var(--ring)}

/* Icon buttons in footer CTA */
.btn-icon{display:inline-flex; align-items:center; gap:10px; text-decoration:none}
.btn-icon .icon{width:20px; height:20px; flex:0 0 20px; fill:currentColor; opacity:.95}
.btn-icon .dot{opacity:.65}

/* ========= Linkfarben ========= */
a {
  color: var(--brand-2);
  text-decoration: none;
  transition: color .2s ease, opacity .2s ease;
}
a:hover {
  color: var(--brand);
  opacity: .85;
}
.site-footer a {
  font-weight: 600;
  border-bottom: 1px solid transparent;
}
.site-footer a:hover {
  border-color: var(--brand);
}

/* ========= Über mich – Bildausrichtung ========= */
.about-grid {
  display: grid;
  grid-template-columns: minmax(320px,520px) 1fr;
  gap: 32px;
  align-items: start;
}

.about-media { align-self: start; }

.about-photo.about-top {
  border-radius: 22px;              /* abgerundete Ecken */
  box-shadow: 0 14px 32px rgba(0,0,0,.12);
  margin-top: 40px;                 /* weiter nach unten */
  transition: transform .5s ease, box-shadow .4s ease;
}

.about-photo.about-top:hover {
  transform: scale(1.015);          /* sanfter Hover-Zoom */
  box-shadow: 0 18px 38px rgba(0,0,0,.16);
}

@media (max-width:900px){
  .about-photo.about-top {
    margin-top: 0;                  /* auf Handy wieder normal */
  }
}


/* ========= Mobile Feintuning ========= */
@media (max-width: 600px){
  .section{
    padding: 60px 0;
  }
  .section:first-of-type{
    padding-top: 40px;
  }
  .hero-top{margin:6px 0 24px}
  .prose{
    font-size:1.02rem;
    line-height:1.8;
  }
}

/* Noch kompakter für sehr kleine Geräte */
@media (max-width: 430px){
  .section{
    padding: 52px 0;
  }
  .h1{
    font-size:2.1rem;
  }
}


/* Mobile-Layout speziell für die Über-mich-Seite */
@media (max-width: 900px){
  .about-grid{
    grid-template-columns: 1fr;
  }
  .about-media{
    justify-self: center;
  }
  .about-photo.about-top{
    width: 100%;
    max-width: 320px;
  }
}
