:root{
  --bg:#f4f8f2;
  --bg2:#ffffff;
  --bg3:#eef4eb;
  --surface:#ffffff;
  --p:#86a47c;
  --pl:#a8c49e;
  --pd:#5c7852;
  --pm:rgba(134,164,124,.09);
  --pm2:rgba(134,164,124,.17);
  --tx:#1a2318;
  --ts:#3d5239;
  --tm:#6b8a66;
  --td:#9ab896;
  --bo:rgba(134,164,124,.2);
  --bs:rgba(134,164,124,.38);
  --shadow:0 2px 16px rgba(26,35,24,.06);
  --shadow-m:0 6px 32px rgba(26,35,24,.1);
  --fd:'Cormorant Garamond',Georgia,serif;
  --fb:'DM Sans',system-ui,sans-serif;
  --ease:cubic-bezier(.4,0,.2,1);
  --nav-h:68px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--bg);color:var(--tx);font-family:var(--fb);line-height:1.75;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}p a{color:var(--p);text-decoration:underline}
h1,h2,h3{font-family:var(--fd);font-weight:300;line-height:1.1}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:200;height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;padding:0 3rem;background:rgba(244,248,242,.93);backdrop-filter:blur(20px);border-bottom:1px solid var(--bo);transition:box-shadow .3s var(--ease)}
nav.scrolled{box-shadow:0 2px 20px rgba(26,35,24,.07)}
.nav-logo{display:flex;align-items:center;gap:.7rem}
/*.logo-mark{width:36px;height:36px;border:1.5px solid var(--bs);border-radius:8px;display:flex;align-items:center;justify-content:center;background:var(--bg2)}*/
.logo-mark img{
  width: 44px;
  height: 44px;
  object-fit: contain;
  display: block;
  border-radius: 6px;
}
.logo-mark svg{width:44px;height:32px}
.nav-name{font-family:var(--fd);font-size:1rem;font-weight:400;color:var(--tx);letter-spacing:.02em}
.nav-links{display:flex;align-items:center;gap:2rem;list-style:none}
.nav-links a{font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ts);transition:color .25s;position:relative;padding-bottom:2px}
.nav-links a::after{content:'';position:absolute;bottom:-2px;left:0;right:0;height:1.5px;background:var(--p);transform:scaleX(0);transition:transform .3s var(--ease);transform-origin:left}
.nav-links a:hover{color:var(--p)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-links a.active{color:var(--p)}
.nav-right{display:flex;align-items:center;gap:1rem}
.lang-wrap{display:flex;background:var(--bg3);border:1px solid var(--bo);border-radius:20px;overflow:hidden}
.lb{padding:.26rem .7rem;background:none;border:none;cursor:pointer;font-family:var(--fb);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--tm);transition:all .25s}
.lb.on{background:var(--p);color:#fff;font-weight:500}
.hb{display:none;flex-direction:column;gap:4px;cursor:pointer;background:none;border:none;padding:4px}
.hb span{display:block;width:22px;height:1.5px;background:var(--ts);transition:all .3s}
.hb.open span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.hb.open span:nth-child(2){opacity:0}
.hb.open span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}

/* ── LAYOUT ── */
.page-top{padding-top:calc(var(--nav-h) + 4rem)}
section{padding:5.5rem 3rem}
.cw{max-width:1100px;margin:0 auto}
.cw-sm{max-width:760px;margin:0 auto}

/* ── LABELS & TITLES ── */
.slabel{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--p);margin-bottom:1.4rem;display:flex;align-items:center;gap:1rem}
.slabel::after{content:'';flex:1;height:1px;background:var(--bo)}
.stitle{font-family:var(--fd);font-size:clamp(2.4rem,5vw,3.8rem);font-weight:300;line-height:1.05;color:var(--tx);margin-bottom:2.8rem}
.stitle em{font-style:italic;color:var(--p)}

/* ── HERO ── */
.hero{
  min-height:100svh;
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:4rem;
  align-items:center;
  padding:9rem 3rem 5rem;
  position:relative;
  overflow:hidden;
  background:var(--bg);
}

