/* =========================================================
   DEEP VIBE MUSIC — Barock-Theater Designsystem
   Tamara Brückner · Hochzeitssängerin
   ========================================================= */

/* ---------- Fonts (selbst gehostet, DSGVO-freundlich) ---------- */
@font-face{font-family:'Cormorant Garamond';font-style:normal;font-weight:400 700;font-display:swap;src:url(../fonts/cormorant.woff2) format('woff2')}
@font-face{font-family:'Cormorant Garamond';font-style:italic;font-weight:400 700;font-display:swap;src:url(../fonts/cormorant-italic.woff2) format('woff2')}
@font-face{font-family:'Jost';font-style:normal;font-weight:300 600;font-display:swap;src:url(../fonts/jost.woff2) format('woff2')}
@font-face{font-family:'Pinyon Script';font-style:normal;font-weight:400;font-display:swap;src:url(../fonts/pinyon.woff2) format('woff2')}

/* ---------- Tokens ---------- */
:root{
  --noir:#0B0807;
  --noir-2:#13100D;
  --noir-3:#1C1611;
  --oxblood:#4A1119;
  --oxblood-2:#3A0D13;
  --wine:#6E1B23;
  --gold:#C9A24B;
  --gold-bright:#EBD28A;
  --gold-deep:#8A6B28;
  --champagne:#F1E4C2;
  --parchment:#F7EFDC;
  --muted:#D2C29C;
  --line:rgba(201,162,75,.22);
  --ease:cubic-bezier(.22,.61,.36,1);
  --ease-curtain:cubic-bezier(.76,0,.24,1);

  --serif:"Cormorant Garamond",Georgia,serif;
  --script:"Pinyon Script",cursive;
  --sans:"Jost",system-ui,sans-serif;
  --maxw:1200px;
}

/* ---------- Reset / Base ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--noir);color:var(--champagne);font-family:var(--sans);
  font-weight:300;line-height:1.65;letter-spacing:.01em;overflow-x:hidden;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
body.locked{overflow:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
::selection{background:var(--gold);color:var(--noir)}

/* ---------- Ambient atmosphere ---------- */
body::before{
  content:"";position:fixed;inset:0;z-index:-3;pointer-events:none;
  background:
    radial-gradient(120% 80% at 50% -10%, rgba(110,27,35,.40), transparent 60%),
    radial-gradient(90% 60% at 88% 112%, rgba(201,162,75,.10), transparent 55%),
    radial-gradient(150% 130% at 50% 50%, transparent 52%, rgba(0,0,0,.88));
}
body::after{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;opacity:.2;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");
}
/* Kerzenlicht-Funken Canvas */
#embers{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.75}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.wrap-narrow{max-width:860px;margin:0 auto;padding:0 28px}

/* ---------- Typography helpers ---------- */
.script{font-family:var(--script);font-weight:400;color:var(--gold-bright);line-height:.9}
.eyebrow{
  font-family:var(--sans);font-weight:500;font-size:.72rem;letter-spacing:.42em;
  text-transform:uppercase;color:var(--gold);display:inline-block;
}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.05;letter-spacing:.005em}
em{font-style:italic}

/* ---------- Scroll progress ---------- */
#progress{position:fixed;top:0;left:0;height:2px;width:0;z-index:200;
  background:linear-gradient(90deg,var(--gold-deep),var(--gold-bright));box-shadow:0 0 10px var(--gold)}

/* ---------- Dividers ---------- */
.divider{display:flex;align-items:center;justify-content:center;gap:18px;margin:0 auto;max-width:520px;color:var(--gold)}
.divider .line{height:1px;flex:1;background:linear-gradient(90deg,transparent,var(--gold-deep) 60%,var(--gold));transform:scaleX(0);transform-origin:right;transition:transform 1.1s var(--ease)}
.divider .line.r{background:linear-gradient(270deg,transparent,var(--gold-deep) 60%,var(--gold));transform-origin:left}
.divider.in .line{transform:scaleX(1)}
.divider svg{width:42px;height:auto;flex:none}
.divider svg path{stroke-dasharray:260;stroke-dashoffset:260;transition:stroke-dashoffset 1.4s var(--ease) .3s}
.divider.in svg path{stroke-dashoffset:0}

/* ---------- Buttons ---------- */
.btn{
  position:relative;display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--sans);font-weight:500;font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;
  padding:1.05em 2.2em;border:1px solid var(--gold);color:var(--gold-bright);
  background:transparent;cursor:pointer;overflow:hidden;transition:color .5s var(--ease);border-radius:1px;
}
.btn span{position:relative;z-index:1}
.btn::before{content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(120deg,var(--gold-deep),var(--gold),var(--gold-bright));
  transform:translateX(-101%);transition:transform .55s var(--ease)}
.btn:hover{color:var(--noir)}
.btn:hover::before{transform:translateX(0)}
.btn.solid{background:linear-gradient(120deg,var(--gold-deep),var(--gold));color:var(--noir);border-color:transparent}
.btn.solid::before{background:linear-gradient(120deg,var(--gold),var(--gold-bright))}
.btn:focus-visible{outline:2px solid var(--gold-bright);outline-offset:4px}
.btn-row{display:flex;gap:16px;flex-wrap:wrap}

/* ---------- Top bar ---------- */
header.bar{
  position:fixed;top:0;left:0;right:0;z-index:130;
  display:flex;align-items:center;justify-content:space-between;
  padding:34px clamp(20px,4vw,46px) 24px;
  transition:background .5s var(--ease),padding .5s var(--ease),border-color .5s var(--ease);
  border-bottom:1px solid transparent;
}
header.bar.scrolled{background:rgba(11,8,7,.84);backdrop-filter:blur(11px);border-bottom:1px solid var(--line);padding-top:16px;padding-bottom:16px}
.brand{position:relative;display:inline-block;line-height:.86;transition:opacity .4s var(--ease)}
.brand .name{display:block;font-family:var(--script);font-size:clamp(1.7rem,4.4vw,2.35rem);color:var(--gold-bright);line-height:.86}
.brand .sub{position:absolute;top:100%;left:0;font-family:var(--sans);font-size:.55rem;letter-spacing:.46em;text-transform:uppercase;color:var(--muted);padding-left:.25em;margin-top:2px;white-space:nowrap}
body.menu-open .brand{opacity:0;pointer-events:none}

/* Burger */
.burger{position:relative;width:54px;height:54px;border:1px solid rgba(201,162,75,.45);
  background:rgba(20,16,14,.4);cursor:pointer;border-radius:2px;z-index:140;
  transition:border-color .4s var(--ease),background .4s var(--ease)}
.burger:hover{border-color:var(--gold);background:rgba(74,17,25,.5)}
.burger:focus-visible{outline:2px solid var(--gold-bright);outline-offset:3px}
.burger i{position:absolute;left:50%;top:50%;width:22px;height:1.6px;background:var(--gold-bright);transform:translate(-50%,-50%);transition:.45s var(--ease)}
.burger i:nth-child(1){transform:translate(-50%,-7px)}
.burger i:nth-child(3){transform:translate(-50%,7px)}
body.menu-open .burger i:nth-child(1){transform:translate(-50%,0) rotate(45deg)}
body.menu-open .burger i:nth-child(2){opacity:0}
body.menu-open .burger i:nth-child(3){transform:translate(-50%,0) rotate(-45deg)}

