:root{
  --bg:#F2F0EC;--ink:#1D1D1B;--neon:#E7FF00;--white:#FFFFFF;
  --line:rgba(29,29,27,.16);--pill:#E7E4DD;--muted:#6b6a64;--maxw:1280px;
  --r:18px;--r-sm:12px;--r-card:16px;
}
*{box-sizing:border-box;margin:0;padding:0}
::selection{background:rgba(166,190,183,.7);color:var(--ink)}
::-moz-selection{background:rgba(166,190,183,.7);color:var(--ink)}
@media (prefers-reduced-motion:no-preference){
  a,.pill,button{transition:color .2s ease,background .2s ease,border-color .2s ease,transform .2s ease}
}
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
}
html{scroll-behavior:smooth}
body{font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);
  -webkit-font-smoothing:antialiased;line-height:1.45;overflow-x:hidden;}
.mono{font-family:"SFMono-Regular",ui-monospace,"Cascadia Code","Roboto Mono",Menlo,Consolas,monospace}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,64px)}
img{display:block;max-width:100%}
sup{font-size:.6em;vertical-align:super;line-height:0}

.pill{display:inline-flex;align-items:center;gap:.6em;background:var(--pill);color:var(--ink);
  border-radius:999px;padding:.7em 1.2em;font-size:13px;letter-spacing:.02em;
  border:1px solid transparent;text-decoration:none;cursor:pointer;
  transition:background .25s,transform .25s,color .25s;}
.pill:hover{background:var(--ink);color:var(--bg)}
.pill--ghost{background:transparent;border-color:var(--line)}
.pill--ghost:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.pill--neon{background:var(--neon);color:var(--ink)}
.pill--neon:hover{background:var(--ink);color:var(--neon)}
.pill--static{cursor:default}
.pill--static:hover{background:var(--pill);color:var(--ink)}
.pill--theme{background:var(--pill);border-color:var(--line);text-decoration:none;transition:background .2s ease,color .2s ease,border-color .2s ease}
.pill--theme:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}


.pill .arr{display:inline-flex;align-items:center;justify-content:center;width:1.05em;height:1.05em;line-height:1;flex:none}
/* Unified arrow hover: rotate 45° clockwise (up-right -> right) + minimal shift right */
.arr svg{transition:transform .3s cubic-bezier(.2,.8,.2,1)}
.pill:hover .arr svg,
.card-more:hover .arr svg,
.info-card a:hover .arr svg,
.map-actions a:hover .arr svg,
a:hover > .arr svg,
button:not(.nl-submit):hover .arr svg{transform:rotate(45deg) translateX(2px)}
.pill .arr svg{width:100%;height:100%;display:block}
.nl-submit .arr{display:inline-flex;align-items:center;justify-content:center;width:1em;height:1em}
.nl-submit .arr svg{width:100%;height:100%}
.card-more .arr{display:inline-flex;align-items:center;justify-content:center;width:1.05em;height:1.05em;flex:none;transition:transform .3s cubic-bezier(.2,.8,.2,1)}
.card-more .arr svg{width:100%;height:100%}

.btn-row{display:flex;flex-wrap:wrap;gap:12px}

.badge{width:clamp(64px,7vw,104px);height:clamp(64px,7vw,104px);background:var(--neon);
  border-radius:50%;display:flex;align-items:center;justify-content:center;flex:none;
  transition:transform .4s cubic-bezier(.2,.8,.2,1);}
.badge svg{width:42%;height:42%}
.badge:hover{transform:rotate(45deg)}

/* NAV */
.nav{position:sticky;top:0;z-index:50;background:rgba(242,240,236,.82);backdrop-filter:blur(10px);
  border-bottom:1px solid transparent;transition:border-color .3s}
.nav.scrolled{border-color:var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:18px clamp(20px,5vw,64px)}
.nav-logo{height:26px;display:block}.nav-logo svg{height:100%;width:auto}
.nav-links{display:flex;gap:clamp(18px,3vw,44px);align-items:center}
.nav-links a{color:var(--ink);text-decoration:none;font-size:14px;border-bottom:1px solid var(--ink);padding-bottom:2px;transition:opacity .2s}
.nav-links a:hover{opacity:.55}
.nav-cta{display:inline-flex}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.burger span{width:26px;height:2px;background:var(--ink);transition:.3s}
.mobile-menu{display:none}

