*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:#05000c;color:white}
a{text-decoration:none;color:inherit}

/* Intro */
.intro-body{height:100vh;overflow:hidden;background:#000}
.intro-body video{position:fixed;inset:0;width:100%;height:100%;object-fit:cover;background:#000}
.intro-overlay{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px;background:radial-gradient(circle at center,rgba(255,0,200,.30),rgba(0,0,0,.86) 60%,#000);z-index:5}
.intro-overlay.hide{display:none}
.intro-ticket{border:2px solid #ffb000;color:#ffb000;border-radius:14px;padding:10px 18px;box-shadow:0 0 20px #ffb000;font-weight:900;letter-spacing:2px}
.intro-overlay h1{font-size:clamp(3rem,12vw,7rem);line-height:.9;margin:18px 0;text-shadow:0 0 8px #fff,0 0 26px #ff00d4,0 0 70px #ff00d4}
.intro-overlay h1 span{color:#00e5ff;text-shadow:0 0 26px #00e5ff}
.intro-overlay p{font-size:1.15rem;color:#ffd8fb}
.abfahrt-btn{border:0;border-radius:18px;margin-top:18px;padding:18px 34px;background:linear-gradient(90deg,#ff7a00,#ff00d4,#00e5ff);color:#fff;font-size:1.35rem;font-weight:900;letter-spacing:2px;box-shadow:0 0 18px #ff00d4,0 0 45px rgba(0,229,255,.45);cursor:pointer;transition:.25s}
.abfahrt-btn:hover{transform:scale(1.07)}
.skip{margin-top:18px;text-decoration:underline;color:#fff}

/* Poster */
.home-body{background:#030008}
.poster{position:relative;min-height:100vh;overflow:hidden;background:
radial-gradient(circle at 28% 12%,rgba(255,0,212,.24),transparent 32%),
radial-gradient(circle at 86% 34%,rgba(0,229,255,.14),transparent 26%),
linear-gradient(180deg,#05000c 0%,#080010 58%,#07000b 100%)}
.poster:before{content:"";position:absolute;inset:0;background:
linear-gradient(90deg,rgba(255,0,212,.05) 1px,transparent 1px),
linear-gradient(rgba(0,229,255,.035) 1px,transparent 1px);background-size:44px 44px;opacity:.75;pointer-events:none}
.confetti:before,.confetti:after{content:"";position:absolute;inset:-20%;background:
radial-gradient(circle,#ffb000 0 3px,transparent 4px) 2% 10%/130px 110px,
radial-gradient(circle,#00e5ff 0 3px,transparent 4px) 18% 75%/160px 150px,
radial-gradient(circle,#ff00d4 0 3px,transparent 4px) 76% 18%/150px 140px,
radial-gradient(circle,#ff4a00 0 3px,transparent 4px) 88% 78%/145px 125px;
animation:confettiMove 16s linear infinite;opacity:.75;pointer-events:none}
.confetti:after{animation-duration:24s;transform:rotate(13deg);opacity:.45}

.topbar{position:absolute;top:0;left:0;right:0;z-index:20;height:76px;display:flex;align-items:center;justify-content:space-between;padding:16px 30px}
.logo{font-weight:900;font-size:1.38rem;line-height:.9;color:#ff45dd;text-shadow:0 0 17px #ff00d4}
.logo span{color:#00e5ff;text-shadow:0 0 17px #00e5ff}
.navlinks{display:flex;gap:42px;font-size:.82rem;font-weight:900;letter-spacing:1px}
.navlinks a:first-child{color:#ff45dd;border-bottom:2px solid #ff45dd;padding-bottom:8px}
.top-pass{border:2px solid #ff45dd;border-radius:14px;padding:11px 18px;font-weight:900;box-shadow:0 0 22px #ff00d4;background:rgba(255,0,212,.08)}

.hero{position:relative;height:58vw;min-height:690px;max-height:820px;overflow:hidden}
.heart-track{position:absolute;top:38px;left:7%;width:86%;height:56%;z-index:1;filter:drop-shadow(0 0 18px #ff00d4)}
.track-fat{fill:none;stroke:#ff00d4;stroke-width:22;stroke-linecap:round;stroke-linejoin:round;filter:url(#pinkGlow);opacity:.85}
.track-dash{fill:none;stroke:#ff65e6;stroke-width:7;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:28 14;animation:railDash 10s linear infinite}
.train rect{fill:#ff006f;filter:url(#pinkGlow)}
.train circle{fill:#00e5ff}
.train{animation:trainBounce 2.2s ease-in-out infinite}

.neon-side-sign{position:absolute;left:34px;top:170px;z-index:4;color:#ff7a00;font-size:2.5rem;font-weight:900;line-height:.88;transform:rotate(-8deg);text-shadow:0 0 7px #fff000,0 0 20px #ff7a00,0 0 42px #ff2f00}
.sound-button{position:absolute;right:74px;top:108px;z-index:12;border:2px solid #ff45dd;background:rgba(6,0,16,.62);color:white;border-radius:999px;width:62px;height:62px;box-shadow:0 0 24px #ff00d4;cursor:pointer}
.sound-button span{position:absolute;right:78px;top:34px;width:154px;text-align:right;color:#ff67e8;font-size:.78rem;transform:rotate(-8deg)}
.hero-grid{position:relative;z-index:6;max-width:1280px;height:100%;margin:0 auto;padding:78px 34px 0;display:grid;grid-template-columns:1fr 1.25fr 1fr;gap:28px;align-items:center}
.left-copy{align-self:center;margin-top:138px}
.left-copy p{font-size:1.05rem;letter-spacing:1px;color:#ffd8fb;margin:0 0 10px}
.left-copy h1{font-size:clamp(3rem,5vw,5.4rem);font-weight:300;line-height:.9;margin:0 0 24px;color:#ff45dd;text-shadow:0 0 12px #ff00d4,0 0 36px #ff00d4}
.left-copy span{display:block;line-height:1.55;max-width:395px}
.left-copy b{color:#ff45dd}
.couple{align-self:end;text-align:center;position:relative}
.couple:after{content:"";position:absolute;inset:18% 12% 6%;background:#ff00d4;filter:blur(72px);z-index:-1;opacity:.72}
.couple img{max-height:72vh;max-width:100%;object-fit:contain;filter:grayscale(1) contrast(1.08) drop-shadow(0 0 24px #ff00d4)}
.date-card{border:2px solid #ff45dd;border-radius:22px;padding:28px;text-align:center;background:rgba(9,0,20,.60);box-shadow:0 0 30px rgba(255,0,212,.70);backdrop-filter:blur(8px);margin-top:125px}
.date-card p{margin:0 0 12px;color:#00e5ff;font-weight:900}
.date-card strong{display:block;margin-bottom:12px;font-size:clamp(2.6rem,4.8vw,4.4rem);font-weight:300;color:#ff58df;text-shadow:0 0 22px #ff00d4}
.date-card span{line-height:1.5}
.arrow{position:absolute;left:50%;bottom:10px;z-index:8;transform:translateX(-50%);font-size:4.2rem;color:#ff45dd;text-shadow:0 0 18px #ff00d4}

.countdown-panel{position:relative;z-index:10;max-width:780px;margin:-48px auto 24px;padding:14px 26px;border:2px solid #ff45dd;border-radius:18px;background:rgba(6,0,14,.94);box-shadow:0 0 30px rgba(255,0,212,.58);text-align:center}
.countdown-panel p{margin:0 0 7px;color:#00e5ff;font-weight:900;letter-spacing:1px}
.countdown{display:flex;align-items:center;justify-content:center;gap:24px}
.countdown strong{display:block;font-size:3.15rem;font-weight:300;color:#ff58df;text-shadow:0 0 20px #ff00d4}
.countdown span{font-size:.72rem;font-weight:900}
.countdown i{font-size:2rem;color:#ff58df;font-style:normal}

.bottom-area{position:relative;z-index:6;max-width:1120px;margin:0 auto;padding:24px 26px 36px;display:grid;grid-template-columns:.85fr 1.2fr .72fr;gap:28px;align-items:center}
.ticket{transform:rotate(-8deg);border:2px solid #ffb000;border-radius:12px;padding:24px;background:rgba(18,8,0,.52);box-shadow:0 0 28px rgba(255,176,0,.70);color:#ffb000}
.ticket h2{font-size:3.5rem;margin:0;font-weight:300;text-shadow:0 0 22px #ffb000}
.ticket h3{font-size:2.1rem;margin:8px 0;text-shadow:0 0 16px #ffb000}
.ticket p{font-weight:900}
.barcode{height:70px;margin-top:16px;background:repeating-linear-gradient(90deg,#ffb000 0 3px,transparent 3px 8px,#ffb000 8px 11px,transparent 11px 16px);filter:drop-shadow(0 0 8px #ffb000)}
.rsvp{border:2px solid #ff45dd;border-radius:18px;padding:28px;background:rgba(9,0,20,.72);box-shadow:0 0 30px rgba(255,0,212,.50)}
.rsvp h2{font-size:2.8rem;font-weight:300;color:#ff58df;text-align:center;margin:0 0 8px;text-shadow:0 0 18px #ff00d4}
.rsvp p{text-align:center;color:#ffd8fb;margin-top:0}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
input,select{width:100%;padding:15px;border-radius:6px;border:1px solid rgba(255,255,255,.35);background:#08000f;color:#fff;margin-bottom:14px;font-size:.95rem}
.essen-block label{display:block;color:#00e5ff;font-weight:900;margin:6px 0 8px;text-shadow:0 0 10px #00e5ff}
.rsvp button{width:100%;padding:16px;border:2px solid #ff45dd;border-radius:8px;background:linear-gradient(180deg,rgba(255,0,212,.62),rgba(255,0,212,.18));color:#fff;font-size:1.2rem;font-weight:900;box-shadow:0 0 24px #ff00d4;cursor:pointer;transition:.25s}
.rsvp button:hover{transform:scale(1.03);filter:brightness(1.25)}
.mood{border:2px solid #ff45dd;border-radius:14px;padding:22px;background:rgba(9,0,20,.72);box-shadow:0 0 25px rgba(255,0,212,.52)}
.mood div{font-size:1.25rem;margin:16px 0;color:#00e5ff;text-shadow:0 0 12px #00e5ff}
.mood div:nth-child(1){color:#24ff80;text-shadow:0 0 12px #24ff80}
.mood div:nth-child(2),.mood div:nth-child(4){color:#ff67e8;text-shadow:0 0 12px #ff00d4}
footer{position:relative;z-index:8;text-align:center;padding:18px;color:#ffd8fb}

@keyframes railDash{to{stroke-dashoffset:-280}}
@keyframes trainBounce{50%{transform:translateY(-12px)}}
@keyframes confettiMove{to{transform:translateY(120px)}}

@media(max-width:900px){
.topbar{position:relative;height:auto;padding:14px 16px;background:#05000c}
.navlinks{display:none}
.top-pass{font-size:.8rem}
.hero{height:auto;min-height:0;padding-bottom:18px}
.heart-track{top:96px;left:-55%;width:210%;height:335px;opacity:.82}
.neon-side-sign{font-size:2rem;top:126px;left:16px}
.sound-button{right:16px;top:100px}
.sound-button span{display:none}
.hero-grid{display:flex;flex-direction:column;text-align:center;padding:40px 20px 0;gap:8px}
.left-copy{margin-top:220px;order:1}
.left-copy span{margin:0 auto}
.couple{order:2}
.couple img{max-height:440px;width:100%}
.date-card{order:3;margin-top:0;width:100%}
.countdown-panel{margin:0 14px 22px}
.countdown{gap:8px}
.countdown strong{font-size:2rem}
.bottom-area{grid-template-columns:1fr;padding:18px}
.ticket{transform:none}
.form-row{grid-template-columns:1fr}
.mood{text-align:center}
}