/* ---------- Curtain menu ---------- */
.overlay{position:fixed;inset:0;z-index:120;pointer-events:none}
.curtain{position:absolute;top:0;bottom:0;width:52%;
  background:
    linear-gradient(90deg, rgba(0,0,0,.55), transparent 30%, transparent 70%, rgba(0,0,0,.55)),
    repeating-linear-gradient(90deg, var(--oxblood) 0 22px, var(--oxblood-2) 22px 44px),
    var(--oxblood);
  transition:transform .8s var(--ease-curtain);box-shadow:0 0 80px rgba(0,0,0,.6) inset}
.curtain.left{left:0;transform:translateX(-101%)}
.curtain.right{right:0;transform:translateX(101%)}
body.menu-open .curtain.left{transform:translateX(0)}
body.menu-open .curtain.right{transform:translateX(0)}
.menu-inner{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;opacity:0;transition:opacity .4s var(--ease);padding:90px 24px 40px}
body.menu-open .menu-inner{opacity:1;transition:opacity .5s var(--ease) .45s;pointer-events:auto}
body.menu-open .overlay{pointer-events:auto}
.menu-mark{font-family:var(--script);font-size:clamp(2.4rem,7vw,3.6rem);color:var(--gold-bright);margin-bottom:.1em}
.menu-tag{font-family:var(--sans);font-size:.6rem;letter-spacing:.4em;text-transform:uppercase;color:var(--champagne);opacity:.7;margin-bottom:30px}
nav.menu-nav{display:flex;flex-direction:column;gap:2px}
nav.menu-nav a{font-family:var(--serif);font-style:italic;font-size:clamp(1.9rem,6vw,3rem);color:var(--parchment);
  padding:.1em .5em;position:relative;transition:color .35s var(--ease),letter-spacing .35s var(--ease);transform:translateY(18px);opacity:0}
body.menu-open nav.menu-nav a{transform:translateY(0);opacity:1;transition:transform .6s var(--ease),opacity .6s var(--ease),color .35s,letter-spacing .35s}
body.menu-open nav.menu-nav a:nth-child(1){transition-delay:.5s}
body.menu-open nav.menu-nav a:nth-child(2){transition-delay:.57s}
body.menu-open nav.menu-nav a:nth-child(3){transition-delay:.64s}
body.menu-open nav.menu-nav a:nth-child(4){transition-delay:.71s}
body.menu-open nav.menu-nav a:nth-child(5){transition-delay:.78s}
body.menu-open nav.menu-nav a:nth-child(6){transition-delay:.85s}
nav.menu-nav a::before{content:"✦";position:absolute;left:-.15em;opacity:0;color:var(--gold);font-size:.36em;top:50%;transform:translateY(-50%) translateX(-6px);transition:.35s var(--ease)}
nav.menu-nav a:hover,nav.menu-nav a.active{color:var(--gold-bright);letter-spacing:.03em}
nav.menu-nav a:hover::before,nav.menu-nav a.active::before{opacity:1;transform:translateY(-50%) translateX(0)}
.menu-foot{margin-top:34px;font-size:.8rem;letter-spacing:.06em;color:var(--muted)}
.menu-foot a{color:var(--gold-bright);border-bottom:1px solid rgba(201,162,75,.4)}
.menu-divider{margin:24px auto;max-width:300px;color:var(--gold-bright)}
.menu-divider .line{background:linear-gradient(90deg,transparent,var(--gold));transform:none}
.menu-divider .line.r{background:linear-gradient(270deg,transparent,var(--gold))}

/* ---------- Intro curtain (Seitenladen) ---------- */
#intro{position:fixed;inset:0;z-index:300;display:flex;align-items:center;justify-content:center;pointer-events:none}
#intro .ipanel{position:absolute;top:0;bottom:0;width:51%;
  background:repeating-linear-gradient(90deg,var(--oxblood) 0 26px,var(--oxblood-2) 26px 52px),var(--oxblood);
  box-shadow:0 0 120px rgba(0,0,0,.7) inset;transition:transform 1.15s var(--ease-curtain) .9s}
#intro .ipanel.l{left:0}
#intro .ipanel.r{right:0}
#intro .imark{position:relative;z-index:2;text-align:center;transition:opacity .6s var(--ease) .55s,transform 1s var(--ease)}
#intro .imark .s{font-family:var(--script);font-size:clamp(3rem,9vw,5.5rem);color:var(--gold-bright);line-height:.9}
#intro .imark .t{font-family:var(--sans);font-size:.62rem;letter-spacing:.5em;text-transform:uppercase;color:var(--champagne);opacity:.8;margin-top:.6em}
body.intro-done #intro{pointer-events:none}
body.intro-done #intro .ipanel.l{transform:translateX(-101%)}
body.intro-done #intro .ipanel.r{transform:translateX(101%)}
body.intro-done #intro .imark{opacity:0;transform:scale(1.04)}
body.intro-done #intro{transition:visibility 0s linear 2.1s;visibility:hidden}

/* ---------- Page transition veil ---------- */
#veil{position:fixed;inset:0;z-index:250;background:var(--noir);opacity:0;pointer-events:none;
  transition:opacity .5s var(--ease)}
#veil.show{opacity:1}
#veil .vmark{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--script);
  font-size:clamp(2.2rem,6vw,3.4rem);color:var(--gold-bright);opacity:0;transition:opacity .5s var(--ease)}
#veil.show .vmark{opacity:1}

/* fade-in page content */
.page-fade{opacity:0;animation:pageIn .9s var(--ease) .1s forwards}
@keyframes pageIn{to{opacity:1}}

/* =========================================================
   SEKTIONEN & KOMPONENTEN
   ========================================================= */
section{position:relative;padding:clamp(78px,11vh,130px) 0}
.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}.reveal.d2{transition-delay:.2s}.reveal.d3{transition-delay:.3s}.reveal.d4{transition-delay:.4s}

.sec-head{text-align:center;margin-bottom:60px}
.sec-head .eyebrow{margin-bottom:18px}
.sec-head h2{font-size:clamp(2.2rem,6vw,3.7rem)}
.sec-head h2 em{color:var(--gold-bright);font-weight:500}
.sec-head p{max-width:580px;margin:18px auto 0;color:var(--muted)}

