/* ============================================
   Haarwerk Waldenbuch — Modern Boutique
   Design Tokens 1:1 aus style-tile.html
   ============================================ */

*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }

:root{
  /* Brand Tokens */
  --bg:#f5efe7;
  --paper:#fbf7f1;
  --paper-deep:#f0e8db;
  --ink:#2a2520;
  --ink-soft:#6b5e51;
  --ink-mute:#9b8e7f;
  --accent:#b08768;
  --accent-deep:#8a6749;
  --accent-soft:#d5b89a;
  --line:#e7ddcf;
  --line-strong:#cfc2ad;
  --success:#7a8c6f;
  --warn:#c4895d;
  --danger:#a85a5a;

  /* Layout */
  --max:1200px;
  --gutter:clamp(20px, 4vw, 48px);
  --radius:6px;
  --radius-lg:10px;

  /* Shadows */
  --shadow-sm:0 1px 0 var(--line);
  --shadow-md:0 4px 24px -8px rgba(42,37,32,.08);
  --shadow-lg:0 12px 40px -12px rgba(42,37,32,.12);

  /* Easing */
  --ease:cubic-bezier(.4,0,.2,1);
}

/* ============================================
   BASE
   ============================================ */
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,sans-serif;
  font-weight:400;
  font-size:16px;
  line-height:1.65;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
}

img,picture,video,svg { max-width:100%; height:auto; display:block; }
a { color:inherit; text-decoration:none; }
button { font:inherit; cursor:pointer; background:none; border:none; color:inherit; }

::selection { background:var(--accent); color:#fff; }

.serif { font-family:'Marcellus',Georgia,'Times New Roman',serif; font-weight:400; letter-spacing:-.005em; }

/* ============================================
   TYPE
   ============================================ */
h1,h2,h3,h4,h5,h6 { font-family:'Marcellus',Georgia,serif; font-weight:400; line-height:1.15; color:var(--ink); }
h1 { font-size:clamp(38px, 5.6vw, 64px); line-height:1.05; letter-spacing:-.01em; }
h2 { font-size:clamp(28px, 3.8vw, 44px); margin-bottom:.4em; }
h3 { font-size:clamp(22px, 2.4vw, 28px); margin-bottom:.4em; }
h4 { font-size:clamp(18px, 1.8vw, 22px); margin-bottom:.4em; }
em { font-style:italic; color:var(--accent); }

p { color:var(--ink-soft); max-width:62ch; }
p + p { margin-top:1em; }

.eyebrow {
  display:inline-block;
  font-family:'Inter',sans-serif;
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ink-soft);
  font-weight:500;
  margin-bottom:18px;
}
.lead { font-size:clamp(17px, 1.6vw, 19px); color:var(--ink); max-width:60ch; line-height:1.55; }

/* ============================================
   LAYOUT
   ============================================ */
.container { max-width:var(--max); margin:0 auto; padding:0 var(--gutter); }

section { padding:clamp(60px, 9vw, 120px) 0; }
section.tight { padding:clamp(40px, 6vw, 80px) 0; }

.grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:clamp(24px, 4vw, 56px); align-items:center; }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px, 2.4vw, 30px); }
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(16px, 2vw, 24px); }
@media(max-width:900px) { .grid-2 { grid-template-columns:1fr; } .grid-3 { grid-template-columns:1fr 1fr; } .grid-4 { grid-template-columns:1fr 1fr; } }
@media(max-width:560px) { .grid-3,.grid-4 { grid-template-columns:1fr; } }

/* ============================================
   NAV
   ============================================ */
.nav{
  position:sticky; top:0; z-index:50;
  background:rgba(245,239,231,.92);
  backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid transparent;
  transition:border-color .3s var(--ease), background .3s var(--ease);
}
.nav.scrolled{ border-bottom-color:var(--line); }
.nav-inner{
  max-width:var(--max); margin:0 auto;
  padding:18px var(--gutter);
  display:flex; align-items:center; justify-content:space-between; gap:24px;
}
.nav-logo img{ height:44px; width:auto; }
.nav-menu{ display:flex; gap:6px; align-items:center; }
.nav-menu a{
  padding:10px 16px; font-size:14px; font-weight:500;
  color:var(--ink); border-radius:999px;
  transition:background .2s var(--ease), color .2s var(--ease);
}
.nav-menu a:hover{ background:var(--paper); }
.nav-menu a.active{ color:var(--accent-deep); }
.nav-menu a.cta{
  background:var(--accent); color:#fff; padding:12px 22px;
}
.nav-menu a.cta:hover{ background:var(--accent-deep); }

.nav-toggle{ display:none; padding:10px; }
.nav-toggle svg{ width:28px; height:28px; }