/* HERO */
.hero{padding-top:clamp(26px,5vw,60px)}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,56px);align-items:center}
.hero h1{font-size:clamp(40px,6.4vw,104px);font-weight:600;letter-spacing:-.03em;line-height:.93;margin-top:14px}
.hero-sub{font-size:clamp(15px,1.5vw,20px);margin-top:18px;font-weight:400;color:#3a3a37;max-width:42ch}
.hero-visual{position:relative;border-radius:var(--r);overflow:hidden;height:clamp(360px,46vw,560px);background:#1d2b27}
.hero-visual img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.05);mix-blend-mode:luminosity}
.hero-visual::before{content:"";position:absolute;inset:0;z-index:0;background:#a6beb7}
.hero-visual::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(180deg, rgba(29,43,39,.10) 0%, rgba(29,43,39,0) 35%, rgba(29,43,39,0) 60%, rgba(29,43,39,.35) 100%);}
.hero-badge{position:absolute;top:18px;right:18px;z-index:3}
.hero-tags{position:absolute;left:16px;right:16px;bottom:16px;display:flex;flex-wrap:wrap;gap:9px;align-items:flex-start;z-index:3}
.hero-tags .pill{background:rgba(242,240,236,.92);backdrop-filter:blur(4px);white-space:normal;max-width:100%;text-decoration:none}
a.pill{transition:background .25s,color .25s,transform .25s}
.hero-tags a.pill:hover{background:var(--ink);color:var(--bg)}
.hero-tags .pill--static{cursor:default}
.hero-tags .pill--static:hover{background:rgba(242,240,236,.92);color:var(--ink)}
/* Countdown — unter Hero, volle Breite, zentriert, ohne Hinterlegung */
.hero-countdown{margin-top:clamp(56px,9vw,120px);margin-bottom:clamp(20px,4vw,56px);text-align:center;color:var(--ink)}
.hero-countdown .cd-cap{font-size:13px;letter-spacing:.08em;color:var(--muted);margin-bottom:clamp(18px,2.4vw,30px)}
.cd-units{display:flex;justify-content:center;align-items:flex-start;gap:clamp(24px,5vw,72px);flex-wrap:wrap}
.cd-unit{text-align:center;min-width:60px}
.cd-num{font-size:clamp(36px,6vw,68px);font-weight:600;letter-spacing:-.025em;line-height:.9;font-variant-numeric:tabular-nums}
.cd-lbl{font-size:clamp(11px,1.2vw,14px);letter-spacing:.05em;color:var(--muted);margin-top:clamp(8px,1vw,14px)}

section{padding:clamp(56px,8vw,120px) 0}
.sec-label{font-size:13px;letter-spacing:.05em;color:var(--muted);margin-bottom:22px;display:flex;align-items:center;gap:10px}
.sec-label::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--neon);display:inline-block}
.sec-head{font-size:clamp(30px,5vw,64px);font-weight:600;letter-spacing:-.02em;line-height:1.02}

/* VISION */
.vision-grid{display:grid;grid-template-columns:1fr 1.25fr;gap:clamp(30px,6vw,90px);align-items:start}
.vision-lead{font-size:clamp(15px,1.6vw,18px);color:#3a3a37;max-width:46ch}
.vision-big{font-size:clamp(30px,5.2vw,68px);font-weight:600;letter-spacing:-.025em;line-height:1.04}
.vision-big .em{position:relative;display:inline-block}
.vision-big .em::after{content:"";position:absolute;left:0;right:0;bottom:.06em;height:.16em;background:var(--neon);z-index:-1;opacity:.9}
.audience-tags{display:flex;gap:12px;flex-wrap:wrap;margin-top:30px}

/* NEWS */
.grid-news{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,1.6vw,22px)}

