/* Page-local styles — Startseite (Homepage). */

/* === HERO === */
.hero{min-height:100vh;position:relative;display:flex;align-items:center;padding:0 3rem;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.1fr 0.9fr;gap:5rem;width:100%;max-width:1400px;margin:0 auto;align-items:center}
.hero-text{position:relative;z-index:2}
.hero-eyebrow{display:inline-flex;align-items:center;gap:0.8rem;font-size:0.78rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--terracotta);margin-bottom:2rem;opacity:0;animation:fadeUp 0.9s 0.2s forwards}
.hero-eyebrow::before{content:'';width:40px;height:1px;background:var(--terracotta)}
.hero h1{font-family:'Cormorant Garamond',serif;font-size:clamp(3rem,6.5vw,5.8rem);font-weight:300;line-height:0.98;letter-spacing:-0.02em;color:var(--ink);margin-bottom:1.8rem;opacity:0;animation:fadeUp 1s 0.4s forwards}
.hero h1 em{font-style:italic;color:var(--terracotta);font-weight:400}
.hero-sub{font-size:1.1rem;font-weight:300;color:var(--ink-soft);max-width:520px;margin-bottom:2.5rem;line-height:1.7;opacity:0;animation:fadeUp 1s 0.6s forwards}
.hero-ctas{display:flex;gap:1.2rem;flex-wrap:wrap;opacity:0;animation:fadeUp 1s 0.8s forwards}

.hero-visual{position:relative;aspect-ratio:1;display:flex;align-items:center;justify-content:center;opacity:0;animation:fadeIn 1.4s 0.5s forwards}
.hero-decor{position:absolute;font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--ink-soft);font-size:0.85rem;letter-spacing:0.1em}
.hero-decor.dec1{top:8%;right:5%;writing-mode:vertical-rl}
.hero-decor.dec2{bottom:10%;left:-2%}

/* === WELCOME === */
.welcome{background:var(--ivory);position:relative;overflow:hidden}
.welcome-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
.welcome-image{
  aspect-ratio:4/5;
  background:
    linear-gradient(135deg, rgba(242,196,164,0.7) 0%, rgba(201,162,79,0.4) 100%),
    radial-gradient(circle at 30% 30%, var(--rose-soft), var(--terracotta));
  border-radius:300px 300px 20px 20px;
  position:relative;overflow:hidden;box-shadow:var(--shadow-warm);
}
.welcome-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 22%;border-radius:inherit;z-index:1}
.welcome-image::after{content:'';position:absolute;inset:0;z-index:2;pointer-events:none;background:radial-gradient(circle at 50% 24%, rgba(255,250,235,0.28) 0%, transparent 60%)}
.welcome-signature{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:2.2rem;color:var(--terracotta);margin-top:2rem;transform:rotate(-3deg);display:inline-block}
.welcome-credentials{font-size:0.8rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--ink-soft);margin-top:0.5rem}
.welcome-text h2{margin-bottom:1.8rem;text-align:left}
.welcome-text .section-eyebrow{justify-content:flex-start}
.welcome-text .section-eyebrow::after{display:none}
.welcome-text p{color:var(--ink-soft);margin-bottom:1.2rem;font-size:1.05rem}
.welcome-actions{margin-top:2.2rem}