@media(max-width:900px){
  .nav-menu{
    position:fixed; inset:64px 0 0 0; flex-direction:column;
    background:var(--bg); padding:30px var(--gutter);
    transform:translateY(-100%); opacity:0; pointer-events:none;
    transition:transform .3s var(--ease), opacity .3s var(--ease);
    gap:6px; align-items:flex-start; overflow-y:auto;
  }
  .nav-menu.open{ transform:translateY(0); opacity:1; pointer-events:auto; }
  .nav-menu a{ width:100%; padding:14px 18px; font-size:17px; }
  .nav-menu a.cta{ text-align:center; margin-top:10px; }
  .nav-toggle{ display:block; }
}

/* ============================================
   BUTTONS
   ============================================ */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 26px;
  font-family:'Inter',sans-serif; font-size:14px; font-weight:500;
  letter-spacing:.04em;
  border-radius:999px;
  border:1px solid transparent;
  transition:background .2s var(--ease), color .2s var(--ease), border-color .2s var(--ease), transform .1s var(--ease);
  cursor:pointer;
  white-space:nowrap;
}
.btn:active{ transform:translateY(1px); }
.btn-primary{ background:var(--accent); color:#fff; border-color:var(--accent); }
.btn-primary:hover{ background:var(--accent-deep); border-color:var(--accent-deep); }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--ink); }
.btn-ghost:hover{ background:var(--ink); color:var(--bg); }
.btn-soft{ background:var(--paper); color:var(--ink); border-color:var(--line); }
.btn-soft:hover{ background:var(--paper-deep); border-color:var(--line-strong); }
.btn-large{ padding:18px 32px; font-size:15px; }

/* ============================================
   STATUS PILL
   ============================================ */
