



/* ==========================================================================
   Author's custom styles
   ========================================================================== */


@import url(../fonts/londrina.css);

   
body {
/*background: #a8d9e7;*/

background: url(../img/content_bg.png) repeat-y left top, url(../img/content_bg2.png) repeat-y right top;
background-color: #80b12d;
background-attachment: fixed;
color: #fff;

font-family: 'Delius', Helvetica, Arial, sans-serif;
font-size: 15px;
}

a:link, a:visited, a:active, a:focus {
    color: #fff;
    
    transition: all 0.3s;
-webkit-transition: all 0.3s; /* Safari */
}

a:focus {
    outline:none;

}


h1,h2,h3,h4,h5,h6 {
font-family: 'londrina_solidregular', cursive;
color: #840059;
font-weight: 400;
}

header {
background: #c9eaf5 url(../img/body_bg.jpg) no-repeat center top;
background-size: 100% 100%;
}

#animationContainer {
height: 450px;
width: 100%;
position: relative;
overflow: hidden;
margin: 0 auto 0 auto;
}

#parallaxContainer, #mobileContainer {
width: 100%;
height: 100%;
margin: 0 auto;
overflow: hidden;
position: relative;

}

.position {
position: absolute;
top: 0;
left: 0;
}



.clouds {
width: 200%;
height: 100%;
background: transparent url(../img/header_clouds.png) repeat-x left 50px;
}

.logo {
width: 100%;
height: 100%;
/*background: transparent url(../img/header_logo.png) no-repeat center 50px;*/
}

a#mina-logo, a#mina-logo-en {
width: 100%;
max-width: 423px;
height: 241px;
display: block;
margin: 10px auto 0 auto;
background: transparent url(../img/header_logo.png) no-repeat center center;
background-size: contain;
}

a#mina-logo-en {
background: transparent url(../img/header_logo_en.png) no-repeat center center;
}



.background {
width: 100%;
height: 100%;
background: transparent url(../img/header_background.png) no-repeat center 110%;

}

.ground {
width: 100%;
height: 100%;
background: transparent url(../img/header_ground.png) no-repeat center bottom;

}

.trees {
width: 100%;
height: 100%;
background: transparent url(../img/header_trees.png) no-repeat center bottom;

}

.augenzwinkern {

    width: 100%;
    height: 100%;
    background: transparent url(../img/zwinkern_animation.gif) no-repeat center bottom;
    position: absolute;

    

    /*left: 50%;
    margin-left: -312px;
    top: 218px;*/

}

#beeContainer {
    position: absolute;

    right: -100px;
    width: 36px;
    height: 120px;
    top: 220px;
    
}

#bee {
    position: absolute;
    background: transparent url(../img/bee_sprite_animation.png) no-repeat left top;
    width: 36px;
    height: 46px;
    left: 0px;
    top: 0px;

}

.appstores {
width: 100%;
height: 200px;
margin-top: 250px;
}

.appstores .row div {
text-align: center;
}

.parallax {
/*left: 50%;*/

background-size: contain;
}


/* animations */
.clouds-ani{
	-webkit-animation: infinite-image 90s linear infinite;
	animation: infinite-image 90s linear infinite;
	
	-webkit-transform: translate3d(0,0,0); transform: translate3d(0,0,0);
}
.trees-ani {
	-webkit-animation: flyCast 10s ease-in-out infinite;   
	animation: flyCast 10s ease-in-out infinite;   
	
	-webkit-transform: translate3d(0,0,0); transform: translate3d(0,0,0);
}

.bee-fly {
    -webkit-animation: infiniteFly 40s linear infinite;
    animation: infiniteFly 40s linear infinite;
	
	-webkit-transform: translate3d(0,0,0); transform: translate3d(0,0,0);
}

/*
@keyframes infinite-image2 {
    0% { left:0; opacity: 0}
    5% { opacity: 1}
    95% {  opacity: 1}
    100% { left: -100%; opacity: 0}
}
*/

@keyframes infinite-image {
    0% { -webkit-transform: translate3d(0,0,0); transform: translate3d(0,0,0); opacity: 0}
    5% { opacity: 1}
    95% {  opacity: 1}
    100% { -webkit-transform: translate3d(-50%,0,0); transform: translate3d(-50%,0,0); opacity: 0}
}

/*
@-webkit-keyframes infinite-image2 {
	0% { left:0; opacity: 0}
	5% { opacity: 1}
	95% {  opacity: 1}
	100% { left: -100%; opacity: 0}
}
*/

@-webkit-keyframes infinite-image {
	0% { -webkit-transform: translate3d(0,0,0); transform: translate3d(0,0,0); opacity: 0}
    5% { opacity: 1}
    95% {  opacity: 1}
    100% { -webkit-transform: translate3d(-50%,0,0); transform: translate3d(-50%,0,0); opacity: 0}
}

@keyframes infiniteFly {
    0% { right:-100px;}
    100% { right: 110%;}
}

@-webkit-keyframes infiniteFly {
     0% { right:-100px;}
    100% { right: 110%;}
}

@keyframes flyCast {
	0% {-webkit-transform: translate(0px, 0px) }
	50% {-webkit-transform: translate(50px, 0px) }
	100% {-webkit-transform: translate(0px, 0px) }
}

@-webkit-keyframes flyCast {
	0% {-webkit-transform: translate(0px, 0px) }
	50% {-webkit-transform: translate(50px, 0px) }
	100% {-webkit-transform: translate(0px, 0px) }
}


/* App Store Buttons */


    .appstoreButton {
        
        background:-webkit-gradient(linear, left top, left bottom, color-stop(0.05, #007dc1), color-stop(1, #0061a7));
        background:-moz-linear-gradient(top, #007dc1 5%, #0061a7 100%);
        background:-webkit-linear-gradient(top, #007dc1 5%, #0061a7 100%);
        background:-o-linear-gradient(top, #007dc1 5%, #0061a7 100%);
        background:-ms-linear-gradient(top, #007dc1 5%, #0061a7 100%);
        background:linear-gradient(to bottom, #007dc1 5%, #0061a7 100%);
        
        background-color:#007dc1;
        
        -moz-border-radius:6px;
        -webkit-border-radius:6px;
        border-radius:6px;
        
       border:1px solid #035b96;
        
        display:inline-block;
        color:#ffffff;
        font-family:arial;
        font-size:20px;
        font-weight:bold;
        padding:6px 12px;
        text-decoration:none;
        
        text-shadow:0px 1px 0px #154682;
        
		text-align: left;
		
		overflow: hidden;
		
		vertical-align: middle;
		
    }
	
	
	
    .appstoreButton:hover, .appstoreButton:focus {
        
        background:-webkit-gradient(linear, left top, left bottom, color-stop(0.05, #0061a7), color-stop(1, #007dc1));
        background:-moz-linear-gradient(top, #0061a7 5%, #007dc1 100%);
        background:-webkit-linear-gradient(top, #0061a7 5%, #007dc1 100%);
        background:-o-linear-gradient(top, #0061a7 5%, #007dc1 100%);
        background:-ms-linear-gradient(top, #0061a7 5%, #007dc1 100%);
        background:linear-gradient(to bottom, #0061a7 5%, #007dc1 100%);
        
        background-color:#0061a7;
		color: #fff;
		
		text-decoration: none;
    }

	
	
	
   
    .googleplayButton {
        
        background:-webkit-gradient(linear, left top, left bottom, color-stop(0.05, #40b800), color-stop(1, #308a00));
        background:-moz-linear-gradient(top, #40b800 5%, #308a00 100%);
        background:-webkit-linear-gradient(top, #40b800 5%, #308a00 100%);
        background:-o-linear-gradient(top, #40b800 5%, #308a00 100%);
        background:-ms-linear-gradient(top, #40b800 5%, #308a00 100%);
        background:linear-gradient(to bottom, #40b800 5%, #308a00 100%);
        
        background-color:#40b800;
        
        -moz-border-radius:6px;
        -webkit-border-radius:6px;
        border-radius:6px;
        
         border:1px solid #349400;
        
        display:inline-block;
        color:#ffffff;
        font-family:arial;
        font-size:20px;
        font-weight:bold;
        padding:6px 12px;
        text-decoration:none;
		
        
        text-shadow:0px 1px 0px #2f6627;
		
		text-align: left;
		
		vertical-align: middle;
        
    }
    .googleplayButton:hover, .googleplayButton:focus {
        
        background:-webkit-gradient(linear, left top, left bottom, color-stop(0.05, #308a00), color-stop(1, #40b800));
        background:-moz-linear-gradient(top, #308a00 5%, #40b800 100%);
        background:-webkit-linear-gradient(top, #308a00 5%, #40b800 100%);
        background:-o-linear-gradient(top, #308a00 5%, #40b800 100%);
        background:-ms-linear-gradient(top, #308a00 5%, #40b800 100%);
        background:linear-gradient(to bottom, #308a00 5%, #40b800 100%);
        
        background-color:#308a00;
		
		color: #fff;
		
		text-decoration: none;
    }

    .appstoreButton, .googleplayButton {
        
        margin: 0 5px 10px 5px;

        transition: all 0.3s;
-webkit-transition: all 0.3s; /* Safari */
    }

	
    .appstoreButton:active, .googleplayButton:active {
        position:relative;
        top:1px;
    }

	

	.appstoreButton img, .appstoreButton span, .googleplayButton img, .googleplayButton span{
	display: inline-block;
	/*float: left;*/
	font-size: 20px;
	line-height: 24px;
	vertical-align: middle;
	}
	
	.appstoreButton span, .googleplayButton span {
	margin-left: 0.5em;
	}
	
	.appstoreButton small, .googleplayButton small {
		display: block;
		font-size: 12px;
		font-weight: normal;
		line-height: 12px;
		
	}


/** BACKGROUND MUSIC PLAYER **/

#backgroundmusic_desktop {
    width: 200px;
    height: 40px;
    position: absolute;
    top: 10px;
    right: 50%;
    margin-right: 23%;
}

#BG_jplayer_container_desktop ul.jp-controls {
    list-style: none;
    margin: 0;
    padding: 0;
}

#BG_jplayer_container_desktop ul.jp-controls li {
    display: inline-block;
}
#BG_jplayer_container_desktop ul.jp-controls li a {
   font-family: 'londrina_solidregular', cursive;
    color: #840059;
    color: rgba(132,0,89,0.5);
    font-size: 24px;
    line-height: 24px;
    padding: 8px;
    display: block;
    text-decoration: none;

    border-radius: 5px;
   
}
#BG_jplayer_container_desktop ul.jp-controls li a:hover {
    color: #840059;
    background-color: rgba(255,255,255,0.6);
}

#BG_jplayer_container_desktop ul.jp-controls li a span {
    font-size: 20px;
    line-height: 20px;
}




/* LANGUAGES */

#languages_desktop {
    width: 200px;
    height: 80px;
    position: absolute;
  
    top: 15px;
    left: 50%;
    margin-left: 24%;
}

#languages_mobile {
    
    padding-bottom: 30px;
}

.languages {
    text-align: center;
}

.languages a {
    display: inline-block;
    text-align: center;
    
    padding: 10px;

    text-decoration: none;

color: #840059;

    transition: all 0.3s;
-webkit-transition: all 0.3s; /* Safari */

border-radius: 5px;
}

.languages a:hover {
    background: #fff;
    background: rgba(255,255,255,0.6);
}

.languages a img {

    transition: all 0.3s;
-webkit-transition: all 0.3s; /* Safari */
}

.languages a span {
    display: block;
    opacity: 0;
    font-size: 20px;
    line-height: 20px;
   
    margin-top: 10px;
    font-family: 'londrina_solidregular', cursive;

        transition: all 0.3s;
-webkit-transition: all 0.3s; /* Safari */
}

.languages a:hover img, .languages a:focus img {
    transform: scale(1.2);
-webkit-transform: scale(1.2);
}

.languages a:hover span, .languages a:focus span {
    opacity: 1;
}

#languages_mobile a {
    color: #fff;
    background: transparent;
}

#languages_mobile a span {
    opacity: 1;
    text-shadow: 1px 1px 1px #000;
}

/** END HEADER **/


/** NAVI **/

nav {
background: #496c10;

background: -moz-radial-gradient(center, ellipse cover,  #608421 0%, #496c10 100%); /* FF3.6+ */
background: -webkit-gradient(radial, center center, 0px, center center, 100%, color-stop(0%,#608421), color-stop(100%,#496c10)); /* Chrome,Safari4+ */
background: -webkit-radial-gradient(center, ellipse cover,  #608421 0%,#496c10 100%); /* Chrome10+,Safari5.1+ */
background: -o-radial-gradient(center, ellipse cover,  #608421 0%,#496c10 100%); /* Opera 12+ */
background: -ms-radial-gradient(center, ellipse cover,  #608421 0%,#496c10 100%); /* IE10+ */
background: radial-gradient(ellipse at center,  #608421 0%,#496c10 100%); /* W3C */


padding: 20px 0 5px 0;
border-bottom: 8px solid #405619;

}

ul#navi {
margin: 0;
list-style: none;
padding: 0;
text-align: center;
}

ul#navi li {
display: inline-block;
margin: 0 5px 15px 5px;
}

ul#navi li a {
font-family: 'londrina_solidregular', cursive;
color: #f2f2ed;
font-size: 20px;
text-decoration: none;
text-shadow: 1px 1px 1px #000;
display: block;
position: relative;
z-index: 10;
padding: 5px 10px;
background-color: #a1690f;
background-image: url(../img/wood-texture.png);

border-radius: 3px;

-webkit-box-shadow:  2px 2px 0px 0px rgba(96, 49, 17, 1), 2px 0px 0px 0px rgba(96,49,17,1), 0px 2px 0px 0px rgba(96,49,17,1);    
box-shadow:  2px 2px 0px 0px rgba(96, 49, 17, 1), 2px 0px 0px 0px rgba(96,49,17,1), 0px 2px 0px 0px rgba(96,49,17,1);

transition: all 0.3s;
-webkit-transition: all 0.3s; /* Safari */


transform: rotate(1deg);
-webkit-transform: rotate(1deg);

}


ul#navi li:nth-child(2n+1) a {
transform: rotate(-1deg);
-webkit-transform: rotate(-1deg);
}


ul#navi li a:hover, ul#navi li a:focus {
transform: scale(1.25) rotate(-5deg);
-webkit-transform: scale(1.25) rotate(-5deg);

color: #fff;

z-index: 20;

text-shadow: 1px 1px 2px #000;

-webkit-box-shadow:  3px 3px 0px 0px rgba(96, 49, 17, 1), 3px 0px 0px 0px rgba(96,49,17,1), 0px 3px 0px 0px rgba(96,49,17,1), 0px 0px 5px rgba(0,0,0,0.5);    
box-shadow:  3px 3px 0px 0px rgba(96, 49, 17, 1), 3px 0px 0px 0px rgba(96,49,17,1), 0px 3px 0px 0px rgba(96,49,17,1), 0px 0px 5px rgba(0,0,0,0.5);
}

ul#navi li:nth-child(2n+1) a:hover, ul#navi li:nth-child(2n+1) a:focus {
transform: scale(1.25) rotate(5deg);
-webkit-transform: scale(1.25) rotate(5deg);
}


/** TOP CONTENT **/

#topcontent {

/*background: #80b12d;*/
color: #fff;
}

#topcontent .container {
    padding-top: 30px;
    padding-bottom: 50px;
   /* background: rgba(0,0,0,0.25);*/
   background: #608421 url(../img/topcontent_lowerBG.png) repeat-x center bottom;
   background-size: contain;
}

#topcontent #intro-img {
    text-align: center;
    margin-bottom: 30px;
    
}

#topcontent #intro-img img {
    display: inline-block;
    
}

#topcontent h1, 
#topcontent h2, 
#topcontent h3, 
#topcontent h4, 
#topcontent h5, 
#topcontent h6,
#content h1, 
#content h2, 
#content h3, 
#content h4, 
#content h5, 
#content h6 {
    color: #fff;
    margin: 0 0 0.6em 0;

    text-shadow: 2px 2px 1px rgba(0,0,0,0.25);
}

#topcontent h2, #content h2 {
    font-size: 2.5em;
    margin-bottom: 10px;
}

#topcontent h2 + *, #content h2 + * {
   margin-top: 20px;
}

#topcontent p.lead {
    
    font-size: 1.2em;
}


#topcontent a:link, #topcontent a:visited, #topcontent a:active, #content a:link, #content a:visited, #content a:active {
    color: #ceff7f;
  
   font-weight: bold;
}

#topcontent a:hover, #content a:hover, #topcontent a:focus, #content a:focus {
    color: #fff;

}

#topcontent p {
    font-size: 110%;
}


/** CONTENT **/


#content {
   /* background: #80b12d;*/
}

#content .container {
    /*background: rgba(0,0,0,0.15);*/
    background: #6c9626;
    padding-top: 30px;
    padding-bottom: 30px;
}




#content section {
    padding-bottom: 30px;
    border-bottom: 5px solid #546d2a;
    margin-bottom: 2em;
}


#content section.text-img, #content section:last-of-type {
    padding-bottom: 0;
    border-bottom: 0;
    margin-bottom: 0;
}

#content section.text-img {
margin-bottom: 1em;
}

/** CD Werbung und Shop **/

#deco_left, #deco_right {
/*
background: red;
*/
}

#amazon-links a[target=_blank], #content .shop-buttons a {

margin: 3px 0;
min-width: 70%;
display: inline-block;
border-radius: 3px;
padding: 6px 10px 6px 50px;
color: #fff;
font-family: 'londrina_solidregular', cursive;
font-weight: normal;
background-color: #7f0057;

font-size: 1.3em;
text-decoration: none;

 -webkit-box-shadow:  2px 2px 0px 0px #520038;    
box-shadow:  2px 2px 0px 0px #520038;

 text-shadow: 1px 1px 1px #000;

}

#content .shop-buttons a {
min-width: 3em;
margin: 0 5px 5px 0;
padding: 10px 13px 10px 60px;
}

