*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --gold:#FF6F61;--gold-light:#FFAAA0;--gold-dark:#E55045;
  --night:#000000;--night-mid:#111111;--night-soft:#1A1A1A;
  --cream:#F7F3ED;--cream-dark:#EDE6D9;
  --text:#1A1E2E;--muted:#6B6560;--white:#FFFFFF;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Jost',sans-serif;
  --ease:0.4s cubic-bezier(0.25,0.46,0.45,0.94);
}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--cream);color:var(--text);overflow-x:hidden}

/* CURSOR */
.cursor{width:12px;height:12px;background:var(--gold);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);mix-blend-mode:multiply}
.cursor-ring{width:36px;height:36px;border:1px solid var(--gold);border-radius:50%;position:fixed;top:0;left:0;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);opacity:.6}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:900;padding:28px 60px;display:flex;align-items:center;justify-content:space-between;transition:var(--ease)}
nav.scrolled{background:rgba(26,30,46,.95);backdrop-filter:blur(20px);padding:18px 60px;border-bottom:1px solid rgba(255,127,80,.15)}
.nav-logo{font-family:var(--serif);font-size:22px;font-weight:500;color:var(--cream);text-decoration:none}
.nav-logo em{font-style:italic;color:var(--gold)}
.nav-links{display:flex;gap:40px;list-style:none}
.nav-links a{font-family:var(--sans);font-size:11px;font-weight:400;letter-spacing:.15em;text-transform:uppercase;color:rgba(247,243,237,.75);text-decoration:none;transition:var(--ease);position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--gold);transition:var(--ease)}
.nav-links a:hover{color:var(--gold)}
.nav-links a:hover::after{width:100%}
.nav-cta{font-family:var(--sans);font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:#000000!important;background:#FFFFFF;padding:10px 24px;border-radius:2px;text-decoration:none;transition:var(--ease);font-weight:500;border:1px solid #000000}
.nav-cta:hover{background:#F5F5F5!important;color:#000000!important}
.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:5px}
.nav-hamburger span{display:block;width:24px;height:1.5px;background:var(--cream);transition:var(--ease)}

/* MOBILE MENU */
.mobile-menu{display:none;position:fixed;inset:0;background:var(--night);z-index:890;flex-direction:column;align-items:center;justify-content:center;gap:40px}
.mobile-menu.open{display:flex}
.mobile-menu a{font-family:var(--serif);font-size:36px;font-weight:300;color:var(--cream);text-decoration:none;font-style:italic;transition:var(--ease)}
.mobile-menu a:hover{color:var(--gold)}
.mobile-close{position:absolute;top:28px;right:32px;font-size:28px;color:rgba(247,243,237,.5);cursor:pointer;background:none;border:none;transition:var(--ease)}

/* PARTICLES */
.particles-canvas{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:3;overflow:hidden}
.particle{position:absolute;pointer-events:none}
@keyframes fall-dot{0%{transform:translateY(0) translateX(0);opacity:0}10%{opacity:.3}90%{opacity:.15}100%{transform:translateY(var(--fall)) translateX(var(--drift));opacity:0}}

/* HERO */
#hero{min-height:100vh;background:var(--night);position:relative;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 70% 50%,rgba(255,127,80,.08) 0%,transparent 70%),radial-gradient(ellipse 40% 60% at 20% 80%,rgba(255,127,80,.05) 0%,transparent 60%),linear-gradient(135deg,#000000 0%,#111111 50%,#000000 100%)}
.hero-circle{position:absolute;right:-5vw;top:50%;transform:translateY(-50%);width:60vw;height:60vw;max-width:800px;max-height:800px;border-radius:50%;border:1px solid rgba(255,127,80,.12);pointer-events:none}
.hero-circle::before{content:'';position:absolute;inset:40px;border-radius:50%;border:1px solid rgba(255,127,80,.08)}
.hero-circle::after{content:'';position:absolute;inset:80px;border-radius:50%;border:1px solid rgba(255,127,80,.05)}
.hero-image-area{position:absolute;right:8%;top:50%;transform:translateY(-50%);width:38vw;max-width:520px;overflow:visible}
.hero-image-area img{width:100%;height:auto;display:block}
.hero-image-placeholder{width:100%;height:100%;background:linear-gradient(160deg,rgba(255,127,80,.15) 0%,rgba(255,127,80,.04) 100%);border:1px solid rgba(255,127,80,.2);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:16px}
.hero-image-placeholder .ph-icon{font-size:48px;opacity:.3}
.hero-image-placeholder p{font-family:var(--sans);font-size:11px;letter-spacing:.2em;color:rgba(255,111,97,.4);text-transform:uppercase}
.hero-content{position:relative;z-index:2;padding:120px 60px 0;max-width:680px}
.hero-eyebrow{font-family:var(--sans);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:28px;opacity:0;animation:slideUp .8s ease .2s forwards;display:flex;align-items:center;gap:16px}
.hero-eyebrow::before{content:'';display:inline-block;width:40px;height:1px;background:var(--gold)}
.hero-h1{font-family:var(--serif);font-size:clamp(48px,6vw,86px);font-weight:300;line-height:1.08;color:var(--cream);margin-bottom:32px;opacity:0;animation:slideUp .8s ease .4s forwards}
.hero-h1 em{font-style:italic;color:var(--gold)}
.hero-sub{font-family:var(--sans);font-size:15px;font-weight:300;line-height:1.8;color:rgba(247,243,237,.65);max-width:440px;margin-bottom:52px;opacity:0;animation:slideUp .8s ease .6s forwards}
.hero-actions{display:grid;grid-template-columns:1fr 1fr;gap:14px;opacity:0;animation:slideUp .8s ease .8s forwards;padding-bottom:60px;max-width:560px}
.hero-actions .btn-primary{justify-content:center;width:100%}
.hero-scroll{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:10px;opacity:0;animation:fadeIn 1s ease 1.5s forwards}
.hero-scroll span{font-family:var(--sans);font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,111,97,.5)}
.scroll-line{width:1px;height:50px;background:linear-gradient(to bottom,rgba(255,127,80,.5),transparent);animation:scrollLine 2s ease-in-out infinite}