.status-pill{
  display:inline-flex; align-items:center; gap:10px;
  padding:8px 16px; border-radius:999px;
  font-size:13px; font-weight:500;
  font-family:'Inter',sans-serif;
}
.status-pill::before{ content:''; width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.status-pill.open{ background:#eef2ea; color:var(--success); }
.status-pill.open::before{ background:var(--success); animation:pulse 2s ease-in-out infinite; }
.status-pill.closed{ background:#f1eae1; color:var(--ink-soft); }
.status-pill.closed::before{ background:var(--ink-mute); }

@keyframes pulse {
  0%,100%{ opacity:1; transform:scale(1); }
  50%{ opacity:.55; transform:scale(1.2); }
}
@media (prefers-reduced-motion: reduce){
  .status-pill.open::before{ animation:none; }
}

/* ============================================
   HERO
   ============================================ */
.hero{
  padding:clamp(50px, 8vw, 100px) 0 clamp(60px, 9vw, 120px);
  background:var(--bg);
  position:relative; overflow:hidden;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:clamp(30px, 5vw, 70px);
  align-items:center;
}
.hero-text { max-width:560px; }
.hero h1 { margin-bottom:22px; }
.hero .lead { margin-bottom:30px; }
.hero-ctas { display:flex; gap:14px; flex-wrap:wrap; margin-bottom:28px; }
.hero-img-wrap{
  border-radius:var(--radius-lg);
  overflow:hidden;
  aspect-ratio: 4/5;
  box-shadow:var(--shadow-lg);
}
.hero-img-wrap img{ width:100%; height:100%; object-fit:cover; filter:saturate(.94); }

@media(max-width:900px){
  .hero-grid{ grid-template-columns:1fr; }
  .hero-img-wrap{ aspect-ratio: 16/12; order:-1; }
}

/* Page Hero (kein Bild) */
.page-hero{
  padding:clamp(50px, 8vw, 100px) 0 clamp(40px, 6vw, 70px);
  background:linear-gradient(180deg, var(--bg) 0%, var(--paper) 100%);
  border-bottom:1px solid var(--line);
  text-align:center;
}
.page-hero h1 { margin:14px 0 18px; }
.page-hero p { margin:0 auto; max-width:54ch; font-size:17px; }

/* ============================================
   CARDS
   ============================================ */
.card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:clamp(22px, 2.4vw, 30px);
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
}
.card:hover{ transform:translateY(-2px); box-shadow:var(--shadow-md); border-color:var(--line-strong); }
.card .eyebrow{ margin-bottom:8px; }
.card h3{ font-size:22px; margin-bottom:8px; }
.card .price{
  color:var(--accent-deep);
  font-weight:500; font-size:13px;
  margin-top:14px;
  letter-spacing:.05em;
  text-transform:uppercase;
}
.card.featured{
  border-left:3px solid var(--accent);
}

/* ============================================
   SERVICES (Preisliste)
   ============================================ */
.service-section{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:clamp(28px, 4vw, 48px);
  margin-bottom:30px;
}
.service-section h3{
  font-size:28px;
  border-bottom:1px solid var(--line);
  padding-bottom:18px;
  margin-bottom:26px;
}
.service-list{ list-style:none; padding:0; margin:0; }
.service-list li{
  display:flex; justify-content:space-between; align-items:flex-start;
  gap:24px; padding:18px 0;
  border-bottom:1px dashed var(--line);
}
.service-list li:last-child{ border-bottom:none; }
.service-list .name{ flex:1; }
.service-list .name strong{
  display:block; font-weight:500; color:var(--ink);
  font-family:'Marcellus',serif; font-size:18px; margin-bottom:4px;
}
.service-list .name span{ font-size:13.5px; color:var(--ink-soft); line-height:1.5; }
.service-list .price{
  font-family:'Marcellus',serif; font-size:20px;
  color:var(--accent-deep); white-space:nowrap;
  padding-top:2px;
}

.price-note{
  background:#fcf4eb;
  border:1px solid #ecd6bc;
  border-radius:var(--radius);
  padding:18px 24px;
  font-size:14px; color:var(--ink-soft);
  margin-bottom:36px;
  display:flex; gap:14px; align-items:flex-start;
}
.price-note .ico{
  font-family:'Marcellus',serif; font-style:italic;
  font-size:24px; color:var(--accent); line-height:1;
}

/* ============================================
   FEATURE / TRUST STRIP
   ============================================ */
.trust{ background:var(--paper); padding:clamp(50px, 7vw, 90px) 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.trust-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:clamp(24px, 3vw, 40px);
}
.trust-item{ text-align:center; }
.trust-item .num{
  font-family:'Marcellus',serif;
  font-size:clamp(40px, 5vw, 56px);
  color:var(--accent);
  line-height:1; margin-bottom:6px;
  letter-spacing:-.01em;
}
.trust-item .label{
  font-size:13px;
  color:var(--ink-soft);
  font-weight:500;
  letter-spacing:.08em;
  text-transform:uppercase;
}
@media(max-width:760px){ .trust-grid{ grid-template-columns:repeat(2,1fr); gap:32px 20px; } }

/* ============================================
   QUOTE
   ============================================ */
.quote-block{
  background:var(--paper); border-radius:var(--radius-lg);
  padding:clamp(32px, 5vw, 60px);
  border:1px solid var(--line);
  text-align:center;
  max-width:780px; margin:0 auto;
}
.quote-block blockquote{
  font-family:'Marcellus',serif; font-style:italic;
  font-size:clamp(22px, 2.6vw, 32px);
  line-height:1.35;
  color:var(--ink);
  margin-bottom:20px;
}
.quote-block cite{
  font-style:normal;
  font-family:'Inter',sans-serif;
  font-size:12px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-soft);
  font-weight:500;
}

/* ============================================
   GALLERY
   ============================================ */
.gallery{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:clamp(12px, 1.5vw, 20px);
}
.gallery-item{
  aspect-ratio:1/1;
  overflow:hidden;
  border-radius:var(--radius);
  background:var(--paper);
  cursor:pointer;
  position:relative;
}
.gallery-item img{
  width:100%; height:100%; object-fit:cover;
  transition:transform .5s var(--ease), filter .25s var(--ease);
  filter:saturate(.94);
}
.gallery-item:hover img{ transform:scale(1.04); filter:saturate(1.02); }
@media(max-width:680px){ .gallery{ grid-template-columns:repeat(2,1fr); } }

/* Lightbox */
.lightbox{
  position:fixed; inset:0; background:rgba(42,37,32,.92);
  display:none; align-items:center; justify-content:center;
  padding:20px; z-index:100;
  -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
}
.lightbox.open{ display:flex; }
.lightbox img{ max-width:90vw; max-height:88vh; border-radius:var(--radius); }
.lightbox-close{
  position:absolute; top:20px; right:20px;
  width:44px; height:44px; border-radius:50%;
  background:rgba(255,255,255,.15); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:28px; line-height:1;
}
.lightbox-close:hover{ background:rgba(255,255,255,.25); }

/* ============================================
   CONTACT / MAP
   ============================================ */
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:clamp(28px, 4vw, 56px);
  align-items:start;
}
@media(max-width:900px){ .contact-grid{ grid-template-columns:1fr; } }

.contact-info{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:clamp(28px, 4vw, 40px);
}
.contact-info dl{ display:grid; grid-template-columns:1fr; gap:18px; margin:0; }
.contact-info dt{
  font-size:11px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-soft); font-weight:500; margin-bottom:4px;
}
.contact-info dd{
  font-family:'Marcellus',serif; font-size:19px; color:var(--ink); margin:0;
}
.contact-info dd a:hover{ color:var(--accent-deep); text-decoration:underline; }