#content .shop-buttons a.noicon,
#content .shop-buttons a.shop-noicon {
padding-left: 13px;
}

#content .shop-buttons a.shop-itunes { background: #7f0057 url(../img/apple-icon-32.png) no-repeat 13px center; }
#content .shop-buttons a.shop-gplay { background: #7f0057 url(../img/googleplay-icon-32.png) no-repeat 13px center; }
#content .shop-buttons a.shop-amazon { background: #7f0057 url(../img/amazon-icon-32.png) no-repeat 13px center; }

#amazon-links a[target=_blank] {
background: #7f0057 url(../img/amazon-32.png) no-repeat 6px center;
}

#amazon-links a[target=_blank]:hover, #content .shop-buttons a:hover {
background-color: #A30070;
}


.shop-img {
margin-bottom: 0.75em;
}



/** CHARAKTERE & AUTOREN **/

#content section.character {
    margin-bottom: 20px;
   
}


.portrait-img {
    margin-right: 15px;
    margin-bottom: 0.8em;
}

.portrait-img.character, .portrait-img.sprecher, .portrait-img.author, .portrait-img.illustrator, .portrait-img.komponist {
    float: left;
}

.portrait-img.character {
    max-width: 45%;
}

.portrait-img.sprecher {    
    max-width: 40%;
}
.portrait-img.author {    
    max-width: 45%;
}
.portrait-img.illustrator {    
    max-width: 45%;
}
.portrait-img.komponist {    
    max-width: 45%;
 
}

.portrait-img img {
padding: 10px;
background: #a1690f url(../img/wood-texture.png);

-webkit-box-shadow:  2px 2px 0px 0px rgba(96, 49, 17, 1), 2px 0px 0px 0px rgba(96,49,17,1), 0px 2px 0px 0px rgba(96,49,17,1);    
box-shadow:  2px 2px 0px 0px rgba(96, 49, 17, 1), 2px 0px 0px 0px rgba(96,49,17,1), 0px 2px 0px 0px rgba(96,49,17,1);

}

.portrait-img.character img, .portrait-img.sprecher img, .portrait-img.illustrator img, .portrait-img.komponist img {
    padding: 5px;
}

span.name {
    font-family: 'londrina_solidregular', cursive;
    font-size: 1.2em;
     text-shadow: 1px 1px 1px rgba(0,0,0,0.25);
    line-height: 1em;
}


/** Illustrationen mit Scroll-Effekt **/

#content section.fullwidth {
    
    background-color: transparent;
    margin-bottom: 30px;

    background-size: cover;

    background-position: center top;

    border-bottom: 5px solid #405619;
    border-top: 5px solid #405619;

   

}

#content section.fullwidth.illustration {
    text-align: center;
}

#content section.fullwidth img {
    display: inline-block;
}

#content section.fullwidth .auszeichnung-container {
    width: 100%;
    margin: 0 auto 0 auto;
}



/** Auszeichnungen Komponisten **/

.auszeichnung {
    padding-top: 25px;
    padding-bottom: 25px;

    text-align: center;
    

    background: rgba(0,0,0,0.5);
}




/** Helfer Klassen **/
.alignleft,
img.alignleft {
	display: inline;
	float: left;
  margin-right: 1.5em;
  margin-bottom: 1.5em;
}
.alignright,
img.alignright {
	display: inline;
	float: right;
  margin-left: 1.5em;
  margin-bottom: 1.5em;
}
.aligncenter,
img.aligncenter {
	clear: both;
	display: block;
	margin-left: auto;
	margin-right: auto;
}
/*
p {
     clear: both;
}
*/


/** RESPONSIVE **/

/** Everything very small **/
@media (max-width: 480px) { 

    #trailer-player .trailer-cover {
        display: none !important;
    }
    #trailer-player .trailer-player {
        width: 100%;
    }

    #topcontent .container {
       padding-bottom: 30px;
    }

    

}

/* Small devices (tablets, 768px and up) */
@media (min-width: 768px) { 

    #animationContainer {
    height: 541px;
    }

    a#mina-logo {
        margin-top: 20px;
    }

    .appstores {
    margin-top: 300px;
    }

/*
    #topcontent .container {
        padding-bottom: 0;
    }
    */

    #topcontent .container {
        padding-bottom: 60px;
    }

    #topcontent #intro-img {
        margin-bottom: 10px;
    }

	
	#content .container .row {
	padding-top: 15px;
	padding-bottom: 15px;
	}


    #content section {
        
        padding-top: 0;
        padding-bottom: 0;
        margin-top: 0;
        /*margin-bottom: 0;*/
        border-bottom: 0;
        
    }


    .portrait-img.sprecher {

        max-width: 100%;
        float: none;
        margin-right: 0;

    }

    .portrait-img.character, .portrait-img.sprecher, .portrait-img.author, .portrait-img.illustrator, .portrait-img.komponist {
        max-width: auto;

    }
    .portrait-img.character img, .portrait-img.sprecher img, .portrait-img.author img, .portrait-img.illustrator img, .portrait-img.komponist img {

        padding: 10px;
    }


    #trailer-player .trailer-player {
        width: 100%;
    }
    #trailer-player .jp-title {
        width: 80%;
    }

    footer section {
        border: none;
        padding-top: 0;
    }



}

@media (min-width: 992px) {

    #trailer-player .trailer-player {
        width: 66.666666666666%;
    }

    #topcontent .container {
        padding-bottom: 70px;
    }


    #content section.fullwidth .auszeichnung-container {
        width: 83.33333333333334%;
    }

     .auszeichnung {
        padding-top: 50px;
        padding-bottom: 50px;
    }

}

/** Very large **/

@media (min-width: 1200px) {

    #topcontent .container {
        padding-bottom: 50px;
        background-size: 50%;
    }

}

blockquote {
    border-left: 4px solid #CEFF7F;
}

blockquote p:before { content: ' „ ' ' '; color: #fff; font-family: Georgia, serif; }
blockquote p:after { content: ' ' ' “ '; color: #fff; font-family: Georgia, serif; }

blockquote footer {
    background: transparent;
    -webkit-box-shadow: none;
    box-shadow: none;
}

blockquote cite {
    color: rgba(255,255,255,0.65);
}


/* ==========================================================================
   2026 modernization: replacements for jQuery plugins (look unchanged)
   ========================================================================== */

/* Bee wing-flap: replaces jquery.spritely (4 frames @ 12 fps, horizontal strip 144x46) */
@keyframes bee-wings {
    from { background-position: 0 0; }
    to   { background-position: -144px 0; }
}
#bee {
    animation: bee-wings 0.3333s steps(4) infinite;
}

/* Smooth vertical drift: bee #top is updated by JS every 3.5s with a new random value */
#bee.bee-drift {
    transition: top 3s ease-in-out;
}

/* Mouse parallax: replaces jquery.parallax.
   JS writes --mx/--my (range -1..1) on #parallaxContainer.
   Each .layer.parallax with data-depth gets a horizontal shift scaled by depth. */
#parallaxContainer {
    --mx: 0;
    --my: 0;
    --parallax-range: 30px;
}
.layer.parallax {
    will-change: transform;
    transform: translate3d(calc(var(--mx) * var(--depth, 0) * var(--parallax-range)), 0, 0);
    transition: transform 200ms ease-out;
}
@media (prefers-reduced-motion: reduce) {
    .layer.parallax { transform: none; transition: none; }
    .clouds-ani, .trees-ani, .bee-fly { animation: none; }
}

/* Background-music toggle button: hide whichever is not the current state */
#BG_jplayer_container_desktop[data-state="paused"] .jp-pause,
#BG_jplayer_container_desktop[data-state="playing"] .jp-play {
    display: none;
}

/* Trailer player: same toggle pattern */
#trailer_jp_container_DE[data-state="paused"] .jp-pause,
#trailer_jp_container_DE[data-state="playing"] .jp-play,
#trailer_jp_container_EN[data-state="paused"] .jp-pause,
#trailer_jp_container_EN[data-state="playing"] .jp-play {
    display: none;
}
#trailer_jp_container_DE[data-muted="true"] .jp-mute,
#trailer_jp_container_DE[data-muted="false"] .jp-unmute,
#trailer_jp_container_EN[data-muted="true"] .jp-mute,
#trailer_jp_container_EN[data-muted="false"] .jp-unmute {
    display: none;
}

/* Parallax-based fullwidth backgrounds (komponisten page): replaces skrollr.
   JS writes --bg-pos (0..100) on the section. */
section.fullwidth[data-parallax-bg] {
    background-position: 50% calc(var(--bg-pos, 50) * 1%);
}

/* Skrollr placeholder offset hack is no longer needed */
#skrollr-body { /* keep selector inert if referenced elsewhere */ }


/* ==========================================================================
   Custom audio player (2026)
   Replaces jPlayer markup. Used for the DE + EN trailer players.
   Native <input type="range"> for seek + volume → touch / keyboard / a11y
   support out of the box. accent-color drives the look.
   ========================================================================== */

.audio-player {
    --ap-accent: #A30070;
    --ap-accent-dark: #840059;
    --ap-track: #ede4ea;
    --ap-text: #4a3242;
    --ap-text-soft: #8d7a86;

    display: flex;
    align-items: stretch;
    background: #fff;
    color: var(--ap-text);
    border-radius: 12px;
    box-shadow: 0 6px 20px -8px rgba(132, 0, 89, 0.35), 0 2px 4px rgba(0, 0, 0, 0.06);
    overflow: hidden;
    accent-color: var(--ap-accent);
}

.audio-player .ap-cover {
    flex: 0 0 auto;
    width: 120px;
    background: #f4eef1;
    display: block;
}
.audio-player .ap-cover img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.audio-player .ap-body {
    flex: 1 1 auto;
    min-width: 0;
    padding: 14px 18px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 8px;
}

.audio-player .ap-title {
    font-family: 'londrina_solidregular', cursive;
    font-size: 18px;
    line-height: 1.2;
    color: var(--ap-accent-dark);
    margin: 0;
    text-shadow: none;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.audio-player .ap-controls {
    display: flex;
    align-items: center;
    gap: 12px;
}

.audio-player .ap-toggle {
    flex: 0 0 auto;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    border: 0;
    background: var(--ap-accent-dark);
    color: #fff;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    transition: background 0.18s, transform 0.1s;
}
.audio-player .ap-toggle:hover { background: var(--ap-accent); }
.audio-player .ap-toggle:active { transform: scale(0.95); }
.audio-player .ap-toggle:focus-visible {
    outline: 2px solid var(--ap-accent);
    outline-offset: 2px;
}
.audio-player .ap-toggle svg {
    width: 18px;
    height: 18px;
    fill: currentColor;
}

/* Show only the icon matching the current state */
.audio-player[data-state="paused"]  .ap-icon-pause,
.audio-player[data-state="playing"] .ap-icon-play  { display: none; }

/* Range sliders (seek + volume) — uniform look via accent-color */
.audio-player input[type="range"] {
    -webkit-appearance: none;
    appearance: none;
    background: var(--ap-track);
    border-radius: 999px;
    height: 6px;
    margin: 0;
    padding: 0;
    cursor: pointer;
    accent-color: var(--ap-accent);
}
.audio-player input[type="range"]:focus { outline: none; }
.audio-player input[type="range"]:focus-visible {
    box-shadow: 0 0 0 3px rgba(163, 0, 112, 0.25);
}
/* WebKit thumb */
.audio-player input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--ap-accent);
    border: 2px solid #fff;
    box-shadow: 0 1px 3px rgba(0,0,0,0.25);
    cursor: pointer;
    transition: transform 0.1s;
}
.audio-player input[type="range"]::-webkit-slider-thumb:hover { transform: scale(1.15); }
.audio-player input[type="range"]::-webkit-slider-runnable-track {
    height: 6px;
    border-radius: 999px;
    background: transparent;
}
/* Firefox */
.audio-player input[type="range"]::-moz-range-thumb {
    width: 14px;
    height: 14px;
    border-radius: 50%;
    background: var(--ap-accent);
    border: 2px solid #fff;
    box-shadow: 0 1px 3px rgba(0,0,0,0.25);
    cursor: pointer;
}
.audio-player input[type="range"]::-moz-range-track {
    height: 6px;
    border-radius: 999px;
    background: var(--ap-track);
}
.audio-player input[type="range"]::-moz-range-progress {
    background: var(--ap-accent);
    height: 6px;
    border-radius: 999px;
}