/* ---------- HERO (Start) ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden}
.hero-img{position:absolute;inset:0;z-index:0;will-change:transform}
.hero-img img{width:100%;height:100%;object-fit:cover;object-position:40% 32%;animation:kb 24s var(--ease) forwards;transform-origin:45% 40%}
@keyframes kb{from{transform:scale(1.18)}to{transform:scale(1.03)}}
.hero-img::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(11,8,7,.6) 0%,rgba(11,8,7,.06) 28%,rgba(11,8,7,.5) 66%,var(--noir) 100%),
  radial-gradient(80% 60% at 28% 42%,transparent,rgba(11,8,7,.5))}
.frame-corner{position:absolute;z-index:3;width:clamp(64px,11vw,140px);height:auto;opacity:.9;filter:drop-shadow(0 2px 8px rgba(0,0,0,.5))}
.fc-tl,.fc-tr{display:none} /* obere Ecken entfernt – kollidierten mit Wortmarke & Menü */
.fc-bl{bottom:24px;left:24px;transform:scaleY(-1)}.fc-br{bottom:24px;right:24px;transform:scale(-1,-1)}
.hero-content{position:relative;z-index:4;width:100%;padding-bottom:clamp(60px,9vh,110px)}
.hero-content .wrap{display:flex;flex-direction:column;align-items:center;text-align:center}
.hero-script{font-family:var(--script);font-size:clamp(3.4rem,11vw,7.2rem);color:var(--gold-bright);text-shadow:0 6px 34px rgba(0,0,0,.65);line-height:.85}
.hero h1{font-size:clamp(1.45rem,3.5vw,2rem);font-weight:400;letter-spacing:.34em;text-transform:uppercase;color:var(--parchment);margin:.6em 0 .15em}
.hero-role{font-family:var(--serif);font-style:italic;font-size:clamp(1.15rem,2.6vw,1.5rem);color:var(--gold);margin-bottom:.9em}
.hero-tag{max-width:440px;color:var(--champagne);opacity:.85;margin-bottom:2em}
.scroll-hint{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);z-index:4;font-size:.58rem;letter-spacing:.4em;text-transform:uppercase;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:10px}
.scroll-hint .dot{width:1px;height:38px;background:linear-gradient(var(--gold),transparent);animation:drop 2.2s var(--ease) infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}40%{transform:scaleY(1);transform-origin:top}60%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---------- Page hero (Unterseiten) ---------- */
.phero{position:relative;padding:clamp(150px,22vh,230px) 0 clamp(50px,7vh,90px);text-align:center;overflow:hidden}
.phero::before{content:"";position:absolute;inset:0;z-index:0;
  background:url(../img/header.jpg) 50% 30%/cover no-repeat}
.phero::after{content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(180deg,rgba(11,8,7,.74),rgba(11,8,7,.82) 58%,var(--noir)),radial-gradient(120% 90% at 50% 0%,rgba(74,17,25,.4),transparent 62%)}
.phero>.wrap{position:relative;z-index:1}
.phero .eyebrow{margin-bottom:20px}
.phero h1{font-size:clamp(2.6rem,8vw,5rem);line-height:1}
.phero h1 .script{display:block;font-size:1.15em;margin-bottom:-.1em}
.phero p{max-width:560px;margin:22px auto 0;color:var(--muted)}
.phero .crumb{font-size:.64rem;letter-spacing:.32em;text-transform:uppercase;color:var(--muted);margin-top:26px}
.phero .crumb a{color:var(--gold)}

/* ---------- Manifesto band ---------- */
.manifesto{text-align:center}
.manifesto p{font-family:var(--serif);font-style:italic;font-size:clamp(1.5rem,3.6vw,2.5rem);line-height:1.45;color:var(--parchment);max-width:920px;margin:0 auto}
.manifesto p .gold{color:var(--gold-bright)}

/* ---------- About ---------- */
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(36px,6vw,80px);align-items:center}
.portrait-frame{position:relative;padding:14px;max-width:440px;margin:0 auto;width:100%}
.portrait-frame::before{content:"";position:absolute;inset:0;border:1px solid var(--gold);box-shadow:0 0 0 6px var(--noir),0 0 0 7px rgba(201,162,75,.35),0 30px 60px rgba(0,0,0,.5)}
.portrait-frame img{width:100%;filter:saturate(.92) contrast(1.03)}
.portrait-frame .corner{position:absolute;width:44px;z-index:2;color:var(--gold)}
.pc-tl{top:-5px;left:-5px}.pc-tr{top:-5px;right:-5px;transform:scaleX(-1)}
.pc-bl{bottom:-5px;left:-5px;transform:scaleY(-1)}.pc-br{bottom:-5px;right:-5px;transform:scale(-1,-1)}
.about-text h2{font-size:clamp(2rem,5vw,3rem);margin-bottom:.35em;font-weight:500}
.about-text h2 .script{display:block;font-size:1.5em;margin-bottom:.02em}
.about-text p{margin-bottom:1.05em;color:var(--champagne);opacity:.88}
.about-text .lead{font-family:var(--serif);font-size:1.34rem;font-style:italic;color:var(--gold-bright);opacity:1;line-height:1.5}
.sig{font-family:var(--script);font-size:2.5rem;color:var(--gold-bright);margin-top:.1em}

/* values list */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:8px}
.value{padding:30px 24px;border:1px solid var(--line);background:linear-gradient(170deg,var(--noir-2),var(--noir));text-align:center}
.value .vi{width:40px;height:40px;margin:0 auto 14px;color:var(--gold-bright)}
.value h4{font-size:1.25rem;margin-bottom:.4em;color:var(--parchment)}
.value p{font-size:.9rem;color:var(--muted);line-height:1.5}

/* ---------- Feature triptych (Start) ---------- */
.tript{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.tcard{position:relative;display:block;padding:40px 30px 34px;background:linear-gradient(170deg,var(--noir-2),var(--noir));border:1px solid var(--line);overflow:hidden;transition:transform .5s var(--ease),border-color .5s var(--ease),background .5s var(--ease)}
.tcard::before{content:"";position:absolute;left:0;right:0;top:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);transform:scaleX(0);transition:transform .5s var(--ease)}
.tcard:hover{transform:translateY(-8px);border-color:rgba(201,162,75,.5);background:linear-gradient(170deg,var(--noir-3),var(--noir-2))}
.tcard:hover::before{transform:scaleX(1)}
.tcard .num{font-family:var(--serif);font-style:italic;font-size:1.1rem;color:var(--gold);margin-bottom:14px}
.tcard .ico{width:48px;height:48px;color:var(--gold-bright);margin-bottom:18px}
.tcard h3{font-size:1.5rem;margin-bottom:.5em;color:var(--parchment);font-weight:500}
.tcard p{font-size:.94rem;color:var(--muted);line-height:1.55}
.tcard .more{display:inline-block;margin-top:18px;font-family:var(--sans);font-size:.68rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-bright)}
.tcard .more::after{content:" →";transition:margin .3s var(--ease)}
.tcard:hover .more::after{margin-left:5px}