/* BAU 2027 SECTION */
.bau-grid{display:grid;grid-template-columns:1.15fr 1fr;gap:clamp(30px,5vw,72px);align-items:start;margin-top:8px}
.bau-intro p{font-size:clamp(15px,1.6vw,17px);color:#3a3a37;max-width:54ch;line-height:1.65;margin-bottom:18px}
.bau-intro strong{font-weight:600;color:var(--ink)}
.bau-themes{margin-top:30px}
.bau-side{display:flex;flex-direction:column;gap:clamp(20px,2.4vw,28px)}
.bau-theme-label{display:block;font-size:12px;letter-spacing:.05em;color:var(--muted);margin-bottom:14px}
.bau-facts{display:grid;grid-template-columns:1fr 1fr;gap:clamp(12px,1.4vw,18px)}
.bau-fact{background:var(--white);border:1px solid var(--line);border-radius:var(--r-card);padding:clamp(18px,2.2vw,26px);display:flex;flex-direction:column;gap:8px}
.bau-fact .bf-n{font-size:clamp(28px,3.4vw,42px);font-weight:600;letter-spacing:-.03em;line-height:.95}
.bau-fact .bf-l{font-size:12px;color:var(--muted);letter-spacing:.03em;line-height:1.4}
.bau-fact .bf-l span{display:block;font-size:12px;font-weight:400;color:#4a4a45;margin-top:4px;letter-spacing:0;font-family:"Helvetica Neue",Helvetica,Arial,sans-serif}
.bau-cta{margin-top:0}
.bau-cta .arr{display:inline-flex;align-items:center;justify-content:center;width:1.05em;height:1.05em;flex:none;transition:transform .3s cubic-bezier(.2,.8,.2,1)}
.bau-cta .arr svg{width:100%;height:100%}

.card{position:relative;border-radius:var(--r-card);overflow:hidden;background:var(--white);
  border:1px solid var(--line);min-height:300px;display:flex;flex-direction:column;
  text-decoration:none;color:var(--ink);transition:transform .35s,box-shadow .35s;}
.card:hover{transform:translateY(-4px);box-shadow:0 18px 40px -24px rgba(29,29,27,.5)}
.card-img{height:188px;position:relative;overflow:hidden}
.card-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s,opacity .45s ease}
.card-img .ci-4c{opacity:0}
.card:hover .card-img img{transform:scale(1.05)}
.card:hover .card-img .ci-bw{opacity:0}
.card:hover .card-img .ci-4c{opacity:1}
.card-cat{position:absolute;top:12px;left:12px;z-index:2;background:var(--bg);font-size:11px;letter-spacing:.04em;padding:5px 11px;border-radius:999px}
.card-body{padding:18px 18px 22px;display:flex;flex-direction:column;gap:10px;flex:1}
.card-body h3{font-size:19px;font-weight:600;letter-spacing:-.01em;line-height:1.15}
.card-body p{font-size:13.5px;color:var(--muted);flex:1}
.card-more{font-size:13px;display:inline-flex;align-items:center;gap:8px;border-bottom:1px solid var(--ink);align-self:flex-start;padding-bottom:2px;cursor:pointer;transition:gap .25s ease,border-color .2s ease}
.card-more:hover{gap:12px}

/* STAGE */
.stage-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(30px,5vw,70px);align-items:stretch}
.stage-copy{display:flex;flex-direction:column}
.stage-copy h2{font-size:clamp(34px,6vw,76px);font-weight:600;letter-spacing:-.025em;line-height:.96;margin-bottom:18px}
.stage-copy p{font-size:clamp(15px,1.6vw,17px);color:#3a3a37;max-width:48ch;margin-bottom:26px}
.stage-copy .btn-row{margin-top:auto}
.booking-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-card);
  padding:clamp(20px,3vw,30px);display:flex;flex-direction:column}