/* === SERVICES === */
.services{background:var(--cream)}
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}
.service-card{background:var(--ivory);padding:3rem;border-radius:24px;position:relative;overflow:hidden;transition:all 0.5s ease;border:1px solid transparent;cursor:pointer}
.service-card:hover{transform:translateY(-4px);border-color:var(--line);box-shadow:var(--shadow)}
.service-card.featured{grid-column:span 2;background:linear-gradient(135deg, var(--terracotta) 0%, var(--terracotta-dark) 100%);color:var(--cream)}
.service-card.featured .service-meta,.service-card.featured .service-desc{color:rgba(245,237,224,0.85)}
.service-card.featured .service-price{color:var(--gold-soft)}
.service-icon{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:1.8rem;background:rgba(190,110,71,0.1);color:var(--terracotta);font-size:1.5rem;transition:all 0.4s ease}
.service-card.featured .service-icon{background:rgba(245,237,224,0.15);color:var(--cream)}
.service-card:hover .service-icon{transform:rotate(-8deg) scale(1.1)}
.service-name{font-family:'Cormorant Garamond',serif;font-size:1.9rem;font-weight:400;line-height:1.1;margin-bottom:0.5rem}
.service-meta{font-size:0.78rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:1.2rem}
.service-desc{color:var(--ink-soft);font-size:0.95rem;margin-bottom:1.8rem;line-height:1.6}
.service-bottom{display:flex;justify-content:space-between;align-items:flex-end;padding-top:1.5rem;border-top:1px solid rgba(217,198,169,0.5)}
.service-card.featured .service-bottom{border-color:rgba(245,237,224,0.2)}
.service-price{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:500;color:var(--terracotta)}
.service-price small{font-family:'Outfit',sans-serif;font-size:0.75rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--ink-soft);font-weight:400;display:block;margin-top:0.2rem}
.service-card.featured .service-price small{color:rgba(245,237,224,0.7)}
.service-book{display:inline-flex;align-items:center;gap:0.5rem;background:none;border:none;cursor:pointer;color:var(--ink);font-family:inherit;font-size:0.78rem;letter-spacing:0.18em;text-transform:uppercase;transition:color 0.3s}
.service-card.featured .service-book{color:var(--cream)}
.service-book:hover{color:var(--terracotta)}
.service-card.featured .service-book:hover{color:var(--gold-soft)}
.services-foot{text-align:center;margin-top:3rem}
.services-foot a{color:var(--terracotta);text-decoration:none;font-size:0.85rem;letter-spacing:0.15em;text-transform:uppercase;border-bottom:1px solid transparent;padding-bottom:2px;transition:border-color 0.3s}
.services-foot a:hover{border-color:var(--terracotta)}

/* === STIMMEN (kompakt) === */
.voices-mini{background:var(--ivory)}
.mini-quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;max-width:1200px;margin:0 auto}
.mini-quote{background:var(--cream);border:1px solid var(--line);border-radius:22px;padding:2.4rem;position:relative;transition:transform 0.4s ease, box-shadow 0.4s ease}
.mini-quote:hover{transform:translateY(-4px);box-shadow:var(--shadow-soft)}
.mini-quote::before{content:'\201C';position:absolute;top:0.6rem;left:1.4rem;font-family:'Cormorant Garamond',serif;font-size:4rem;line-height:1;color:var(--rose-soft);opacity:0.8}
.mini-quote p{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.45rem;line-height:1.3;color:var(--ink);margin:1.2rem 0 1.4rem;position:relative;z-index:1}
.mini-quote .mq-author{font-size:0.75rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--terracotta)}
.voices-foot{text-align:center;margin-top:3rem}
.voices-foot a{color:var(--terracotta);text-decoration:none;font-size:0.85rem;letter-spacing:0.15em;text-transform:uppercase;border-bottom:1px solid transparent;padding-bottom:2px;transition:border-color 0.3s}
.voices-foot a:hover{border-color:var(--terracotta)}