.hours-list{ list-style:none; padding:0; margin:8px 0 0 0; }
.hours-list li{
  display:flex; justify-content:space-between;
  padding:8px 0; border-bottom:1px dashed var(--line);
  font-size:14.5px;
}
.hours-list li:last-child{ border-bottom:none; }
.hours-list .day{ color:var(--ink); font-weight:500; }
.hours-list .time{ color:var(--ink-soft); font-variant-numeric:tabular-nums; }
.hours-list li.today{ background:#fbf7ee; padding:8px 14px; border-radius:4px; }
.hours-list li.today .day{ color:var(--accent-deep); }
.hours-list li.closed .time{ color:var(--ink-mute); font-style:italic; }

#map{
  height:480px;
  border-radius:var(--radius-lg);
  overflow:hidden;
  border:1px solid var(--line);
}
@media(max-width:900px){ #map{ height:380px; } }

/* ============================================
   FORM
   ============================================ */
.form-grid{
  display:grid; grid-template-columns:1fr 1fr;
  gap:18px;
}
.form-grid .full{ grid-column:1/-1; }
@media(max-width:680px){ .form-grid{ grid-template-columns:1fr; } }

.label{
  display:block;
  font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink-soft); font-weight:500;
  margin-bottom:8px;
}
.input, .textarea, .select{
  display:block; width:100%;
  padding:14px 16px;
  border:1px solid var(--line);
  background:#fff;
  border-radius:4px;
  font-family:'Inter',sans-serif;
  font-size:15px; color:var(--ink);
  outline:none;
  transition:border-color .2s var(--ease), background .2s var(--ease);
}
.input:focus, .textarea:focus, .select:focus{
  border-color:var(--accent);
  background:#fffefa;
}
.textarea{ resize:vertical; min-height:130px; line-height:1.55; }

/* ============================================
   FOOTER
   ============================================ */
footer.site-footer{
  background:var(--ink);
  color:#d9cdb9;
  padding:clamp(50px, 6vw, 80px) 0 30px;
  margin-top:0;
}
.foot-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:clamp(24px, 3vw, 48px);
  margin-bottom:40px;
}
@media(max-width:880px){ .foot-grid{ grid-template-columns:1fr 1fr; gap:36px 24px; } }
@media(max-width:480px){ .foot-grid{ grid-template-columns:1fr; } }
.foot-logo img{
  height:38px; width:auto;
  filter:brightness(0) invert(1) opacity(.85);
  margin-bottom:18px;
}
.foot-grid h4{
  font-family:'Inter',sans-serif;
  font-size:11px; font-weight:500;
  letter-spacing:.18em; text-transform:uppercase;
  color:#f0e2c8; margin-bottom:16px;
}
.foot-grid ul{ list-style:none; padding:0; }
.foot-grid li{ margin-bottom:8px; font-size:14px; }
.foot-grid a:hover{ color:#fff; text-decoration:underline; }
.foot-grid p{ font-size:14px; color:#bca890; line-height:1.6; }
.foot-bottom{
  padding-top:24px;
  border-top:1px solid rgba(217,205,185,.15);
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:14px;
  font-size:12.5px; color:#9a8870;
}
.foot-bottom a:hover{ color:#fff; }

/* ============================================
   UTILITIES
   ============================================ */
.center { text-align:center; }
.muted { color:var(--ink-soft); }
.mt-0{ margin-top:0; }
.mt-1{ margin-top:.5em; }
.mt-2{ margin-top:1em; }
.mt-3{ margin-top:2em; }
.mt-4{ margin-top:3em; }
.mb-2{ margin-bottom:1em; }
.mb-3{ margin-bottom:2em; }

/* Reveal — Content sichtbar als Default! Animation NUR als Enhancement. */
.reveal { /* opacity:1 immer */ }
@media (prefers-reduced-motion: no-preference){
  html.js-loaded .reveal {
    opacity:0;
    transform:translateY(20px);
    transition: opacity .7s var(--ease), transform .7s var(--ease);
  }
  html.js-loaded .reveal.visible {
    opacity:1;
    transform:translateY(0);
  }
}

/* Section divider */
.divider {
  border:0; border-top:1px solid var(--line);
  margin:clamp(40px, 6vw, 80px) 0;
}

/* Section header utility */
.sec-head{ text-align:center; margin-bottom:clamp(36px, 5vw, 60px); }
.sec-head .eyebrow{ margin-bottom:14px; }
.sec-head p{ margin:14px auto 0; }