/* ---------- Alternating service rows ---------- */
.srow{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,70px);align-items:center;margin-bottom:clamp(40px,6vw,80px)}
.srow:last-child{margin-bottom:0}
.srow .stext .rn{font-family:var(--serif);font-style:italic;font-size:3rem;color:var(--gold);line-height:1}
.srow .stext h3{font-size:clamp(1.8rem,4vw,2.6rem);margin:.1em 0 .5em;color:var(--parchment);font-weight:500}
.srow .stext p{color:var(--champagne);opacity:.86;margin-bottom:1em}
.srow .stext ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.srow .stext li{position:relative;padding-left:24px;color:var(--muted);font-size:.96rem}
.srow .stext li::before{content:"✦";position:absolute;left:0;color:var(--gold);font-size:.7em;top:.25em}
.svisual{position:relative;aspect-ratio:4/3;border:1px solid var(--line);background:linear-gradient(160deg,var(--noir-2),var(--oxblood-2));display:grid;place-items:center;overflow:hidden}
.svisual::before,.svisual::after{content:"";position:absolute;width:34px;height:34px;border:1px solid var(--gold);opacity:.55}
.svisual::before{top:12px;left:12px;border-right:none;border-bottom:none}
.svisual::after{bottom:12px;right:12px;border-left:none;border-top:none}
.svisual .big-ico{width:84px;height:84px;color:var(--gold-bright);opacity:.85}
.srow:nth-child(even) .svisual{order:-1}

/* ---------- Audio player ---------- */
#musicpane{background:radial-gradient(120% 60% at 50% 0%,rgba(74,17,25,.4),transparent 60%),linear-gradient(var(--noir),var(--noir-2),var(--noir))}
.player{max-width:700px;margin:0 auto;background:linear-gradient(160deg,rgba(30,23,20,.92),rgba(18,13,11,.96));
  border:1px solid rgba(201,162,75,.32);padding:clamp(26px,4vw,44px);position:relative;
  box-shadow:0 30px 70px rgba(0,0,0,.55),0 0 0 1px rgba(0,0,0,.4) inset}
.player::before,.player::after{content:"";position:absolute;width:30px;height:30px;border:1px solid var(--gold);opacity:.6}
.player::before{top:10px;left:10px;border-right:none;border-bottom:none}
.player::after{bottom:10px;right:10px;border-left:none;border-top:none}
.track-head{display:flex;align-items:center;gap:22px;margin-bottom:24px}
.medallion{flex:none;width:76px;height:76px;border-radius:50%;cursor:pointer;position:relative;border:none;
  background:radial-gradient(circle at 35% 30%,var(--gold-bright),var(--gold) 45%,var(--gold-deep));
  box-shadow:0 0 0 6px rgba(201,162,75,.12),0 0 0 7px rgba(201,162,75,.3),0 10px 24px rgba(0,0,0,.5);
  display:grid;place-items:center;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.medallion:hover{transform:scale(1.05)}
.medallion:focus-visible{outline:2px solid var(--gold-bright);outline-offset:5px}
.medallion svg{width:26px;height:26px;fill:var(--noir);margin-left:3px}
.medallion .pause{position:absolute;opacity:0;margin-left:0}
.player.playing .medallion .play{opacity:0}
.player.playing .medallion .pause{opacity:1}
.player.playing .medallion::after{content:"";position:absolute;inset:-7px;border-radius:50%;border:1px solid var(--gold);opacity:.5;animation:pulse 1.8s ease-out infinite}
@keyframes pulse{from{transform:scale(1);opacity:.5}to{transform:scale(1.26);opacity:0}}
.track-meta .t-label{font-family:var(--sans);font-size:.6rem;letter-spacing:.34em;text-transform:uppercase;color:var(--gold)}
.track-meta .t-title{font-family:var(--serif);font-style:italic;font-size:1.55rem;color:var(--parchment);line-height:1.1;margin-top:.15em}
/* equalizer */
.eq{display:flex;align-items:flex-end;gap:3px;height:22px;margin-left:auto}
.eq span{width:3px;height:6px;background:var(--gold);opacity:.5;border-radius:2px}
.player.playing .eq span{animation:eq 1s ease-in-out infinite}
.player.playing .eq span:nth-child(2){animation-delay:.18s}
.player.playing .eq span:nth-child(3){animation-delay:.36s}
.player.playing .eq span:nth-child(4){animation-delay:.12s}
.player.playing .eq span:nth-child(5){animation-delay:.42s}
@keyframes eq{0%,100%{height:5px}50%{height:22px}}
.progress-row{display:flex;align-items:center;gap:14px;font-family:var(--sans);font-size:.78rem;color:var(--muted);font-variant-numeric:tabular-nums}
.pbar{flex:1;height:5px;background:rgba(201,162,75,.16);border-radius:3px;cursor:pointer;position:relative}
.pbar .fill{position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(90deg,var(--gold-deep),var(--gold-bright));border-radius:3px}
.pbar .knob{position:absolute;top:50%;width:13px;height:13px;border-radius:50%;background:var(--gold-bright);box-shadow:0 0 8px var(--gold);transform:translate(-50%,-50%);left:0;opacity:0;transition:opacity .2s}
.pbar:hover .knob{opacity:1}

/* ---------- Video frame ---------- */
.video-wrap{max-width:520px;margin:0 auto}
.video-frame{position:relative;padding:10px;background:var(--noir-2);border:1px solid rgba(201,162,75,.3);box-shadow:0 24px 50px rgba(0,0,0,.5)}
.video-frame video{width:100%;display:block;background:#000}
.video-cap{text-align:center;margin-top:16px;font-family:var(--serif);font-style:italic;color:var(--gold);font-size:1.05rem}

/* ---------- Repertoire chips ---------- */
.rep-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.rep{padding:28px 20px;text-align:center;border:1px solid var(--line);background:linear-gradient(170deg,var(--noir-2),var(--noir));transition:transform .4s var(--ease),border-color .4s}
.rep:hover{transform:translateY(-6px);border-color:rgba(201,162,75,.5)}
.rep .ri{width:38px;height:38px;margin:0 auto 12px;color:var(--gold-bright)}
.rep h4{font-size:1.2rem;color:var(--parchment);margin-bottom:.3em}
.rep p{font-size:.84rem;color:var(--muted);line-height:1.5}

/* ---------- Testimonials slider ---------- */
.tsl{position:relative;max-width:820px;margin:0 auto;text-align:center}
.tsl .qm{font-family:var(--serif);font-size:6rem;line-height:0;color:var(--gold);opacity:.4;display:block;height:.45em;margin-bottom:.15em}
.tsl-stack{display:grid}
.tsl-stack>.slide{grid-area:1/1;opacity:0;transform:translateY(14px);transition:opacity .7s var(--ease),transform .7s var(--ease);pointer-events:none}
.tsl-stack>.slide.active{opacity:1;transform:none;pointer-events:auto}
.slide blockquote{font-family:var(--serif);font-style:italic;font-size:clamp(1.4rem,3.2vw,2.1rem);line-height:1.42;color:var(--parchment)}
.slide cite{display:block;margin-top:26px;font-family:var(--sans);font-style:normal;font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold)}
.tdots{display:flex;gap:10px;justify-content:center;margin-top:34px}
.tdots button{width:9px;height:9px;border-radius:50%;border:1px solid var(--gold);background:transparent;cursor:pointer;padding:0;transition:background .3s,transform .3s}
.tdots button.active{background:var(--gold-bright);transform:scale(1.25)}

/* ---------- Timeline (Ablauf) ---------- */
.timeline{max-width:760px;margin:0 auto;position:relative}
.timeline::before{content:"";position:absolute;left:27px;top:8px;bottom:8px;width:1px;background:linear-gradient(var(--gold),var(--gold-deep),transparent)}
.tstep{position:relative;padding:0 0 44px 78px}
.tstep:last-child{padding-bottom:0}
.tstep .tn{position:absolute;left:0;top:0;width:56px;height:56px;border-radius:50%;border:1px solid var(--gold);
  display:grid;place-items:center;font-family:var(--serif);font-style:italic;font-size:1.4rem;color:var(--gold-bright);background:var(--noir);box-shadow:0 0 0 5px var(--noir)}
.tstep h3{font-size:1.5rem;color:var(--parchment);margin-bottom:.3em;font-weight:500}
.tstep p{color:var(--muted)}

/* ---------- FAQ accordion ---------- */
.faq{max-width:780px;margin:0 auto}
.fitem{border-bottom:1px solid var(--line)}
.fq{width:100%;text-align:left;background:none;border:none;cursor:pointer;color:var(--parchment);
  font-family:var(--serif);font-size:clamp(1.15rem,2.6vw,1.5rem);padding:26px 44px 26px 0;position:relative;transition:color .3s}
.fq:hover{color:var(--gold-bright)}
.fq::after{content:"+";position:absolute;right:6px;top:50%;transform:translateY(-50%);font-family:var(--sans);font-weight:300;font-size:1.6rem;color:var(--gold);transition:transform .4s var(--ease)}
.fitem.open .fq::after{transform:translateY(-50%) rotate(45deg)}
.fa{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
.fa p{padding:0 0 26px;color:var(--muted);max-width:90%}

/* ---------- CTA band ---------- */
.cta-band{text-align:center;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;z-index:-1;background:radial-gradient(100% 80% at 50% 50%,rgba(74,17,25,.55),transparent 70%)}
.cta-band h2{font-size:clamp(2.2rem,6vw,4rem);margin-bottom:.3em}
.cta-band h2 .script{display:block;font-size:1.25em;color:var(--gold-bright)}
.cta-band p{max-width:520px;margin:0 auto 2em;color:var(--champagne);opacity:.85}

/* ---------- Kontakt / Form ---------- */
.contact-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(40px,6vw,80px);align-items:start}
.contact-info h2{font-size:clamp(2rem,5vw,3rem);margin-bottom:.3em;font-weight:500}
.contact-info h2 .script{display:block;font-size:1.4em;color:var(--gold-bright)}
.contact-info p{color:var(--champagne);opacity:.85;margin-bottom:1.6em;max-width:380px}
.contact-list{list-style:none;display:flex;flex-direction:column;gap:18px}
.contact-list li{display:flex;align-items:center;gap:16px;font-size:1rem}
.contact-list .ci{width:44px;height:44px;flex:none;border:1px solid rgba(201,162,75,.4);display:grid;place-items:center;color:var(--gold-bright);border-radius:2px}
.contact-list .ci svg{width:18px;height:18px}
.contact-list a:hover{color:var(--gold-bright)}

form.book{background:linear-gradient(160deg,var(--noir-2),rgba(18,13,11,.7));border:1px solid rgba(201,162,75,.28);padding:clamp(26px,4vw,42px);position:relative}
form.book::before{content:"";position:absolute;top:8px;left:8px;right:8px;bottom:8px;border:1px solid rgba(201,162,75,.14);pointer-events:none}
.field{margin-bottom:20px;position:relative}
.field label{display:block;font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.field label .req{color:var(--wine);opacity:.9}
.field input,.field textarea,.field select{width:100%;background:rgba(11,8,7,.55);border:1px solid rgba(201,162,75,.25);color:var(--parchment);
  font-family:var(--sans);font-size:1rem;padding:13px 15px;border-radius:2px;transition:border-color .3s,box-shadow .3s}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,75,.15)}