.hero-photo-wrap{
  position:relative;
  display:flex;
  justify-content:center;
  align-items:center;
}

.hero-photo-frame{
  width:100%;
  max-width:340px;
  aspect-ratio:3/4;
  border-radius:18px;
  overflow:hidden;
  box-shadow:var(--shadow-m);
  margin-left:auto;
}

.hero-photo-frame img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:70% center;
}

.hero-photo-badge{display:none}

.hpb-val{
  font-family:var(--fd);
  font-size:1.1rem;
  color:var(--p);
  line-height:1;
}

.hpb-lab{
  font-size:.7rem;
  text-transform:uppercase;
  color:var(--tm);
}
.hero-bg{position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse at 70% 25%,rgba(134,164,124,.1) 0%,transparent 55%),radial-gradient(ellipse at 20% 80%,rgba(134,164,124,.06) 0%,transparent 55%)}
.hero-line{position:absolute;top:0;bottom:0;right:38%;width:1px;background:linear-gradient(to bottom,transparent,var(--bo) 25%,var(--bo) 75%,transparent);opacity:.5}
.hero-inner{max-width:1100px;margin:0 auto;width:100%;position:relative;z-index:1}
.hero-tag{display:flex;align-items:center;gap:1rem;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--p);margin-bottom:1.8rem}
.hero-tag::before{content:'';width:28px;height:1px;background:var(--p)}
.hero-name{font-family:var(--fd);font-size:clamp(4rem,10vw,9rem);font-weight:300;line-height:.9;color:var(--tx);margin-bottom:1.6rem}
.hero-name em{font-style:italic;color:var(--p);display:block}
.hero-pillars{display:flex;gap:1.5rem;margin-bottom:2.5rem;flex-wrap:wrap}
.hp{display:flex;align-items:center;gap:.5rem;font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ts);cursor:pointer;transition:color .25s}
.hp::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--p);flex-shrink:0}
.hp:hover{color:var(--p)}
.hero-claim{font-family:var(--fd);font-size:clamp(1.3rem,3vw,2rem);font-style:italic;font-weight:300;color:var(--ts);max-width:540px;margin-bottom:1.2rem;line-height:1.4}
.hero-sub{font-size:.92rem;color:var(--tm);max-width:480px;line-height:1.9;font-weight:300;margin-bottom:2.8rem}
.ctas{display:flex;gap:1rem;flex-wrap:wrap}

/* ── BUTTONS ── */
.btn-p{padding:.75rem 1.8rem;background:var(--p);color:#fff;border:none;font-family:var(--fb);font-size:.78rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:background .25s,transform .25s;display:inline-block;border-radius:4px}
.btn-p:hover{background:var(--pd);transform:translateY(-2px)}
.btn-s{padding:.75rem 1.8rem;background:transparent;color:var(--p);border:1.5px solid var(--bs);font-family:var(--fb);font-size:.78rem;font-weight:400;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:all .25s;display:inline-block;border-radius:4px}
.btn-s:hover{background:var(--pm);border-color:var(--p);transform:translateY(-2px)}

/* ── CARDS ── */
.card{background:var(--surface);border:1px solid var(--bo);border-radius:14px;padding:2rem 1.8rem;box-shadow:var(--shadow);transition:box-shadow .3s,border-color .3s,transform .3s}
.card:hover{box-shadow:var(--shadow-m);border-color:var(--bs);transform:translateY(-3px)}

/* ── AREA CARDS (homepage) ── */
.areas{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.area-card{background:var(--surface);border:1px solid var(--bo);border-radius:18px;padding:2.5rem 2rem;box-shadow:var(--shadow);transition:all .35s var(--ease);display:flex;flex-direction:column;position:relative;overflow:hidden}
.area-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--p);transform:scaleX(0);transition:transform .4s var(--ease);transform-origin:left}
.area-card:hover{box-shadow:var(--shadow-m);border-color:var(--bs);transform:translateY(-4px)}
.area-card:hover::before{transform:scaleX(1)}
.area-n{font-family:var(--fd);font-size:3.5rem;font-weight:300;color:var(--bo);line-height:1;margin-bottom:1.2rem}
.area-t{font-family:var(--fd);font-size:1.6rem;font-weight:400;color:var(--tx);margin-bottom:.8rem}
.area-d{font-size:.88rem;color:var(--tm);line-height:1.8;flex:1;margin-bottom:1.5rem;font-weight:300}
.area-link{font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:var(--p);display:inline-flex;align-items:center;gap:.4rem;transition:gap .25s}
.area-link:hover{gap:.8rem}

