:root{--sage: #6B8F71;--sage-dark: #4A6B50;--sage-light: #EAF0EB;--gold: #C5A467;--gold-light: #F5EDD8;--caramel: #D4A574;--cream: #F5F0E8;--cream-dark: #EDE7DA;--forest: #2C4A3E;--bark: #6B5B45;--text: #2C2C2C;--text-soft: #6B6B6B;--white: #FFFFFF;--error: #C0392B;--font-display: "Cormorant Garamond", Georgia, serif;--font-body: "DM Sans", system-ui, sans-serif;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 20px;--shadow-sm: 0 2px 8px rgba(44, 74, 62, .08);--shadow-md: 0 6px 24px rgba(44, 74, 62, .12);--shadow-lg: 0 16px 48px rgba(44, 74, 62, .16);--transition: .2s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font-body);font-weight:400;color:var(--text);background:var(--cream);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");pointer-events:none;z-index:9999;opacity:.4}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{text-align:center;padding:24px 24px 16px;background:linear-gradient(180deg,var(--forest) 0%,var(--sage-dark) 100%);position:relative;overflow:hidden}.app-header:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:32px;background:var(--cream);clip-path:ellipse(55% 100% at 50% 100%)}.header-eyebrow{font-family:var(--font-body);font-size:11px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}.header-title{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.2rem);font-weight:400;color:var(--white);line-height:1.15;letter-spacing:-.01em}.header-title em{font-style:italic;color:var(--gold)}.header-subtitle{margin-top:12px;font-size:14px;color:#ffffffa6;font-weight:300}.app-main{flex:1;max-width:900px;width:100%;margin:0 auto;padding:24px 24px 48px}.step-indicator{display:flex;align-items:center;justify-content:center;margin-bottom:20px;gap:0}.step-item{display:flex;flex-direction:column;align-items:center;gap:8px;position:relative}.step-item+.step-item:before{content:"";position:absolute;right:100%;top:18px;width:64px;height:1px;background:var(--cream-dark);transform:translate(-4px)}.step-item.done+.step-item:before,.step-item.active+.step-item:before{background:linear-gradient(90deg,var(--gold),var(--cream-dark))}.step-item.done+.step-item.done:before,.step-item.done+.step-item.active:before{background:var(--gold)}.step-circle{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-body);font-size:13px;font-weight:500;border:1.5px solid var(--cream-dark);background:var(--white);color:var(--text-soft);transition:all var(--transition);z-index:1}.step-item.active .step-circle{background:var(--forest);border-color:var(--forest);color:var(--white);box-shadow:0 0 0 4px var(--sage-light)}.step-item.done .step-circle{background:var(--gold);border-color:var(--gold);color:var(--white)}.step-label{font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text-soft);white-space:nowrap}.step-item.active .step-label{color:var(--forest)}.step-item.done .step-label{color:var(--gold)}.section-heading{text-align:center;margin-bottom:16px}.section-heading h2{font-family:var(--font-display);font-size:clamp(1.6rem,3vw,2.4rem);font-weight:500;color:var(--forest);letter-spacing:-.01em}.section-heading p{margin-top:8px;font-size:15px;color:var(--text-soft);font-weight:300}.kalender-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}.kalender-woche{border-radius:var(--radius-md);padding:8px;cursor:pointer;transition:all var(--transition);border:1.5px solid transparent;position:relative;background:var(--white);box-shadow:var(--shadow-sm)}.kalender-woche:hover:not(.ausgebucht):not(.vergangen){transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--sage)}.kalender-woche.selected{border-color:var(--forest);background:var(--sage-light);box-shadow:var(--shadow-md)}.kalender-woche.vergangen{opacity:.4;cursor:not-allowed}.kalender-woche.ausgebucht{background:var(--cream-dark);cursor:not-allowed}.kalender-woche.ausgebucht .woche-datum{text-decoration:line-through;opacity:.5}.woche-kw{font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-soft);margin-bottom:4px}.woche-datum{font-size:13px;font-weight:500;color:var(--forest);line-height:1.3}.woche-ampel{display:flex;align-items:center;gap:5px;margin-top:8px}.ampel-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.ampel-dot.frei{background:#48bb78}.ampel-dot.wenig{background:#c5a467}.ampel-dot.fast-voll{background:#e69a2e}.ampel-dot.ausgebucht{background:#cbd5e0}.ampel-text{font-size:11px;color:var(--text-soft)}.woche-tw-badge{position:absolute;top:-6px;right:-6px;font-size:9px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;background:var(--gold);color:var(--white);padding:2px 6px;border-radius:10px;white-space:nowrap;max-width:90px;overflow:hidden;text-overflow:ellipsis}.monat-gruppe{margin-bottom:16px}.monat-label{font-family:var(--font-display);font-size:1.1rem;font-weight:500;color:var(--bark);margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--cream-dark);letter-spacing:.02em}.kategorie-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.kategorie-karte{background:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1.5px solid transparent;cursor:pointer;transition:all var(--transition)}.kategorie-karte:hover:not(.nicht-verfuegbar){transform:translateY(-3px);box-shadow:var(--shadow-lg);border-color:var(--sage)}.kategorie-karte.selected{border-color:var(--forest);box-shadow:var(--shadow-md)}.kategorie-karte.nicht-verfuegbar{opacity:.5;cursor:not-allowed}.kategorie-bild{height:140px;background:linear-gradient(135deg,var(--sage-dark) 0%,var(--forest) 100%);position:relative;display:flex;align-items:flex-end;padding:16px}.kategorie-bild-icon{font-size:36px;position:absolute;top:50%;left:50%;transform:translate(-50%,-60%);opacity:.25;filter:grayscale(1) brightness(2)}.kategorie-bild-name{font-family:var(--font-display);font-size:1.4rem;font-weight:500;color:var(--white);position:relative;z-index:1;letter-spacing:.01em}.kategorie-body{padding:20px}.kategorie-beschreibung{font-size:13px;color:var(--text-soft);line-height:1.6;margin-bottom:16px;font-weight:300}.kategorie-ausstattung{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}.ausstattung-tag{font-size:11px;font-weight:500;background:var(--sage-light);color:var(--sage-dark);padding:3px 9px;border-radius:20px;letter-spacing:.03em}.kategorie-preise{display:flex;gap:12px;margin-bottom:16px}.preis-option{flex:1;background:var(--cream);border-radius:var(--radius-sm);padding:10px 12px;cursor:pointer;border:1.5px solid transparent;transition:all var(--transition)}.preis-option:hover,.preis-option.selected{border-color:var(--gold);background:var(--gold-light)}.preis-option-label{font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-soft);margin-bottom:3px}.preis-option-wert{font-family:var(--font-display);font-size:1.3rem;font-weight:600;color:var(--forest)}.preis-option-sub{font-size:10px;color:var(--text-soft)}.kategorie-verfuegbar{font-size:12px;color:var(--sage);font-weight:500}.kategorie-verfuegbar.knapp{color:var(--caramel)}.kategorie-verfuegbar.voll{color:var(--text-soft)}.formular-section{background:var(--white);border-radius:var(--radius-lg);padding:16px 20px;box-shadow:var(--shadow-sm);margin-bottom:12px}.formular-section-title{font-family:var(--font-display);font-size:1.2rem;font-weight:500;color:var(--forest);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--cream-dark);letter-spacing:.01em}.formular-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}.formular-row.single{grid-template-columns:1fr}.formular-row.triple{grid-template-columns:1fr 1fr 1fr}@media (max-width: 600px){.formular-row,.formular-row.triple{grid-template-columns:1fr}}.form-field{display:flex;flex-direction:column;gap:4px}.form-label{font-size:12px;font-weight:500;letter-spacing:.05em;text-transform:uppercase;color:var(--text-soft)}.form-label.required:after{content:" *";color:var(--error)}.form-input,.form-select,.form-textarea{font-family:var(--font-body);font-size:15px;font-weight:400;color:var(--text);background:var(--cream);border:1.5px solid var(--cream-dark);border-radius:var(--radius-sm);padding:8px 12px;transition:border-color var(--transition),box-shadow var(--transition);outline:none;width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--sage);box-shadow:0 0 0 3px var(--sage-light)}.form-input.error,.form-select.error{border-color:var(--error)}.form-error-msg{font-size:12px;color:var(--error)}.form-textarea{resize:vertical;min-height:72px}.zusammenfassung{background:linear-gradient(135deg,var(--forest) 0%,var(--sage-dark) 100%);border-radius:var(--radius-lg);padding:32px;color:var(--white);margin-bottom:24px;position:relative;overflow:hidden}.zusammenfassung:after{content:"🌿";position:absolute;right:24px;top:24px;font-size:64px;opacity:.1}.zus-label{font-size:10px;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:4px}.zus-wert{font-family:var(--font-display);font-size:1.15rem;font-weight:500;color:var(--white);margin-bottom:20px}.zus-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}.zus-preis{grid-column:1 / -1;border-top:1px solid rgba(255,255,255,.15);padding-top:16px;display:flex;justify-content:space-between;align-items:baseline}.zus-preis-label{font-size:13px;color:#ffffffb3}.zus-preis-wert{font-family:var(--font-display);font-size:2rem;font-weight:600;color:var(--gold)}.zus-preis-sub{font-size:12px;color:#ffffff80;margin-left:8px}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;background:var(--forest);color:var(--white);font-family:var(--font-body);font-size:14px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;padding:14px 36px;border-radius:var(--radius-sm);border:none;cursor:pointer;transition:all var(--transition);box-shadow:0 4px 16px #2c4a3e4d}.btn-primary:hover{background:var(--sage-dark);transform:translateY(-1px);box-shadow:0 6px 20px #2c4a3e66}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-secondary{display:inline-flex;align-items:center;gap:6px;background:transparent;color:var(--text-soft);font-family:var(--font-body);font-size:13px;font-weight:500;padding:10px 20px;border-radius:var(--radius-sm);border:1.5px solid var(--cream-dark);cursor:pointer;transition:all var(--transition)}.btn-secondary:hover{border-color:var(--sage);color:var(--sage-dark)}.schritt-nav{display:flex;justify-content:space-between;align-items:center;margin-top:20px;padding-top:14px;border-top:1px solid var(--cream-dark)}.erfolg-screen{text-align:center;padding:48px 24px;animation:fadeInUp .6s ease both}.erfolg-icon{width:72px;height:72px;background:var(--sage-light);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;font-size:32px}.erfolg-titel{font-family:var(--font-display);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:500;color:var(--forest);margin-bottom:12px}.erfolg-nr{font-size:14px;color:var(--text-soft);margin-bottom:32px}.erfolg-nr strong{font-weight:600;color:var(--gold);font-size:16px}.erfolg-hinweis{background:var(--gold-light);border-radius:var(--radius-md);padding:20px 24px;font-size:14px;color:var(--bark);line-height:1.7;max-width:480px;margin:0 auto;font-weight:300}.lade-container{text-align:center;padding:64px 24px;color:var(--text-soft)}.lade-spinner{width:32px;height:32px;border:2px solid var(--cream-dark);border-top-color:var(--sage);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}.fehler-box{background:#fef2f2;border:1px solid #FECACA;border-radius:var(--radius-md);padding:16px 20px;color:var(--error);font-size:14px;text-align:center;margin-bottom:24px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.schritt-content{animation:fadeInUp .35s ease both}@media (max-width: 480px){.app-main{padding:24px 16px 64px}.step-indicator{gap:0}.step-item+.step-item:before{width:32px}.formular-section{padding:20px 16px}.zusammenfassung{padding:20px}}