.field textarea{resize:vertical;min-height:120px}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%23C9A24B' stroke-width='1.5'%3E%3Cpath d='M3 5l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 15px center}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
form.book .btn{width:100%;justify-content:center;margin-top:8px}
.form-note{font-size:.74rem;color:var(--muted);text-align:center;margin-top:14px;line-height:1.5}
.form-msg{display:none;padding:16px;margin-bottom:18px;border:1px solid;font-size:.92rem;text-align:center;border-radius:2px}
.form-msg.ok{display:block;border-color:rgba(201,162,75,.5);color:var(--gold-bright);background:rgba(201,162,75,.08)}
.form-msg.err{display:block;border-color:rgba(140,30,40,.6);color:#e7a9ad;background:rgba(110,27,35,.18)}

/* ---------- Footer ---------- */
footer{padding:72px 0 40px;text-align:center;border-top:1px solid var(--line);background:var(--noir)}
footer .fmark{font-family:var(--script);font-size:2.9rem;color:var(--gold-bright)}
footer .ftag{font-size:.6rem;letter-spacing:.4em;text-transform:uppercase;color:var(--muted);margin:.4em 0 22px}
.fnav{display:flex;gap:24px;justify-content:center;flex-wrap:wrap;margin-bottom:26px;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase}
.fnav a{color:var(--champagne);opacity:.8;transition:color .3s,opacity .3s}
.fnav a:hover{color:var(--gold-bright);opacity:1}
.fsocial{display:flex;gap:14px;justify-content:center;margin-bottom:26px}
.fsocial a{width:44px;height:44px;border:1px solid rgba(201,162,75,.35);display:grid;place-items:center;color:var(--gold-bright);transition:.4s var(--ease);border-radius:2px}
.fsocial a:hover{background:var(--gold);color:var(--noir);border-color:var(--gold)}
.fsocial svg{width:18px;height:18px}
footer .legal{font-size:.78rem;color:var(--muted)}
footer .legal a{color:var(--gold)}
footer .copy{font-size:.72rem;color:#8c7c5e;margin-top:14px;letter-spacing:.05em}
footer .region{font-size:.74rem;color:var(--muted);margin-bottom:14px;letter-spacing:.12em}

/* ---------- Künstler-Teaser (Bild + Text) ---------- */
.teaser{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,6vw,80px);align-items:center}
.teaser .tframe{position:relative;padding:12px;max-width:430px;width:100%;margin:0 auto}
.teaser .tframe::before{content:"";position:absolute;inset:0;border:1px solid var(--gold);box-shadow:0 0 0 6px var(--noir),0 0 0 7px rgba(201,162,75,.3),0 30px 60px rgba(0,0,0,.5)}
.teaser .tframe img{width:100%;filter:saturate(.9) contrast(1.03)}
.teaser .tframe .corner{position:absolute;width:42px;z-index:2;color:var(--gold)}
.teaser-text .eyebrow{margin-bottom:16px}
.teaser-text h2{font-size:clamp(2rem,5vw,3.1rem);font-weight:500;margin-bottom:.4em}
.teaser-text h2 .script{display:block;font-size:1.45em;color:var(--gold-bright);line-height:.9}
.teaser-text p{color:var(--champagne);opacity:.88;margin-bottom:1.2em}
.teaser:nth-of-type(even) .tframe{order:-1}

/* ---------- Parallax-Band (Vollbild-Bild + Zitat) ---------- */
.pband{position:relative;min-height:60vh;display:flex;align-items:center;justify-content:center;overflow:hidden;text-align:center}
.pband .pbg{position:absolute;inset:-12% 0;z-index:0;will-change:transform}
.pband .pbg img{width:100%;height:100%;object-fit:cover;object-position:50% 38%;filter:grayscale(.2) contrast(1.05)}
.pband::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(var(--noir),rgba(11,8,7,.55) 40%,rgba(11,8,7,.55) 60%,var(--noir)),radial-gradient(70% 60% at 50% 50%,rgba(74,17,25,.4),transparent)}
.pband .pq{position:relative;z-index:2;max-width:760px;padding:60px 28px}
.pband .pq p{font-family:var(--serif);font-style:italic;font-size:clamp(1.6rem,3.8vw,2.7rem);line-height:1.4;color:var(--parchment)}
.pband .pq cite{display:block;margin-top:22px;font-family:var(--script);font-size:2rem;color:var(--gold-bright);font-style:normal}

