:root{--color-primary: #e8a0b8;--color-primary-dark: #d488a4;--color-secondary: #f5e6d3;--color-accent: #7b9e87;--color-accent-dark: #5f8269;--color-text: #3d3d3d;--color-white: #fffaf5;--font-display: "Caveat", cursive;--font-body: "Nunito", system-ui, sans-serif;--shadow-soft: 0 8px 32px rgba(61, 61, 61, .1);--radius: 16px;--radius-lg: 24px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-body);color:var(--color-text);background:var(--color-secondary);min-height:100dvh;line-height:1.6;-webkit-font-smoothing:antialiased}#root{min-height:100dvh}h1,h2,h3{font-family:var(--font-display);font-weight:600;line-height:1.2}a{color:var(--color-accent-dark)}button{font-family:var(--font-body);cursor:pointer;border:none;background:none}.page{width:100%;max-width:720px;margin:0 auto;padding:2rem 1.25rem 3rem;animation:fadeIn .5s ease}.page--wide{max-width:960px}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes popIn{0%{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}@keyframes floatUp{0%{opacity:0;transform:translateY(0) scale(.8)}15%{opacity:1}to{opacity:0;transform:translateY(-120px) scale(1.1)}}@keyframes wiggle{0%,to{transform:rotate(-3deg)}50%{transform:rotate(3deg)}}@keyframes glowPulse{0%,to{box-shadow:0 0 #e8a0b866}50%{box-shadow:0 0 24px 8px #e8a0b880}}.title-xl{font-size:clamp(2.4rem,8vw,3.5rem);color:var(--color-primary-dark);margin-bottom:.75rem}.title-lg{font-size:clamp(1.8rem,5vw,2.5rem);color:var(--color-primary-dark);margin-bottom:.75rem}.title-md{font-size:clamp(1.4rem,4vw,1.8rem);color:var(--color-primary-dark);margin-bottom:.5rem}.subtitle{font-size:1.1rem;opacity:.85;margin-bottom:2rem}.text-block{font-size:1.05rem;margin-bottom:1.25rem}.text-block p+p{margin-top:.75rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.9rem 1.75rem;border-radius:999px;font-weight:700;font-size:1rem;transition:transform .2s,box-shadow .2s,background .2s}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn-primary{background:var(--color-primary);color:var(--color-white);box-shadow:var(--shadow-soft)}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-2px);box-shadow:0 12px 28px #e8a0b859}.btn-secondary{background:var(--color-accent);color:var(--color-white);box-shadow:var(--shadow-soft)}.btn-secondary:hover:not(:disabled){background:var(--color-accent-dark);transform:translateY(-2px)}.btn-outline{background:transparent;border:2px solid var(--color-primary);color:var(--color-primary-dark)}.btn-outline:hover:not(:disabled){background:#e8a0b826}.btn-block{width:100%}.option-btn{display:block;width:100%;text-align:left;padding:1rem 1.25rem;margin-bottom:.75rem;border-radius:var(--radius);background:var(--color-white);border:2px solid transparent;color:var(--color-text);font-size:1rem;font-weight:600;box-shadow:var(--shadow-soft);transition:border-color .2s,transform .2s,background .2s}.option-btn:hover:not(:disabled){border-color:var(--color-primary);transform:translate(4px)}.option-btn:disabled{opacity:.7;cursor:default}.option-btn--selected{border-color:var(--color-accent);background:#7b9e871f}.comment-box{margin:1.25rem 0;padding:1rem 1.25rem;border-radius:var(--radius);font-style:italic;animation:popIn .35s ease}.comment-box--correct{background:#7b9e8733;border-left:4px solid var(--color-accent);color:var(--color-accent-dark)}.comment-box--wrong{background:#e8a0b833;border-left:4px solid var(--color-primary)}.card{background:var(--color-white);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-soft)}.icon-row{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center;margin:1.5rem 0}.icon-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem 1rem;border-radius:999px;background:#7b9e8726;font-size:.9rem;font-weight:600}.letter-row{display:flex;justify-content:center;gap:.4rem;flex-wrap:wrap;margin:2rem 0 1rem}.letter-slot{width:2.2rem;height:2.6rem;display:flex;align-items:center;justify-content:center;border-radius:8px;background:var(--color-white);border:2px dashed var(--color-primary);font-family:var(--font-display);font-size:1.5rem;font-weight:600;color:var(--color-primary-dark);transition:all .3s ease}.letter-slot--filled{border-style:solid;border-color:var(--color-accent);background:#7b9e8733;animation:popIn .4s ease}.letter-slot--complete{animation:glowPulse 1.5s ease infinite}.dest-grid{display:grid;gap:1rem;margin:1.5rem 0}@media(min-width:640px){.dest-grid{grid-template-columns:repeat(3,1fr)}}.dest-card{border-radius:var(--radius-lg);overflow:hidden;background:var(--color-white);box-shadow:var(--shadow-soft);transition:transform .25s,box-shadow .25s;border:3px solid transparent;display:flex;flex-direction:column}.dest-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px #3d3d3d26}.dest-card--selected{border-color:var(--color-primary);animation:glowPulse 2s ease infinite}.dest-card__image{position:relative;height:160px;width:100%;display:flex;align-items:center;justify-content:center;font-size:3rem;border:none;padding:0;cursor:pointer;overflow:hidden}.dest-card__photo{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.dest-card__info-hint{position:absolute;bottom:.5rem;right:.5rem;z-index:2;padding:.3rem .65rem;border-radius:999px;background:#ffffffeb;font-size:.7rem;font-weight:700;color:var(--color-accent-dark);box-shadow:var(--shadow-soft)}.dest-card__body{padding:1rem;flex:1;display:flex;flex-direction:column}.dest-card__select{margin-top:auto;padding-top:.75rem;width:100%;font-size:.9rem}.dest-card__select--active{background:#e8a0b833;border-color:var(--color-primary)}.dest-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;background:#3d3d3d8c;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fadeIn .25s ease}.dest-modal{position:relative;width:100%;max-width:520px;max-height:90dvh;overflow-y:auto;background:var(--color-white);border-radius:var(--radius-lg);box-shadow:0 24px 64px #3d3d3d40;animation:popIn .3s ease}.dest-modal__close{position:absolute;top:.75rem;right:.75rem;z-index:10;width:2.25rem;height:2.25rem;border-radius:50%;background:#fffffff2;color:var(--color-text);font-size:1rem;font-weight:700;box-shadow:var(--shadow-soft);display:flex;align-items:center;justify-content:center}.dest-modal__gallery{position:relative;height:220px;background:var(--color-secondary);overflow:hidden}.dest-modal__image{width:100%;height:100%;object-fit:cover}.dest-modal__fallback{position:absolute;top:0;right:0;bottom:0;left:0;display:none;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;font-size:3rem;color:#fff}.dest-modal__fallback span{font-size:.75rem;font-weight:600;opacity:.9;padding:0 1rem;text-align:center}.dest-modal__fallback--visible{display:flex}.dest-modal__nav{position:absolute;top:50%;transform:translateY(-50%);width:2.25rem;height:2.25rem;border-radius:50%;background:#ffffffeb;color:var(--color-text);font-size:1.25rem;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-soft)}.dest-modal__nav:disabled{opacity:.35;cursor:not-allowed}.dest-modal__nav--prev{left:.5rem}.dest-modal__nav--next{right:.5rem}.dest-modal__dots{position:absolute;bottom:.65rem;left:50%;transform:translate(-50%);display:flex;gap:.35rem}.dest-modal__dot{width:8px;height:8px;border-radius:50%;background:#ffffff8c;padding:0}.dest-modal__dot--active{background:#fff;transform:scale(1.2)}.dest-modal__body{padding:1.25rem 1.25rem 1.5rem}.dest-modal__highlights{list-style:none;margin:0 0 1.25rem;padding:0;display:flex;flex-direction:column;gap:.45rem}.dest-modal__highlights li{padding:.45rem .75rem;border-radius:8px;background:#7b9e871f;font-size:.9rem;font-weight:600}.dest-modal__highlights li:before{content:"✓ ";color:var(--color-accent-dark)}.dest-card__name{font-family:var(--font-display);font-size:1.25rem;color:var(--color-primary-dark);margin-bottom:.35rem}.dest-card__desc{font-size:.85rem;opacity:.8;margin-bottom:.5rem}.dest-card__teaser{font-size:.75rem;font-weight:700;color:var(--color-accent-dark)}.calendar{margin:1.5rem 0}.calendar__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.calendar__month{font-family:var(--font-display);font-size:1.5rem;color:var(--color-primary-dark)}.calendar__nav{width:2.5rem;height:2.5rem;border-radius:50%;background:var(--color-primary);color:#fff;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:background .2s}.calendar__nav:hover{background:var(--color-primary-dark)}.calendar__weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:4px;text-align:center;font-size:.75rem;font-weight:700;opacity:.6}.calendar__weekday--weekend{color:var(--color-primary-dark);opacity:1}.calendar__days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar__day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:10px;font-size:.9rem;font-weight:600;background:var(--color-white);transition:background .2s,color .2s}.calendar__day--empty{background:transparent;pointer-events:none}.calendar__day--weekend{background:#7b9e872e;border:2px solid rgba(123,158,135,.35)}.calendar__day--disabled{opacity:.35;pointer-events:none;cursor:not-allowed}.calendar__day--disabled.calendar__day--weekend{background:#7b9e871a;border-color:#7b9e8733}.calendar__day--selectable:hover{background:#e8a0b859;border-color:var(--color-primary)}.calendar__day--selected{background:var(--color-primary);border-color:var(--color-primary-dark);color:#fff}.runaway-btn-wrap{display:flex;justify-content:center;margin:1.25rem 0 .5rem}.runaway-btn{padding:.75rem 1.25rem;border-radius:999px;background:var(--color-accent);color:#fff;font-weight:700;font-size:.9rem;box-shadow:var(--shadow-soft);-webkit-user-select:none;user-select:none;touch-action:none}.runaway-btn--inline{position:relative}.runaway-btn--escaped{position:fixed;z-index:100;transition:left .15s ease-out,top .15s ease-out}.runaway-message{margin-top:3rem;padding:1.25rem;border-radius:var(--radius);background:#e8a0b840;border:2px solid var(--color-primary);font-weight:700;text-align:center;animation:popIn .4s ease}.confetti-piece{position:fixed;width:10px;height:10px;top:-10px;z-index:200;pointer-events:none;animation:confettiFall linear forwards}@keyframes confettiFall{to{transform:translateY(100vh) rotate(720deg);opacity:0}}.cake{font-size:4rem;display:inline-block;animation:wiggle 1.5s ease-in-out infinite;margin:1rem 0}.hidden-heart{position:fixed;bottom:12px;right:12px;font-size:1rem;opacity:.15;cursor:pointer;border:none;background:none;transition:opacity .2s;z-index:50}.hidden-heart:hover{opacity:.4}.easter-egg-toast{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);padding:1rem 1.5rem;background:var(--color-primary);color:#fff;border-radius:var(--radius);font-weight:700;z-index:300;animation:popIn .3s ease;box-shadow:var(--shadow-soft);max-width:90vw;text-align:center}.confirm-box{margin:1.5rem 0;padding:1.25rem;border-radius:var(--radius);background:#7b9e8726;border:2px solid var(--color-accent);text-align:center;animation:popIn .4s ease}.weekend-list{list-style:none;margin:.5rem 0 1rem;padding:0;display:flex;flex-direction:column;gap:.5rem}.weekend-list li{padding:.6rem .9rem;border-radius:var(--radius);background:#7b9e871f;font-weight:600;font-size:.95rem}.weekend-list--compact{margin-top:.75rem;margin-bottom:0}.weekend-list--compact li{font-size:.85rem;padding:.45rem .75rem}.ergebnis-card{display:flex;flex-direction:column;gap:1.25rem}.ergebnis-row{display:flex;flex-direction:column;gap:.35rem}@media(min-width:480px){.ergebnis-row{flex-direction:row;align-items:baseline;gap:1rem}}.ergebnis-label{font-weight:700;min-width:6rem;color:var(--color-accent-dark)}.ergebnis-value{font-size:1.1rem;font-weight:600}.ergebnis-value--highlight{font-family:var(--font-display);font-size:1.5rem;color:var(--color-primary-dark)}.ergebnis-meta{margin-top:.5rem;padding-top:1rem;border-top:1px solid rgba(123,158,135,.25);font-size:.85rem;opacity:.65}.ergebnis-gallery{display:grid;gap:1rem;margin-top:1.5rem}.ergebnis-gallery__item{margin:0;border-radius:var(--radius);overflow:hidden;background:var(--color-white);box-shadow:var(--shadow-soft)}.ergebnis-gallery__img{display:block;width:100%;max-height:320px;object-fit:cover}.ergebnis-gallery__caption{padding:.75rem 1rem;font-size:.85rem;opacity:.75}.footer-note{margin-top:2.5rem;text-align:center;font-family:var(--font-display);font-size:1.4rem;color:var(--color-primary-dark)}.actions{margin-top:2rem;display:flex;flex-direction:column;gap:.75rem;align-items:center}.progress-dots{display:flex;gap:.5rem;justify-content:center;margin-bottom:1.5rem}.progress-dot{width:10px;height:10px;border-radius:50%;background:#e8a0b84d;transition:background .3s,transform .3s}.progress-dot--active{background:var(--color-primary);transform:scale(1.2)}.progress-dot--done{background:var(--color-accent)}