/* BUTTONS */
.btn-primary{display:inline-flex;align-items:center;gap:10px;padding:16px 36px;background:#FFFFFF;color:#000000;border:1px solid #000000;font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;text-decoration:none;border-radius:2px;transition:var(--ease);position:relative;overflow:hidden}
.btn-primary::after{content:'';position:absolute;top:-10%;left:-110%;width:55%;height:120%;background:linear-gradient(105deg,transparent 25%,rgba(0,0,0,0.07) 50%,transparent 75%);transform:skewX(-18deg);animation:shimmer-cta 5.5s ease-in-out infinite;pointer-events:none;opacity:.85}
.btn-primary:hover{background:#F5F5F5;color:#000000;transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.14)}
.btn-primary:hover::after{opacity:1;animation-duration:3.2s}
.btn-ghost{display:inline-flex;align-items:center;gap:10px;padding:16px 36px;border:1px solid rgba(255,127,80,.4);color:rgba(247,243,237,.8);font-family:var(--sans);font-size:11px;font-weight:400;letter-spacing:.2em;text-transform:uppercase;text-decoration:none;border-radius:2px;transition:var(--ease);position:relative;overflow:hidden}
.btn-ghost::after{content:'';position:absolute;top:-10%;left:-110%;width:55%;height:120%;background:linear-gradient(105deg,transparent 25%,rgba(255,255,255,0.14) 50%,transparent 75%);transform:skewX(-18deg);animation:shimmer-cta 5.5s ease-in-out 1.6s infinite;pointer-events:none;opacity:.8}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-ghost:hover::after{opacity:1;animation-duration:3.2s}

/* MARQUEE */
.marquee-section{background:#000000;padding:16px 0;overflow:hidden}
.marquee-track{display:flex;animation:marquee 25s linear infinite;white-space:nowrap}
.marquee-track span{font-family:var(--serif);font-size:15px;font-weight:400;font-style:italic;color:#FFFFFF;padding:0 40px}
.marquee-dot{color:rgba(255,255,255,0.5);font-size:6px;vertical-align:middle}

/* SHARED */
.eyebrow{font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:.35em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;display:flex;align-items:center;gap:14px}
.eyebrow::before{content:'';display:inline-block;width:30px;height:1px;background:var(--gold)}
.eyebrow.center{justify-content:center}
.eyebrow.center::before{display:none}
.sec-title{font-family:var(--serif);font-size:clamp(36px,4vw,58px);font-weight:300;line-height:1.15;color:var(--text)}
.sec-title em{font-style:italic;color:var(--gold-dark)}
.sec-title.light{color:var(--cream)}
.sec-title.light em{color:var(--gold)}

/* STORY */
#story{padding:120px 60px;background:var(--cream)}
.story-grid{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.story-image-block{position:relative}
.story-img-main{width:100%;aspect-ratio:4/5;background:var(--cream-dark);border:1px solid rgba(255,127,80,.2);display:flex;align-items:center;justify-content:center;overflow:hidden}
.story-img-main img{width:100%;height:100%;object-fit:cover;display:block}
.img-ph{display:flex;flex-direction:column;align-items:center;gap:12px}
.img-ph .ph-icon{font-size:40px;opacity:.2;color:var(--gold)}
.img-ph p{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);opacity:.4}
.story-accent-card{position:absolute;right:-40px;bottom:-40px;width:180px;background:var(--night);padding:24px;border:1px solid rgba(255,127,80,.2)}
.story-accent-card .number{font-family:var(--serif);font-size:48px;font-weight:300;color:var(--gold);line-height:1;display:block}
.story-accent-card .label{font-family:var(--sans);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:rgba(247,243,237,.5);margin-top:8px}
.story-text{display:flex;flex-direction:column;gap:24px}
.story-text p{font-family:var(--sans);font-size:16px;font-weight:300;line-height:1.85;color:var(--muted)}
.story-sig{font-family:var(--serif);font-size:28px;font-style:italic;color:var(--gold-dark);margin-top:8px}

/* VALUES */
#values{background:var(--night);padding:120px 60px}
.values-inner{max-width:1200px;margin:0 auto}
.values-header{text-align:center;margin-bottom:80px}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.value-card{background:var(--night-mid);padding:52px 40px;transition:var(--ease);position:relative;overflow:hidden}
.value-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:2px;background:linear-gradient(to right,var(--gold),transparent);opacity:0;transition:var(--ease)}
.value-card:hover{background:var(--night-soft)}
.value-card:hover::before{opacity:1}
.val-num{font-family:var(--serif);font-size:80px;font-weight:300;color:rgba(255,111,97,.08);line-height:1;position:absolute;top:20px;right:24px}
.val-icon{font-size:28px;margin-bottom:24px}
.val-title{font-family:var(--serif);font-size:26px;font-weight:400;color:var(--cream);margin-bottom:16px}
.val-desc{font-family:var(--sans);font-size:14px;font-weight:300;line-height:1.8;color:rgba(247,243,237,.5)}

/* PRODUCTS */
#produkte{padding:120px 60px;background:var(--cream-dark)}
.products-inner{max-width:1200px;margin:0 auto}
.products-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:64px}
.products-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.product-card{background:var(--cream);position:relative;overflow:hidden;transition:var(--ease)}
.product-card:hover{transform:translateY(-6px);box-shadow:0 24px 60px rgba(26,30,46,.12)}
.product-img{width:100%;aspect-ratio:3/4;background:var(--cream-dark);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}
.product-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.product-badge{position:absolute;top:16px;left:16px;font-family:var(--sans);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:#FFFFFF;background:#000000;padding:5px 12px;z-index:1}
.product-info{padding:24px}
.product-name{font-family:var(--serif);font-size:22px;font-weight:400;color:var(--text);margin-bottom:8px}
.product-desc{font-family:var(--sans);font-size:13px;font-weight:300;color:var(--muted);line-height:1.6;margin-bottom:16px}
.product-price{font-family:var(--serif);font-size:20px;color:var(--gold-dark)}
.product-cta{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--gold-dark);margin-top:12px;text-decoration:none;transition:var(--ease)}
.product-cta:hover{gap:12px}
.products-note{text-align:center;margin-top:48px;font-family:var(--sans);font-size:13px;font-weight:300;color:var(--muted);font-style:italic}

/* BUTLER */
#butler{background:var(--night);padding:120px 60px;overflow:hidden;position:relative}
.butler-bg-text{position:absolute;font-family:var(--serif);font-size:200px;font-weight:300;color:rgba(255,111,97,.03);top:50%;left:50%;transform:translate(-50%,-50%);white-space:nowrap;pointer-events:none;letter-spacing:-.05em}
.butler-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:100px;align-items:center;position:relative;z-index:2}
.butler-text p{font-family:var(--sans);font-size:16px;font-weight:300;line-height:1.85;color:rgba(247,243,237,.6);margin-top:28px;margin-bottom:48px}
.butler-steps{display:flex;flex-direction:column}
.butler-step{display:flex;gap:24px;align-items:flex-start;padding:24px 0;border-bottom:1px solid rgba(255,127,80,.1);transition:var(--ease)}
.butler-step:first-child{border-top:1px solid rgba(255,127,80,.1)}
.butler-step:hover{padding-left:8px}
.step-num{font-family:var(--serif);font-size:32px;font-weight:300;color:rgba(255,111,97,.3);flex-shrink:0;width:40px;line-height:1}
.step-title{font-family:var(--serif);font-size:19px;color:var(--cream);margin-bottom:6px;font-weight:400}
.step-desc{font-family:var(--sans);font-size:13px;font-weight:300;line-height:1.6;color:rgba(247,243,237,.45)}
.butler-action{background:var(--night-mid);border:1px solid rgba(255,127,80,.2);padding:52px;text-align:center;position:relative}
.butler-action::before{content:'✦';position:absolute;top:-12px;left:50%;transform:translateX(-50%);font-size:14px;color:var(--gold);background:var(--night-mid);padding:0 10px}
.butler-action-title{font-family:var(--serif);font-size:32px;font-weight:300;font-style:italic;color:var(--cream);margin-bottom:16px;line-height:1.3}
.butler-action p{font-family:var(--sans);font-size:13px;font-weight:300;line-height:1.7;color:rgba(247,243,237,.5);margin-bottom:36px}
.butler-channels{display:flex;flex-direction:column;gap:12px;margin-top:36px}
.channel-btn{display:flex;align-items:center;gap:14px;padding:14px 24px;border:1px solid rgba(255,127,80,.2);color:rgba(247,243,237,.75);font-family:var(--sans);font-size:12px;font-weight:400;letter-spacing:.1em;text-decoration:none;transition:var(--ease)}
.channel-btn:hover{border-color:var(--gold);color:var(--gold);background:rgba(255,127,80,.05)}
.channel-btn-primary{background:#FFFFFF!important;border:1px solid #000000!important;color:#000000!important;font-weight:500!important}
.channel-btn-primary:hover{background:#F5F5F5!important;transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.12)}
.ch-icon{font-size:18px}

/* TESTIMONIALS */
#bewertungen{padding:120px 60px;background:var(--cream)}
.testimonials-inner{max-width:1200px;margin:0 auto}
.testimonials-header{text-align:center;margin-bottom:72px}
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.testimonial-card{background:var(--white);padding:40px;border:1px solid rgba(255,127,80,.12);position:relative;transition:var(--ease)}
.testimonial-card:hover{border-color:rgba(255,111,97,.35);transform:translateY(-4px)}
.testimonial-card::before{content:'\201C';font-family:var(--serif);font-size:80px;color:var(--gold);opacity:.2;position:absolute;top:10px;left:28px;line-height:1}
.stars{display:flex;gap:4px;margin-bottom:20px}
.star{color:var(--gold);font-size:13px}
.testimonial-text{font-family:var(--serif);font-size:17px;font-weight:400;line-height:1.7;color:var(--text);font-style:italic;margin-bottom:28px}
.testimonial-author{display:flex;align-items:center;gap:14px}
.author-avatar{width:40px;height:40px;border-radius:50%;background:var(--cream-dark);border:2px solid var(--gold-light);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:16px;color:var(--gold-dark)}
.author-name{font-family:var(--sans);font-size:13px;font-weight:500;color:var(--text)}
.author-source{font-family:var(--sans);font-size:11px;color:var(--muted);margin-top:2px}
.google-badge-wrapper{text-align:center;margin-top:48px}
.google-badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--sans);font-size:11px;color:var(--muted);letter-spacing:.05em;text-decoration:none;transition:var(--ease)}
.google-badge:hover{color:var(--gold-dark)}

/* ATELIER */
#atelier{background:var(--night-mid);padding:120px 60px}
.atelier-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.atelier-text p{font-family:var(--sans);font-size:15px;font-weight:300;line-height:1.85;color:rgba(247,243,237,.6);margin-bottom:20px}
.atelier-details{margin-top:48px;display:flex;flex-direction:column;border-top:1px solid rgba(255,127,80,.15)}
.atelier-detail-row{display:flex;gap:24px;align-items:flex-start;padding:20px 0;border-bottom:1px solid rgba(255,127,80,.1)}
.detail-icon{font-size:18px;flex-shrink:0;opacity:.7;margin-top:1px}
.detail-label{font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:4px}
.detail-value{font-family:var(--sans);font-size:14px;font-weight:300;color:rgba(247,243,237,.7);line-height:1.5}
.maps-link{text-decoration:none;display:block}
.maps-link:hover .detail-value{color:var(--gold)}
.maps-badge{display:inline-flex;align-items:center;gap:5px;margin-top:8px;font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);opacity:.7;padding:5px 10px;border:1px solid rgba(255,127,80,.25);border-radius:2px;transition:var(--ease)}
.maps-link:hover .maps-badge{opacity:1;background:rgba(255,127,80,.08)}
.atelier-image-block{position:relative}
.atelier-img{width:100%;aspect-ratio:1;background:var(--night-soft);display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,127,80,.15);overflow:hidden}
.atelier-img img{width:100%;height:100%;object-fit:cover;display:block}
.atelier-map-overlay{position:absolute;bottom:-24px;right:-24px;width:140px;height:140px;background:var(--night);border:1px solid rgba(255,127,80,.2);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px;padding:16px}
.map-text{font-family:var(--sans);font-size:9px;letter-spacing:.15em;text-transform:uppercase;color:rgba(247,243,237,.5);line-height:1.5}