/* ── TIMELINE ── */
.tl{position:relative;padding-left:2.2rem}
.tl::before{content:'';position:absolute;left:0;top:.5rem;bottom:0;width:1px;background:linear-gradient(to bottom,var(--p) 0%,var(--bo) 70%,transparent 100%)}
.tli{position:relative;padding-bottom:3rem}
.tli:last-child{padding-bottom:0}
.tli::before{content:'';position:absolute;left:-2.2rem;top:.5rem;width:9px;height:9px;border-radius:50%;background:var(--p);transform:translateX(-4px);box-shadow:0 0 12px rgba(134,164,124,.4)}
.tl-date{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--p);margin-bottom:.35rem}
.tl-role{font-family:var(--fd);font-size:1.4rem;font-weight:400;color:var(--tx);margin-bottom:.2rem;display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.tl-co{font-size:.88rem;color:var(--tm);margin-bottom:.6rem;font-weight:300}
.tl-desc{font-size:.88rem;color:var(--ts);line-height:1.8;max-width:580px;font-weight:300}
.badge{font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;padding:.2rem .6rem;background:var(--pm2);color:var(--pd);border:1px solid var(--bs);font-family:var(--fb);border-radius:4px}

/* ── TAGS ── */
.tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.8rem}
.tag{font-size:.67rem;letter-spacing:.08em;text-transform:uppercase;padding:.2rem .55rem;background:var(--pm);color:var(--pd);border:1px solid var(--bo);border-radius:4px}

