
:root{
  --bg:#f7f3ee;
  --paper:#fffdf9;
  --paper-2:#fffaf2;
  --text:#2b201d;
  --muted:#6f635c;
  --line:#e7d7cb;
  --accent:#7d2047;
  --accent-2:#a55a7a;
  --accent-soft:#f2e6ec;
  --gold:#8e6b2f;
  --shadow:0 16px 40px rgba(54,30,22,.10);
  --radius:22px;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--text);
  font-family: Georgia, "Times New Roman", serif;
  background:
    radial-gradient(1200px 500px at 100% 0, rgba(165,90,122,.08), transparent 58%),
    radial-gradient(900px 450px at 0 0, rgba(125,32,71,.06), transparent 55%),
    linear-gradient(180deg, #faf7f2, #f6f1eb 65%, #f8f4ef);
  line-height:1.65;
}
img{max-width:100%;display:block}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:var(--max);margin:0 auto;padding:0 18px}
.skip-link{position:absolute;left:-999px}
.skip-link:focus{left:12px;top:12px;background:#fff;padding:8px 12px;border-radius:10px;z-index:999}
header{
  position:sticky;top:0;z-index:100;
  background:rgba(250,247,242,.9);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 0}
.brand{display:flex;align-items:center;gap:12px;color:var(--text);font-weight:700}
.brand img{width:52px;height:auto;border-radius:12px}
.nav-toggle{display:none;border:1px solid var(--line);background:#fff;padding:10px 12px;border-radius:12px;font:inherit}
.navlinks{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.navlinks a{padding:9px 12px;border-radius:12px;color:var(--text)}
.navlinks a.active,.navlinks a:hover{background:var(--accent-soft);text-decoration:none}
.cta,.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 16px;border-radius:14px;font-weight:700;text-decoration:none
}
.cta{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;box-shadow:var(--shadow)}
.btn{border:1px solid var(--line);background:#fff;color:var(--text)}
.btn:hover,.cta:hover{text-decoration:none;filter:brightness(1.02)}
.hero{padding:34px 0 16px}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:24px;align-items:stretch}
.card{
  background:rgba(255,253,249,.88);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.hero-copy{padding:30px}
.kicker{
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--accent);
  font-size:.82rem;
  font-weight:700
}
.title-small{font-size:1.06rem;color:var(--muted);margin-top:.2rem}
h1{font-size:clamp(2rem,5vw,4rem);line-height:1.03;margin:.2em 0}
h2{font-size:clamp(1.7rem,3vw,2.5rem);line-height:1.1;margin:0 0 12px}
h3{font-size:clamp(1.22rem,2vw,1.45rem);margin:0 0 8px}
.lead{font-size:1.12rem;color:var(--muted);margin:0 0 16px}
.eyebrow{font-style:italic;color:var(--gold);font-size:1.05rem;margin-bottom:10px}
.badges,.hero-actions{display:flex;flex-wrap:wrap;gap:10px}
.badge{padding:7px 11px;border:1px solid var(--line);border-radius:999px;background:#fff;font-size:.96rem}
.hero-media{overflow:hidden;position:relative;min-height:420px}
.hero-media img{width:100%;height:100%;object-fit:cover}
.hero-media::after{
  content:"";position:absolute;inset:auto 0 0 0;height:38%;
  background:linear-gradient(180deg, transparent, rgba(26,13,10,.28));
}
.statline{
  display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:18px
}
.stat{
  background:var(--paper-2);border:1px solid var(--line);border-radius:18px;padding:14px;text-align:center
}
.stat strong{display:block;font-size:1.28rem;color:var(--accent)}
.section{padding:18px 0}
.section-header{display:flex;justify-content:space-between;align-items:end;gap:12px;margin-bottom:14px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.tile{overflow:hidden}
.tile img{width:100%;aspect-ratio:16/10;object-fit:cover}
.tile-body{padding:16px 16px 18px}
.note{padding:14px 16px;border-left:4px solid var(--accent);background:var(--accent-soft);border-radius:14px}
.video-wrap{position:relative;aspect-ratio:16/9;border-radius:18px;overflow:hidden;background:#1f1417}
.video-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.quote-block{
  background:linear-gradient(180deg, #fffdf9, #fbf6f0);
  border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow)
}
.quote-block blockquote{font-size:clamp(1.3rem,2.4vw,1.9rem);line-height:1.35;margin:0;font-style:italic}
.quote-block cite{display:block;margin-top:12px;color:var(--muted)}
.timeline{display:grid;gap:12px}
.timeline-item{display:grid;grid-template-columns:92px 1fr;gap:16px;padding:16px;border:1px solid var(--line);border-radius:18px;background:#fff}
.timeline-item strong{color:var(--accent)}
.ribbon{
  display:inline-block;padding:7px 10px;border-radius:999px;background:#fff;
  border:1px solid var(--line);color:var(--accent);font-weight:700;font-size:.92rem
}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gallery img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:16px;border:1px solid var(--line);box-shadow:var(--shadow)}
.form{padding:20px}
label{display:block;font-weight:700;margin:10px 0 6px}
input,textarea{width:100%;padding:12px 13px;border:1px solid var(--line);border-radius:14px;background:#fff;font:inherit}
textarea{min-height:140px;resize:vertical}
.list-clean{padding-left:1.1em;margin:10px 0}
hr.sep{border:none;border-top:1px solid var(--line);margin:18px 0}
.footer{
  margin-top:34px;padding:26px 0 38px;border-top:1px solid var(--line);color:var(--muted)
}
.footer-grid{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.small{font-size:.95rem}
.hero-classic{
  background:
    linear-gradient(145deg, rgba(255,253,249,.96), rgba(251,244,236,.96)),
    radial-gradient(circle at 85% 20%, rgba(165,90,122,.10), transparent 25%);
}
.highlight{
  background:linear-gradient(180deg, #fffefb, #fbf4ef);
}
.mini-awards{display:grid;gap:10px}
.mini-awards .item{padding:12px 14px;border:1px solid var(--line);border-radius:16px;background:#fff}
.caption{color:var(--muted);font-size:.92rem;margin-top:8px}
@media (max-width: 980px){
  .hero-grid,.grid-3,.grid-2,.gallery{grid-template-columns:1fr}
  .statline{grid-template-columns:1fr}
}
@media (max-width: 860px){
  .nav-toggle{display:inline-flex}
  .navlinks{display:none;position:absolute;left:18px;right:18px;top:74px;background:#fff;border:1px solid var(--line);padding:12px;border-radius:18px;box-shadow:var(--shadow)}
  .navlinks.open{display:flex;flex-direction:column;align-items:stretch}
  .nav .cta{display:none}
  .timeline-item{grid-template-columns:1fr}
}


/* Feinrunde: bessere Bildausschnitte und stärkere Programmsektion */
#programme .grid-3{
  align-items:stretch;
}
#programme .tile{
  display:flex;
  flex-direction:column;
}
#programme .tile img{
  aspect-ratio: 16 / 9;
  object-fit: cover;
}
#programme .tile-body{
  flex:1;
}
.programme-intro{
  max-width: 820px;
  margin-bottom: 14px;
}
.programme-intro p{
  color: var(--muted);
  margin-top: 0;
}
img.crop-top{object-position:center 18%;}
img.crop-center{object-position:center center;}
img.crop-right{object-position:72% center;}
img.crop-left{object-position:28% center;}
.start-cta{
  background:linear-gradient(180deg,#fffdf9,#fbf4ef);
}
.start-cta .hero-actions{
  margin-top:16px;
}
@media (max-width: 980px){
  #programme .tile img{
    aspect-ratio: 3 / 2;
  }
}



/* --- Bildausschnitte repariert --- */
.tile img{
    aspect-ratio:16/9;
    object-fit:cover;
    object-position:center 30%;
}

/* spezieller Ausschnitt für Plaudernde Zauberkunst */
.img-plauder{
    object-position:center 15%;
}

/* H1 etwas dezenter */
h1{
    font-size:42px;
    line-height:1.2;
}

/* Vertrauensblock */
.trust-block{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
    gap:20px;
    text-align:center;
    margin:40px 0;
}
.trust-item{
    background:#faf7f2;
    padding:20px;
    border-radius:10px;
}

/* Trick Story */
.trick-story{
    margin:60px 0;
}
.trick-gallery{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
    gap:20px;
}
.trick-gallery img{
    width:100%;
    border-radius:10px;
}
.social-icon {
  width: 22px;
  height: 22px;
  vertical-align: middle;
  opacity: 0.85;
  transition: opacity 0.2s ease;
}
