:root {
  --teal:      #009ba3;
  --teal-dark: #007a80;
  --teal-pale: #e8f6f7;
  --teal-mid:  #c5e7e9;
  --white:     #ffffff;
  --off:       #f8f8f6;
  --paper:     #fbfaf7;
  --text:      #1a1a1a;
  --muted:     #6b6b6b;
  --border:    #e8e8e4;
  --r:         8px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Outfit',sans-serif;background:var(--white);color:var(--text);-webkit-font-smoothing:antialiased;line-height:1.6}

/* ── NAV ── */
nav.sub{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.98);
  backdrop-filter:saturate(180%) blur(6px);
  border-bottom:1px solid var(--border);
  padding:0 clamp(1rem,4vw,2.5rem);
}
.nav-inner{max-width:1180px;margin:0 auto;height:85px;display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:.8rem;text-decoration:none}
.logo img{height:68px;width:auto;display:block}
.logo-text{font-size:.88rem;font-weight:600;color:var(--text);line-height:1.25}
.logo-text small{display:block;font-size:.72rem;font-weight:400;color:var(--muted)}
.nav-links{list-style:none;display:flex;gap:.15rem}
.nav-links a{text-decoration:none;font-size:.83rem;font-weight:500;padding:.45rem .85rem;border-radius:var(--r);color:var(--muted);transition:color .15s,background .15s}
.nav-links a:hover,.nav-links a.active{color:var(--teal);background:var(--teal-pale)}
.nav-cta{background:var(--teal)!important;color:#fff!important;padding:.5rem 1.2rem!important;border-radius:50px!important;font-weight:600!important;margin-left:.4rem}
.nav-cta:hover{background:var(--teal-dark)!important}

.ham{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.4rem}
.ham span{display:block;width:23px;height:2px;border-radius:2px;background:var(--text);transition:transform .25s,opacity .25s}
.ham.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.ham.open span:nth-child(2){opacity:0}
.ham.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mob{display:none;flex-direction:column;position:fixed;top:85px;left:0;right:0;bottom:0;z-index:99;background:var(--white);overflow-y:auto;padding:1rem 0 2rem}
.mob.open{display:flex}
.mob a{text-decoration:none;color:var(--text);font-size:1.05rem;font-weight:500;padding:1rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.mob a::after{content:'→';color:var(--teal);font-size:.85rem}

/* ── PAGE INTRO ── */
.intro{
  position:relative;
  background:
    linear-gradient(100deg,var(--paper) 0%,var(--paper) 55%,transparent 55%),
    url('../bilder/wohnzimmer-schrank.jpg') right center / cover no-repeat;
  border-bottom:1px solid var(--border);
  overflow:hidden;
}
.intro::before{content:'';position:absolute;top:0;bottom:0;left:55%;width:1px;background:linear-gradient(to bottom,transparent,var(--border) 30%,var(--border) 70%,transparent)}
.intro-inner{max-width:1180px;margin:0 auto;padding:clamp(2.2rem,5vw,3.4rem) clamp(1.2rem,4vw,2.5rem)}
.intro-text{max-width:620px;min-height:300px;display:flex;flex-direction:column;justify-content:center}
.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.78rem;color:var(--muted);margin-bottom:1.1rem;flex-wrap:wrap}
.breadcrumb a{color:var(--muted);text-decoration:none;transition:color .15s}
.breadcrumb a:hover{color:var(--teal)}
.breadcrumb .sep{color:var(--teal);font-weight:700}
.breadcrumb .cur{color:var(--text);font-weight:600}
.intro-kicker{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);margin-bottom:.6rem}
.intro h1{font-family:'Fraunces',serif;font-size:clamp(2rem,4.6vw,3.1rem);font-weight:600;line-height:1.1;margin-bottom:1rem}
.intro h1 em{font-style:italic;color:var(--teal)}
.intro-claim{font-size:1.05rem;color:var(--muted);max-width:520px;line-height:1.6}