.audio-player .ap-seek {
    flex: 1 1 auto;
    min-width: 0;
}

.audio-player .ap-meta {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    line-height: 1;
    color: var(--ap-text-soft);
    font-variant-numeric: tabular-nums;
}

.audio-player .ap-time {
    color: var(--ap-text-soft);
}
.audio-player .ap-current::after {
    content: "/";
    padding: 0 6px 0 8px;
    opacity: 0.45;
}
.audio-player .ap-mute { margin-left: auto; }

.audio-player .ap-mute {
    flex: 0 0 auto;
    width: 28px;
    height: 28px;
    border: 0;
    background: transparent;
    color: var(--ap-accent-dark);
    cursor: pointer;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 4px;
    transition: background 0.15s;
}
.audio-player .ap-mute:hover { background: var(--ap-track); }
.audio-player .ap-mute svg { width: 20px; height: 20px; fill: currentColor; }
.audio-player[data-muted="true"]  .ap-icon-unmute,
.audio-player[data-muted="false"] .ap-icon-mute   { display: none; }

.audio-player .ap-volume {
    flex: 0 1 80px;
    min-width: 60px;
}

@media (max-width: 600px) {
    .audio-player { flex-direction: column; }
    .audio-player .ap-cover { width: 100%; height: 140px; }
    .audio-player .ap-title { white-space: normal; }
}


/* ==========================================================================
   App showcase home page (2026)
   ========================================================================== */

:root {
    --m-magenta: #840059;
    --m-magenta-bright: #A30070;
    --m-magenta-soft: #FF4DC3;
    --m-green: #80b12d;
    --m-green-dark: #608421;
    --m-green-darker: #496c10;
    --m-sky: #62c7da;
    --m-sky-dark: #217f9a;
    --m-gold: #f3b43f;
    --m-gold-soft: #ffe2a2;
    --m-plum: #4b1740;
    --m-cream: #f9f4e8;
    --m-ink: #2a1a24;
    --m-ink-soft: #5a4452;
    --m-card: #ffffff;
}

body.home-page {
    background: var(--m-cream);
    overflow-x: hidden;
}

body.home-page nav {
    background:
        radial-gradient(ellipse at center, rgba(255, 77, 195, 0.18) 0%, rgba(255, 77, 195, 0) 58%),
        linear-gradient(180deg, #7f0057 0%, #4b1740 100%);
    border-bottom-color: #35102d;
}

body.home-page ul#navi li a {
    background-color: #a1690f;
    box-shadow:
        2px 2px 0 0 rgba(74, 23, 64, 0.75),
        2px 0 0 0 rgba(74, 23, 64, 0.75),
        0 2px 0 0 rgba(74, 23, 64, 0.75);
}

#page-content {
    background: var(--m-cream);
    color: var(--m-ink);
    padding-top: 0;
    padding-bottom: 0;
    box-shadow: none;
}

#page-content,
#page-content * {
    box-sizing: border-box;
}

#page-content .container-wide {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}

#page-content h2 {
    color: #fff;
    font-size: clamp(28px, 4vw, 44px);
    line-height: 1.1;
    margin: 0 0 16px 0;
    text-shadow: 2px 2px 1px rgba(0,0,0,0.18);
}

#page-content h3 {
    color: #fff;
    font-size: clamp(22px, 2.5vw, 28px);
    line-height: 1.15;
    margin: 0 0 10px 0;
    text-shadow: 1px 1px 1px rgba(0,0,0,0.18);
}

#page-content p { font-size: 16px; line-height: 1.55; }
#page-content p.lead { font-size: clamp(17px, 1.6vw, 20px); line-height: 1.5; opacity: 0.95; }

#page-content a:link,
#page-content a:visited { color: #ceff7f; font-weight: bold; }
#page-content a:hover { color: #fff; }

/* Soft reveal-on-scroll */
.reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 0.7s ease-out, transform 0.7s ease-out;
}
.reveal.is-visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
    .reveal { opacity: 1; transform: none; transition: none; }
}

/* --- Section spacing --- */
.page-section { padding: 64px 0; position: relative; }
.page-section + .page-section { padding-top: 0; }
@media (max-width: 720px) {
    .page-section { padding: 48px 0; }
}

/* ============================ HERO ============================ */
.hero {
    padding-top: 68px;
    padding-bottom: 78px;
    position: relative;
    overflow: hidden;
    color: #463043;
    background:
        radial-gradient(ellipse 42% 55% at 78% 50%, rgba(132, 0, 89, 0.16) 0%, rgba(132, 0, 89, 0) 72%),
        radial-gradient(ellipse 42% 52% at 92% 92%, rgba(255, 226, 162, 0.50) 0%, rgba(255, 226, 162, 0) 68%),
        radial-gradient(ellipse 44% 60% at 12% 8%, rgba(255,255,255,0.34) 0%, rgba(255,255,255,0) 72%),
        linear-gradient(135deg, #b9d9dc 0%, #d7e6d3 55%, #f1d594 100%);
}
.hero::before,
.features::before,
.app-awards-section::before,
.mitsing-section::after,
.trailer-poster-section::before,
.press-section::before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    height: 1px;
    background: rgba(255,255,255,0.18);
    pointer-events: none;
}
.hero::after {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 70px;
    background: linear-gradient(180deg, rgba(249,244,232,0) 0%, rgba(249,244,232,0.9) 100%);
    pointer-events: none;
    z-index: 0;
}
.hero .container-wide { position: relative; z-index: 1; }
.hero-inner {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 56px;
    align-items: center;
}
.hero-text,
.hero-visual {
    min-width: 0;
}
@media (max-width: 880px) {
    .hero-inner { grid-template-columns: 1fr; gap: 32px; text-align: center; }
}
.hero-eyebrow {
    display: inline-block;
    background: rgba(255,255,255,0.55);
    color: #6a255c;
    border: 1px solid rgba(255,255,255,0.65);
    padding: 6px 14px;
    border-radius: 999px;
    font-family: 'londrina_solidregular', cursive;
    font-size: 14px;
    letter-spacing: 0.5px;
    margin-bottom: 18px;
    backdrop-filter: blur(4px);
}
.hero-title {
    font-family: 'londrina_solidregular', cursive;
    color: #5f1552;
    font-size: clamp(36px, 6vw, 64px);
    line-height: 1;
    margin: 0 0 18px 0;
    text-shadow: 2px 2px 0 rgba(255,255,255,0.72), 0 4px 14px rgba(132,0,89,0.10);
}
.hero-lead {
    font-size: clamp(17px, 1.8vw, 21px);
    line-height: 1.5;
    margin: 0 0 28px 0;
    max-width: 540px;
    color: #473644;
    opacity: 0.96;
}
@media (max-width: 880px) { .hero-lead { margin-left: auto; margin-right: auto; } }
.hero-ctas {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    align-items: center;
}
@media (max-width: 880px) { .hero-ctas { justify-content: center; } }
@media (max-width: 560px) {
    html,
    body.home-page,
    body.home-page header,
    body.home-page #animationContainer,
    body.home-page #mobileContainer {
        width: 100%;
        max-width: 100vw;
        overflow-x: hidden;
    }
    body.home-page #mobileContainer a#mina-logo,
    body.home-page #mobileContainer a#mina-logo-en {
        width: calc(100vw - 24px);
        max-width: 366px;
        margin-left: auto;
        margin-right: auto;
    }
    #page-content .container-wide,
    #page-content .hero-inner,
    #page-content .features-grid,
    #page-content .laurel-row,
    #page-content .mitsing-showcase,
    #page-content .mitsing-teaser-grid {
        max-width: calc(100vw - 32px);
        margin-left: auto;
        margin-right: auto;
    }
    #page-content .container-wide {
        padding-left: 16px;
        padding-right: 16px;
    }
    #page-content h2,
    #page-content h3,
    #page-content p,
    #page-content .lead,
    #page-content .hero-hint {
        max-width: 100%;
        overflow-wrap: anywhere;
    }
    #page-content .feature-card,
    #page-content .song-teaser,
    #page-content .mitsing-stage,
    #page-content .mitsing-feature-panel {
        max-width: calc(100vw - 32px);
    }
    nav .container,
    nav .row,
    nav [class*="col-"] {
        width: 100%;
        max-width: 100%;
        margin-left: 0;
        margin-right: 0;
        padding-left: 8px;
        padding-right: 8px;
        box-sizing: border-box;
    }
    ul#navi {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 10px 8px;
        max-width: 340px;
        margin-left: auto;
        margin-right: auto;
    }
    ul#navi li {
        margin: 0;
        flex: 0 1 calc(50% - 8px);
        max-width: 160px;
    }
    ul#navi li a {
        font-size: 18px;
        padding: 5px 8px;
        box-sizing: border-box;
        width: 100%;
    }
    .hero {
        padding-top: 44px;
        padding-bottom: 64px;
    }
    .hero-title {
        font-size: 32px;
        max-width: 12ch;
        margin-left: auto;
        margin-right: auto;
    }
    .hero-eyebrow,
    .hero-hint {
        max-width: 300px;
        box-sizing: border-box;
        margin-left: auto;
        margin-right: auto;
    }
    .hero-lead {
        max-width: 100%;
        font-size: 16px;
        overflow-wrap: anywhere;
    }
    .hero-ctas {
        flex-direction: column;
        align-items: center;
    }
    .btn-appstore,
    .btn-secondary {
        max-width: 100%;
        justify-content: center;
    }
    .btn-secondary {
        text-align: center;
    }
}
.hero-hint {
    display: block;
    margin-top: 14px;
    font-size: 14px;
    color: rgba(71,54,68,0.76);
    opacity: 1;
}

/* Modern app-store badge button */
.btn-appstore {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: #111;
    color: #fff !important;
    text-decoration: none !important;
    padding: 13px 22px;
    border-radius: 14px;
    font-family: 'Delius', sans-serif;
    font-weight: 700;
    font-size: 15px;
    box-shadow: 0 10px 28px -10px rgba(0,0,0,0.55), inset 0 1px 0 rgba(255,255,255,0.08);
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.btn-appstore:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 32px -10px rgba(0,0,0,0.65), inset 0 1px 0 rgba(255,255,255,0.12);
    color: #fff !important;
}
.btn-appstore .badge-icon { width: 28px; height: 28px; flex-shrink: 0; }
.btn-appstore .badge-text { display: flex; flex-direction: column; line-height: 1.1; text-align: left; }
.btn-appstore .badge-text small { font-size: 11px; font-weight: 400; opacity: 0.85; }
.btn-appstore .badge-text strong { font-size: 18px; font-family: 'Delius', sans-serif; }

.btn-secondary {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(255,255,255,0.95);
    color: var(--m-magenta) !important;
    text-decoration: none !important;
    padding: 13px 20px;
    border-radius: 14px;
    font-family: 'Delius', sans-serif;
    font-weight: 700;
    font-size: 15px;
    box-shadow: 0 8px 24px -10px rgba(0,0,0,0.35);
    transition: transform 0.15s ease, background 0.15s ease;
}
.btn-secondary:hover { transform: translateY(-2px); background: #fff; color: var(--m-magenta-bright) !important; }
.btn-secondary svg { width: 18px; height: 18px; fill: currentColor; }

/* Hero visual: floating app icon + decorative magic */
.hero-visual {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    aspect-ratio: 1;
    max-width: 370px;
    margin: 0 auto;
}
.hero-visual::before,
.hero-visual::after {
    content: "";
    position: absolute;
    border-radius: 50%;
    z-index: 0;
    pointer-events: none;
}
.hero-visual::before {
    width: 100%; height: 100%;
    background:
        radial-gradient(circle at 50% 55%, rgba(255, 255, 255, 0.56) 0%, rgba(132, 0, 89, 0.14) 34%, transparent 68%);
    filter: blur(26px);
    animation: hero-glow 6s ease-in-out infinite;
}
.hero-visual::after {
    width: 80%; height: 80%;
    top: 8%; left: 12%;
    background: radial-gradient(circle at 30% 30%, rgba(255,255,255,0.45), transparent 60%);
    mix-blend-mode: overlay;
}
@keyframes hero-glow {
    0%, 100% { opacity: 0.85; transform: scale(1); }
    50%      { opacity: 1;    transform: scale(1.04); }
}
.hero-app-icon {
    width: 60%;
    aspect-ratio: 1;
    border-radius: 22%;
    object-fit: cover;
    box-shadow:
        0 22px 42px -20px rgba(0,0,0,0.35),
        0 12px 24px -10px rgba(132,0,89,0.35),
        inset 0 1px 0 rgba(255,255,255,0.35);
    position: relative;
    z-index: 2;
    animation: hero-bob 6s ease-in-out infinite;
}
@keyframes hero-bob {
    0%, 100% { transform: translateY(0) rotate(-1deg); }
    50%      { transform: translateY(-6px) rotate(1deg); }
}
@media (prefers-reduced-motion: reduce) {
    .hero-app-icon, .hero-visual::before { animation: none; }
}

/* Floating sparkle stars around the app icon */
.hero-sparkles {
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 3;
}
.hero-sparkle {
    position: absolute;
    color: #fff;
    opacity: 0;
    animation: sparkle-twinkle 3s ease-in-out infinite;
    filter: drop-shadow(0 0 5px rgba(132, 0, 89, 0.35));
}
.hero-sparkle svg { display: block; width: 100%; height: 100%; }
/* Position + size + delays for individual sparkles */
.hero-sparkle:nth-child(1) { top:  6%; left: 12%; width: 22px; height: 22px; animation-delay: 0s; }
.hero-sparkle:nth-child(2) { top: 18%; left: 78%; width: 28px; height: 28px; animation-delay: 0.6s; }
.hero-sparkle:nth-child(3) { top: 48%; left:  4%; width: 18px; height: 18px; animation-delay: 1.2s; }
.hero-sparkle:nth-child(n+4) { display: none; }
@keyframes sparkle-twinkle {
    0%, 100% { opacity: 0;    transform: scale(0.4) rotate(0deg); }
    40%      { opacity: 1;    transform: scale(1)   rotate(90deg); }
    60%      { opacity: 0.85; transform: scale(0.9) rotate(140deg); }
    80%      { opacity: 0;    transform: scale(0.5) rotate(180deg); }
}
@media (prefers-reduced-motion: reduce) {
    .hero-sparkle { animation: none; opacity: 0.7; transform: scale(1); }
}

/* ============================ FEATURE CARDS ============================ */
.features {
    background:
        radial-gradient(ellipse 38% 64% at 8% 12%, rgba(255, 226, 162, 0.34), transparent 70%),
        linear-gradient(180deg, #fff8df 0%, var(--m-cream) 100%);
    color: var(--m-ink);
    padding-top: 56px;
    padding-bottom: 72px;
}
#page-content .features h2 {
    color: var(--m-magenta);
    text-shadow: none;
}
#page-content .features p.lead {
    color: var(--m-ink-soft);
    opacity: 1;
}
.features-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    margin-top: 36px;
}
@media (max-width: 880px) {
    .features-grid { grid-template-columns: 1fr; }
}
.feature-card {
    background: rgba(255,255,255,0.90);
    border: 1px solid rgba(132,0,89,0.10);
    border-radius: 18px;
    padding: 28px 24px;
    text-align: left;
    backdrop-filter: blur(6px);
    transition: transform 0.2s ease, background 0.2s ease;
    box-shadow: 0 18px 40px -26px rgba(74, 23, 64, 0.55);
}
.feature-card:hover { transform: translateY(-4px); background: #fff; }
.feature-card .feature-icon {
    width: 56px;
    height: 56px;
    border-radius: 14px;
    background: linear-gradient(135deg, var(--m-magenta), var(--m-magenta-bright));
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    margin-bottom: 18px;
    box-shadow: 0 8px 18px -6px rgba(132,0,89,0.5);
}
.feature-card .feature-icon svg { width: 30px; height: 30px; fill: currentColor; }
#page-content .feature-card h3 { font-size: 22px; margin-bottom: 8px; color: var(--m-magenta); text-shadow: none; }
.feature-card p { margin: 0; color: var(--m-ink-soft); }

/* ============================ MITSING SECTION ============================ */
.mitsing-section {
    background:
        linear-gradient(180deg, rgba(82, 24, 70, 0.94) 0%, rgba(75, 23, 64, 0.90) 45%, rgba(40, 41, 79, 0.96) 100%),
        url('../img/mitsing/background.jpg') center/cover no-repeat;
    padding-top: 80px;
    padding-bottom: 80px;
    position: relative;
    overflow: hidden;
    color: #fff;
}
.mitsing-section::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse at 20% 0%, rgba(255, 226, 162, 0.24), transparent 48%),
        radial-gradient(ellipse at 100% 100%, rgba(98, 199, 218, 0.16), transparent 52%);
    pointer-events: none;
}
.mitsing-section > .container-wide { position: relative; }
.mitsing-section .section-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 24px;
    margin-bottom: 36px;
    flex-wrap: wrap;
}
.mitsing-section .section-head .section-intro { flex: 1; min-width: 260px; }
#page-content .mitsing-section p.lead {
    color: rgba(255,255,255,0.88);
    opacity: 1;
}
.badge-new {
    display: inline-block;
    background: linear-gradient(135deg, var(--m-gold-soft), var(--m-gold));
    color: #4b1740;
    padding: 6px 14px;
    border-radius: 999px;
    font-family: 'londrina_solidregular', cursive;
    font-size: 14px;
    letter-spacing: 1px;
    margin-bottom: 14px;
    box-shadow: 0 6px 14px -4px rgba(0,0,0,0.35);
    text-transform: uppercase;
}