/* ---------- Galerie-Strip ---------- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.glift{position:relative;overflow:hidden;cursor:pointer;border:1px solid var(--line);aspect-ratio:1;background:var(--noir-2)}
.glift img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease),filter .5s;filter:grayscale(.15)}
.glift::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(11,8,7,.5));opacity:0;transition:opacity .4s}
.glift:hover img{transform:scale(1.07);filter:grayscale(0)}
.glift:hover::after{opacity:1}
.glift .gi{position:absolute;right:12px;bottom:12px;z-index:2;color:var(--gold-bright);opacity:0;transform:translateY(6px);transition:.4s var(--ease)}
.glift:hover .gi{opacity:1;transform:none}
.glift .gi svg{width:20px;height:20px}

/* ---------- Lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:260;background:rgba(7,5,4,.94);display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .4s var(--ease);padding:30px}
.lightbox.show{opacity:1;pointer-events:auto}
.lightbox img{max-width:92vw;max-height:88vh;border:1px solid rgba(201,162,75,.4);box-shadow:0 30px 80px rgba(0,0,0,.7)}
.lightbox .lx{position:absolute;top:24px;right:28px;width:48px;height:48px;border:1px solid rgba(201,162,75,.5);background:rgba(20,16,14,.5);color:var(--gold-bright);font-size:1.5rem;cursor:pointer;border-radius:2px;line-height:1}
.lightbox .lnav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border:1px solid rgba(201,162,75,.4);background:rgba(20,16,14,.5);color:var(--gold-bright);font-size:1.6rem;cursor:pointer;border-radius:2px}
.lightbox .lprev{left:24px}.lightbox .lnext{right:24px}

/* ---------- Video-Grid ---------- */
.video-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;max-width:760px;margin:0 auto}
.vcard .video-frame video{aspect-ratio:478/850;object-fit:cover}
.vcard .vlabel{text-align:center;margin-top:14px;font-family:var(--serif);font-style:italic;color:var(--gold);font-size:1.02rem}
.player + .player{margin-top:22px}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:980px){
  .about-grid,.contact-grid{grid-template-columns:1fr;gap:48px}
  .about-text{text-align:center}
  .values{max-width:480px;margin-inline:auto}
  .srow{grid-template-columns:1fr;gap:30px}
  .srow:nth-child(even) .svisual{order:0}
  .tript{grid-template-columns:1fr;max-width:440px;margin-inline:auto}
  .rep-grid{grid-template-columns:1fr 1fr}
  .teaser{grid-template-columns:1fr;gap:40px;max-width:480px;margin-inline:auto}
  .teaser:nth-of-type(even) .tframe{order:0}
  .teaser-text{text-align:center}
  .video-grid{grid-template-columns:1fr;max-width:420px}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .curtain{width:100%}
  .curtain.right{display:none}
  .curtain.left{transform:translateY(-101%)}
  body.menu-open .curtain.left{transform:translateY(0)}
  #intro .ipanel{width:100%}
  #intro .ipanel.l{transform:none}
  #intro .ipanel.r{display:none}
  body.intro-done #intro .ipanel.l{transform:translateY(-101%)}
}
@media(max-width:560px){
  .wrap,.wrap-narrow{padding:0 20px}
  .values{grid-template-columns:1fr}
  .rep-grid{grid-template-columns:1fr}
  .row2{grid-template-columns:1fr}
  .frame-corner{width:54px}
  .brand .sub{display:none}
  .track-head{flex-wrap:wrap}
  .eq{display:none}
  .tstep{padding-left:66px}
  .timeline::before{left:23px}
}

/* =========================================================
   REDUCED MOTION
   ========================================================= */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto}
  .hero-img img{animation:none;transform:scale(1.03)}
  .reveal{opacity:1;transform:none}
  #embers{display:none}
  #intro{display:none}
  .divider .line{transform:scaleX(1)}
  .divider svg path{stroke-dashoffset:0}
}

/* =========================================================
   KONTRAST-FEINSCHLIFF (gestochen scharf)
   ========================================================= */
.hero-tag,.about-text p,.srow .stext p,.cta-band p,.contact-info p,.teaser-text p{opacity:1}
.hero h1,.hero-role,.hero-tag{text-shadow:0 2px 16px rgba(0,0,0,.75),0 1px 3px rgba(0,0,0,.6)}
.hero-script{text-shadow:0 6px 34px rgba(0,0,0,.7),0 2px 6px rgba(0,0,0,.55)}
.menu-tag{opacity:.9}
.sec-head p,.tcard p,.rep p,.value p,.phero p{color:var(--muted)}
/* etwas stärkerer Verlauf unten im Hero für klare Lesbarkeit */
.hero-img::after{background:linear-gradient(180deg,rgba(11,8,7,.62) 0%,rgba(11,8,7,.08) 26%,rgba(11,8,7,.55) 62%,var(--noir) 100%),radial-gradient(80% 60% at 28% 42%,transparent,rgba(11,8,7,.55))}

/* =========================================================
   ANIMIERTE ERFOLGSMELDUNG (Anfrageformular)
   ========================================================= */
.form-success{display:none;text-align:center;
  background:linear-gradient(160deg,var(--noir-2),rgba(18,13,11,.7));
  border:1px solid rgba(201,162,75,.3);padding:clamp(40px,6vw,60px) clamp(26px,4vw,42px);position:relative}