/* INSTAGRAM */
#instagram{padding:120px 60px;background:var(--cream);text-align:center}
.instagram-inner{max-width:800px;margin:0 auto}
.instagram-inner p{font-family:var(--sans);font-size:16px;font-weight:300;line-height:1.8;color:var(--muted);margin-bottom:48px}
.instagram-handle{display:inline-flex;align-items:center;gap:12px;font-family:var(--serif);font-size:clamp(18px,3.5vw,32px);font-weight:300;font-style:italic;color:var(--gold-dark);text-decoration:none;transition:var(--ease);margin-bottom:48px;max-width:100%}
.instagram-handle:hover{color:var(--gold)}
.ig-gallery{margin-top:60px}
.ig-photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:28px;max-width:720px;margin-left:auto;margin-right:auto}
.ig-photo-cell{position:relative;aspect-ratio:1;overflow:hidden;display:block;text-decoration:none;background:var(--cream-dark)}
.ig-photo-cell img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform .7s cubic-bezier(0.25,0.46,0.45,0.94),box-shadow .35s ease}
.ig-photo-cell::after{content:'';position:absolute;inset:0;background:rgba(0,0,0,0);transition:background .35s ease}
.ig-photo-cell:hover img{transform:scale(1.04)}
.ig-photo-cell:hover::after{background:rgba(0,0,0,.12)}
.ig-feed-cta{display:inline-block;font-family:var(--sans);font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--gold-dark);text-decoration:none;transition:var(--ease);padding-bottom:2px;border-bottom:1px solid rgba(139,107,61,.3)}
.ig-feed-cta:hover{color:var(--gold);border-bottom-color:var(--gold)}