/* === BOOKING === */
.booking{background:linear-gradient(180deg, var(--ivory) 0%, var(--cream-2) 100%);position:relative}
.booking-card{background:var(--ivory);border-radius:32px;padding:3.5rem;box-shadow:var(--shadow);max-width:1100px;margin:0 auto;position:relative;overflow:hidden}
.booking-card::before{content:'';position:absolute;top:-100px;right:-100px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle, var(--rose-soft) 0%, transparent 70%);opacity:0.45}
.booking-steps{display:flex;justify-content:center;gap:0;margin-bottom:3rem;position:relative;z-index:2}
.step{display:flex;align-items:center;gap:0.8rem;color:var(--ink-soft);font-size:0.8rem;letter-spacing:0.15em;text-transform:uppercase;transition:color 0.3s}
.step.active{color:var(--ink)}
.step.done{color:var(--terracotta)}
.step-num{width:34px;height:34px;border-radius:50%;background:transparent;border:1px solid currentColor;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-weight:500}
.step.active .step-num,.step.done .step-num{background:currentColor}
.step.active .step-num{color:var(--ink)}
.step.done .step-num{color:var(--terracotta)}
.step.active .step-num span,.step.done .step-num span{color:var(--ivory)}
.step-divider{width:60px;height:1px;background:var(--line);margin:0 1.2rem;align-self:center;margin-top:17px}

.booking-content{position:relative;z-index:2;min-height:380px}
.booking-pane{display:none}
.booking-pane.active{display:block;animation:fadeUp 0.5s ease}

.service-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}
.service-option{padding:1.5rem;border:1px solid var(--line);border-radius:16px;cursor:pointer;background:transparent;font-family:inherit;text-align:left;transition:all 0.3s;color:var(--ink)}
.service-option:hover{border-color:var(--terracotta);background:rgba(190,110,71,0.04)}
.service-option.selected{border-color:var(--terracotta);background:rgba(190,110,71,0.08)}
.service-option-name{font-family:'Cormorant Garamond',serif;font-size:1.25rem;margin-bottom:0.3rem}
.service-option-meta{font-size:0.8rem;color:var(--ink-soft);display:flex;justify-content:space-between;align-items:center;margin-top:0.5rem}
.service-option-meta strong{color:var(--terracotta);font-weight:500}

.calendar-wrap{display:grid;grid-template-columns:1.3fr 1fr;gap:2.5rem;align-items:start}
.calendar{background:var(--cream);padding:1.8rem;border-radius:18px}
.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}
.calendar-month{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:500}
.cal-nav{background:transparent;border:1px solid var(--line);width:34px;height:34px;border-radius:50%;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;color:var(--ink);transition:all 0.3s;font-size:1rem}
.cal-nav:hover:not(:disabled){background:var(--ink);color:var(--cream);border-color:var(--ink)}
.cal-nav:disabled{opacity:0.3;cursor:not-allowed}
.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.day-label{text-align:center;font-size:0.7rem;letter-spacing:0.15em;text-transform:uppercase;color:var(--ink-soft);padding:0.5rem 0}
.day{aspect-ratio:1;border:none;background:transparent;cursor:pointer;border-radius:8px;font-family:inherit;font-size:0.9rem;color:var(--ink);transition:all 0.2s;position:relative}
.day:hover:not(:disabled){background:rgba(190,110,71,0.1)}
.day.selected{background:var(--ink);color:var(--cream)}
.day:disabled{color:var(--line);cursor:not-allowed;opacity:0.5}
.day.today{font-weight:500;color:var(--terracotta)}
.day.has-slots::after{content:'';position:absolute;bottom:5px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--amber)}
.day.selected.has-slots::after{background:var(--gold-soft)}

.slots-panel h3{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:500;margin-bottom:0.3rem}
.slots-panel .slot-day{color:var(--ink-soft);font-size:0.9rem;margin-bottom:1.5rem}
.slots{display:grid;grid-template-columns:repeat(2,1fr);gap:0.6rem;max-height:280px;overflow-y:auto;padding-right:0.5rem}
.slots::-webkit-scrollbar{width:4px}
.slots::-webkit-scrollbar-track{background:transparent}
.slots::-webkit-scrollbar-thumb{background:var(--line);border-radius:4px}
.slot{padding:0.85rem;border:1px solid var(--line);border-radius:10px;background:transparent;cursor:pointer;font-family:inherit;font-size:0.9rem;color:var(--ink);transition:all 0.2s;text-align:center}
.slot:hover:not(:disabled){border-color:var(--terracotta);color:var(--terracotta)}
.slot.selected{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.slot:disabled{opacity:0.35;cursor:not-allowed;text-decoration:line-through}
.no-slots{text-align:center;padding:3rem 1rem;color:var(--ink-soft);font-style:italic}
.no-slots::before{content:'';display:block;width:40px;height:1px;background:var(--line);margin:0 auto 1rem}

.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem;max-width:640px;margin:0 auto}
.form-field.full{grid-column:span 2}
.form-field textarea{min-height:90px}