/* ── CONTENT ── */
.page{
  max-width:1180px;margin:0 auto;
  padding:clamp(2.5rem,6vw,4rem) clamp(1.2rem,4vw,2.5rem);
  display:grid;grid-template-columns:1fr 320px;
  gap:clamp(2rem,4vw,3.5rem);align-items:start;
}
.article h2{font-family:'Fraunces',serif;font-size:clamp(1.5rem,2.8vw,2rem);font-weight:600;line-height:1.25;color:var(--text);margin:2.2rem 0 1rem;padding-left:1rem;position:relative}
.article h2::before{content:'';position:absolute;left:0;top:.3em;bottom:.3em;width:3px;background:var(--teal);border-radius:3px}
.article h2:first-child{margin-top:0}
.article h3{font-family:'Fraunces',serif;font-size:1.2rem;font-weight:600;color:var(--text);margin:1.6rem 0 .6rem}
.article p{color:#333;font-size:1rem;line-height:1.8;margin-bottom:1rem}
.article p.lead{font-size:1.12rem;line-height:1.7;color:var(--text);font-weight:400;border-left:0;margin-bottom:1.6rem}
.article blockquote{border-left:3px solid var(--teal);padding:.4rem 0 .4rem 1.3rem;margin:1.4rem 0;font-style:italic;color:var(--muted);font-family:'Fraunces',serif;font-size:1.08rem}
.article ul,.article ol{margin:.6rem 0 1.3rem 1.4rem;color:#333;font-size:1rem;line-height:1.75}
.article ul li,.article ol li{margin-bottom:.3rem}

/* ── FEATURE LIST ── */
.features{background:var(--paper);border:1px solid var(--border);border-radius:var(--r);padding:1.6rem 1.8rem;margin:1.8rem 0 2rem}
.features h3{font-family:'Fraunces',serif;font-size:1.15rem;font-weight:600;margin-bottom:1rem;color:var(--text)}
.feat-grid{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.feat{display:flex;gap:.75rem;align-items:flex-start;font-size:.93rem;line-height:1.5}
.feat-ic{width:28px;height:28px;border-radius:6px;background:var(--teal-pale);color:var(--teal);display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0;font-size:.88rem}

/* ── SIDEBAR ── */
.aside{position:sticky;top:90px}
.side-box{background:var(--paper);border:1px solid var(--border);border-radius:var(--r);padding:1.5rem;margin-bottom:1.2rem}
.side-box h3{font-family:'Fraunces',serif;font-size:1.1rem;font-weight:600;margin-bottom:1rem;color:var(--text)}
.side-list{list-style:none;display:flex;flex-direction:column;gap:.15rem}
.side-list a{display:flex;justify-content:space-between;align-items:center;text-decoration:none;color:var(--text);font-size:.92rem;font-weight:500;padding:.7rem .9rem;border-radius:6px;transition:background .15s,color .15s,padding-left .15s}
.side-list a:hover{background:var(--teal-pale);color:var(--teal);padding-left:1.1rem}
.side-list a.active{background:var(--teal);color:#fff}
.side-list a::after{content:'→';opacity:.4;font-size:.85rem}
.side-list a:hover::after,.side-list a.active::after{opacity:1}
.side-facts{display:flex;flex-direction:column;gap:.8rem}
.sf-row{display:flex;gap:.75rem;align-items:flex-start;font-size:.87rem}
.sf-ic{width:28px;height:28px;border-radius:6px;background:var(--teal-pale);color:var(--teal);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sf-lbl{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.sf-val{font-size:.92rem;font-weight:600;color:var(--text)}
.sf-val a{color:inherit;text-decoration:none}
.side-cta{background:var(--teal);color:#fff;border-radius:var(--r);padding:1.4rem 1.5rem}
.side-cta p{font-size:.88rem;color:rgba(255,255,255,.85);margin-bottom:.5rem}
.side-cta strong{display:block;font-size:1.3rem;color:#fff;margin-bottom:.9rem;font-family:'Fraunces',serif}
.btn-w-sm{display:inline-block;background:#fff;color:var(--teal);padding:.6rem 1.2rem;border-radius:50px;font-size:.85rem;font-weight:700;text-decoration:none;transition:transform .15s}
.btn-w-sm:hover{transform:translateY(-1px)}

/* ── GALLERY ── */
.gallery-block{background:var(--off);padding:clamp(3rem,6vw,4.5rem) clamp(1.2rem,4vw,2.5rem);border-top:1px solid var(--border)}
.gallery-wrap{max-width:1180px;margin:0 auto}
.gb-head{max-width:620px;margin-bottom:2rem}
.gb-head .kicker{display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);margin-bottom:.5rem}
.gb-head h2{font-family:'Fraunces',serif;font-size:clamp(1.6rem,3vw,2.2rem);font-weight:600;margin-bottom:.6rem}
.gb-head p{color:var(--muted);font-size:.98rem;line-height:1.6}
.gg{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem}
.gg-item{position:relative;overflow:hidden;border-radius:var(--r);aspect-ratio:4/3;cursor:pointer;background:#eee}
.gg-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gg-item:hover img{transform:scale(1.05)}
.gg-cap{position:absolute;left:0;right:0;bottom:0;padding:1.5rem 1.2rem .9rem;color:#fff;font-size:.88rem;font-weight:600;background:linear-gradient(to top,rgba(0,0,0,.75) 0%,rgba(0,0,0,0) 100%);transform:translateY(30%);opacity:0;transition:transform .3s,opacity .3s}
.gg-item:hover .gg-cap{transform:translateY(0);opacity:1}
.gg-item:nth-child(1){grid-row:span 2;aspect-ratio:auto}
.gg-item:nth-child(1) img{min-height:100%}

/* ── CTA BAND ── */
.ctaband{background:var(--teal);color:#fff;padding:clamp(2.5rem,5vw,3.5rem) clamp(1.2rem,4vw,2.5rem)}
.ctab-in{max-width:1180px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.ctab-txt h2{font-family:'Fraunces',serif;font-size:clamp(1.5rem,3vw,2rem);font-weight:600;margin-bottom:.3rem;color:#fff}
.ctab-txt p{color:rgba(255,255,255,.85);font-size:1rem}
.ctab-btns{display:flex;gap:.7rem;flex-wrap:wrap}
.btn-w{background:#fff;color:var(--teal);padding:.85rem 1.8rem;border-radius:50px;font-weight:700;text-decoration:none;font-size:.95rem;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 14px rgba(0,0,0,.15)}
.btn-w:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(0,0,0,.2)}
.btn-ghost{border:2px solid rgba(255,255,255,.6);color:#fff;padding:.8rem 1.6rem;border-radius:50px;font-weight:500;text-decoration:none;font-size:.95rem;transition:border-color .2s,background .2s}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.1)}

/* ── FOOTER ── */
footer{background:#111;color:rgba(255,255,255,.55);padding:3rem 1.5rem 1.5rem}
.f-in{max-width:1180px;margin:0 auto}
.f-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2rem;margin-bottom:2.4rem}
.f-col h4{color:#fff;font-family:'Fraunces',serif;font-size:1rem;margin-bottom:1rem;font-weight:600}
.f-col ul{list-style:none;display:flex;flex-direction:column;gap:.5rem}
.f-col a{color:rgba(255,255,255,.55);text-decoration:none;font-size:.88rem;transition:color .15s}
.f-col a:hover{color:var(--teal)}
.f-brand{display:flex;align-items:center;gap:.8rem;margin-bottom:1rem}
.f-brand img{height:52px;width:auto;background:#fff;padding:4px 6px;border-radius:4px}
.f-brand .bt{color:#fff;font-weight:600;font-size:.98rem}
.f-brand .bt small{display:block;color:rgba(255,255,255,.5);font-size:.75rem;font-weight:400}
.f-col p{font-size:.85rem;line-height:1.7;color:rgba(255,255,255,.55)}
.f-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:1.3rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.8rem}

/* ── OPENING HOURS WIDGET ── */
.hours-widget{position:fixed;top:105px;right:clamp(.8rem,2vw,1.4rem);z-index:90;font-family:'Outfit',sans-serif}
.hw-trigger{
  display:flex;align-items:center;gap:.6rem;
  background:var(--white);border:1px solid var(--border);
  padding:.55rem .95rem .55rem .7rem;border-radius:50px;
  box-shadow:0 4px 16px rgba(0,0,0,.06);
  cursor:pointer;transition:all .2s;font-family:inherit;font-size:.85rem;color:var(--text);font-weight:500;
}
.hw-trigger:hover{box-shadow:0 6px 22px rgba(0,0,0,.1);transform:translateY(-1px)}
.hw-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.hw-dot.open{background:#22c55e;box-shadow:0 0 0 3px rgba(34,197,94,.2)}
.hw-dot.closed{background:#ef4444;box-shadow:0 0 0 3px rgba(239,68,68,.2)}
.hw-label{font-weight:600}
.hw-label.open{color:#16a34a}
.hw-label.closed{color:#dc2626}
.hw-panel{
  position:absolute;top:calc(100% + .6rem);right:0;
  width:300px;background:var(--white);border:1px solid var(--border);
  border-radius:var(--r);padding:1.2rem 1.3rem;
  box-shadow:0 12px 40px rgba(0,0,0,.12);
  opacity:0;transform:translateY(-6px) scale(.98);pointer-events:none;
  transition:opacity .2s,transform .2s;
}
.hw-panel.open{opacity:1;transform:none;pointer-events:auto}
.hw-panel h4{font-family:'Fraunces',serif;font-size:1.05rem;font-weight:600;margin-bottom:.8rem;display:flex;align-items:center;gap:.5rem}
.hw-panel h4 .ic{width:28px;height:28px;border-radius:6px;background:var(--teal-pale);color:var(--teal);display:flex;align-items:center;justify-content:center;font-size:.85rem}
.hw-row{display:flex;justify-content:space-between;padding:.4rem 0;border-bottom:1px dashed var(--border);font-size:.85rem}
.hw-row:last-of-type{border:none}
.hw-row .d{color:var(--muted)}
.hw-row .t{font-weight:600}
.hw-sep{height:1px;background:var(--border);margin:.4rem 0}
.hw-foot{margin-top:.8rem;display:flex;gap:.5rem}
.hw-btn{flex:1;background:var(--teal);color:#fff;text-decoration:none;text-align:center;padding:.55rem;border-radius:50px;font-size:.8rem;font-weight:600;transition:background .2s}
.hw-btn:hover{background:var(--teal-dark)}
.hw-btn.ghost{background:transparent;color:var(--teal);border:1px solid var(--teal)}
.hw-btn.ghost:hover{background:var(--teal-pale)}

/* ── PHONE FAB (mobile) ── */
.tel-fab{
  display:none;position:fixed;bottom:1.2rem;right:1.2rem;z-index:90;
  align-items:center;gap:.6rem;
  height:58px;padding:0 1.2rem 0 .8rem;border-radius:50px;
  background:var(--teal);color:#fff;text-decoration:none;font-family:'Outfit',sans-serif;
  box-shadow:0 6px 22px rgba(0,155,163,.45);
  transition:transform .2s,background .2s;
}
.tel-fab .ic{
  width:42px;height:42px;border-radius:50%;
  background:rgba(255,255,255,.2);
  display:flex;align-items:center;justify-content:center;
  font-size:1.25rem;flex-shrink:0;
}
.tel-fab .num{font-size:.98rem;font-weight:700;letter-spacing:.01em;white-space:nowrap}
.tel-fab::before{content:'';position:absolute;inset:-4px;border-radius:50px;border:2px solid var(--teal);opacity:.3;animation:pulse 2s infinite;pointer-events:none}
@keyframes pulse{0%{transform:scale(1);opacity:.3}70%{transform:scale(1.08);opacity:0}100%{transform:scale(1.08);opacity:0}}
.tel-fab:hover{transform:translateY(-2px);background:var(--teal-dark)}

/* ── RESPONSIVE ── */
@media(max-width:960px){
  .page{grid-template-columns:1fr}
  .aside{position:static}
  .feat-grid{grid-template-columns:1fr}
  .intro{background:var(--paper)!important}
  .intro::before{display:none}
  .gg{grid-template-columns:1fr 1fr}
  .gg-item:nth-child(1){grid-row:auto;aspect-ratio:4/3}
  .f-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .nav-links{display:none}
  .ham{display:flex}
  .gg{grid-template-columns:1fr}
  .f-grid{grid-template-columns:1fr}
  .ctab-in{flex-direction:column;align-items:flex-start}
  .hours-widget{top:100px;right:.6rem}
  .hw-trigger{padding:.45rem .8rem .45rem .55rem;font-size:.78rem}
  .hw-panel{width:calc(100vw - 1.2rem);max-width:320px;right:0}
  .tel-fab{display:flex}
}