/* SEO */
#seo-content{background:var(--cream-dark);padding:80px 60px}
.seo-inner{max-width:900px;margin:0 auto}
.seo-inner h2{font-family:var(--serif);font-size:clamp(28px,3vw,42px);font-weight:300;color:var(--text);margin-bottom:24px;line-height:1.2}
.seo-inner h2 em{font-style:italic;color:var(--gold-dark)}
.seo-inner h3{font-family:var(--serif);font-size:clamp(20px,2.2vw,30px);font-weight:400;color:var(--text);margin:36px 0 16px}
.seo-inner p{font-family:var(--sans);font-size:15px;font-weight:300;line-height:1.9;color:var(--muted);margin-bottom:20px}
.seo-inner strong{font-weight:500;color:var(--text)}
.seo-quote-box{margin-top:48px;padding:32px 40px;background:var(--cream);border:1px solid rgba(255,127,80,.2);border-left:3px solid var(--gold)}
.seo-quote-box p{font-family:var(--serif);font-size:20px;font-style:italic;color:var(--text);line-height:1.6;margin:0}
.seo-quote-box cite{display:block;font-family:var(--sans);font-size:12px;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-top:16px;font-style:normal}

/* BESTELLEN */
#bestellen{scroll-margin-top:80px;background:var(--cream);padding:120px 60px}
.bestellen-inner{max-width:680px;margin:0 auto;text-align:center}
.bestellen-eyebrow{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin-bottom:24px}
.bestellen-title{font-family:var(--serif);font-size:clamp(30px,3.5vw,52px);font-weight:300;color:var(--text);line-height:1.2;margin-bottom:0}
.bestellen-title em{font-style:italic;color:var(--gold-dark)}
.bestellen-divider{width:48px;height:1px;background:var(--gold);margin:32px auto 40px}
.bestellen-text{font-family:var(--sans);font-size:16px;font-weight:300;line-height:1.85;color:var(--text-light);text-align:left;max-width:580px;margin:0 auto}
.bestellen-text p{margin-bottom:20px}
.bestellen-text p:last-child{margin-bottom:0}
.bestellen-text strong{font-weight:500;color:var(--text)}
.bestellen-text a{color:var(--gold-dark);text-decoration:none;border-bottom:1px solid rgba(229,80,69,.3);transition:border-color .25s ease}
.bestellen-text a:hover{border-color:var(--gold-dark)}
.bestellen-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:48px}