.form-success::before{content:"";position:absolute;top:8px;left:8px;right:8px;bottom:8px;border:1px solid rgba(201,162,75,.14);pointer-events:none}
.form-success.show{display:block;animation:fsIn .7s var(--ease) both}
@keyframes fsIn{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.seal-wrap{position:relative;width:112px;height:112px;margin:0 auto 18px}
.seal-wrap::before{content:"";position:absolute;inset:-6px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,162,75,.4),transparent 68%);transform:scale(.3);opacity:0}
.form-success.show .seal-wrap::before{animation:sealGlow 1.3s var(--ease) .85s}
@keyframes sealGlow{0%{transform:scale(.3);opacity:0}45%{opacity:1}100%{transform:scale(1.7);opacity:0}}
.seal{position:absolute;inset:0;width:112px;height:112px;color:var(--gold-bright)}
.seal circle,.seal path{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round}
.seal .s-ring{stroke-width:2;stroke-dasharray:327;stroke-dashoffset:327}
.seal .s-ring2{stroke-width:1;opacity:.4;stroke-dasharray:277;stroke-dashoffset:277}
.seal .s-check{stroke-width:4.5;stroke-dasharray:90;stroke-dashoffset:90}
.form-success.show .s-ring{animation:draw 1s var(--ease) .2s forwards}
.form-success.show .s-ring2{animation:draw 1.2s var(--ease) .35s forwards}
.form-success.show .s-check{animation:draw .55s var(--ease) .95s forwards}
@keyframes draw{to{stroke-dashoffset:0}}
.fs-script{font-family:var(--script);font-size:clamp(2.6rem,7vw,3.6rem);color:var(--gold-bright);line-height:.9;margin-bottom:.25em}
.fs-text{color:var(--champagne);max-width:430px;margin:0 auto 1.6em;line-height:1.65}
@media(prefers-reduced-motion:reduce){
  .seal .s-ring,.seal .s-ring2,.seal .s-check{stroke-dashoffset:0}
}

/* =========================================================
   USP-BADGE, PAKETE, WHATSAPP, FOOTER-KONTAKT, RATGEBER
   ========================================================= */
/* USP-Badge (Hero) */
.hero-usp{display:inline-flex;align-items:center;gap:10px;margin-bottom:1.4em;
  font-family:var(--sans);font-size:.62rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold-bright);
  border:1px solid rgba(201,162,75,.5);padding:8px 16px;border-radius:2px;background:rgba(11,8,7,.35);
  text-shadow:0 1px 3px rgba(0,0,0,.6)}
.hero-usp .dot{width:5px;height:5px;border-radius:50%;background:var(--gold);flex:none;box-shadow:0 0 6px var(--gold)}
/* USP-Linie (Über) */
.usp-line{font-family:var(--serif);font-style:italic;font-size:clamp(1.3rem,3vw,1.8rem);color:var(--gold-bright);
  text-align:center;margin:0 auto;max-width:640px}

/* Pakete / Bausteine */
.pak-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.pak{position:relative;padding:32px 24px;text-align:center;border:1px solid var(--line);
  background:linear-gradient(170deg,var(--noir-2),var(--noir));transition:transform .45s var(--ease),border-color .45s}
.pak:hover{transform:translateY(-6px);border-color:rgba(201,162,75,.5)}
.pak .pi{width:42px;height:42px;margin:0 auto 14px;color:var(--gold-bright)}
.pak h3{font-size:1.4rem;color:var(--parchment);margin-bottom:.35em;font-weight:500}
.pak p{font-size:.9rem;color:var(--muted);line-height:1.55}
.pak.feature{border-color:rgba(201,162,75,.6);background:linear-gradient(170deg,var(--noir-3),var(--oxblood-2))}
.pak .tag{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:linear-gradient(120deg,var(--gold-deep),var(--gold));
  color:var(--noir);font-family:var(--sans);font-size:.56rem;letter-spacing:.18em;text-transform:uppercase;padding:4px 12px;border-radius:2px;white-space:nowrap}
.pak-note{text-align:center;margin-top:32px;color:var(--champagne)}
.pak-note .price{font-family:var(--serif);font-style:italic;font-size:1.3rem;color:var(--gold-bright);display:block;margin-top:.3em}

/* WhatsApp Floating-Button */
.wa-float{position:fixed;right:20px;bottom:20px;z-index:110;width:58px;height:58px;border-radius:50%;
  display:grid;place-items:center;color:var(--noir);
  background:radial-gradient(circle at 35% 30%,var(--gold-bright),var(--gold) 55%,var(--gold-deep));
  box-shadow:0 8px 24px rgba(0,0,0,.5),0 0 0 1px rgba(201,162,75,.4);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease)}
.wa-float:hover{transform:scale(1.08) translateY(-2px);box-shadow:0 12px 30px rgba(0,0,0,.6)}
.wa-float svg{width:30px;height:30px}
.wa-float::after{content:"";position:absolute;inset:0;border-radius:50%;border:1px solid var(--gold);
  animation:waPulse 2.6s ease-out infinite}
@keyframes waPulse{0%{transform:scale(1);opacity:.55}70%{opacity:0}100%{transform:scale(1.5);opacity:0}}
body.menu-open .wa-float{opacity:0;pointer-events:none;transition:opacity .3s}

/* Footer-Kontaktzeile */
.fcontact{font-size:.84rem;letter-spacing:.04em;color:var(--champagne);margin-bottom:10px}
.fcontact a{color:var(--gold-bright)}
.fcontact a:hover{color:var(--parchment)}

/* Ratgeber-Artikel */
.article{max-width:780px;margin:0 auto}
.article h2{font-size:clamp(1.7rem,4vw,2.4rem);color:var(--parchment);margin:1.4em 0 .5em;font-weight:500}
.article h2:first-child{margin-top:0}
.article h2 em{color:var(--gold-bright)}
.article p{color:var(--champagne);margin-bottom:1.1em;line-height:1.75}
.article ul{list-style:none;margin:0 0 1.4em;display:flex;flex-direction:column;gap:10px}
.article li{position:relative;padding-left:26px;color:var(--champagne)}
.article li::before{content:"✦";position:absolute;left:0;top:.15em;color:var(--gold);font-size:.8em}
.article .song-list{display:grid;grid-template-columns:1fr 1fr;gap:10px 28px}
.article .song-list li{padding-left:22px}
.article .lead{font-family:var(--serif);font-style:italic;font-size:1.35rem;color:var(--gold-bright);line-height:1.5;margin-bottom:1.4em}
.article .note{border-left:2px solid var(--gold);padding:6px 0 6px 18px;color:var(--muted);font-style:italic;margin:1.6em 0}

/* Responsive Ergänzungen */
@media(max-width:980px){
  .pak-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .pak-grid{grid-template-columns:1fr}
  .article .song-list{grid-template-columns:1fr}
  .wa-float{width:52px;height:52px;right:16px;bottom:16px}
  .wa-float svg{width:27px;height:27px}
  .hero-usp{font-size:.56rem;letter-spacing:.2em;padding:7px 12px}
  footer{padding-bottom:92px}
}

/* =========================================================
   AGENTUR-CREDIT + HUMAN-CHECK
   ========================================================= */