/* ── MUSIC TABLE ── */
.music-grid{display:flex;flex-direction:column;gap:1px;background:var(--bo);border-radius:12px;overflow:hidden}
.music-row{display:grid;grid-template-columns:2fr 1.5fr 1fr 1fr;gap:1.5rem;padding:1.4rem 1.8rem;background:var(--surface);transition:background .2s;align-items:start}
.music-row:hover{background:var(--pm)}
.music-row.header{background:var(--bg3);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--tm);padding:.9rem 1.8rem}
.mr-main{font-family:var(--fd);font-size:1.1rem;font-weight:400;color:var(--tx)}
.mr-sub{font-size:.82rem;color:var(--tm);margin-top:.15rem}
.role-badge{font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;padding:.22rem .6rem;border-radius:20px;font-family:var(--fb);display:inline-block}
.role-badge.dir{background:rgba(134,164,124,.15);color:#3d6635;border:1px solid rgba(134,164,124,.3)}
.role-badge.mus{background:rgba(80,110,180,.1);color:#3a4e8a;border:1px solid rgba(80,110,180,.2)}
.role-badge.guest{background:rgba(180,140,60,.1);color:#7a5a10;border:1px solid rgba(180,140,60,.2)}

/* ── FILTER PILLS ── */
.filters{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2rem}
.fpill{padding:.35rem .9rem;border-radius:20px;border:1.5px solid var(--bo);background:var(--surface);font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ts);cursor:pointer;transition:all .25s;font-family:var(--fb)}
.fpill:hover,.fpill.on{background:var(--p);color:#fff;border-color:var(--p)}

/* ── MUSIK KARTEN ── */
.musik-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.2rem;margin-top:1rem}
.mcard{background:var(--surface);border:1px solid var(--bo);border-radius:14px;padding:1.6rem 1.8rem;box-shadow:var(--shadow);transition:all .3s var(--ease);display:flex;flex-direction:column;gap:.5rem;position:relative;overflow:hidden}
.mcard::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--p);transform:scaleX(0);transition:transform .4s var(--ease);transform-origin:left}
.mcard:hover{box-shadow:var(--shadow-m);border-color:var(--bs);transform:translateY(-3px)}
.mcard:hover::before{transform:scaleX(1)}
.mcard-role{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;padding:.22rem .65rem;border-radius:20px;font-family:var(--fb);display:inline-block;width:fit-content}
.role-conductor{background:rgba(134,164,124,.15);color:#3d6635;border:1px solid rgba(134,164,124,.3)}
.role-musician{background:rgba(80,110,180,.1);color:#3a4e8a;border:1px solid rgba(80,110,180,.2)}
.role-guest{background:rgba(180,140,60,.1);color:#7a5a10;border:1px solid rgba(180,140,60,.2)}
.role-director{background:rgba(134,164,124,.15);color:#3d6635;border:1px solid rgba(134,164,124,.3)}
.mcard-ensemble{font-family:var(--fd);font-size:1.25rem;font-weight:400;color:var(--tx);line-height:1.2;margin-top:.2rem}
.mcard-meta{font-size:.8rem;color:var(--tm);line-height:1.7;font-weight:300}
.mcard-program{font-size:.84rem;color:var(--ts);line-height:1.8;font-weight:300;margin-top:.3rem;padding-top:.6rem;border-top:1px solid var(--bo)}

/* ── ABOUT ── */
.about-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:4.5rem;align-items:start}
.about-qualities{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.5rem}
.about-body p{color:var(--ts);margin-bottom:1.6rem;font-size:.93rem;line-height:1.9;font-weight:300}
.about-body p strong{color:var(--tx);font-weight:500}
.about-quote{font-family:var(--fd);font-size:1.4rem;font-style:italic;font-weight:300;color:var(--p);line-height:1.45;border-left:2.5px solid var(--p);padding-left:1.4rem;margin:2rem 0}
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.stat-card{background:var(--surface);border:1px solid var(--bo);border-radius:12px;padding:1.5rem 1.3rem;box-shadow:var(--shadow)}
.stat-n{font-family:var(--fd);font-size:2.5rem;font-weight:300;color:var(--p);line-height:1;margin-bottom:.3rem}
.stat-l{font-size:.74rem;letter-spacing:.05em;text-transform:uppercase;color:var(--tm);line-height:1.45}

/* ── NOTONO ── */
.notono-hero{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.notono-logo-wrap{
  background:var(--bg3);
  border:1px solid var(--bo);
  border-radius:20px;
  width:100%;
  max-width:360px;
  aspect-ratio:4/3;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:var(--shadow-m);
  margin-left:5rem;
  margin-top:-7rem;
}
.notono-logo-wrap img{
  width:70%;
  height:auto;
  display:block;
  margin:auto;
}
.notono-facts{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:2rem}
.nf{background:var(--surface);border:1px solid var(--bo);border-radius:10px;padding:1.2rem;box-shadow:var(--shadow)}
.nf-n{font-family:var(--fd);font-size:2rem;font-weight:300;color:var(--p);line-height:1;margin-bottom:.25rem}
.nf-l{font-size:.74rem;letter-spacing:.05em;text-transform:uppercase;color:var(--tm)}

/* Stats (notono-stats) */
.notono-stats{display:flex;gap:1.2rem;margin-top:2rem;flex-wrap:wrap}
.nstat{background:var(--surface);border:1px solid var(--bo);border-radius:12px;padding:1.2rem 1.6rem;box-shadow:var(--shadow);flex:1;min-width:120px}
.nstat-val{font-family:var(--fd);font-size:2.2rem;font-weight:300;color:var(--p);line-height:1;margin-bottom:.3rem}
.nstat-lab{font-size:.74rem;letter-spacing:.05em;text-transform:uppercase;color:var(--tm);line-height:1.4}

/* Qualitäten / Rollen-Karten */
section.green{background:var(--bg3)}
.qual-item{background:var(--surface);border:1px solid var(--bo);border-radius:14px;padding:1.6rem 1.5rem;box-shadow:var(--shadow);transition:all .3s var(--ease)}
.qual-item:hover{box-shadow:var(--shadow-m);border-color:var(--bs);transform:translateY(-2px)}
.qual-icon{font-size:1.4rem;color:var(--p);margin-bottom:.8rem;line-height:1}
.qual-title{font-family:var(--fd);font-size:1.15rem;font-weight:400;color:var(--tx);margin-bottom:.5rem}
.qual-desc{font-size:.84rem;color:var(--tm);line-height:1.8;font-weight:300}

/* ── CONTACT ── */
.contact-inner{text-align:center;max-width:560px;margin:0 auto}
.cemail{font-family:var(--fd);font-size:clamp(1.5rem,3.5vw,2.4rem);color:var(--p);font-style:italic;font-weight:300;transition:color .25s;display:inline-block}
.cemail:hover{color:var(--pd)}
.csub{font-size:.9rem;color:var(--tm);line-height:1.85;margin-bottom:2rem;font-weight:300}
.social-links{display:flex;justify-content:center;gap:2rem;margin-top:1.8rem}
.slink{font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:var(--tm);border-bottom:1px solid var(--bo);padding-bottom:.2rem;transition:all .25s}
.slink:hover{color:var(--p);border-color:var(--p)}

/* ── CONTACT BLOCK ── */
.contact-block{text-align:center;max-width:560px;margin:0 auto;padding:2rem 2rem;background:var(--surface);border:1px solid var(--bo);border-radius:18px;box-shadow:var(--shadow)}
.contact-block .slabel{justify-content:center;margin-bottom:1rem}
.contact-block h2{font-family:var(--fd);font-size:clamp(2rem,4vw,3rem);font-weight:300}
.contact-block h2 em{font-style:italic;color:var(--p)}
.contact-block p{font-size:.92rem;color:var(--tm);line-height:1.85;font-weight:300;margin-top:.8rem}

/* ── CONTACT FORM ── */
.contact-form{width:100%;margin-top:.5rem;text-align:left}
.cf-row{margin-bottom:1rem}
.cf-input{width:100%;padding:.75rem 1rem;background:var(--bg);border:1.5px solid var(--bo);border-radius:8px;font-family:var(--fb);font-size:.88rem;color:var(--tx);transition:border-color .25s;outline:none}
.cf-input:focus{border-color:var(--p)}
.cf-textarea{min-height:140px;resize:vertical}
.cf-submit{width:100%;justify-content:center;margin-top:.5rem}

/* ── IMPRESSUM ── */
.imp-content,.impressum-body{max-width:640px}
.imp-content h3,.impressum-body h3{font-family:var(--fd);font-size:1.15rem;font-weight:400;color:var(--tx);margin:2.2rem 0 .6rem;padding-top:.8rem;border-top:1px solid var(--bo)}
.imp-content h3:first-of-type,.impressum-body h3:first-of-type{border-top:none;padding-top:0}
.imp-content p,.impressum-body p{font-size:.88rem;color:var(--ts);line-height:1.9;margin-bottom:.6rem}
.imp-content a,.impressum-body a{color:var(--p);text-decoration:underline}

/* ── FOOTER ── */
footer{background:var(--bg2);border-top:1px solid var(--bo);padding:1.6rem 3rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.8rem}
.fc{font-size:.76rem;color:var(--td)}
.fl{display:flex;gap:1.5rem}
.fl a{font-size:.76rem;color:var(--td);transition:color .25s}
.fl a:hover{color:var(--p)}

/* ── STATES ── */
.loading{display:flex;justify-content:center;padding:3rem}
.spinner{width:32px;height:32px;border:2px solid var(--bo);border-top-color:var(--p);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.empty{text-align:center;padding:4rem 2rem;color:var(--tm)}
.empty p{font-family:var(--fd);font-size:1.3rem;font-style:italic}

/* ── ANIMATE ── */
.fi{opacity:0;transform:translateY(18px);transition:opacity .65s var(--ease),transform .65s var(--ease)}
.fi.on{opacity:1;transform:translateY(0)}
.fi.d1{transition-delay:.08s}.fi.d2{transition-delay:.16s}.fi.d3{transition-delay:.24s}
.fi.d4{transition-delay:.32s}.fi.d5{transition-delay:.4s}

/* ── RESPONSIVE ── */
@media(max-width:960px){
  nav{padding:0 1.5rem}

  /* FIX 1: Menü-Dropdown mit Hintergrund, damit Text lesbar ist */
  .nav-links{
    display:none;
    position:fixed;
    inset:0;
    top:var(--nav-h);
    background:rgba(244,248,242,.98);
    backdrop-filter:blur(20px);
    -webkit-backdrop-filter:blur(20px);
    flex-direction:column;
    gap:1.5rem;
    align-items:flex-start;
    padding:2.5rem 1.5rem;
    z-index:190;
    border-top:1px solid var(--bo);
    box-shadow:0 8px 32px rgba(26,35,24,.12);
  }
  .nav-links.open{display:flex}
  .nav-links a{font-size:.9rem;padding:.3rem 0}
  .hb{display:flex}

  /* FIX 2: Abstand zwischen Header und erstem Seiteninhalt */
  section{padding:4rem 1.5rem}
  section:first-of-type{padding-top:calc(var(--nav-h) + 2.5rem)}

  .areas{grid-template-columns:1fr}
  .about-grid{grid-template-columns:1fr;gap:3rem}
  .music-row{grid-template-columns:1.5fr 1fr}
  .music-row .col-3,.music-row .col-4,.music-row.header .col-3,.music-row.header .col-4{display:none}
  footer{padding:1.4rem 1.5rem;flex-direction:column;text-align:center}

  /* FIX 4: Button-Abstand wenn sie umbrechen */
  .hero-ctas{display:flex;gap:.75rem;flex-wrap:wrap}
  .ctas{display:flex;gap:.75rem;flex-wrap:wrap}
  .hero-ctas .btn-p,.hero-ctas .btn-s{flex:1;min-width:130px;text-align:center}

  /* FIX 5: Notono – Logo oben via grid-template-areas, Rechteck-Format */
  .notono-hero{
    grid-template-columns:1fr;
    grid-template-areas:"logo" "text";
  }
  .notono-logo-wrap{
    grid-area:logo;
    margin-left:0;
    margin-top:0;
    margin-bottom:1.5rem;
    max-width:280px;
    aspect-ratio:4/3;
    align-self:start;
  }
  .notono-text{
    grid-area:text;
  }

  /* FIX Menü: volle Höhe, damit alle 4 Links sichtbar und scrollbar sind */
  .nav-links{
    bottom:0;
    height:calc(100vh - var(--nav-h));
    overflow-y:auto;
  }
}

@media(max-width:600px){
  .stat-grid{grid-template-columns:1fr 1fr}
  .hero-line{display:none}
  .music-row{grid-template-columns:1fr}
  .music-row.header{display:none}
  .notono-facts{grid-template-columns:1fr 1fr}

  /* FIX 3: Hero – Bild oben, Text darunter */
  .hero{
    grid-template-columns:1fr;
    padding:calc(var(--nav-h) + 2rem) 1.5rem 3rem;
    min-height:auto;
    gap:2rem;
  }
  .hero-photo-wrap{
    order:-1; /* Bild zuerst */
    justify-content:center;
  }
  .hero-photo-frame{
    max-width:130px;
    margin:0 auto;
    aspect-ratio:3/4;
  }
  .hero-text{order:0}
  .hero-name{font-size:clamp(3rem,14vw,5rem)}

  /* FIX 4: Buttons auf Mobile mit Abstand */
  .hero-ctas{gap:.6rem}
  .hero-ctas .btn-p,.hero-ctas .btn-s{
    flex:1 1 100%;
    text-align:center;
    justify-content:center;
  }

  /* FIX 2: Genug Abstand oben auf allen Seiten */
  section:first-of-type{padding-top:calc(var(--nav-h) + 2rem)}

  /* Notono-Logo auf Mobile: klein, oben, linksbündig */
  .notono-logo-wrap{
    max-width:220px;
    aspect-ratio:5/2;
    margin-top:1rem;
    justify-content:center;
    margin-bottom:-2rem;
  }
}