.mitsing-showcase {
    display: grid;
    grid-template-columns: minmax(0, 1.45fr) minmax(280px, 0.75fr);
    gap: 24px;
    align-items: stretch;
    max-width: 1120px;
    margin: 0 auto 32px;
}

.mitsing-stage {
    position: relative;
    overflow: hidden;
    min-height: 320px;
    border-radius: 8px;
    box-shadow: 0 26px 54px -28px rgba(0,0,0,0.7);
}

.mitsing-stage img {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 320px;
    object-fit: cover;
}

.mitsing-stage-panel {
    position: absolute;
    left: 18px;
    bottom: 18px;
    width: min(360px, calc(100% - 36px));
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 16px 18px;
    border-radius: 8px;
    background: rgba(255, 252, 244, 0.93);
    color: #4b1740;
    box-shadow: 0 16px 32px -20px rgba(0,0,0,0.55);
}

.mitsing-stage-panel strong {
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    font-size: 26px;
    line-height: 1;
}

.mitsing-stage-panel span {
    font-size: 13px;
    line-height: 1.4;
}

.mitsing-mode-label {
    font-weight: 700;
    color: #8b005f;
    letter-spacing: 0.4px;
}

.mitsing-feature-panel {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 14px;
    border-radius: 8px;
    padding: 28px;
    background:
        linear-gradient(180deg, rgba(255,252,244,0.96), rgba(255,246,225,0.94)),
        url('../img/mitsing/recordings-background.jpg') center/cover;
    color: #493143;
    box-shadow: 0 26px 54px -32px rgba(0,0,0,0.72);
}

#page-content .mitsing-feature-panel h3 {
    color: #7d0055;
    font-size: 30px;
    line-height: 1;
    margin: 0;
    text-shadow: none;
}

.mitsing-feature-panel p {
    margin: 0;
    line-height: 1.55;
    color: #493143;
}

.mitsing-feature-list {
    display: grid;
    gap: 10px;
    list-style: none;
    margin: 4px 0 0;
    padding: 0;
}

.mitsing-feature-list li {
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 700;
    color: #4b1740;
}

.mitsing-feature-list span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    border-radius: 50%;
    flex: 0 0 34px;
    background: #8b005f;
    color: #fff;
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    font-size: 22px;
    line-height: 1;
}

@media (max-width: 920px) {
    .mitsing-showcase {
        grid-template-columns: 1fr;
    }
    .mitsing-feature-panel {
        padding: 24px;
    }
}

.songs-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 22px;
}
@media (max-width: 720px) {
    .songs-grid { grid-template-columns: 1fr; }
}