.bk-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.bk-live{display:inline-flex;align-items:center;gap:7px;font-size:11px;letter-spacing:.04em;color:var(--muted)}
.bk-live i{width:8px;height:8px;border-radius:50%;background:var(--neon);display:block;box-shadow:0 0 0 0 rgba(231,255,0,.7);animation:bkPulse 2s infinite}
@keyframes bkPulse{0%{box-shadow:0 0 0 0 rgba(160,180,40,.55)}70%{box-shadow:0 0 0 7px rgba(160,180,40,0)}100%{box-shadow:0 0 0 0 rgba(160,180,40,0)}}
.bk-days{display:flex;gap:7px;margin-bottom:14px;flex-wrap:wrap}
.bk-day{font-size:12px;font-family:ui-monospace,monospace;padding:6px 11px;border:1px solid var(--line);border-radius:999px;cursor:pointer;transition:.2s;background:none}
.bk-day:hover:not(.active){background:var(--pill);border-color:var(--ink)}
.bk-day.active{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.slot{display:flex;justify-content:space-between;align-items:center;padding:13px 4px;border-top:1px solid var(--line);font-size:14px;gap:10px}
.slot:last-of-type{border-bottom:1px solid var(--line)}
.slot .t{font-family:ui-monospace,monospace}
.slot .stat{margin-left:auto;font-size:12px;font-family:ui-monospace,monospace}
.slot .free{color:#2c7a2c}.slot .full{color:var(--muted)}
.bk-btn{font-size:12px;border:1px solid var(--ink);border-radius:999px;padding:5px 13px;background:none;cursor:pointer;transition:.2s}
.bk-btn:hover{background:var(--ink);color:var(--bg)}
.bk-btn:disabled{opacity:.35;cursor:not-allowed}

/* TICKET */
.ticket{display:grid;grid-template-columns:1fr 1.1fr;gap:0;border-radius:var(--r);overflow:hidden;border:1px solid var(--line)}
.ticket-img{position:relative;min-height:320px}
.ticket-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ticket-img .badge{position:absolute;left:22px;bottom:22px;z-index:2}
.ticket-body{background:#EBE8E1;padding:clamp(28px,4vw,52px);display:flex;flex-direction:column;justify-content:center;gap:18px}
.ticket-tag{align-self:flex-start;background:var(--neon);font-size:12px;letter-spacing:.03em;padding:6px 14px;border-radius:999px}
.ticket-body h2{font-size:clamp(34px,5.2vw,64px);font-weight:600;letter-spacing:-.025em;line-height:.94}
.ticket-body p{font-size:14.5px;color:#4a4a45;max-width:42ch}

/* NEWSLETTER */
.news-sec{background:rgba(166,190,183,0.30);color:var(--ink);border-radius:var(--r)}
.news-sec .wrap{padding-top:clamp(56px,7vw,96px);padding-bottom:clamp(56px,7vw,96px)}
.nl-grid{display:grid;grid-template-columns:.7fr 1.3fr;gap:clamp(30px,5vw,70px);align-items:start}
.nl-label{font-size:13px;letter-spacing:.05em;color:var(--muted)}
.nl-grid h2{font-size:clamp(30px,5vw,62px);font-weight:600;letter-spacing:-.02em;line-height:1.02;margin-bottom:18px}
.nl-grid p{color:#3a4a45;font-size:15px;max-width:50ch;margin-bottom:30px}
.nl-form{display:flex;flex-direction:column;gap:14px;max-width:560px}
.nl-field-label{font-size:12px;color:var(--muted)}
.nl-row{display:flex;gap:12px;flex-wrap:wrap}
.nl-input{flex:1;min-width:220px;background:rgba(255,255,255,.5);border:1px solid rgba(29,29,27,.22);border-radius:999px;padding:15px 22px;color:var(--ink);font-size:15px;font-family:inherit}
.nl-input::placeholder{color:#6f7d78}.nl-input:focus{outline:none;border-color:var(--ink);background:rgba(255,255,255,.8)}
.nl-submit{background:var(--neon);color:var(--ink);border:none;border-radius:50%;width:56px;height:56px;min-width:56px;padding:0;cursor:pointer;font-size:20px;transition:transform .4s cubic-bezier(.2,.8,.2,1);display:flex;align-items:center;justify-content:center;flex:none}
.nl-submit:hover{transform:rotate(45deg)}
.nl-consent{font-size:12px;color:#5a6a65;display:flex;gap:9px;align-items:flex-start;line-height:1.4}
.nl-consent input{margin-top:2px;accent-color:var(--neon)}
.nl-perks{display:flex;flex-direction:column;gap:14px;border-top:1px solid rgba(29,29,27,.18);padding-top:24px}
.perk{display:flex;gap:12px;align-items:flex-start;font-size:14px;color:#2e3a36}
.perk .pk{color:#3a4a45;font-weight:600;font-size:13px;margin-top:2px}
.nl-ok{display:none;color:#1f5c2f;font-size:15px;font-weight:600}

/* TEAM */
.team-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:clamp(30px,5vw,70px);align-items:center}
.team-copy h2{font-size:clamp(34px,5.5vw,72px);font-weight:600;letter-spacing:-.025em;line-height:.98;margin-bottom:18px}
.team-copy p{font-size:15px;color:#3a3a37;max-width:46ch;margin-bottom:26px}
.team-img{position:relative;min-height:340px;border-radius:var(--r);overflow:hidden}
.team-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.smiley{position:absolute;left:18px;bottom:18px;z-index:3;
  width:clamp(64px,7vw,104px);height:clamp(64px,7vw,104px);background:#a6beb7;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-family:ui-monospace,monospace;font-size:clamp(26px,3vw,42px);font-weight:600;color:var(--ink);
  letter-spacing:-.04em;transition:transform .4s cubic-bezier(.2,.8,.2,1);}
.smiley span{display:inline-block;line-height:1}
.smiley:hover{transform:rotate(45deg)}
.team-people{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}
.role-tag{display:inline-flex;align-items:center;gap:9px;font-size:13px;font-family:ui-monospace,monospace;
  background:var(--pill);border:none;border-radius:999px;padding:9px 17px;color:var(--ink);cursor:pointer;
  transition:background .25s,color .25s,transform .2s}
.role-tag::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--neon);display:inline-block;transition:transform .2s}
.role-tag:hover{background:var(--ink);color:var(--bg);transform:translateY(-2px)}
.role-tag:hover::before{transform:scale(1.3)}

/* INFO */
.info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,1.6vw,22px)}
.info-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-card);padding:clamp(22px,3vw,32px);display:flex;flex-direction:column;gap:10px}
.info-card .ic-k{font-size:12px;color:var(--muted);letter-spacing:.04em}
.info-card .ic-v{font-size:20px;font-weight:600;letter-spacing:-.01em}
.info-card .ic-v span{display:block;font-size:15px;font-weight:400;color:#4a4a45;margin-top:2px}
.info-card a{color:var(--ink);font-size:13px;border-bottom:1px solid var(--ink);text-decoration:none;align-self:flex-start;padding-bottom:2px;margin-top:6px;display:inline-flex;align-items:center;gap:7px}
.info-card a .arr{display:inline-flex;align-items:center;justify-content:center;width:1.05em;height:1.05em;flex:none;transition:transform .3s cubic-bezier(.2,.8,.2,1)}
.info-card a .arr svg{width:100%;height:100%}

.map-hall-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:clamp(16px,2vw,24px);margin-top:22px;align-items:start}
.panel{background:var(--white);border:1px solid var(--line);border-radius:var(--r-card);padding:clamp(20px,2.5vw,28px)}
.panel h3{font-size:20px;font-weight:600;margin-bottom:6px}
.panel .ph-sub{font-size:13px;color:var(--muted);margin-bottom:16px}
.map-box{position:relative;border-radius:var(--r-sm);overflow:hidden;border:1px solid var(--line);background:#e9ebe7}
.map-box svg{width:100%;display:block}
.map-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.arrive-list{list-style:none;margin:18px 0 0;padding:0;display:flex;flex-direction:column;gap:0}
.arrive-list li{display:flex;gap:14px;align-items:baseline;padding:12px 2px;border-top:1px solid var(--line);font-size:13.5px;color:#3a3a37;line-height:1.5}
.arrive-list li:last-child{border-bottom:1px solid var(--line)}
.arrive-list .al-k{flex:none;width:54px;font-size:11px;letter-spacing:.05em;color:var(--muted);text-transform:uppercase}
.hall-box{position:relative;border-radius:var(--r-sm);overflow:hidden;background:transparent}
.hall-box img{width:100%}
.hall-box .hallplan-svg{display:block;width:100%;height:auto}
.hall-legend{display:flex;align-items:center;gap:10px;font-size:13px;margin-top:14px;color:#3a3a37}
.hall-legend .sw{width:22px;height:14px;background:var(--neon);border:1.5px solid var(--ink);border-radius:3px;display:inline-block}
.stand-head{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px}
.stand-fact{flex:0 0 auto;width:max-content;min-width:0;background:var(--pill);border:1px solid var(--line);border-radius:var(--r-sm);padding:12px 14px;overflow:hidden}
.stand-fact .sf-k{font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.stand-fact .sf-v{font-size:17px;font-weight:600;line-height:1.2;overflow-wrap:break-word;word-break:break-word}

/* FOOTER */
.footer{background:var(--ink);color:var(--bg);padding:clamp(50px,6vw,80px) 0 30px}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
.footer-logo svg{height:30px;width:auto}
.footer-addr{font-size:13.5px;color:#bdbcb5;line-height:1.7;margin-top:18px}
.footer-col h4{font-size:12px;letter-spacing:.05em;color:#8d8c86;margin-bottom:14px}
.footer-col a{display:block;color:var(--bg);text-decoration:none;font-size:14px;margin-bottom:9px;opacity:.85;transition:opacity .2s}
.footer-col a:hover{opacity:1}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;margin-top:48px;padding-top:22px;border-top:1px solid rgba(242,240,236,.16);font-size:12.5px;color:#8d8c86}
.footer-bottom a{color:#8d8c86;text-decoration:none;margin-left:18px}
.footer-bottom a:hover{color:var(--bg)}

/* ===== TEAM-DETAIL-OVERLAY ===== */
.area-overlay{position:fixed;inset:0;z-index:200;
  background:rgba(20,24,22,.55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  opacity:0;visibility:hidden;transition:opacity .35s ease,visibility .35s;
  display:flex;justify-content:center;padding:clamp(0px,2.4vw,40px)}
.area-overlay.open{opacity:1;visibility:visible}
.area-panel{position:relative;width:100%;max-width:1180px;background:var(--bg);
  border:1px solid rgba(29,29,27,.22);border-radius:var(--r);overflow:hidden;
  display:flex;flex-direction:column;max-height:100%;
  box-shadow:0 40px 90px -30px rgba(20,24,22,.7);
  transform:translateY(20px) scale(.985);transition:transform .4s cubic-bezier(.2,.8,.2,1)}
.area-overlay.open .area-panel{transform:none}
.area-bar{position:sticky;top:0;z-index:10;background:rgba(242,240,236,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.area-bar-inner{display:flex;align-items:center;justify-content:space-between;padding:16px clamp(20px,4vw,40px)}
.area-back{display:inline-flex;align-items:center;gap:10px;background:none;border:none;cursor:pointer;
  font-size:14px;color:var(--ink);font-family:inherit;padding:8px 0;transition:opacity .2s}
.area-back:hover{opacity:.6}
.area-back .arr-back{display:inline-flex;width:1.1em;height:1.1em}
.area-back .arr-back svg{width:100%;height:100%}
.area-bar-logo{height:24px}.area-bar-logo svg{height:100%;width:auto}
.area-scroll{overflow-y:auto;flex:1}
.area-hero{padding:clamp(40px,6vw,80px) 0 clamp(30px,4vw,50px)}
.area-title{font-size:clamp(40px,7vw,92px);font-weight:600;letter-spacing:-.03em;line-height:.95;margin:10px 0 14px}
.area-tagline{font-size:clamp(14px,1.6vw,18px);color:var(--muted);margin-bottom:20px}
.area-intro{font-size:clamp(15px,1.6vw,18px);color:#3a3a37;max-width:60ch;line-height:1.6}
.area-people-sec{padding:clamp(30px,4vw,50px) 0}
.area-group{margin-bottom:clamp(34px,4vw,56px)}
.area-group:last-child{margin-bottom:0}
.area-group-head{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;margin-bottom:20px;
  padding-bottom:14px;border-bottom:1px solid var(--line)}
.area-group-head h3{font-size:clamp(22px,2.6vw,30px);font-weight:600;letter-spacing:-.02em}
.area-group-head .agh-tag{font-size:13px;color:var(--muted);font-family:ui-monospace,monospace}
.area-group .area-people{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,1.6vw,20px)}
.area-people{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(14px,1.6vw,20px)}
.person-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-card);
  padding:clamp(18px,2.2vw,26px);display:flex;flex-direction:column;gap:14px;transition:transform .3s,box-shadow .3s}
.person-card:hover{transform:translateY(-3px);box-shadow:0 16px 36px -24px rgba(29,29,27,.45)}
.person-top{display:flex;align-items:center;gap:14px}
.person-avatar{width:54px;height:54px;border-radius:50%;background:var(--neon);color:var(--ink);
  display:flex;align-items:center;justify-content:center;font-weight:600;font-size:18px;letter-spacing:-.02em;flex:none;
  font-family:ui-monospace,monospace}
.person-name{font-size:19px;font-weight:600;letter-spacing:-.01em}
.person-role{font-size:13px;color:var(--muted);line-height:1.4}
.person-card .person-contact{display:flex;gap:10px;flex-wrap:wrap;margin-top:auto;padding-top:6px}
.person-contact a{font-size:12px;font-family:ui-monospace,monospace;border:1px solid var(--line);
  border-radius:999px;padding:6px 13px;color:var(--ink);text-decoration:none;transition:.2s}
.person-contact a:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.area-quote-sec{padding:clamp(20px,3vw,40px) 0}
.area-quote{font-size:clamp(24px,3.6vw,46px);font-weight:600;letter-spacing:-.02em;line-height:1.15;
  max-width:20ch;border-left:4px solid var(--neon);padding-left:clamp(18px,2vw,28px)}
.area-book-sec{padding:clamp(40px,6vw,90px) 0 clamp(60px,8vw,120px)}
.area-contact{margin-top:24px;display:flex;flex-direction:column;gap:12px}
.contact-row{display:flex;gap:14px;font-size:14px;align-items:baseline}
.contact-row .ck{color:var(--muted);min-width:64px;font-size:12px}
.contact-row a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--ink);padding-bottom:1px}
body.overlay-open{overflow:hidden}

@media(max-width:900px){
  .area-people{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .area-people{grid-template-columns:1fr}
}

@media(max-width:900px){
  .nav-links,.nav-cta{display:none}
  .burger{display:flex}
  .mobile-menu{display:none;flex-direction:column;gap:4px;padding:8px clamp(20px,5vw,64px) 20px;background:var(--bg);border-bottom:1px solid var(--line)}
  .mobile-menu.open{display:flex}
  .mobile-menu a{padding:12px 0;border-bottom:1px solid var(--line);text-decoration:none;color:var(--ink);font-size:16px}
  .mobile-menu .pill{margin-top:10px;justify-content:center}
  .hero-grid,.vision-grid,.stage-grid,.ticket,.nl-grid,.team-grid,.map-hall-grid,.bau-grid{grid-template-columns:1fr}
  .grid-news{grid-template-columns:1fr 1fr}
  .info-grid{grid-template-columns:1fr}
  .ticket-img{min-height:220px}
  .team-img{order:-1}
  .hero-visual{height:clamp(320px,80vw,460px)}
}
@media(max-width:560px){
  .grid-news{grid-template-columns:1fr}
  .cd-units{gap:10px}.cd-unit{min-width:36px}
}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* IMPRESSUM-MODAL */
.imprint-overlay{position:fixed;inset:0;z-index:300;background:rgba(20,24,22,.55);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s;
  display:flex;align-items:center;justify-content:center;padding:clamp(14px,3vw,40px)}
.imprint-overlay.open{opacity:1;visibility:visible}
.imprint-panel{width:100%;max-width:680px;max-height:100%;background:var(--bg);
  border:1px solid rgba(29,29,27,.22);border-radius:var(--r);overflow:hidden;
  display:flex;flex-direction:column;box-shadow:0 40px 90px -30px rgba(20,24,22,.7);
  transform:translateY(18px) scale(.99);transition:transform .35s cubic-bezier(.2,.8,.2,1)}
.imprint-overlay.open .imprint-panel{transform:none}
.imprint-bar{display:flex;align-items:center;justify-content:space-between;
  padding:16px clamp(20px,3vw,32px);border-bottom:1px solid var(--line);
  background:rgba(242,240,236,.92);backdrop-filter:blur(10px)}
.imprint-bar .mono{font-size:13px;letter-spacing:.05em}
.imprint-close{background:none;border:1px solid var(--line);border-radius:999px;
  width:34px;height:34px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--ink);transition:.2s;flex:none}
.imprint-close svg{width:16px;height:16px}
.imprint-close:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.imprint-scroll{overflow-y:auto}
/* ===== BOOKING (Microsoft Bookings) OVERLAY ===== */
.book-overlay{position:fixed;inset:0;z-index:320;background:rgba(20,24,22,.55);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s;
  display:flex;align-items:center;justify-content:center;padding:clamp(14px,3vw,40px)}
.book-overlay.open{opacity:1;visibility:visible}
.book-panel{width:100%;max-width:760px;height:min(86vh,860px);background:var(--bg);
  border:1px solid rgba(29,29,27,.22);border-radius:var(--r);overflow:hidden;
  display:flex;flex-direction:column;box-shadow:0 40px 90px -30px rgba(20,24,22,.7);
  transform:translateY(18px) scale(.99);transition:transform .35s cubic-bezier(.2,.8,.2,1)}
.book-overlay.open .book-panel{transform:translateY(0) scale(1)}
.book-bar{display:flex;align-items:center;justify-content:space-between;
  padding:16px clamp(20px,3vw,32px);border-bottom:1px solid var(--line);
  background:rgba(242,240,236,.92);backdrop-filter:blur(10px);flex:none}
.book-close{background:none;border:1px solid var(--line);border-radius:999px;
  width:34px;height:34px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--ink);transition:.2s;flex:none}
.book-close:hover{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.book-frame-wrap{position:relative;flex:1;background:#fff}
.book-frame-wrap iframe{width:100%;height:100%;border:0;display:block}
.book-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;gap:14px;
  padding:clamp(24px,5vw,56px);background:var(--bg)}
.book-placeholder .bp-tag{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12px;
  letter-spacing:.05em;color:var(--muted);background:var(--pill);padding:6px 13px;border-radius:999px}
.book-placeholder h3{font-size:clamp(22px,3vw,30px);font-weight:600;max-width:24ch;line-height:1.15}
.book-placeholder p{font-size:14px;color:var(--muted);max-width:46ch}
.bk-teaser-note{font-size:12px;color:var(--muted);margin-top:10px}
.imprint-content{padding:clamp(26px,4vw,44px)}
.imprint-content h2{font-size:clamp(24px,3.4vw,34px);font-weight:600;letter-spacing:-.02em;margin-bottom:24px}
.imp-block{padding:16px 0;border-top:1px solid var(--line)}
.imp-block:first-of-type{border-top:none;padding-top:0}
.imp-k{display:block;font-size:11px;letter-spacing:.05em;color:var(--muted);text-transform:uppercase;margin-bottom:6px}
.imp-block p{font-size:14.5px;color:#3a3a37;line-height:1.6}
.imp-company{font-size:17px;font-weight:600;color:var(--ink);margin-bottom:8px}
.imp-block a{color:var(--ink);border-bottom:1px solid var(--ink);text-decoration:none}
.imp-block a:hover{opacity:.6}
.imp-note{font-size:12.5px;color:var(--muted);line-height:1.5;margin-top:22px;padding-top:18px;border-top:1px solid var(--line)}
body.modal-open{overflow:hidden}