/* FAQ */
#faq{background:var(--white);padding:80px 60px}
.faq-inner{max-width:900px;margin:0 auto}
.faq-inner h2{font-family:var(--serif);font-size:clamp(28px,3vw,42px);font-weight:300;color:var(--text);margin-bottom:48px;line-height:1.2}
.faq-inner h2 em{font-style:italic;color:var(--gold-dark)}
.faq-list{display:flex;flex-direction:column}
.faq-item{border-bottom:1px solid rgba(255,127,80,.15)}
.faq-item:first-child{border-top:1px solid rgba(255,127,80,.15)}
.faq-q{font-family:var(--serif);font-size:19px;font-weight:400;color:var(--text);padding:22px 0;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px;transition:color .3s}
.faq-q::-webkit-details-marker{display:none}
.faq-q::after{content:'+';font-family:var(--sans);font-size:20px;font-weight:200;color:var(--gold);flex-shrink:0;transition:transform .3s}
details[open] .faq-q::after{transform:rotate(45deg)}
details[open] .faq-q{color:var(--gold-dark)}
.faq-a{font-family:var(--sans);font-size:14px;font-weight:300;line-height:1.8;color:var(--muted);padding:0 0 22px;max-width:720px}

/* FOOTER */
footer{background:var(--night);padding:80px 60px 40px;border-top:1px solid rgba(255,127,80,.1)}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:60px;margin-bottom:60px;padding-bottom:60px;border-bottom:1px solid rgba(247,243,237,.06)}
.footer-logo{font-family:var(--serif);font-size:24px;font-weight:400;color:var(--cream);margin-bottom:20px;display:block}
.footer-logo em{font-style:italic;color:var(--gold)}
.footer-brand p{font-family:var(--sans);font-size:13px;font-weight:300;line-height:1.8;color:rgba(247,243,237,.4);max-width:260px;margin-bottom:28px}
.footer-tagline{font-family:var(--serif);font-size:16px;font-style:italic;color:var(--gold);opacity:.7}
.footer-col h4{font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin-bottom:24px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.footer-col ul li a{font-family:var(--sans);font-size:13px;font-weight:300;color:rgba(247,243,237,.45);text-decoration:none;transition:var(--ease)}
.footer-col ul li a:hover{color:var(--gold)}
.footer-col address{font-style:normal;display:flex;flex-direction:column;gap:10px}
.footer-col address p{font-family:var(--sans);font-size:13px;font-weight:300;color:rgba(247,243,237,.45);line-height:1.5}
.footer-col address a{color:rgba(255,111,97,.7);text-decoration:none;font-size:13px;font-weight:300;transition:var(--ease)}
.footer-col address a:hover{color:var(--gold)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.footer-bottom p{font-family:var(--sans);font-size:11px;color:rgba(247,243,237,.25)}
.footer-legal{display:flex;gap:24px}
.footer-legal a{font-family:var(--sans);font-size:11px;color:rgba(247,243,237,.25);text-decoration:none;transition:var(--ease)}
.footer-legal a:hover{color:var(--gold)}

/* IMPRESSUM / DATENSCHUTZ SEITEN */
.subpage-hero{min-height:40vh;background:var(--night);display:flex;align-items:flex-end;padding:60px}
.subpage-hero-inner{max-width:900px;margin:0 auto;width:100%}
.subpage-content{max-width:900px;margin:0 auto;padding:80px 60px}
.subpage-content h2{font-family:var(--serif);font-size:clamp(22px,2.5vw,34px);font-weight:300;color:var(--text);margin:48px 0 16px;line-height:1.2}
.subpage-content h2:first-child{margin-top:0}
.subpage-content h2 em{font-style:italic;color:var(--gold-dark)}
.subpage-content h3{font-family:var(--serif);font-size:clamp(17px,2vw,24px);font-weight:400;color:var(--text);margin:32px 0 12px}
.subpage-content p{font-family:var(--sans);font-size:15px;font-weight:300;line-height:1.9;color:var(--muted);margin-bottom:16px}
.subpage-content a{color:var(--gold-dark);text-decoration:none;transition:var(--ease)}
.subpage-content a:hover{color:var(--gold)}
.subpage-content ul{padding-left:20px;margin-bottom:16px}
.subpage-content ul li{font-family:var(--sans);font-size:15px;font-weight:300;line-height:1.9;color:var(--muted);margin-bottom:6px}
.subpage-content strong{font-weight:500;color:var(--text)}
.subpage-divider{height:1px;background:rgba(255,127,80,.15);margin:40px 0}
.back-link{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:rgba(247,243,237,.5);text-decoration:none;transition:var(--ease);margin-top:8px}
.back-link:hover{color:var(--gold)}

/* TERMIN */
#termin{background:var(--cream);padding:120px 60px}
.termin-inner{max-width:860px;margin:0 auto}
.termin-header{text-align:center;margin-bottom:60px}
.termin-intro{font-family:var(--sans);font-size:15px;font-weight:300;line-height:1.8;color:var(--muted);max-width:540px;margin:16px auto 0}
.termin-calendar-wrap{margin-bottom:52px}
.termin-calendar{background:var(--white);border:1px solid rgba(0,0,0,.1);padding:40px;max-width:500px;margin:0 auto}
.cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}
.cal-nav-btn{background:none;border:1px solid rgba(0,0,0,.18);width:36px;height:36px;border-radius:2px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text);transition:var(--ease);flex-shrink:0}
.cal-nav-btn:hover:not(:disabled){border-color:var(--night);background:rgba(0,0,0,.04)}
.cal-nav-btn:disabled{opacity:.3;cursor:not-allowed}
.cal-title{font-family:var(--serif);font-size:22px;font-weight:300;color:var(--text);text-align:center}
.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:6px}
.cal-weekdays span{font-family:var(--sans);font-size:9px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);text-align:center;padding:6px 0}
.cal-fri-header{color:var(--text)!important;font-weight:600!important}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.cal-day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-size:12px;font-weight:300;color:rgba(107,101,96,.4);border-radius:2px;border:1px solid transparent;transition:all .18s ease;user-select:none;cursor:default}
.cal-day.cal-past{color:rgba(107,101,96,.28);font-weight:300}
.cal-day.cal-today{border-color:rgba(0,0,0,.15);color:var(--text);font-weight:400}
.cal-day.cal-friday{color:var(--text);font-weight:500;border:1px solid rgba(0,0,0,.22);cursor:pointer}
.cal-day.cal-friday:hover{background:rgba(0,0,0,.05);border-color:var(--night)}
.cal-day.cal-friday.cal-selected{background:var(--night);color:var(--cream);border-color:var(--night);font-weight:500}
.cal-legend{display:flex;align-items:center;gap:20px;margin-top:20px;flex-wrap:wrap}
.cal-legend-item{display:flex;align-items:center;gap:7px;font-family:var(--sans);font-size:10px;letter-spacing:.08em;color:var(--muted)}
.cal-legend-dot{display:inline-block;width:14px;height:14px;border-radius:2px;flex-shrink:0}
.cal-legend-dot--avail{background:var(--night);border:1px solid var(--night)}
.cal-legend-dot--past{background:transparent;border:1px solid rgba(0,0,0,.18);opacity:.45}
.termin-booking{display:none;animation:fadeIn .4s ease}
.termin-booking.is-visible{display:block}
.booking-date-banner{background:var(--night);padding:22px 32px;display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin-bottom:3px}
.bdb-label{font-family:var(--sans);font-size:9px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:rgba(247,243,237,.45);white-space:nowrap}
.bdb-value{font-family:var(--serif);font-size:21px;font-weight:300;font-style:italic;color:var(--cream)}
.booking-section{background:var(--white);border:1px solid rgba(0,0,0,.08);padding:36px;margin-bottom:3px}
.booking-section:last-child{margin-bottom:0}
.booking-section-title{font-family:var(--serif);font-size:20px;font-weight:400;color:var(--text);margin-bottom:24px}
.booking-type-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.booking-type-card{cursor:pointer;display:block;position:relative}
.booking-type-card input[type="radio"]{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.btc-inner{display:block;padding:22px 20px;border:1px solid rgba(0,0,0,.14);background:var(--cream);transition:var(--ease);cursor:pointer}
.booking-type-card:hover .btc-inner{border-color:rgba(0,0,0,.4)}
.booking-type-card input:checked~.btc-inner{border-color:var(--night);background:var(--night)}
.booking-type-card input:checked~.btc-inner .btc-icon,
.booking-type-card input:checked~.btc-inner .btc-title,
.booking-type-card input:checked~.btc-inner .btc-sub{color:var(--cream)}
.btc-icon{display:block;font-size:20px;margin-bottom:10px;color:var(--gold);transition:color .25s}
.btc-title{display:block;font-family:var(--serif);font-size:17px;font-weight:400;color:var(--text);margin-bottom:5px;transition:color .25s}
.btc-sub{display:block;font-family:var(--sans);font-size:11px;font-weight:300;line-height:1.55;color:var(--muted);transition:color .25s}
.booking-slots-section{display:none}
.booking-slots-section.is-visible{display:block}
.slots-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.slot-btn{padding:14px 6px;border:1px solid rgba(0,0,0,.2);background:var(--cream);font-family:var(--sans);font-size:12px;font-weight:400;letter-spacing:.06em;color:var(--text);cursor:pointer;border-radius:2px;transition:var(--ease)}
.slot-btn:hover{border-color:var(--night);background:rgba(0,0,0,.04)}
.slot-btn.is-selected{background:var(--night);color:var(--cream);border-color:var(--night)}
.booking-form{display:flex;flex-direction:column;gap:18px}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-group{display:flex;flex-direction:column;gap:7px}
.form-label{font-family:var(--sans);font-size:10px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--text)}
.req-star{color:var(--gold-dark)}
.form-opt{font-weight:300;text-transform:none;letter-spacing:0;color:var(--muted);font-size:10px}
.form-input{font-family:var(--sans);font-size:14px;font-weight:300;color:var(--text);background:var(--cream);border:1px solid rgba(0,0,0,.2);padding:11px 15px;border-radius:2px;outline:none;transition:border-color .2s ease;-webkit-appearance:none;appearance:none;width:100%}
.form-input:focus{border-color:var(--night);background:var(--white)}
.form-input::placeholder{color:rgba(107,101,96,.4)}
.form-textarea{resize:vertical;min-height:76px}
.form-consent-wrap{display:flex;flex-direction:column;gap:10px}
.form-consent-label{display:flex;align-items:flex-start;gap:13px;cursor:pointer}
.form-consent-label input[type="checkbox"]{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.consent-box{flex-shrink:0;width:18px;height:18px;border:1px solid rgba(0,0,0,.3);border-radius:2px;margin-top:2px;display:flex;align-items:center;justify-content:center;transition:var(--ease);background:var(--cream)}
.form-consent-label input:checked~.consent-box{background:var(--night);border-color:var(--night)}
.form-consent-label input:checked~.consent-box::after{content:'✓';font-size:11px;color:var(--cream);line-height:1;display:block}
.consent-text{font-family:var(--sans);font-size:13px;font-weight:300;line-height:1.7;color:var(--text)}
.form-dsgvo-hint{font-family:var(--sans);font-size:11px;color:var(--muted);line-height:1.6;padding-left:31px}
.form-dsgvo-hint a{color:var(--gold-dark);text-decoration:none;transition:var(--ease)}
.form-dsgvo-hint a:hover{color:var(--gold)}
.form-error-box{display:none;background:rgba(160,40,40,.06);border:1px solid rgba(160,40,40,.22);padding:13px 17px;font-family:var(--sans);font-size:13px;font-weight:300;color:#8b2020;line-height:1.6;border-radius:2px}
.form-error-box.is-visible{display:block}
.booking-submit-btn{width:100%;justify-content:center;margin-top:4px}
.termin-success{display:none;animation:fadeIn .5s ease}
.termin-success.is-visible{display:block}
.termin-success-inner{background:var(--white);border:1px solid rgba(255,127,80,.18);padding:64px 48px;text-align:center}
.success-ornament{font-size:28px;color:var(--gold);margin-bottom:20px;animation:slideUp .6s ease}
.success-title{font-family:var(--serif);font-size:38px;font-weight:300;color:var(--text);margin-bottom:16px}
.success-text{font-family:var(--sans);font-size:15px;font-weight:300;line-height:1.85;color:var(--muted);max-width:460px;margin:0 auto 36px}

/* SONNENTANZ RADIO */
.radio-player{position:fixed;right:28px;bottom:48px;z-index:850;cursor:pointer;user-select:none;outline:none;-webkit-tap-highlight-color:transparent}
.radio-player-inner{display:flex;align-items:center;gap:15px;background:rgba(6,6,6,.93);border:1px solid rgba(255,111,97,.2);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);padding:16px 24px 16px 20px;border-radius:100px;box-shadow:0 8px 32px rgba(0,0,0,.45),0 2px 8px rgba(0,0,0,.3);transition:border-color .3s ease,box-shadow .3s ease}
.radio-player:hover .radio-player-inner{border-color:rgba(255,111,97,.45);box-shadow:0 10px 40px rgba(0,0,0,.55),0 2px 8px rgba(0,0,0,.3)}
.radio-player.is-playing .radio-player-inner{border-color:rgba(255,111,97,.5);animation:radio-glow 4s ease-in-out infinite}
.radio-icon{font-size:20px;color:var(--gold);flex-shrink:0;line-height:1}
.radio-info{display:flex;flex-direction:column;gap:3px}
.radio-name{font-family:var(--serif);font-size:17px;font-weight:400;font-style:italic;color:rgba(247,243,237,.9);letter-spacing:.01em;white-space:nowrap;line-height:1}
.radio-status{font-family:var(--sans);font-size:11px;font-weight:500;letter-spacing:.24em;text-transform:uppercase;color:rgba(247,243,237,.32);transition:color .3s ease}
.radio-player.is-playing .radio-status{color:var(--gold)}
.radio-bars{display:flex;align-items:flex-end;gap:3.5px;height:18px;flex-shrink:0;opacity:0;transition:opacity .4s ease}
.radio-player.is-playing .radio-bars{opacity:1}
.radio-bars span{display:block;width:3.5px;border-radius:3px;background:var(--gold);transform-origin:bottom}
.radio-bars span:nth-child(1){height:7px;animation:rb1 .65s ease-in-out infinite}
.radio-bars span:nth-child(2){height:14px;animation:rb2 .65s ease-in-out infinite .1s}
.radio-bars span:nth-child(3){height:9px;animation:rb3 .65s ease-in-out infinite .22s}
.radio-bars span:nth-child(4){height:17px;animation:rb4 .65s ease-in-out infinite .05s}
@keyframes rb1{0%,100%{height:5px}50%{height:14px}}
@keyframes rb2{0%,100%{height:16px}50%{height:5px}}
@keyframes rb3{0%,100%{height:9px}50%{height:18px}}
@keyframes rb4{0%,100%{height:18px}50%{height:6px}}
@keyframes radio-glow{0%,100%{box-shadow:0 8px 32px rgba(0,0,0,.45),0 2px 8px rgba(0,0,0,.3),0 0 0 0 rgba(255,111,97,.0)}50%{box-shadow:0 8px 32px rgba(0,0,0,.45),0 2px 8px rgba(0,0,0,.3),0 0 24px rgba(255,111,97,.2)}}

/* ANIMATIONEN */
@keyframes slideUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes scrollLine{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
@keyframes shine{0%{left:-100%}100%{left:200%}}
@keyframes shimmer-cta{
  0%{left:-110%;opacity:0}
  6%{opacity:1}
  34%{left:210%;opacity:1}
  40%{left:210%;opacity:0}
  100%{left:210%;opacity:0}
}

.reveal{opacity:0;transform:translateY(40px);transition:opacity .8s ease,transform .8s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.1s}
.reveal-delay-2{transition-delay:.2s}
.reveal-delay-3{transition-delay:.3s}

/* RESPONSIVE */
@media(max-width:1024px){
  nav{padding:24px 32px}
  nav.scrolled{padding:16px 32px}
  .nav-links,.nav-cta{display:none}
  .nav-hamburger{display:flex}
  .hero-circle{display:none}
  #hero{min-height:100vh;display:flex !important;flex-direction:column !important;justify-content:flex-start !important;align-items:stretch !important}
  .hero-image-area{
    display:block !important;
    position:relative !important;
    right:auto !important;
    top:auto !important;
    transform:none !important;
    width:100% !important;
    max-width:100% !important;
    aspect-ratio:auto !important;
    height:auto !important;
    margin-top:68px !important;
    overflow:visible !important;
    flex-shrink:0 !important;
    z-index:5 !important;
  }
  .hero-image-area img{width:100% !important;height:auto !important;object-fit:unset !important;display:block !important}
  .hero-content{padding:36px 32px 64px;max-width:100%}
  #story{padding:80px 32px}
  .story-grid{grid-template-columns:1fr;gap:60px}
  .story-accent-card{right:16px;bottom:-24px}
  #values{padding:80px 32px}
  .values-grid{grid-template-columns:1fr}
  #produkte{padding:80px 32px}
  .products-header{flex-direction:column;align-items:flex-start;gap:24px}
  .products-grid{grid-template-columns:1fr 1fr}
  #butler{padding:80px 32px}
  .butler-inner{grid-template-columns:1fr;gap:60px}
  #bewertungen{padding:80px 32px}
  .testimonials-grid{grid-template-columns:1fr}
  #atelier{padding:80px 32px}
  .atelier-inner{grid-template-columns:1fr;gap:60px}
  #termin{padding:80px 32px}
  .termin-calendar{padding:28px 20px}
  .booking-type-grid{grid-template-columns:1fr}
  .slots-grid{grid-template-columns:repeat(2,1fr)}
  .form-row-2{grid-template-columns:1fr}
  .booking-section{padding:28px 24px}
  .booking-date-banner{padding:18px 24px}
  .termin-success-inner{padding:48px 28px}
  #instagram{padding:80px 32px}
  .ig-photo-grid{grid-template-columns:repeat(3,1fr);gap:4px}
  #seo-content{padding:60px 32px}
  #bestellen{padding:80px 32px}
  .bestellen-text{font-size:15px}
  #faq{padding:60px 32px}
  footer{padding:60px 32px 32px}
  .footer-top{grid-template-columns:1fr 1fr;gap:40px}
  .subpage-hero{padding:40px 32px}
  .subpage-content{padding:60px 32px}
  .radio-player{right:16px;bottom:28px}
  .radio-player-inner{padding:10px 15px 10px 13px;gap:9px}
  .radio-name{font-size:12px}
  .radio-bars{height:12px}
}
@media(max-width:640px){
  .products-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .hero-h1{font-size:42px}
  .ig-photo-grid{grid-template-columns:repeat(2,1fr);gap:4px}
  .hero-actions{grid-template-columns:1fr;max-width:320px}
  #bestellen{padding:64px 24px}
  .bestellen-actions{flex-direction:column;align-items:center}
  .bestellen-actions .btn-primary{width:100%;max-width:320px;justify-content:center}
}