.song-card {
    background: var(--m-card);
    color: var(--m-ink);
    border-radius: 18px;
    padding: 22px 24px;
    box-shadow: 0 14px 36px -16px rgba(0,0,0,0.5);
    display: flex;
    flex-direction: column;
    gap: 14px;
}
.song-card.locked { opacity: 0.92; }
.song-card .song-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
}
.song-card .song-title {
    font-family: 'londrina_solidregular', cursive;
    color: var(--m-magenta);
    font-size: 24px;
    line-height: 1.1;
    margin: 0 0 4px 0;
}
.song-card .song-subtitle {
    color: var(--m-ink-soft);
    font-size: 13px;
    margin: 0;
}
.song-card .song-flags {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 6px;
}
.tag-free, .tag-locked {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 999px;
    font-family: 'londrina_solidregular', cursive;
    font-size: 12px;
    letter-spacing: 0.4px;
}
.tag-free   { background: #d9f3a6; color: #3d6a00; }
.tag-locked { background: #f1e6ec; color: var(--m-magenta); }

.karaoke-mode {
    display: inline-flex;
    background: #f4ecf2;
    border-radius: 999px;
    padding: 3px;
    gap: 3px;
}
.karaoke-mode label {
    cursor: pointer;
    padding: 6px 12px;
    border-radius: 999px;
    font-size: 12px;
    font-weight: 600;
    color: var(--m-ink-soft);
    transition: background 0.15s, color 0.15s;
}
.karaoke-mode input[type="radio"] {
    position: absolute;
    width: 1px; height: 1px; opacity: 0; pointer-events: none;
}
.karaoke-mode input[type="radio"]:checked + label {
    background: var(--m-magenta);
    color: #fff;
    box-shadow: 0 2px 8px -2px rgba(132,0,89,0.6);
}
.karaoke-mode input[type="radio"]:focus-visible + label {
    outline: 2px solid var(--m-magenta-bright);
    outline-offset: 2px;
}

.song-card .lyrics-preview {
    background: #faf3e9;
    color: var(--m-ink);
    border-left: 4px solid var(--m-magenta-soft);
    border-radius: 8px;
    padding: 12px 14px;
    font-family: 'Delius', sans-serif;
    font-size: 14px;
    line-height: 1.55;
    white-space: pre-line;
    margin: 0;
    max-height: 130px;
    overflow: hidden;
    position: relative;
}
.song-card .lyrics-preview::after {
    content: "";
    position: absolute;
    inset: auto 0 0 0;
    height: 36px;
    background: linear-gradient(to bottom, rgba(250,243,233,0), #faf3e9);
}

.song-card .song-locked-cta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 10px;
    background: #f7eff4;
    border-radius: 10px;
    padding: 10px 14px;
    font-size: 13px;
    color: var(--m-magenta);
}
.song-card .song-locked-cta svg { width: 18px; height: 18px; fill: currentColor; flex-shrink: 0; }

/* Reuse .audio-player styles but tweak for embed inside song-card */
.song-card .audio-player {
    box-shadow: none;
    border: 1px solid rgba(0,0,0,0.06);
    border-radius: 14px;
}
.song-card .audio-player .ap-body { padding: 12px 14px; }
.song-card .audio-player .ap-cover { display: none; }
.song-card .audio-player .ap-title { display: none; }

/* ============================ TRAILER SECTION ============================ */
.trailer-section {
    background: linear-gradient(180deg, #496c10 0%, #405619 100%);
    padding-top: 72px;
    padding-bottom: 72px;
}
.trailer-section .trailer-wrap {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    align-items: center;
}
@media (max-width: 880px) {
    .trailer-section .trailer-wrap { grid-template-columns: 1fr; }
}

/* ============================ CAST ============================ */
.cast-section {
    background: linear-gradient(180deg, #405619 0%, #2f4111 100%);
    padding-top: 72px;
    padding-bottom: 72px;
}
.cast-section .section-head { margin-bottom: 36px; text-align: center; }
.cast-section .section-head h2 { margin: 0 auto 14px auto; }
.cast-section .section-head p  { max-width: 640px; margin: 0 auto; }

.cast-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 18px;
}
.cast-card {
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.14);
    border-radius: 14px;
    overflow: hidden;
    text-align: center;
    transition: transform 0.2s ease, background 0.2s ease;
}
.cast-card:hover { transform: translateY(-4px); background: rgba(255,255,255,0.14); }
.cast-card img { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; }
.cast-card .cast-meta { padding: 12px 14px; }
.cast-card .cast-meta strong { display: block; font-family: 'londrina_solidregular', cursive; font-size: 17px; color: #fff; }
.cast-card .cast-meta span { display: block; font-size: 13px; color: rgba(255,255,255,0.75); margin-top: 2px; }

/* ============================ PRESS QUOTES ============================ */
.press-section {
    background:
        radial-gradient(ellipse 50% 70% at 90% 5%, rgba(255, 77, 195, 0.20), transparent 70%),
        linear-gradient(180deg, #fff2c7 0%, #f8e4a9 100%);
    padding-top: 72px;
    padding-bottom: 72px;
    color: var(--m-ink);
}
.press-section .section-head { text-align: center; margin-bottom: 36px; }
#page-content .press-section .section-head h2 {
    color: var(--m-magenta);
    text-shadow: none;
}
#page-content .press-section .section-head p.lead {
    color: var(--m-ink-soft);
    opacity: 1;
}
.press-grid {
    columns: 2;
    column-gap: 22px;
}
@media (max-width: 720px) { .press-grid { columns: 1; } }
.press-quote {
    break-inside: avoid;
    background: rgba(255,255,255,0.74);
    border: 1px solid rgba(132,0,89,0.12);
    border-left: 4px solid var(--m-magenta-soft);
    border-radius: 14px;
    padding: 18px 22px;
    margin: 0 0 22px 0;
    color: var(--m-ink);
    font-size: 16px;
    line-height: 1.55;
    box-shadow: 0 14px 34px -24px rgba(74, 23, 64, 0.55);
}
.press-quote p { margin: 0 0 10px 0; font-style: italic; }
.press-quote p::before { content: "„"; color: var(--m-magenta-soft); margin-right: 2px; }
.press-quote p::after  { content: "“"; color: var(--m-magenta-soft); margin-left: 2px; }
.press-quote cite { font-style: normal; font-size: 13px; color: var(--m-ink-soft); }

/* ============================ FINAL CTA ============================ */
.cta-final {
    background:
        radial-gradient(ellipse 50% 100% at 50% 0%, rgba(255, 226, 162, 0.18), transparent 70%),
        linear-gradient(180deg, #4b1740 0%, #35102d 100%);
    padding: 80px 0;
    text-align: center;
    color: #fff;
}
.cta-final h2 {
    font-size: clamp(32px, 5vw, 52px);
    line-height: 1;
    margin: 0 0 16px 0;
    color: #fff;
    text-shadow: 2px 2px 0 rgba(0,0,0,0.18);
}
.cta-final p.lead { color: rgba(255,255,255,0.92); margin: 0 auto 28px auto; max-width: 540px; }
.cta-final .btn-appstore { transform: scale(1.1); }
.cta-final .btn-appstore:hover { transform: scale(1.12) translateY(-2px); }
.cta-final .awards {
    margin-top: 44px;
    max-width: 720px;
    width: 100%;
    height: auto;
    opacity: 0.9;
}
.btn-download-white {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    background: #fff;
    color: var(--m-magenta) !important;
    text-decoration: none !important;
    font-family: 'Delius', sans-serif;
    font-size: 15px;
    font-weight: 700;
    padding: 13px 22px;
    border-radius: 14px;
    box-shadow:
        0 14px 30px -14px rgba(0,0,0,0.70),
        inset 0 1px 0 rgba(255,255,255,0.85);
    transition: transform 0.15s ease, box-shadow 0.15s ease, color 0.15s ease;
}
.btn-download-white:hover,
.btn-download-white:focus {
    color: var(--m-magenta-bright) !important;
    transform: translateY(-2px);
    box-shadow:
        0 18px 34px -14px rgba(0,0,0,0.78),
        inset 0 1px 0 rgba(255,255,255,0.95);
}
.btn-download-white svg {
    width: 18px;
    height: 18px;
    fill: currentColor;
    flex-shrink: 0;
}


/* ==========================================================================
   Site footer (2026)
   ========================================================================== */

.site-footer {
    background:
        radial-gradient(ellipse 80% 60% at 50% 0%, rgba(255, 255, 255, 0.06), transparent 60%),
        linear-gradient(180deg, #6c004a 0%, #4a0034 100%);
    color: rgba(255, 255, 255, 0.92);
    padding: 56px 0 32px;
    box-shadow: inset 0 8px 18px -10px rgba(0, 0, 0, 0.55);
}

.site-footer a:link,
.site-footer a:visited {
    color: var(--m-magenta-soft);
    text-decoration: none;
    font-weight: 600;
    transition: color 0.2s ease;
}
.site-footer a:hover,
.site-footer a:focus {
    color: #fff;
}

.site-footer .container-wide {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 24px;
}

.footer-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
    flex-wrap: wrap;
    padding-bottom: 28px;
    margin-bottom: 24px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.footer-brand {
    display: flex;
    align-items: center;
    gap: 16px;
}

.footer-icon {
    width: 56px;
    height: 56px;
    border-radius: 14px;
    flex-shrink: 0;
    box-shadow:
        0 6px 14px -4px rgba(0, 0, 0, 0.5),
        inset 0 1px 0 rgba(255, 255, 255, 0.25);
}

.footer-brand-text strong {
    display: block;
    font-family: 'londrina_solidregular', cursive;
    font-size: 22px;
    line-height: 1.1;
    color: #fff;
    letter-spacing: 0.3px;
}
.footer-brand-text span {
    display: block;
    font-size: 14px;
    color: rgba(255, 255, 255, 0.72);
    margin-top: 4px;
}

.footer-cta .btn-appstore {
    padding: 11px 18px;
    border-radius: 12px;
}
.footer-cta .btn-appstore .badge-text strong { font-size: 16px; }

.footer-bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 14px;
    font-size: 13px;
    color: rgba(255, 255, 255, 0.65);
}

.footer-rights {
    margin: 0;
    color: rgba(255, 255, 255, 0.65);
}

.footer-links {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 22px;
    align-items: center;
}
.footer-links li {
    position: relative;
    font-size: 13px;
    color: rgba(255, 255, 255, 0.65);
}
.footer-links li + li::before {
    content: "·";
    position: absolute;
    left: -13px;
    color: rgba(255, 255, 255, 0.3);
}

@media (max-width: 720px) {
    .site-footer { padding: 44px 0 28px; }
    .footer-top, .footer-bottom {
        flex-direction: column;
        align-items: flex-start;
    }
    .footer-cta { width: 100%; }
    .footer-brand { width: 100%; }
}


/* ==========================================================================
   Press section: prominent star quotes (Joko + Stefan) + regular grid below
   ========================================================================== */

.press-stars {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 22px;
    margin-bottom: 36px;
}
@media (max-width: 720px) {
    .press-stars { grid-template-columns: 1fr; }
}

.press-star-card {
    background: rgba(255,255,255,0.82);
    border: 1px solid rgba(132,0,89,0.12);
    border-radius: 18px;
    padding: 28px 28px 24px;
    position: relative;
    overflow: hidden;
    transition: transform 0.2s ease, background 0.2s ease;
    box-shadow: 0 16px 38px -26px rgba(74, 23, 64, 0.58);
}
.press-star-card:hover {
    transform: translateY(-3px);
    background: #fff;
}
.press-star-card::before {
    content: "\201E"; /* „ */
    position: absolute;
    top: -10px;
    left: 16px;
    font-family: Georgia, 'Times New Roman', serif;
    font-size: 120px;
    line-height: 1;
    color: var(--m-magenta-soft);
    opacity: 0.6;
    pointer-events: none;
}

.press-star-quote {
    font-family: 'londrina_solidregular', cursive;
    font-size: clamp(20px, 2.2vw, 26px);
    line-height: 1.25;
    color: var(--m-magenta);
    margin: 0 0 22px 0;
    text-shadow: none;
    position: relative;
    z-index: 1;
}

.press-star-author {
    display: flex;
    align-items: center;
    gap: 14px;
}
.press-star-avatar {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    object-fit: cover;
    background: linear-gradient(135deg, var(--m-magenta), var(--m-magenta-bright));
    border: 2px solid rgba(255,255,255,0.2);
    box-shadow: 0 6px 14px -4px rgba(0,0,0,0.4);
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-family: 'londrina_solidregular', cursive;
    font-size: 24px;
    line-height: 1;
}
.press-star-meta {
    display: flex;
    flex-direction: column;
    line-height: 1.25;
}
.press-star-meta strong {
    font-family: 'londrina_solidregular', cursive;
    font-size: 20px;
    color: var(--m-magenta);
    letter-spacing: 0.2px;
}
.press-star-meta span {
    font-size: 13px;
    color: var(--m-ink-soft);
    margin-top: 2px;
}

/* Educational recommendation block (Ohrenspitzer / Stiftung MKFS) */
.press-recommendation {
    background: linear-gradient(135deg, rgba(255,255,255,0.10), rgba(255,255,255,0.04));
    border: 1px solid rgba(255,255,255,0.18);
    border-left: 4px solid #ceff7f;
    border-radius: 18px;
    padding: 28px 32px;
    margin: 0 0 36px 0;
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 24px;
    align-items: center;
    transition: background 0.2s ease, transform 0.2s ease;
}
.press-recommendation:hover {
    background: linear-gradient(135deg, rgba(255,255,255,0.14), rgba(255,255,255,0.06));
    transform: translateY(-2px);
}
@media (max-width: 720px) {
    .press-recommendation {
        grid-template-columns: 1fr;
        text-align: center;
        padding: 24px 22px;
    }
}

.recommendation-seal {
    width: 84px;
    height: 84px;
    border-radius: 50%;
    background: linear-gradient(135deg, #ceff7f, #80b12d);
    color: #2a4a0e;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 10px 24px -6px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.5);
    font-family: 'londrina_solidregular', cursive;
    line-height: 1;
    flex-shrink: 0;
}
.recommendation-seal svg { width: 44px; height: 44px; fill: currentColor; }
@media (max-width: 720px) {
    .recommendation-seal { margin: 0 auto; }
}

.recommendation-body .recommendation-label {
    display: inline-block;
    font-family: 'londrina_solidregular', cursive;
    font-size: 13px;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    background: rgba(206, 255, 127, 0.18);
    color: #ceff7f;
    padding: 4px 12px;
    border-radius: 999px;
    margin-bottom: 12px;
}
.recommendation-body blockquote {
    font-family: 'londrina_solidregular', cursive;
    font-size: clamp(18px, 2vw, 22px);
    line-height: 1.3;
    color: #fff;
    margin: 0 0 12px 0;
    text-shadow: 1px 1px 1px rgba(0,0,0,0.18);
}
.recommendation-body cite {
    display: block;
    font-style: normal;
    font-size: 13px;
    color: rgba(255,255,255,0.7);
    line-height: 1.5;
}
.recommendation-body cite strong { color: #fff; font-weight: 600; }
.recommendation-body cite a:link,
.recommendation-body cite a:visited {
    color: #ceff7f;
    text-decoration: none;
    border-bottom: 1px dotted rgba(206, 255, 127, 0.5);
}
.recommendation-body cite a:hover { color: #fff; border-bottom-color: #fff; }

.press-also {
    margin: 32px auto 0;
    max-width: 720px;
    text-align: center;
    font-size: 14px;
    color: var(--m-ink-soft);
    line-height: 1.55;
}
#page-content .press-section a:link,
#page-content .press-section a:visited {
    color: var(--m-magenta);
    border-bottom: 1px dotted rgba(132, 0, 89, 0.35);
    text-decoration: none;
}
#page-content .press-section a:hover,
#page-content .press-section a:focus {
    color: var(--m-magenta-bright);
    border-bottom-color: var(--m-magenta-bright);
}


/* ==========================================================================
   Homepage: prominent Ohrenspitzer / school feature block
   ========================================================================== */

.school-feature-section {
    background:
        radial-gradient(ellipse 70% 50% at 50% 0%, rgba(206,255,127,0.18), transparent 60%),
        linear-gradient(180deg, #496c10 0%, #3d5a0c 100%);
    padding: 80px 0;
    position: relative;
    overflow: hidden;
}
.school-feature-section::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse at 90% 30%, rgba(255,255,255,0.06), transparent 50%),
        radial-gradient(ellipse at 0% 80%, rgba(206,255,127,0.10), transparent 50%);
    pointer-events: none;
}
.school-feature-section > .container-wide { position: relative; }

.school-feature {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 36px;
    align-items: center;
    background: linear-gradient(135deg, rgba(255,255,255,0.10), rgba(255,255,255,0.04));
    border: 1px solid rgba(206,255,127,0.25);
    border-radius: 22px;
    padding: 40px 44px;
    box-shadow: 0 24px 60px -20px rgba(0,0,0,0.4);
}
@media (max-width: 880px) {
    .school-feature {
        grid-template-columns: 1fr;
        gap: 24px;
        padding: 32px 24px;
        text-align: center;
    }
}

.school-feature .school-seal {
    width: 130px;
    height: 130px;
    border-radius: 50%;
    background: linear-gradient(135deg, #ceff7f, #80b12d 60%, #6c9626);
    color: #2a4a0e;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow:
        0 16px 36px -8px rgba(0,0,0,0.45),
        inset 0 2px 0 rgba(255,255,255,0.45),
        0 0 0 6px rgba(206,255,127,0.15);
    flex-shrink: 0;
    margin: 0 auto;
}
.school-feature .school-seal svg { width: 70px; height: 70px; fill: currentColor; }

.school-feature-body .school-eyebrow {
    display: inline-block;
    font-family: 'londrina_solidregular', cursive;
    font-size: 13px;
    letter-spacing: 1.8px;
    text-transform: uppercase;
    background: rgba(206, 255, 127, 0.20);
    color: #ceff7f;
    padding: 5px 14px;
    border-radius: 999px;
    margin-bottom: 14px;
}

.school-feature-body h2 {
    color: #fff;
    font-size: clamp(28px, 3.4vw, 38px);
    line-height: 1.1;
    margin: 0 0 14px 0;
    text-shadow: 2px 2px 0 rgba(0,0,0,0.18);
}

.school-feature-body blockquote {
    font-family: 'londrina_solidregular', cursive;
    color: #fff;
    font-size: clamp(18px, 2vw, 22px);
    line-height: 1.3;
    margin: 0 0 16px 0;
    border: 0;
    padding: 0;
}
.school-feature-body blockquote p { margin: 0; }
.school-feature-body blockquote::before { content: "„"; color: #ceff7f; margin-right: 2px; }
.school-feature-body blockquote::after  { content: "“"; color: #ceff7f; margin-left: 2px; }

.school-feature-body cite {
    display: block;
    font-style: normal;
    font-size: 14px;
    color: rgba(255,255,255,0.72);
    margin-bottom: 22px;
}
.school-feature-body cite strong { color: #fff; }

.school-feature-cta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
}
@media (max-width: 880px) { .school-feature-cta { justify-content: center; } }

.btn-school {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: linear-gradient(135deg, #ceff7f, #a4d955);
    color: #2a4a0e !important;
    text-decoration: none !important;
    padding: 13px 22px;
    border-radius: 14px;
    font-family: 'Delius', sans-serif;
    font-weight: 700;
    font-size: 15px;
    box-shadow: 0 10px 24px -8px rgba(0,0,0,0.4);
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.btn-school:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 28px -8px rgba(0,0,0,0.5);
    color: #2a4a0e !important;
}
.btn-school svg { width: 18px; height: 18px; fill: currentColor; }

.btn-pdf {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #ceff7f !important;
    text-decoration: none !important;
    font-size: 14px;
    font-weight: 600;
    border-bottom: 1px dotted rgba(206, 255, 127, 0.5);
    padding-bottom: 1px;
    transition: color 0.15s, border-color 0.15s;
}
.btn-pdf:hover { color: #fff !important; border-bottom-color: #fff; }
.btn-pdf svg { width: 16px; height: 16px; fill: currentColor; }


/* ==========================================================================
   School / classroom page (schule.html, en/schools.html)
   ========================================================================== */

.school-hero {
    background:
        radial-gradient(ellipse 70% 60% at 50% 0%, rgba(206,255,127,0.25), transparent 60%),
        linear-gradient(180deg, #6c9626 0%, #496c10 100%);
    padding: 88px 0 64px;
    text-align: center;
    color: #fff;
}
.school-hero .hero-eyebrow {
    background: rgba(206,255,127,0.20);
    color: #ceff7f;
    border-color: rgba(206,255,127,0.4);
}
.school-hero h1 {
    font-family: 'londrina_solidregular', cursive;
    color: #fff;
    font-size: clamp(36px, 5.5vw, 60px);
    line-height: 1;
    margin: 0 0 18px 0;
    text-shadow: 3px 3px 0 rgba(0,0,0,0.25);
}
.school-hero p.lead {
    max-width: 700px;
    margin: 0 auto 28px;
    font-size: clamp(17px, 1.7vw, 20px);
    color: rgba(255,255,255,0.95);
}

.school-quote {
    background: linear-gradient(135deg, rgba(255,255,255,0.10), rgba(255,255,255,0.04));
    border: 1px solid rgba(206,255,127,0.25);
    border-radius: 22px;
    padding: 56px 56px 44px;
    margin: 0 auto;
    max-width: 980px;
    position: relative;
    text-align: left;
}
@media (max-width: 720px) {
    .school-quote { padding: 44px 28px 32px; }
}
.school-quote::before {
    content: "„";
    position: absolute;
    top: -32px;
    left: 28px;
    font-family: Georgia, serif;
    font-size: 180px;
    line-height: 1;
    color: #ceff7f;
    opacity: 0.6;
}
.school-quote blockquote {
    font-family: 'londrina_solidregular', cursive;
    color: #fff;
    font-size: clamp(24px, 3.2vw, 38px);
    line-height: 1.25;
    margin: 0 0 22px 0;
    border: 0;
    padding: 0;
    position: relative;
    z-index: 1;
    text-shadow: 1px 1px 1px rgba(0,0,0,0.18);
}
.school-quote blockquote p {
    margin: 0;
    font-family: inherit;
    font-size: inherit;
    line-height: inherit;
    color: inherit;
}
.school-quote cite {
    display: block;
    font-style: normal;
    font-size: 15px;
    color: rgba(255,255,255,0.78);
    line-height: 1.55;
}
.school-quote cite strong { color: #fff; }

/* Key-facts grid */
.school-facts {
    background:
        radial-gradient(ellipse 60% 80% at 50% 0%, rgba(255,255,255,0.06), transparent 60%),
        linear-gradient(180deg, #496c10 0%, #405619 100%);
    padding: 64px 0 72px;
}
.facts-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
    margin-top: 32px;
}
@media (max-width: 880px) {
    .facts-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
    .facts-grid { grid-template-columns: 1fr; }
}
.fact-card {
    background: rgba(255,255,255,0.07);
    border: 1px solid rgba(255,255,255,0.14);
    border-radius: 14px;
    padding: 22px 20px;
    text-align: left;
    transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}
.fact-card:hover {
    transform: translateY(-3px);
    background: rgba(255,255,255,0.12);
    border-color: rgba(255, 77, 195, 0.3);
}
.fact-card .fact-icon {
    width: 44px;
    height: 44px;
    border-radius: 12px;
    background: linear-gradient(135deg, var(--m-magenta-bright, #A30070), var(--m-magenta, #840059));
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 14px;
    box-shadow: 0 8px 18px -4px rgba(132, 0, 89, 0.55), inset 0 1px 0 rgba(255,255,255,0.2);
}
.fact-card .fact-icon svg { width: 24px; height: 24px; fill: currentColor; }
.fact-card .fact-label {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: rgba(255,255,255,0.7);
    margin: 0 0 4px;
}
.fact-card .fact-value {
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    font-size: 19px;
    color: #fff;
    line-height: 1.2;
    margin: 0;
    text-shadow: 1px 1px 0 rgba(0,0,0,0.18);
}

/* Exercises section */
.school-exercises { background: linear-gradient(180deg, #405619 0%, #2f4111 100%); padding: 72px 0; }
.school-exercises .section-head { text-align: center; margin-bottom: 36px; }

.exercise-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
}
@media (max-width: 880px) {
    .exercise-grid { grid-template-columns: 1fr; }
}
.exercise-card {
    background: rgba(255,255,255,0.07);
    border: 1px solid rgba(255,255,255,0.14);
    border-radius: 16px;
    padding: 24px 22px;
    transition: transform 0.2s ease, background 0.2s ease;
}
.exercise-card:hover { transform: translateY(-3px); background: rgba(255,255,255,0.12); }
.exercise-card .ex-number {
    display: inline-block;
    background: linear-gradient(135deg, #ceff7f, #80b12d);
    color: #2a4a0e;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    font-family: 'londrina_solidregular', cursive;
    font-size: 18px;
    line-height: 36px;
    text-align: center;
    margin-bottom: 14px;
}
.exercise-card h3 { font-family: 'londrina_solidregular', cursive; color: #fff; font-size: 22px; margin: 0 0 6px; }
.exercise-card .ex-meta { font-size: 13px; color: rgba(255,255,255,0.6); margin: 0 0 14px; }
.exercise-card p { margin: 0; color: rgba(255,255,255,0.9); }

/* Trust strip (logos / supporters) */
.school-trust {
    background: linear-gradient(180deg, #2f4111 0%, #1f2c0b 100%);
    padding: 56px 0;
    text-align: center;
}
.school-trust h2 { color: #fff; margin-bottom: 14px; }
.school-trust p.lead { max-width: 640px; margin: 0 auto 28px; color: rgba(255,255,255,0.85); }
.trust-logos {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: stretch;
    gap: 18px;
    margin-top: 28px;
}
.trust-logo {
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.18);
    border-radius: 12px;
    padding: 22px 28px;
    min-width: 200px;
    min-height: 120px;
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 10px;
    transition: background 0.2s, transform 0.2s, border-color 0.2s;
}
.trust-logo:hover {
    background: rgba(255,255,255,0.14);
    border-color: rgba(255,255,255,0.3);
    transform: translateY(-2px);
}
.trust-logo img {
    width: auto;
    height: 50px;
    max-width: 220px;
    /* Force all logos to pure white regardless of source color */
    filter: brightness(0) invert(1);
    opacity: 0.92;
    transition: opacity 0.2s;
}
.trust-logo:hover img { opacity: 1; }
.trust-logo span {
    display: block;
    font-size: 11px;
    line-height: 1.3;
    color: rgba(255,255,255,0.6);
    text-align: center;
    font-family: 'Delius', sans-serif;
    letter-spacing: 0;
    max-width: 200px;
}
.press-also a:link,
.press-also a:visited {
    color: var(--m-magenta-soft);
    text-decoration: none;
    border-bottom: 1px dotted rgba(255, 77, 195, 0.4);
    transition: color 0.15s, border-color 0.15s;
}
.press-also a:hover,
.press-also a:focus { color: #fff; border-bottom-color: #fff; }

#page-content .press-section .press-also a:link,
#page-content .press-section .press-also a:visited {
    color: var(--m-magenta) !important;
    border-bottom-color: rgba(132, 0, 89, 0.35) !important;
}

#page-content .press-section .press-also a.press-also-link,
#page-content .press-section .press-also a.press-also-link:link,
#page-content .press-section .press-also a.press-also-link:visited {
    color: #840059 !important;
    border-bottom: 1px dotted rgba(132, 0, 89, 0.45) !important;
    text-decoration: none !important;
}

#page-content .press-section .press-also a:hover,
#page-content .press-section .press-also a:focus {
    color: var(--m-magenta-bright) !important;
    border-bottom-color: var(--m-magenta-bright) !important;
}


/* ==========================================================================
   Imprint / legal page
   ========================================================================== */

.imprint-hero {
    background:
        radial-gradient(ellipse 60% 50% at 50% 0%, rgba(255,255,255,0.10), transparent 60%),
        linear-gradient(180deg, #6c004a 0%, #4a0034 100%);
    padding: 72px 0 56px;
    text-align: center;
    color: #fff;
}
.imprint-hero h1 {
    font-family: 'londrina_solidregular', cursive;
    color: #fff;
    font-size: clamp(36px, 5vw, 56px);
    line-height: 1;
    margin: 0 0 12px;
    text-shadow: 2px 2px 0 rgba(0,0,0,0.2);
}
.imprint-hero p.lead {
    margin: 0 auto;
    color: rgba(255,255,255,0.85);
    font-size: 16px;
}

.imprint-body {
    background: linear-gradient(180deg, #6c9626 0%, #5a8021 100%);
    padding: 56px 0 80px;
    color: #fff;
}
.imprint-body .container-wide {
    max-width: 860px;
}
.imprint-body a:link,
.imprint-body a:visited {
    color: #ceff7f;
    text-decoration: none;
    border-bottom: 1px dotted rgba(206,255,127,0.5);
    transition: color 0.15s, border-color 0.15s;
}
.imprint-body a:hover,
.imprint-body a:focus { color: #fff; border-bottom-color: #fff; }

/* Top contact card (Visitenkarte) */
.imprint-card {
    background: #fff;
    color: var(--m-ink, #2a1a24);
    border-radius: 18px;
    padding: 36px 40px;
    box-shadow: 0 18px 40px -16px rgba(0,0,0,0.45);
    margin-bottom: 40px;
    border-top: 6px solid var(--m-magenta-bright, #A30070);
}
@media (max-width: 600px) {
    .imprint-card { padding: 28px 22px; }
}
/* Higher specificity than #page-content h2 (0,1,0,1) */
#page-content .imprint-card h2 {
    font-family: 'londrina_solidregular', 'Trebuchet MS', Helvetica, sans-serif;
    color: var(--m-magenta, #840059);
    font-size: clamp(22px, 2.4vw, 28px);
    margin: 0 0 4px;
    line-height: 1.15;
    text-shadow: none;
}
.imprint-card .imprint-address {
    margin: 0 0 22px;
    color: var(--m-ink-soft, #5a4452);
    font-size: 15px;
}

.imprint-contact {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
    margin: 0 0 22px;
}
@media (max-width: 600px) {
    .imprint-contact { grid-template-columns: 1fr; }
}
.imprint-contact a {
    display: flex;
    align-items: center;
    gap: 10px;
    background: #f7eff4;
    color: var(--m-magenta) !important;
    padding: 12px 14px;
    border-radius: 10px;
    text-decoration: none;
    font-weight: 600;
    font-size: 14px;
    border-bottom: 0 !important;
    transition: background 0.15s, transform 0.15s;
}
.imprint-contact a:hover {
    background: #efdce8;
    color: var(--m-magenta-bright) !important;
    transform: translateY(-1px);
}
.imprint-contact a svg {
    width: 18px;
    height: 18px;
    fill: currentColor;
    flex-shrink: 0;
}

.imprint-meta {
    margin: 0;
    padding-top: 18px;
    border-top: 1px solid #efe2eb;
    color: var(--m-ink-soft);
    font-size: 14px;
    line-height: 1.55;
}

/* Legal text sections */
.imprint-block {
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 12px;
    padding: 20px 24px;
    margin: 0 0 14px;
}
#page-content .imprint-block h3 {
    font-family: 'londrina_solidregular', 'Trebuchet MS', Helvetica, sans-serif;
    font-size: 19px;
    color: #fff;
    margin: 0 0 10px;
    text-shadow: 1px 1px 1px rgba(0,0,0,0.15);
}
.imprint-block p {
    margin: 0 0 10px;
    color: rgba(255,255,255,0.92);
    font-size: 15px;
    line-height: 1.6;
}
.imprint-block p:last-child { margin-bottom: 0; }

/* Two-column key/value rows for quick facts inside blocks */
.imprint-block dl {
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 6px 16px;
    margin: 0;
    color: rgba(255,255,255,0.92);
    font-size: 15px;
}
@media (max-width: 600px) {
    .imprint-block dl { grid-template-columns: 1fr; gap: 2px 0; }
    .imprint-block dl dt { margin-top: 8px; }
}
.imprint-block dl dt {
    font-weight: 600;
    color: rgba(255,255,255,0.7);
}
.imprint-block dl dd { margin: 0; }


/* ==========================================================================
   Composers page (komponisten.html)
   ========================================================================== */

.composers-hero {
    background:
        radial-gradient(ellipse 70% 60% at 50% 0%, rgba(255,255,255,0.12), transparent 60%),
        linear-gradient(180deg, #6c9626 0%, #496c10 100%);
    padding: 80px 0 60px;
    text-align: center;
    color: #fff;
}
.composers-hero h1 {
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    color: #fff;
    font-size: clamp(36px, 5vw, 56px);
    line-height: 1;
    margin: 16px 0 18px;
    text-shadow: 3px 3px 0 rgba(0,0,0,0.25);
}
.composers-hero .hero-eyebrow {
    background: rgba(255,255,255,0.18);
    color: #fff;
    border-color: rgba(255,255,255,0.3);
}
.composers-hero p.lead {
    max-width: 760px;
    margin: 0 auto 28px;
    font-size: clamp(16px, 1.6vw, 19px);
    line-height: 1.55;
    color: rgba(255,255,255,0.95);
}

.studio-strip {
    display: inline-flex;
    align-items: center;
    gap: 18px;
    background: linear-gradient(135deg, #2a1320 0%, #1a0c14 100%);
    color: #fff;
    padding: 14px 28px 14px 18px;
    border-radius: 999px;
    box-shadow: 0 10px 28px -10px rgba(0,0,0,0.5),
                inset 0 1px 0 rgba(255,255,255,0.08);
    transition: transform 0.15s, box-shadow 0.15s, background 0.15s;
    text-decoration: none !important;
    border-bottom: 0 !important;
}
.studio-strip:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 32px -10px rgba(0,0,0,0.6),
                inset 0 1px 0 rgba(255,255,255,0.12);
    background: linear-gradient(135deg, #3a1d2e 0%, #2a1320 100%);
}
.studio-strip img {
    height: 56px;
    width: auto;
    display: block;
}
.studio-strip .studio-label {
    display: flex;
    flex-direction: column;
    line-height: 1.15;
    text-align: left;
}
.studio-strip .studio-label small {
    font-family: 'Delius', sans-serif;
    color: rgba(255,255,255,0.65);
    font-size: 12px;
    font-weight: 400;
    letter-spacing: 0.4px;
    text-transform: uppercase;
}
.studio-strip .studio-label strong {
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    color: #fff;
    font-size: 20px;
    letter-spacing: 0.3px;
    font-weight: 400;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.studio-strip .studio-label strong svg {
    opacity: 0.6;
    transition: transform 0.15s, opacity 0.15s;
}
.studio-strip:hover .studio-label strong svg {
    transform: translate(2px, -2px);
    opacity: 1;
}

/* Awards strip — imascore-studio background with parallax */
.awards-strip {
    background-color: #2f4111;
    background-image: linear-gradient(rgba(0,0,0,0.55), rgba(0,0,0,0.65)), url('../img/imascore-studio.jpg');
    background-size: cover;
    background-position: 50% 50%;
    background-attachment: scroll;
    padding: 56px 0;
    text-align: center;
    color: #fff;
}
.awards-strip h2 {
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    color: #fff;
    font-size: clamp(24px, 3vw, 36px);
    margin: 0 0 22px;
    text-shadow: 2px 2px 1px rgba(0,0,0,0.4);
}
.awards-strip img {
    max-width: 720px;
    width: 100%;
    height: auto;
    display: inline-block;
    filter: drop-shadow(0 6px 14px rgba(0,0,0,0.4));
}
.awards-strip .awards-mobile { display: none; }
@media (max-width: 720px) {
    .awards-strip .awards-desktop { display: none; }
    .awards-strip .awards-mobile { display: inline-block; }
}


.composers-list {
    background: linear-gradient(180deg, #496c10 0%, #405619 100%);
    padding: 72px 0 80px;
}
.composers-list .container-wide { max-width: 980px; }
.composers-list .section-head {
    text-align: center;
    margin-bottom: 36px;
}
.composers-list .section-head h2 {
    color: #fff;
    font-size: clamp(26px, 3vw, 34px);
    margin: 0 0 12px;
    text-shadow: 2px 2px 0 rgba(0,0,0,0.18);
}
.composers-list .section-head p.lead {
    color: rgba(255,255,255,0.85);
    max-width: 620px;
    margin: 0 auto;
}

.composer-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 22px;
}

.composer-card {
    display: grid;
    grid-template-columns: 180px 1fr;
    gap: 28px;
    align-items: start;
    background: rgba(255,255,255,0.07);
    border: 1px solid rgba(255,255,255,0.14);
    border-radius: 18px;
    padding: 26px 30px;
    transition: transform 0.2s ease, background 0.2s ease;
}
.composer-card:hover {
    transform: translateY(-3px);
    background: rgba(255,255,255,0.12);
}
@media (max-width: 720px) {
    .composer-card {
        grid-template-columns: 1fr;
        gap: 18px;
        padding: 22px 22px;
        text-align: left;
    }
}

.composer-photo {
    width: 180px;
    height: 180px;
    border-radius: 14px;
    overflow: hidden;
    background: var(--m-magenta-dark, #6c004a);
    box-shadow: 0 8px 18px -4px rgba(0,0,0,0.45);
    position: relative;
}
.composer-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
@media (max-width: 720px) {
    .composer-photo { width: 140px; height: 140px; margin: 0 auto; }
}

.composer-meta { padding-top: 4px; }
.composer-meta .composer-name {
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    font-size: clamp(22px, 2.2vw, 28px);
    color: #fff;
    line-height: 1.1;
    margin: 0 0 4px;
    text-shadow: 1px 1px 0 rgba(0,0,0,0.18);
}
.composer-meta .composer-role {
    display: inline-block;
    background: rgba(255,255,255,0.12);
    border: 1px solid rgba(255,255,255,0.2);
    color: #fff;
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    font-size: 13px;
    letter-spacing: 0.5px;
    padding: 4px 12px;
    border-radius: 999px;
    margin-bottom: 14px;
}
.composer-meta .composer-quote {
    color: rgba(255,255,255,0.95);
    font-size: 16px;
    line-height: 1.6;
    margin: 0 0 12px;
    border-left: 3px solid var(--m-magenta-soft);
    padding-left: 14px;
    font-style: italic;
}
.composer-meta .composer-quote::before { content: "„"; color: var(--m-magenta-soft); margin-right: 1px; }
.composer-meta .composer-quote::after  { content: "“"; color: var(--m-magenta-soft); margin-left: 1px; }
.composer-meta .composer-text {
    color: rgba(255,255,255,0.92);
    font-size: 15px;
    line-height: 1.6;
    margin: 0;
}


/* ==========================================================================
   Illustrator page (illustrator.html)
   ========================================================================== */

/* Reuse composers-hero base look for illustrator hero — green gradient. */
.illustrator-hero {
    background:
        radial-gradient(ellipse 70% 60% at 50% 0%, rgba(255,255,255,0.12), transparent 60%),
        linear-gradient(180deg, #6c9626 0%, #496c10 100%);
    padding: 80px 0 60px;
    text-align: center;
    color: #fff;
}
.illustrator-hero h1 {
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    color: #fff;
    font-size: clamp(36px, 5vw, 56px);
    line-height: 1;
    margin: 16px 0 18px;
    text-shadow: 3px 3px 0 rgba(0,0,0,0.25);
}
.illustrator-hero .hero-eyebrow {
    background: rgba(255,255,255,0.18);
    color: #fff;
    border-color: rgba(255,255,255,0.3);
}
.illustrator-hero p.lead {
    max-width: 760px;
    margin: 0 auto;
    font-size: clamp(16px, 1.6vw, 19px);
    line-height: 1.55;
    color: rgba(255,255,255,0.95);
}

/* Bio card with portrait */
.illustrator-bio-section {
    background: linear-gradient(180deg, #5a8021 0%, #496c10 100%);
    padding: 64px 0;
}
.illustrator-bio {
    max-width: 980px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 36px;
    align-items: start;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.16);
    border-radius: 20px;
    padding: 32px 36px;
}
@media (max-width: 720px) {
    .illustrator-bio {
        grid-template-columns: 1fr;
        gap: 22px;
        padding: 26px 22px;
    }
}
.illustrator-portrait {
    border-radius: 14px;
    overflow: hidden;
    background: var(--m-magenta-dark, #6c004a);
    box-shadow: 0 12px 28px -8px rgba(0,0,0,0.5);
    aspect-ratio: 200/293;
    max-width: 240px;
    width: 100%;
}
@media (max-width: 720px) {
    .illustrator-portrait { max-width: 200px; margin: 0 auto; }
}
.illustrator-portrait img { width: 100%; height: 100%; object-fit: cover; display: block; }

.illustrator-bio-text h2 {
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    color: #fff;
    font-size: clamp(24px, 2.6vw, 32px);
    line-height: 1.1;
    margin: 0 0 6px;
    text-shadow: 1px 1px 0 rgba(0,0,0,0.18);
}
.illustrator-bio-text .role {
    display: inline-block;
    background: rgba(255,255,255,0.12);
    border: 1px solid rgba(255,255,255,0.2);
    color: #fff;
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    font-size: 13px;
    letter-spacing: 0.5px;
    padding: 4px 12px;
    border-radius: 999px;
    margin-bottom: 16px;
}
.illustrator-bio-text p {
    color: rgba(255,255,255,0.92);
    font-size: 15.5px;
    line-height: 1.65;
    margin: 0 0 12px;
}
.illustrator-bio-text p:last-child { margin-bottom: 0; }

/* Client logos strip */
.clients-strip {
    background: rgba(0,0,0,0.18);
    border-radius: 14px;
    padding: 18px 22px;
    margin-top: 18px;
}
.clients-strip .clients-label {
    display: block;
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    font-size: 12px;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.6);
    margin-bottom: 8px;
}
.clients-strip .clients-list {
    color: rgba(255,255,255,0.92);
    font-size: 14.5px;
    line-height: 1.55;
    margin: 0;
}
.clients-strip .clients-list strong {
    color: #fff;
    font-weight: 600;
}

/* Process steps */
.illustrator-process {
    background: linear-gradient(180deg, #496c10 0%, #405619 100%);
    padding: 72px 0 80px;
}
.illustrator-process .section-head {
    text-align: center;
    margin-bottom: 40px;
}
.illustrator-process .section-head h2 {
    color: #fff;
    font-size: clamp(26px, 3vw, 36px);
    margin: 0 0 12px;
    text-shadow: 2px 2px 0 rgba(0,0,0,0.18);
}
.illustrator-process .section-head p.lead {
    color: rgba(255,255,255,0.85);
    max-width: 620px;
    margin: 0 auto;
}

.process-step {
    display: grid;
    grid-template-columns: 90px 1fr;
    gap: 28px;
    align-items: start;
    max-width: 980px;
    margin: 0 auto 32px;
}
@media (max-width: 720px) {
    .process-step { grid-template-columns: 1fr; gap: 14px; }
}
.process-step-num {
    width: 80px;
    height: 80px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--m-magenta), var(--m-magenta-bright));
    color: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    font-size: 36px;
    box-shadow: 0 10px 22px -6px rgba(132,0,89,0.5);
    flex-shrink: 0;
}
@media (max-width: 720px) {
    .process-step-num { width: 60px; height: 60px; font-size: 28px; margin: 0 auto; }
}
.process-step-body h3 {
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    color: #fff;
    font-size: clamp(22px, 2.2vw, 28px);
    line-height: 1.1;
    margin: 0 0 10px;
    text-shadow: 1px 1px 0 rgba(0,0,0,0.18);
}
.process-step-body p {
    color: rgba(255,255,255,0.92);
    font-size: 15.5px;
    line-height: 1.6;
    margin: 0;
}

.process-image {
    max-width: 1100px;
    margin: 0 auto 40px;
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 16px 36px -12px rgba(0,0,0,0.5);
    background: #fff;
}
.process-image img {
    width: 100%;
    height: auto;
    display: block;
}


/* ==========================================================================
   Voices page (sprecher.html)
   ========================================================================== */

.voices-hero {
    background:
        radial-gradient(ellipse 70% 60% at 50% 0%, rgba(255,255,255,0.12), transparent 60%),
        linear-gradient(180deg, #6c9626 0%, #5c8521 100%);
    padding: 72px 0 36px;
    text-align: center;
    color: #fff;
}
.voices-hero h1 {
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    color: #fff;
    font-size: clamp(36px, 5vw, 56px);
    line-height: 1;
    margin: 16px 0 18px;
    text-shadow: 3px 3px 0 rgba(0,0,0,0.25);
}
.voices-hero .hero-eyebrow {
    background: rgba(255,255,255,0.18);
    color: #fff;
    border-color: rgba(255,255,255,0.3);
}
.voices-hero p.lead {
    max-width: 760px;
    margin: 0 auto;
    font-size: clamp(16px, 1.6vw, 19px);
    line-height: 1.55;
    color: rgba(255,255,255,0.95);
}

.voices-body {
    background: linear-gradient(180deg, #5c8521 0%, #405619 100%);
    padding: 28px 0 80px;
}

.voices-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
    max-width: 1180px;
    margin: 0 auto;
}
@media (max-width: 980px) {
    .voices-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .voices-grid { grid-template-columns: 1fr; }
}

.voice-card {
    background: rgba(255,255,255,0.07);
    border: 1px solid rgba(255,255,255,0.14);
    border-radius: 16px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: transform 0.2s ease, background 0.2s ease;
}
.voice-card:hover {
    transform: translateY(-4px);
    background: rgba(255,255,255,0.12);
}
.voice-photo {
    aspect-ratio: 4/3;
    overflow: hidden;
    background: var(--m-magenta-dark, #6c004a);
    position: relative;
}
.voice-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.4s ease;
}
.voice-card:hover .voice-photo img {
    transform: scale(1.05);
}
.voice-body {
    padding: 18px 20px 20px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.voice-name {
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    color: #fff;
    font-size: 22px;
    line-height: 1.1;
    margin: 0;
    text-shadow: 1px 1px 0 rgba(0,0,0,0.18);
}
.voice-role {
    display: inline-block;
    background: rgba(255,255,255,0.12);
    border: 1px solid rgba(255,255,255,0.2);
    color: #fff;
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    font-size: 12px;
    letter-spacing: 0.5px;
    padding: 3px 10px;
    border-radius: 999px;
    align-self: flex-start;
}
.voice-bio {
    font-size: 14px;
    line-height: 1.55;
    color: rgba(255,255,255,0.92);
    margin: 0;
}
.voice-bio strong {
    color: var(--m-magenta-soft);
    font-weight: 600;
}
.voice-years {
    display: inline-block;
    font-size: 12px;
    color: rgba(255,255,255,0.55);
    font-variant-numeric: tabular-nums;
    margin-left: 6px;
    font-weight: 400;
}


/* ==========================================================================
   Homepage: Apple features (laurel wreaths)
   ========================================================================== */

.app-awards-section {
    background:
        radial-gradient(ellipse 70% 58% at 50% 0%, rgba(255,226,162,0.14), transparent 62%),
        radial-gradient(ellipse 50% 70% at 90% 80%, rgba(98,199,218,0.10), transparent 70%),
        linear-gradient(180deg, #a30070 0%, #840059 72%, #6c004a 100%);
    padding: 72px 0 80px;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.app-awards-section .section-head {
    max-width: 720px;
    margin: 0 auto 36px;
}
.app-awards-section .section-head h2 {
    color: #fff;
    font-size: clamp(26px, 3vw, 36px);
    margin: 0 0 12px;
    text-shadow: 2px 2px 0 rgba(0,0,0,0.18);
}
.app-awards-section .section-head p.lead {
    color: rgba(255,255,255,0.85);
    margin: 0;
}

.laurel-row {
    display: flex;
    justify-content: center;
    align-items: stretch;
    flex-wrap: nowrap;
    gap: 18px;
    max-width: 820px;
    margin: 0 auto;
}
.laurel {
    position: relative;
    width: 252px;
    height: 182px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    transition: transform 0.2s ease;
}
.laurel:hover { transform: translateY(-3px); }

/* The actual laurel wreath as PNG background, recolored to white via filter */
.laurel::before {
    content: "";
    position: absolute;
    inset: 0;
    background: url('../img/laurel-wreath.png') center/contain no-repeat;
    filter: brightness(0) invert(1);
    opacity: 0.92;
    transition: opacity 0.2s ease;
    z-index: 0;
    pointer-events: none;
}
.laurel:hover::before { opacity: 1; }

.laurel-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    position: relative;
    z-index: 1;
    max-width: 68%;
    text-align: center;
}
.laurel-apple {
    width: 32px;
    height: 32px;
    fill: #fff;
    opacity: 0.95;
    margin-bottom: 2px;
}
.laurel-title {
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    font-size: 20px;
    line-height: 1.1;
    color: #fff;
    text-align: center;
    text-shadow: 1px 1px 0 rgba(0,0,0,0.18);
}
.laurel-sub {
    font-size: 11px;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    color: rgba(255,255,255,0.7);
}

@media (max-width: 820px) {
    .laurel-row {
        flex-wrap: wrap;
        max-width: 540px;
    }
}


/* ==========================================================================
   Homepage: Trailer poster (single play button, no scroll player)
   ========================================================================== */

.trailer-poster-section {
    background:
        radial-gradient(ellipse 48% 70% at 15% 0%, rgba(255, 226, 162, 0.18), transparent 70%),
        linear-gradient(180deg, #1f788c 0%, #155b70 100%);
    padding: 72px 0 80px;
    position: relative;
    overflow: hidden;
}
.trailer-poster-section .section-head {
    text-align: center;
    margin-bottom: 36px;
}
.trailer-poster-section .section-head h2 {
    color: #fff;
    font-size: clamp(28px, 3.2vw, 40px);
    margin: 0 0 10px;
    text-shadow: 2px 2px 0 rgba(0,0,0,0.18);
}
.trailer-poster-section .section-head p {
    color: rgba(255,255,255,0.88);
    max-width: 600px;
    margin: 0 auto;
    font-size: 16px;
    line-height: 1.55;
}

.trailer-poster {
    max-width: 820px;
    margin: 0 auto;
    aspect-ratio: 16 / 9;
    border-radius: 22px;
    overflow: hidden;
    position: relative;
    box-shadow:
        0 28px 60px -18px rgba(0,0,0,0.65),
        0 12px 24px -8px rgba(132,0,89,0.35);
    background: #1a1a0c center/cover;
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    border: 0;
    padding: 0;
    width: 100%;
    display: block;
}
.trailer-poster:hover {
    transform: translateY(-3px);
    box-shadow:
        0 36px 70px -18px rgba(0,0,0,0.7),
        0 16px 32px -8px rgba(132,0,89,0.5);
}
.trailer-poster-image {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    transition: transform 0.6s ease;
}
.trailer-poster:hover .trailer-poster-image { transform: scale(1.04); }
.trailer-poster::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 50% 50% at 50% 50%, rgba(0,0,0,0.35), transparent 70%),
        linear-gradient(180deg, rgba(0,0,0,0.1) 0%, rgba(0,0,0,0.5) 100%);
    z-index: 1;
}

.trailer-play-btn {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: clamp(80px, 12vw, 130px);
    height: clamp(80px, 12vw, 130px);
    border-radius: 50%;
    background: rgba(255,255,255,0.96);
    color: var(--m-magenta);
    box-shadow:
        0 14px 32px -6px rgba(0,0,0,0.55),
        0 0 0 0 rgba(255, 77, 195, 0.5);
    border: 0;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
    transition: background 0.2s ease, color 0.2s ease, box-shadow 0.3s ease, transform 0.2s ease;
    animation: trailer-pulse 2.4s ease-out infinite;
}
.trailer-poster:hover .trailer-play-btn {
    background: var(--m-magenta);
    color: #fff;
    transform: translate(-50%, -50%) scale(1.06);
}
.trailer-play-btn svg {
    width: 42%;
    height: 42%;
    fill: currentColor;
    margin-left: 8%;
}
@keyframes trailer-pulse {
    0%   { box-shadow: 0 14px 32px -6px rgba(0,0,0,0.55), 0 0 0 0    rgba(255, 77, 195, 0.55); }
    70%  { box-shadow: 0 14px 32px -6px rgba(0,0,0,0.55), 0 0 0 30px rgba(255, 77, 195, 0); }
    100% { box-shadow: 0 14px 32px -6px rgba(0,0,0,0.55), 0 0 0 0    rgba(255, 77, 195, 0); }
}
@media (prefers-reduced-motion: reduce) { .trailer-play-btn { animation: none; } }

/* Playing state */
.trailer-poster[data-state="playing"] .trailer-play-btn {
    animation: none;
    background: var(--m-magenta);
    color: #fff;
}
.trailer-poster[data-state="playing"] .trailer-play-icon { display: none; }
.trailer-poster[data-state="paused"]  .trailer-pause-icon { display: none; }

.trailer-poster-caption {
    position: absolute;
    left: 28px;
    bottom: 22px;
    color: #fff;
    z-index: 2;
    text-align: left;
    text-shadow: 1px 1px 4px rgba(0,0,0,0.6);
}
.trailer-poster-caption strong {
    display: block;
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    font-size: clamp(18px, 2vw, 22px);
    line-height: 1.15;
}
.trailer-poster-caption span {
    display: block;
    font-size: 13px;
    opacity: 0.85;
    margin-top: 2px;
}


/* ==========================================================================
   Homepage: Mitsing cards without audio players (teaser only)
   ========================================================================== */

.mitsing-teaser-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    max-width: 1120px;
    margin: 0 auto;
}
@media (max-width: 880px) { .mitsing-teaser-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .mitsing-teaser-grid { grid-template-columns: 1fr; } }

.song-teaser {
    background: #fffaf2;
    border: 1px solid rgba(255,255,255,0.54);
    border-radius: 8px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    min-width: 0;
    box-shadow: 0 20px 38px -26px rgba(0,0,0,0.72);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.song-teaser:hover {
    transform: translateY(-3px);
    box-shadow: 0 24px 44px -24px rgba(0,0,0,0.8);
}
.song-cover {
    display: block;
    width: 100%;
    aspect-ratio: 1;
    object-fit: cover;
    background: #f6e8cc;
}
.song-info {
    display: flex;
    flex-direction: column;
    gap: 7px;
    padding: 16px 18px 18px;
    flex: 1;
}
.song-teaser .song-number {
    display: inline-block;
    align-self: flex-start;
    font-family: 'Delius', sans-serif;
    font-size: 11px;
    font-weight: 700;
    color: #fff;
    background: #8b005f;
    letter-spacing: 1.8px;
    text-transform: uppercase;
    padding: 3px 10px;
    border-radius: 999px;
    margin-bottom: 4px;
}
#page-content .song-teaser .song-title {
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    font-size: 22px;
    color: #7d0055;
    line-height: 1.1;
    margin: 0;
    text-shadow: none;
}
.song-teaser .song-subtitle {
    font-size: 13px;
    color: rgba(73,49,67,0.68);
    margin: 0 0 8px;
}
.song-teaser .song-credit {
    font-size: 13px;
    color: #493143;
    line-height: 1.5;
    margin: 0;
}
.song-teaser .song-credit strong { color: #7d0055; }


/* ==========================================================================
   Audio drama page (hoerspiel.html)
   ========================================================================== */

.drama-hero {
    background:
        radial-gradient(ellipse 70% 60% at 50% 0%, rgba(255,255,255,0.12), transparent 60%),
        linear-gradient(180deg, #6c9626 0%, #5c8521 100%);
    padding: 72px 0 40px;
    text-align: center;
    color: #fff;
}
.drama-hero h1 {
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    color: #fff;
    font-size: clamp(36px, 5vw, 56px);
    line-height: 1;
    margin: 16px 0 18px;
    text-shadow: 3px 3px 0 rgba(0,0,0,0.25);
}
.drama-hero .hero-eyebrow {
    background: rgba(255,255,255,0.18);
    color: #fff;
    border-color: rgba(255,255,255,0.3);
}
.drama-hero p.lead {
    max-width: 760px;
    margin: 0 auto;
    font-size: clamp(16px, 1.6vw, 19px);
    line-height: 1.55;
    color: rgba(255,255,255,0.95);
}

/* Story blocks — alternating image/text rows */
.drama-story {
    background: linear-gradient(180deg, #5a8021 0%, #496c10 100%);
    padding: 56px 0 64px;
}
.drama-story .container-wide { max-width: 1080px; }

.drama-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    align-items: center;
    margin-bottom: 32px;
}
.drama-row:last-child { margin-bottom: 0; }
@media (max-width: 720px) {
    .drama-row { grid-template-columns: 1fr; gap: 22px; }
}
.drama-row.reverse .drama-row-image { order: 2; }
.drama-row.reverse .drama-row-text  { order: 1; }
@media (max-width: 720px) {
    .drama-row.reverse .drama-row-image { order: 1; }
    .drama-row.reverse .drama-row-text  { order: 2; }
}

.drama-row-image {
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 18px 40px -16px rgba(0,0,0,0.55);
    background: #1a1a0c;
    aspect-ratio: 2/1;
}
.drama-row-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.6s ease;
}
.drama-row-image:hover img { transform: scale(1.04); }

.drama-row-text h3 {
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    color: #fff;
    font-size: clamp(24px, 2.6vw, 32px);
    line-height: 1.15;
    margin: 0 0 14px;
    text-shadow: 1px 1px 0 rgba(0,0,0,0.18);
}
.drama-row-text p {
    color: rgba(255,255,255,0.94);
    font-size: 16px;
    line-height: 1.65;
    margin: 0 0 12px;
}
.drama-row-text p:last-child { margin: 0; }


/* ==========================================================================
   Makers page (autoren.html — Jeffrey Wipprecht & Christian Zeiger)
   ========================================================================== */

.makers-hero {
    background:
        radial-gradient(ellipse 70% 60% at 50% 0%, rgba(255,255,255,0.12), transparent 60%),
        linear-gradient(180deg, #6c9626 0%, #5c8521 100%);
    padding: 72px 0 40px;
    text-align: center;
    color: #fff;
}
.makers-hero h1 {
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    color: #fff;
    font-size: clamp(36px, 5vw, 56px);
    line-height: 1;
    margin: 16px 0 18px;
    text-shadow: 3px 3px 0 rgba(0,0,0,0.25);
}
.makers-hero .hero-eyebrow {
    background: rgba(255,255,255,0.18);
    color: #fff;
    border-color: rgba(255,255,255,0.3);
}
.makers-hero p.lead {
    max-width: 760px;
    margin: 0 auto;
    font-size: clamp(16px, 1.6vw, 19px);
    line-height: 1.55;
    color: rgba(255,255,255,0.95);
}

.makers-body {
    background: linear-gradient(180deg, #5c8521 0%, #405619 100%);
    padding: 40px 0 80px;
}
.makers-body .container-wide { max-width: 1080px; }

.makers-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 28px;
}

.maker-card {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: 36px;
    align-items: start;
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.16);
    border-radius: 20px;
    padding: 32px 36px;
    transition: transform 0.2s ease, background 0.2s ease;
}
.maker-card:hover {
    transform: translateY(-3px);
    background: rgba(255,255,255,0.12);
}
@media (max-width: 720px) {
    .maker-card {
        grid-template-columns: 1fr;
        gap: 22px;
        padding: 26px 22px;
        text-align: center;
    }
}

.maker-portrait {
    width: 240px;
    height: 240px;
    max-width: 100%;
    border-radius: 18px;
    overflow: hidden;
    background: var(--m-magenta-dark, #6c004a);
    box-shadow: 0 14px 30px -8px rgba(0,0,0,0.45);
}
.maker-portrait img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
@media (max-width: 720px) {
    .maker-portrait {
        width: 200px;
        height: 200px;
        margin: 0 auto;
    }
}

.maker-meta { padding-top: 4px; }
.maker-meta .maker-name {
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    color: #fff;
    font-size: clamp(26px, 3vw, 34px);
    line-height: 1;
    margin: 0 0 4px;
    text-shadow: 1px 1px 0 rgba(0,0,0,0.18);
}
.maker-meta .maker-year {
    display: inline-block;
    font-size: 13px;
    color: rgba(255,255,255,0.6);
    font-variant-numeric: tabular-nums;
    margin-bottom: 14px;
}
.maker-meta .maker-role {
    display: inline-block;
    background: linear-gradient(135deg, var(--m-magenta), var(--m-magenta-bright));
    color: #fff;
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    font-size: 13px;
    letter-spacing: 0.6px;
    padding: 5px 14px;
    border-radius: 999px;
    margin-bottom: 18px;
    box-shadow: 0 6px 14px -4px rgba(132,0,89,0.5);
}
.maker-meta p {
    color: rgba(255,255,255,0.92);
    font-size: 15.5px;
    line-height: 1.65;
    margin: 0 0 12px;
}
.maker-meta p:last-child { margin-bottom: 0; }
.maker-meta .maker-link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: #ceff7f;
    text-decoration: none;
    font-size: 14px;
    font-weight: 600;
    border-bottom: 1px dotted rgba(206,255,127,0.5);
    padding-bottom: 1px;
    transition: color 0.15s, border-color 0.15s;
}
.maker-meta .maker-link:hover {
    color: #fff;
    border-bottom-color: #fff;
}
.maker-meta .maker-link svg {
    width: 14px;
    height: 14px;
    fill: currentColor;
    opacity: 0.7;
}


/* ==========================================================================
   Characters page (charaktere.html)
   ========================================================================== */

.characters-hero {
    background:
        radial-gradient(ellipse 70% 60% at 50% 0%, rgba(255,255,255,0.12), transparent 60%),
        linear-gradient(180deg, #6c9626 0%, #5c8521 100%);
    padding: 72px 0 36px;
    text-align: center;
    color: #fff;
}
.characters-hero h1 {
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    color: #fff;
    font-size: clamp(36px, 5vw, 56px);
    line-height: 1;
    margin: 16px 0 18px;
    text-shadow: 3px 3px 0 rgba(0,0,0,0.25);
}
.characters-hero .hero-eyebrow {
    background: rgba(255,255,255,0.18);
    color: #fff;
    border-color: rgba(255,255,255,0.3);
}
.characters-hero p.lead {
    max-width: 720px;
    margin: 0 auto;
    font-size: clamp(16px, 1.6vw, 19px);
    line-height: 1.55;
    color: rgba(255,255,255,0.95);
}

.characters-body {
    background: linear-gradient(180deg, #5c8521 0%, #405619 100%);
    padding: 36px 0 72px;
}

.characters-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
    max-width: 1180px;
    margin: 0 auto;
}
@media (max-width: 980px) {
    .characters-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .characters-grid { grid-template-columns: 1fr; max-width: 420px; }
}

.character-card {
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.16);
    border-radius: 18px;
    padding: 28px 24px 24px;
    text-align: center;
    transition: transform 0.2s ease, background 0.2s ease;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
}
.character-card:hover {
    transform: translateY(-4px);
    background: rgba(255,255,255,0.14);
}
.character-card .character-avatar {
    width: 140px;
    height: 140px;
    border-radius: 50%;
    overflow: hidden;
    background: var(--m-magenta-dark, #6c004a);
    box-shadow:
        0 12px 24px -8px rgba(0,0,0,0.45),
        inset 0 1px 0 rgba(255,255,255,0.2);
    border: 4px solid rgba(255,255,255,0.85);
    margin-bottom: 4px;
    flex-shrink: 0;
}
.character-card .character-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.character-card .character-name {
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    color: #fff;
    font-size: clamp(24px, 2.6vw, 30px);
    line-height: 1.1;
    margin: 0;
    text-shadow: 1px 1px 0 rgba(0,0,0,0.2);
}
.character-card .character-role {
    display: inline-block;
    background: linear-gradient(135deg, var(--m-magenta), var(--m-magenta-bright));
    color: #fff;
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    font-size: 12px;
    letter-spacing: 0.8px;
    padding: 5px 14px;
    border-radius: 999px;
    box-shadow: 0 6px 12px -4px rgba(132,0,89,0.5);
}
.character-card .character-desc {
    color: rgba(255,255,255,0.92);
    font-size: 14px;
    line-height: 1.6;
    margin: 4px 0 0;
}


/* ==========================================================================
   Coloring sheets section (Ausmalbilder zum Download)
   ========================================================================== */

.coloring-section {
    background: linear-gradient(180deg, #5c8521 0%, #496c10 100%);
    padding: 72px 0 80px;
}
.coloring-section .section-head {
    text-align: center;
    max-width: 720px;
    margin: 0 auto 40px;
}
.coloring-section .section-head h2 {
    color: #fff;
    font-size: clamp(28px, 3vw, 38px);
    margin: 0 0 12px;
    text-shadow: 2px 2px 0 rgba(0,0,0,0.18);
}
.coloring-section .section-head p.lead {
    color: rgba(255,255,255,0.92);
    font-size: clamp(15px, 1.4vw, 17px);
    margin: 0;
}
.coloring-section .section-head .badge-new {
    margin-bottom: 14px;
}

.coloring-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
    max-width: 920px;
    margin: 0 auto;
}
@media (max-width: 720px) {
    .coloring-grid { grid-template-columns: 1fr; max-width: 360px; }
}

.coloring-card {
    background: transparent;
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 14px 36px -16px rgba(0,0,0,0.55);
    display: flex;
    flex-direction: column;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.coloring-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 22px 48px -16px rgba(0,0,0,0.65);
}
.coloring-card .coloring-preview {
    aspect-ratio: 4 / 5;
    background: #fefcf6;
    overflow: hidden;
    position: relative;
}
.coloring-card .coloring-preview img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    transform: scale(1.18);
    transform-origin: center center;
    display: block;
    transition: transform 0.4s ease;
}
.coloring-card:hover .coloring-preview img {
    transform: scale(1.24);
}
.coloring-card .coloring-body {
    background: linear-gradient(180deg, var(--m-magenta-bright, #A30070) 0%, var(--m-magenta, #840059) 100%);
    padding: 22px 22px 24px;
    display: flex;
    flex-direction: column;
    gap: 14px;
    align-items: center;
    justify-content: flex-start;
    text-align: center;
    position: relative;
    flex: 1 1 auto;
}
.coloring-card .coloring-body::before {
    content: "";
    position: absolute;
    top: -10px; left: 50%;
    transform: translateX(-50%);
    width: 0; height: 0;
    border-left: 12px solid transparent;
    border-right: 12px solid transparent;
    border-bottom: 10px solid var(--m-magenta-bright, #A30070);
}
.coloring-card .coloring-name {
    font-family: 'londrina_solidregular', 'Trebuchet MS', sans-serif;
    color: #fff !important;
    font-size: 26px;
    line-height: 1;
    margin: 0 !important;
    text-shadow: 1px 1px 0 rgba(0,0,0,0.18) !important;
}
.coloring-card .coloring-meta {
    font-size: 11px;
    color: rgba(255,255,255,0.7) !important;
    margin: 0 !important;
    letter-spacing: 1px;
    text-transform: uppercase;
    text-shadow: none !important;
}
.coloring-card .btn-download {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: #fff;
    color: var(--m-magenta) !important;
    text-decoration: none !important;
    padding: 11px 20px;
    border-radius: 999px;
    font-family: 'Delius', sans-serif;
    font-weight: 700;
    font-size: 14px;
    box-shadow: 0 4px 14px -4px rgba(0,0,0,0.35);
    transition: background 0.15s, transform 0.15s, color 0.15s;
    border-bottom: 0 !important;
    white-space: nowrap;
    margin-top: auto;
}
.coloring-card .btn-download:hover {
    background: var(--m-cream, #faf3e9);
    color: var(--m-magenta-bright) !important;
    transform: translateY(-1px);
}
.coloring-card .btn-download svg {
    width: 16px;
    height: 16px;
    fill: currentColor;
}

/* Star voices section header */
.voices-stars-head {
    text-align: center;
    margin-bottom: 28px;
}
.voices-stars-head h2 {
    color: #fff;
    font-size: clamp(22px, 2.4vw, 28px);
    margin: 0 0 8px;
    text-shadow: 1px 1px 0 rgba(0,0,0,0.18);
}
.voices-stars-head p {
    color: rgba(255,255,255,0.78);
    font-size: 14px;
    margin: 0;
}


/* ==========================================================================
   Image protection: no drag, no long-press save, no text-select on images
   (cannot block screenshots / DevTools; just discourages casual saving)
   ========================================================================== */
img {
    -webkit-user-select: none;
       -moz-user-select: none;
        -ms-user-select: none;
            user-select: none;
    -webkit-user-drag: none;
            user-drag: none;
    -webkit-touch-callout: none;
}