.credit{margin-top:14px;font-size:.74rem;letter-spacing:.04em;color:#9a8a68;
  display:flex;align-items:center;justify-content:center;gap:9px;flex-wrap:wrap}
.dhs{display:inline-flex;align-items:center;gap:8px}
.dhs img{width:20px;height:20px;display:block;filter:drop-shadow(0 0 5px rgba(182,230,29,.5))}
.dhs-wm{font-family:var(--sans);font-weight:600;font-size:.86rem;letter-spacing:.01em}
.dhs-wm .d3-white{color:#EDEDED}
.dhs-wm .d3-green{color:#B6E61D;font-style:italic}

/* Human-Check */
.human-check #hquestion{color:var(--gold-bright);font-style:italic;font-family:var(--serif);font-size:1.05em}
.human-check input{max-width:none}

/* =========================================================
   GEFÜHRTER CHATBOT
   ========================================================= */
.dvm-chat{position:fixed;left:20px;bottom:20px;z-index:109}
.dc-launch{position:relative;width:58px;height:58px;border-radius:50%;border:none;cursor:pointer;display:grid;place-items:center;color:var(--noir);
  background:radial-gradient(circle at 35% 30%,var(--gold-bright),var(--gold) 55%,var(--gold-deep));
  box-shadow:0 8px 24px rgba(0,0,0,.5),0 0 0 1px rgba(201,162,75,.4);transition:transform .35s var(--ease)}
.dc-launch:hover{transform:scale(1.07)}
.dc-launch svg{width:28px;height:28px;position:absolute;transition:opacity .3s var(--ease),transform .3s var(--ease)}
.dc-ic-close{opacity:0;transform:rotate(-45deg)}
.dvm-chat.open .dc-ic-chat{opacity:0;transform:rotate(45deg)}
.dvm-chat.open .dc-ic-close{opacity:1;transform:none}
.dc-launch::after{content:"";position:absolute;inset:0;border-radius:50%;border:1px solid var(--gold);animation:waPulse 2.6s ease-out infinite}
.dvm-chat.open .dc-launch::after{display:none}
.dc-bubble{position:absolute;left:2px;bottom:72px;white-space:nowrap;background:var(--noir-2);color:var(--champagne);
  border:1px solid var(--line);padding:9px 14px;border-radius:14px 14px 14px 4px;font-size:.82rem;cursor:pointer;
  box-shadow:0 8px 20px rgba(0,0,0,.45);opacity:0;transform:translateY(8px);pointer-events:none;transition:.4s var(--ease)}
.dc-bubble.show{opacity:1;transform:none;pointer-events:auto}
.dc-panel{position:absolute;left:0;bottom:74px;width:362px;max-width:calc(100vw - 40px);height:520px;max-height:calc(100vh - 130px);
  display:flex;flex-direction:column;background:linear-gradient(180deg,var(--noir-2),var(--noir));
  border:1px solid rgba(201,162,75,.32);border-radius:7px;overflow:hidden;
  box-shadow:0 30px 70px rgba(0,0,0,.6);opacity:0;transform:translateY(16px) scale(.98);pointer-events:none;transform-origin:left bottom;transition:.4s var(--ease)}
.dvm-chat.open .dc-panel{opacity:1;transform:none;pointer-events:auto}
.dc-head{display:flex;align-items:center;gap:12px;padding:15px 16px;background:linear-gradient(120deg,var(--oxblood-2),var(--noir-3));border-bottom:1px solid var(--line)}
.dc-av{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;color:var(--noir);background:radial-gradient(circle at 35% 30%,var(--gold-bright),var(--gold-deep));flex:none}
.dc-av svg{width:20px;height:20px}
.dc-ht{display:flex;flex-direction:column;line-height:1.25;flex:1}
.dc-ht strong{font-family:var(--serif);font-size:1.05rem;color:var(--parchment);font-weight:600}
.dc-ht span{font-size:.72rem;color:var(--muted)}
.dc-x{background:none;border:none;color:var(--muted);font-size:1.5rem;cursor:pointer;line-height:1;padding:0 4px}
.dc-x:hover{color:var(--gold-bright)}
.dc-msgs{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}
.dc-msg{max-width:84%;padding:10px 13px;border-radius:14px;font-size:.9rem;line-height:1.5}
.dc-msg.bot{align-self:flex-start;background:rgba(201,162,75,.1);border:1px solid rgba(201,162,75,.2);color:var(--champagne);border-bottom-left-radius:4px}
.dc-msg.bot a{color:var(--gold-bright);text-decoration:underline}
.dc-msg.user{align-self:flex-end;background:linear-gradient(120deg,var(--oxblood),var(--wine));color:var(--parchment);border-bottom-right-radius:4px}
.dc-msg.typing{display:flex;gap:5px;align-items:center}
.dc-msg.typing span{width:7px;height:7px;border-radius:50%;background:var(--gold);opacity:.5;animation:dcTyp 1.2s infinite}
.dc-msg.typing span:nth-child(2){animation-delay:.2s}.dc-msg.typing span:nth-child(3){animation-delay:.4s}
@keyframes dcTyp{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
.dc-cta{align-self:flex-start;display:inline-block;padding:9px 16px;background:linear-gradient(120deg,var(--gold-deep),var(--gold));color:var(--noir);
  font-family:var(--sans);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;text-decoration:none;border-radius:3px;font-weight:600}
.dc-cta:hover{filter:brightness(1.1)}
.dc-chips{display:flex;flex-wrap:wrap;gap:7px;padding:0 16px 12px}
.dc-chip{background:transparent;border:1px solid rgba(201,162,75,.4);color:var(--gold-bright);font-family:var(--sans);font-size:.76rem;padding:7px 12px;border-radius:20px;cursor:pointer;transition:.25s}
.dc-chip:hover{background:rgba(201,162,75,.14);border-color:var(--gold)}
.dc-input{display:flex;gap:8px;padding:12px 14px;border-top:1px solid var(--line);background:var(--noir)}
.dc-input input{flex:1;min-width:0;background:var(--noir-2);border:1px solid var(--line);border-radius:22px;color:var(--parchment);padding:10px 16px;font-family:var(--sans);font-size:.88rem;outline:none}
.dc-input input:focus{border-color:rgba(201,162,75,.55)}
.dc-input button{width:42px;height:42px;border-radius:50%;border:none;cursor:pointer;flex:none;display:grid;place-items:center;color:var(--noir);background:radial-gradient(circle at 35% 30%,var(--gold-bright),var(--gold-deep))}
.dc-input button svg{width:18px;height:18px}
body.menu-open .dvm-chat{opacity:0;pointer-events:none;transition:opacity .3s}
body.chat-open .wa-float{opacity:0;pointer-events:none;transition:opacity .3s}
/* Credit-Link */
.dhs{text-decoration:none;cursor:pointer;transition:filter .3s}
.dhs:hover{filter:brightness(1.15)}
@media(max-width:560px){
  .dvm-chat{left:16px;bottom:16px}
  .dc-launch{width:52px;height:52px}
  .dc-panel{width:calc(100vw - 32px);height:72vh;bottom:66px}
}