.summary{max-width:540px;margin:0 auto;background:var(--cream);border-radius:18px;padding:2rem}
.summary-row{display:flex;justify-content:space-between;align-items:flex-start;padding:0.9rem 0;border-bottom:1px solid var(--line);gap:1rem}
.summary-row:last-child{border-bottom:none}
.summary-label{font-size:0.75rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--ink-soft)}
.summary-value{font-family:'Cormorant Garamond',serif;font-size:1.15rem;text-align:right}
.summary-total .summary-value{color:var(--terracotta);font-size:1.4rem;font-weight:500}

.booking-actions{display:flex;justify-content:space-between;margin-top:2.5rem;gap:1rem}
.btn-text{background:none;border:none;cursor:pointer;font-family:inherit;color:var(--ink-soft);font-size:0.8rem;letter-spacing:0.2em;text-transform:uppercase;padding:1.1rem 0;transition:color 0.3s}
.btn-text:hover{color:var(--terracotta)}

.confirm-success{text-align:center;padding:2rem 0}
.confirm-icon{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg, var(--amber) 0%, var(--coral) 100%);margin:0 auto 1.5rem;display:flex;align-items:center;justify-content:center;color:var(--cream);font-size:2.5rem;animation:popIn 0.5s ease}
.confirm-success h3{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:400;margin-bottom:0.8rem}
.confirm-success p{color:var(--ink-soft);max-width:440px;margin:0 auto 2rem}

/* === IMPULSE (Blog-Teaser) === */
.impulse{background:var(--cream)}
.impulse-grid{display:grid;grid-template-columns:1.35fr 1fr;gap:1.5rem;align-items:stretch}
.post{background:var(--ivory);border:1px solid var(--line);border-radius:24px;overflow:hidden;display:flex;flex-direction:column;cursor:pointer;transition:transform 0.45s ease, box-shadow 0.45s ease, border-color 0.45s ease;text-decoration:none;color:inherit}
.post:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
.post-thumb{position:relative;overflow:hidden}
.post-thumb::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 25%, rgba(255,250,235,0.4) 0%, transparent 55%)}
.post-featured .post-thumb{aspect-ratio:16/10}
.post-sm .post-thumb{aspect-ratio:16/7}
.thumb-coral{background:linear-gradient(140deg, var(--coral-soft) 0%, var(--coral) 50%, var(--copper) 100%)}
.thumb-amber{background:linear-gradient(140deg, var(--gold-soft) 0%, var(--amber) 55%, var(--copper) 100%)}
.thumb-rose{background:linear-gradient(140deg, var(--rose-soft) 0%, var(--rose) 55%, var(--terracotta) 100%)}
.post-body{padding:2rem 2.2rem;display:flex;flex-direction:column;flex:1}
.post-featured .post-body{padding:2.6rem 2.6rem}
.post-cat{font-size:0.72rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--terracotta);margin-bottom:0.9rem}
.post h3{font-family:'Cormorant Garamond',serif;font-weight:400;line-height:1.12;margin-bottom:0.9rem}
.post-featured h3{font-size:2.1rem}
.post-sm h3{font-size:1.4rem}
.post p{color:var(--ink-soft);font-size:0.97rem;line-height:1.6;margin-bottom:1.4rem}
.post-sm p{font-size:0.9rem;margin-bottom:1rem}
.post-meta{margin-top:auto;display:flex;align-items:center;gap:0.8rem;font-size:0.75rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--ink-soft)}
.post-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--line)}
.post-more{color:var(--terracotta);font-weight:400}
.impulse-col{display:flex;flex-direction:column;gap:1.5rem}
.impulse-foot{text-align:center;margin-top:3rem}
.impulse-foot a{color:var(--terracotta);text-decoration:none;font-size:0.85rem;letter-spacing:0.15em;text-transform:uppercase;border-bottom:1px solid transparent;padding-bottom:2px;transition:border-color 0.3s}
.impulse-foot a:hover{border-color:var(--terracotta)}

