/* =====================================================
   Blumen-Slanec.at — main.css
   ===================================================== */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
[data-go]{cursor:pointer}
:root{
  --ink:    #1A1209;
  --pine:   #2B4A1C;
  --sage:   #4E7A3A;
  --cream:  #FAF6EF;
  --cream2: #F0E9DC;
  --gold:   #B8922A;
  --gold-lt:#E2C472;
  --white:  #FFFFFF;
  --r:      10px;
  --r-lg:   20px;
  --max:    1300px;
}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--ink);line-height:1.6;overflow-x:hidden}
h1,h2,h3,h4{font-family:'Cormorant Garamond',serif;line-height:1.15}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}

/* ── Utilities ────────────────────────────── */
.container{max-width:var(--max);margin:0 auto;padding:0 2rem}
.eyebrow{font-family:'DM Sans',sans-serif;font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:600;display:block;margin-bottom:.55rem}

/* ── Buttons ──────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 2rem;border-radius:4px;font-family:'DM Sans',sans-serif;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;cursor:pointer;border:none;transition:.2s}
.btn-pine{background:var(--pine);color:#fff}
.btn-pine:hover{background:var(--sage)}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{filter:brightness(1.1)}
.btn-outline{background:transparent;border:1.5px solid var(--pine);color:var(--pine)}
.btn-outline:hover{background:var(--pine);color:#fff}

/* ── Header ───────────────────────────────── */
header{position:sticky;top:0;z-index:900;background:rgba(250,246,239,.97);backdrop-filter:blur(10px);border-bottom:1px solid rgba(43,74,28,.1)}
.nav-inner{max-width:var(--max);margin:0 auto;padding:.9rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:2rem}
.logo{display:flex;flex-direction:column;line-height:1}
.logo-top{font-family:'DM Sans',sans-serif;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:600}
.logo-name{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.75rem;color:var(--pine);font-weight:400}
.logo-name em{font-style:normal;font-weight:600}
nav{display:flex;gap:2rem;align-items:center}
nav a{font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);opacity:.6;font-weight:500;transition:.2s}
nav a:hover{opacity:1;color:var(--pine)}
.nav-cta{background:var(--pine);color:#fff!important;opacity:1!important;padding:.5rem 1.3rem;border-radius:4px}
.nav-cta:hover{background:var(--sage)!important}
#hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:.3rem}
#hamburger span{display:block;width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}
#hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
#hamburger.open span:nth-child(2){opacity:0}
#hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
#mobile-menu{display:none;position:fixed;inset:0;background:var(--cream);z-index:890;flex-direction:column;align-items:center;justify-content:center;gap:2rem}
#mobile-menu.open{display:flex}
#mobile-menu a{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.6rem;color:var(--pine)}

/* ── USP strip ────────────────────────────── */
#usp{background:var(--pine);padding:1rem 2rem}
.usp-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.07)}
.usp-item{background:var(--pine);padding:.85rem 1.5rem;display:flex;align-items:center;gap:.8rem}
.usp-icon{font-size:1.1rem;opacity:.75;flex-shrink:0}
.usp-item h4{font-family:'DM Sans',sans-serif;font-size:.75rem;color:#fff;font-weight:600;letter-spacing:.05em;text-transform:uppercase}
.usp-item p{font-size:.7rem;color:rgba(255,255,255,.45);margin-top:.1rem}

/* ── Homepage hero ────────────────────────── */
#hero{display:grid;grid-template-columns:1.1fr 1fr;min-height:88vh}
.hero-photo{position:relative;overflow:hidden}
.hero-photo img{width:100%;height:100%;min-height:88vh;object-fit:cover;display:block}
.hero-content{background:var(--pine);display:flex;flex-direction:column;justify-content:center;padding:5rem 4.5rem 4rem;position:relative;overflow:hidden}
.hero-bg-word{position:absolute;bottom:-3rem;right:-2rem;font-family:'Cormorant Garamond',serif;font-size:18rem;font-weight:600;color:rgba(255,255,255,.03);line-height:1;pointer-events:none;white-space:nowrap}
.hero-tag{display:inline-flex;align-items:center;gap:.6rem;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:3px;padding:.35rem .9rem;font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold-lt);font-weight:600;margin-bottom:2.2rem;width:fit-content}
.hero-content h1{font-size:clamp(2.6rem,3.8vw,4.4rem);color:#fff;font-weight:300;line-height:1.1;margin-bottom:1.4rem}
.hero-content h1 em{font-style:italic;color:var(--gold-lt)}
.hero-content h1 strong{font-weight:600;display:block}
.hero-sub{color:rgba(255,255,255,.6);font-size:.95rem;line-height:1.8;margin-bottom:2.5rem;max-width:360px}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:3.5rem}
.hero-btns .btn-ghost{border:1.5px solid rgba(255,255,255,.25);color:rgba(255,255,255,.8);background:transparent}
.hero-btns .btn-ghost:hover{background:rgba(255,255,255,.1);color:#fff}
.hero-trust{border-top:1px solid rgba(255,255,255,.1);padding-top:2rem;display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.ht-item{text-align:center}
.ht-val{font-family:'Cormorant Garamond',serif;font-size:2.2rem;color:#fff;font-weight:300;display:block;line-height:1}
.ht-label{font-size:.65rem;color:rgba(255,255,255,.4);letter-spacing:.1em;text-transform:uppercase;margin-top:.3rem;display:block}

/* ── Occasions grid ───────────────────────── */
#anlaesse{padding:6rem 2rem}
.anlaesse-head{text-align:center;margin-bottom:3rem}
.anlaesse-head h2{font-size:clamp(2rem,2.8vw,3rem);font-weight:300}
.anlaesse-head h2 em{font-style:italic;color:var(--sage)}
.occ-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.occ-tile{border-radius:var(--r-lg);overflow:hidden;position:relative;aspect-ratio:.85/1;cursor:pointer;transition:.3s;display:block;text-decoration:none}
.occ-tile:hover{transform:translateY(-5px);box-shadow:0 16px 40px rgba(26,18,9,.18)}
.occ-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:.45s;display:block}
.occ-tile:hover .occ-img{transform:scale(1.06)}
.occ-grad{position:absolute;inset:0;background:linear-gradient(170deg,transparent 30%,rgba(26,18,9,.78) 100%)}
.occ-body{position:absolute;bottom:1.3rem;left:1.4rem;right:1.4rem}
.occ-body h3{font-family:'Cormorant Garamond',serif;color:#fff;font-size:1.3rem;font-weight:400;font-style:italic;margin-bottom:.2rem}
.occ-body p{font-size:.68rem;color:rgba(255,255,255,.55);letter-spacing:.08em;text-transform:uppercase}
.occ-all{grid-column:1/-1;aspect-ratio:unset;height:220px;border-radius:var(--r-lg)}
.occ-all .occ-grad{background:linear-gradient(90deg,rgba(26,18,9,.85) 0%,rgba(26,18,9,.4) 60%,transparent 100%)}
.occ-all .occ-body{bottom:unset;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:space-between;right:2.5rem;left:2.5rem}
.occ-all .occ-body-text h3{font-size:1.8rem}
.occ-all .occ-body-text p{margin-top:.3rem}
.occ-all-btn{background:var(--gold);color:#fff;padding:.7rem 1.8rem;border-radius:4px;font-family:'DM Sans',sans-serif;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;white-space:nowrap;flex-shrink:0;transition:.2s}
.occ-all:hover .occ-all-btn{filter:brightness(1.1)}

/* ── Wien / Bezirke ───────────────────────── */
#wien{background:var(--pine);padding:7rem 0 0}
.wien-top{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start;max-width:var(--max);margin:0 auto;padding:0 2rem 5rem}
.wien-text h2{font-size:clamp(2.4rem,3.2vw,3.8rem);font-weight:300;color:#fff;margin-bottom:1.2rem;line-height:1.05}
.wien-text h2 em{font-style:italic;color:var(--gold-lt)}
.wien-text p{font-size:.95rem;color:rgba(255,255,255,.55);line-height:1.85;margin-bottom:.9rem;max-width:420px}
.wien-features{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin:2rem 0 2.5rem}
.wf{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:var(--r);padding:1rem 1.2rem}
.wf h4{font-family:'DM Sans',sans-serif;font-size:.78rem;font-weight:600;color:#fff;letter-spacing:.04em;margin-bottom:.2rem}
.wf p{font-size:.72rem;color:rgba(255,255,255,.4);line-height:1.5}
.wien-deco{display:flex;flex-direction:column;justify-content:flex-start;padding-top:1rem}
.wien-deco-num{font-family:'Cormorant Garamond',serif;font-size:clamp(10rem,16vw,18rem);font-weight:300;color:rgba(255,255,255,.06);line-height:.85;display:block;margin-bottom:-2rem}
.wien-deco-label{font-size:.72rem;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.2);font-weight:600;padding-left:.3rem}
.bezirke-grid{width:100%;display:grid;grid-template-columns:repeat(8,1fr);border-top:1px solid rgba(255,255,255,.07)}
.bz{border-right:1px solid rgba(255,255,255,.07);border-bottom:1px solid rgba(255,255,255,.07);padding:1.6rem 1.4rem 1.4rem;cursor:default;transition:.25s;position:relative;overflow:hidden}
.bz:nth-child(8n){border-right:none}
.bz::before{content:'';position:absolute;inset:0;background:var(--sage);transform:translateY(100%);transition:.3s cubic-bezier(.4,0,.2,1);z-index:0}
.bz:hover::before{transform:translateY(0)}
.bz-num{font-family:'Cormorant Garamond',serif;font-size:2.8rem;font-weight:300;color:rgba(255,255,255,.18);line-height:1;display:block;margin-bottom:.5rem;position:relative;z-index:1;transition:.25s}
.bz-name{font-size:.65rem;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.08em;display:block;line-height:1.4;position:relative;z-index:1;transition:.25s}
.bz:hover .bz-num{color:rgba(255,255,255,.9)}
.bz:hover .bz-name{color:rgba(255,255,255,.7)}
.bz.featured{grid-column:span 2}
.bz.featured .bz-num{font-size:4.5rem;color:var(--gold-lt)}
.bz.featured .bz-name{font-size:.75rem;color:rgba(255,255,255,.6)}
.bz.featured:hover .bz-num{color:#fff}

/* ── FAQ ──────────────────────────────────── */
#faq{padding:6rem 2rem;background:var(--cream2)}
.faq-inner{max-width:760px;margin:0 auto}
.faq-head{text-align:center;margin-bottom:3rem}
.faq-head h2{font-size:clamp(2rem,2.8vw,2.8rem);font-weight:300}
.faq-item{border-bottom:1px solid rgba(26,18,9,.08);padding:1.3rem 0}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;cursor:pointer;font-family:'Cormorant Garamond',serif;font-size:1.15rem;color:var(--ink)}
.faq-icon{width:28px;height:28px;border-radius:50%;border:1.5px solid rgba(26,18,9,.15);display:flex;align-items:center;justify-content:center;font-size:1rem;color:var(--pine);flex-shrink:0;font-style:normal;font-family:'DM Sans',sans-serif;line-height:1;transition:.2s}
.faq-a{display:none;font-size:.86rem;color:var(--ink);opacity:.6;line-height:1.75;padding-top:.75rem}
.faq-item.open .faq-a{display:block}
.faq-item.open .faq-icon{background:var(--pine);color:#fff;border-color:var(--pine)}

/* ── Footer ───────────────────────────────── */
footer{background:var(--ink);color:rgba(255,255,255,.55);padding:4rem 2rem 2rem}
.footer-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:3.5rem;margin-bottom:3rem}
.footer-logo{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.5rem;color:#fff;margin-bottom:.8rem}
.footer-brand p{font-size:.8rem;line-height:1.75;max-width:280px}
.footer-col h4{font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.28);margin-bottom:1rem;font-weight:600}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.55rem}
.footer-col ul li a{font-size:.8rem;transition:.2s}
.footer-col ul li a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding-top:1.4rem;display:flex;justify-content:space-between;align-items:center;font-size:.73rem;max-width:var(--max);margin:0 auto;flex-wrap:wrap;gap:.8rem}
.footer-bottom a{color:rgba(255,255,255,.3);margin-left:1.2rem;transition:.2s}
.footer-bottom a:hover{color:rgba(255,255,255,.7)}
.lang-sw{display:flex;gap:.35rem}
.lang-btn{font-size:.65rem;letter-spacing:.1em;padding:.18rem .55rem;border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.35);border-radius:3px;transition:.2s}
.lang-btn.active,.lang-btn:hover{border-color:var(--gold);color:var(--gold-lt)}

/* ── Inner page hero ──────────────────────── */
.inner-hero{position:relative;height:400px;overflow:hidden}
.inner-hero img{width:100%;height:100%;object-fit:cover;display:block}
.inner-hero-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(26,18,9,.78) 0%,rgba(26,18,9,.35) 55%,transparent 100%)}
.inner-hero-content{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:3rem 4rem}
.inner-hero-eyebrow{font-family:'DM Sans',sans-serif;font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-lt);font-weight:600;margin-bottom:.6rem;display:block}
.inner-hero-content h1{font-size:clamp(2rem,3vw,3.2rem);color:#fff;font-weight:300;line-height:1.1}
.inner-hero-content h1 em{font-style:italic;color:var(--gold-lt)}

/* ── Breadcrumb ───────────────────────────── */
.breadcrumb{background:var(--cream2);padding:.75rem 2rem;border-bottom:1px solid rgba(26,18,9,.06)}
.bc-inner{max-width:var(--max);margin:0 auto;display:flex;align-items:center;gap:.5rem;font-size:.74rem;color:var(--ink);opacity:.55;flex-wrap:wrap}
.bc-inner a{color:var(--pine);opacity:.8;transition:.2s}
.bc-inner a:hover{opacity:1}
.bc-sep{opacity:.3}

/* ── Inner page main layout ───────────────── */
.inner-wrap{max-width:var(--max);margin:0 auto;padding:4rem 2rem 5rem;display:grid;grid-template-columns:300px 1fr;gap:4rem;align-items:start}
.inner-sidebar{position:sticky;top:120px}
.inner-sidebar h2{font-size:clamp(1.6rem,2vw,2.2rem);font-weight:300;line-height:1.1;margin-bottom:1rem}
.inner-sidebar h2 em{font-style:italic;color:var(--sage)}
.inner-sidebar p{font-size:.86rem;color:var(--ink);opacity:.6;line-height:1.8;margin-bottom:1.2rem}
.inner-sidebar .btn{width:100%;justify-content:center;margin-top:.5rem}

/* ── Product grid (inner pages) ───────────── */
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.p-card{background:#fff;border-radius:var(--r-lg);overflow:hidden;transition:.3s;cursor:pointer;display:block;text-decoration:none}
.p-card:hover{transform:translateY(-5px);box-shadow:0 16px 48px rgba(13,31,20,.12)}
.p-img{height:260px;position:relative;overflow:hidden;background:var(--cream2)}
.p-img img{width:100%;height:100%;object-fit:cover;display:block;transition:.4s}
.p-card:hover .p-img img{transform:scale(1.05)}
.p-body{padding:1.2rem 1.4rem 1.5rem}
.p-name{font-family:'Cormorant Garamond',serif;font-size:1.2rem;color:var(--ink);margin-bottom:.4rem}
.p-desc{font-size:.78rem;color:var(--ink);opacity:.5;line-height:1.55;margin-bottom:1rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.p-foot{display:flex;align-items:center;justify-content:space-between}
.p-price{font-family:'Cormorant Garamond',serif;font-size:1.4rem;color:var(--pine)}
.p-price small{font-family:'DM Sans',sans-serif;font-size:.62rem;color:var(--ink);opacity:.4;display:block;text-transform:uppercase;letter-spacing:.06em}
.p-btn{background:var(--pine);color:#fff;border:none;border-radius:4px;padding:.5rem 1.2rem;font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:.2s;font-family:'DM Sans',sans-serif}
.p-btn:hover{background:var(--sage)}
.inner-cta{grid-column:1/-1;text-align:center;padding:2.5rem;background:var(--cream2);border-radius:var(--r-lg);margin-top:.5rem}
.inner-cta p{font-size:.88rem;color:var(--ink);opacity:.6;margin-bottom:1.2rem}

/* ── Responsive ───────────────────────────── */
@media(max-width:1024px){
  .inner-wrap{grid-template-columns:1fr}
  .inner-sidebar{position:static}
  .prod-grid{grid-template-columns:repeat(2,1fr)}
  .bezirke-grid{grid-template-columns:repeat(4,1fr)}
  .wien-top{grid-template-columns:1fr;gap:2rem}
  .wien-deco{display:none}
}
@media(max-width:768px){
  #hero{grid-template-columns:1fr}
  .hero-photo{height:50vh;min-height:unset}
  .hero-photo img{min-height:50vh}
  .hero-content{padding:3rem 1.5rem}
  .usp-grid{grid-template-columns:repeat(2,1fr)}
  .occ-grid{grid-template-columns:repeat(2,1fr)}
  .occ-all{height:160px}
  .prod-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr}
  .bezirke-grid{grid-template-columns:repeat(3,1fr)}
  nav{display:none}
  #hamburger{display:flex}
  .inner-hero{height:280px}
  .inner-hero-content{padding:2rem}
}