/* === HOURS / CONTACT === */
.hours{background:var(--terracotta-dark);color:var(--cream);position:relative;overflow:hidden}
.hours::before{content:'';position:absolute;top:-200px;right:-200px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle, rgba(242,196,164,0.22) 0%, transparent 70%)}
.hours-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center;position:relative;z-index:2}
.hours h2{text-align:left;color:var(--cream)}
.hours h2 em{color:var(--gold-soft)}
.hours .section-eyebrow{justify-content:flex-start;color:var(--gold-soft)}
.hours .section-eyebrow::before{background:var(--gold-soft)}
.hours .section-eyebrow::after{display:none}
.hours-intro{color:rgba(245,237,224,0.85);font-size:1.05rem;margin-bottom:2rem;max-width:480px}
.hours-list{list-style:none}
.hours-list li{display:flex;justify-content:space-between;padding:1.2rem 0;border-bottom:1px solid rgba(245,237,224,0.15);font-size:1rem}
.hours-list li strong{font-weight:400;font-family:'Cormorant Garamond',serif;font-size:1.2rem}
.hours-list .day-name{color:var(--gold-soft)}
.hours-block{background:rgba(245,237,224,0.06);border-radius:24px;padding:2.5rem;backdrop-filter:blur(20px);border:1px solid rgba(245,237,224,0.12)}
.hours-block h4{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:500;margin-bottom:1rem;color:var(--gold-soft)}
.contact-link{display:flex;align-items:center;gap:1rem;color:var(--cream);text-decoration:none;padding:1rem 0;border-bottom:1px solid rgba(245,237,224,0.15);transition:color 0.3s}
.contact-link:last-child{border-bottom:none}
.contact-link:hover{color:var(--gold-soft)}
.contact-link-icon{width:40px;height:40px;border-radius:50%;background:rgba(245,237,224,0.1);display:flex;align-items:center;justify-content:center;font-size:1.1rem}
.contact-link-text small{display:block;font-size:0.7rem;letter-spacing:0.2em;text-transform:uppercase;color:rgba(245,237,224,0.6);margin-bottom:0.2rem}

/* === RESPONSIVE === */
@media (max-width:900px){
  .hero{padding:6rem 1.5rem 4rem;min-height:auto}
  .hero-grid{grid-template-columns:1fr;gap:3rem}
  .hero-visual{max-width:380px;margin:0 auto;order:-1}
  .hero-decor{display:none}
  .welcome-grid,.hours-grid{grid-template-columns:1fr;gap:3rem}
  .services-grid{grid-template-columns:1fr}
  .service-card.featured{grid-column:span 1}
  .mini-quotes{grid-template-columns:1fr}
  .impulse-grid{grid-template-columns:1fr}
  .booking-card{padding:2rem 1.5rem}
  .calendar-wrap{grid-template-columns:1fr;gap:2rem}
  .booking-steps{flex-wrap:wrap;gap:0.5rem;justify-content:flex-start}
  .step-divider{display:none}
  .step{font-size:0.7rem}
  .form-grid{grid-template-columns:1fr}
  .form-field.full{grid-column:span 1}
  .booking-actions{flex-direction:column-reverse}
  .booking-actions .btn{width:100%;justify-content:center}
}
