:root{--blau:#0058a3;--blau-dunkel:#003d73;--gelb:#ffda1a;--rot:#e00751;--papier:#f5f5f0;--safe-bottom:env(safe-area-inset-bottom,0px)}*{box-sizing:border-box}html,body{background:var(--blau);color:#1a1a1a;touch-action:manipulation;-webkit-tap-highlight-color:transparent;height:100%;margin:0;font-family:Noto Sans,Segoe UI,system-ui,sans-serif;overflow-x:hidden}#app{flex-direction:column;min-height:100dvh;display:flex}.kopf{background:var(--blau);align-items:center;gap:10px;padding:10px 14px 6px;display:flex}.kopf img{border-radius:4px;height:40px}.kopf h1{color:var(--gelb);letter-spacing:.06em;margin:0;font-size:1.5rem;font-weight:900}.statsleiste{background:var(--gelb);color:var(--blau-dunkel);text-align:center;border-top:4px solid var(--blau-dunkel);border-bottom:4px solid var(--blau-dunkel);padding:10px 14px}.statsleiste .spass-anzeige{font-size:2rem;font-weight:900;line-height:1.1}.statsleiste .sps-anzeige{opacity:.85;font-size:.9rem;font-weight:700}.statsleiste .sterne-anzeige{color:var(--rot);font-size:.85rem;font-weight:700}main{background:var(--papier);flex:1;overflow-y:auto}.tab-panel{padding:14px 14px calc(76px + var(--safe-bottom));display:none}.tab-panel.aktiv{display:block}.abschnitt{color:var(--blau);letter-spacing:.08em;text-transform:uppercase;margin:18px 0 8px;font-size:1.05rem;font-weight:900}.zelt-buehne{justify-content:center;padding:8px 0 4px;display:flex;position:relative}.zelt-knopf{cursor:pointer;-webkit-user-select:none;user-select:none;background:0 0;border:none;width:min(64vw,260px);padding:0}.zelt-knopf svg{width:100%;height:auto;display:block}.zelt-knopf:active svg{animation:.25s zeltwackel}@keyframes zeltwackel{0%{transform:scale(1)rotate(0)}35%{transform:scale(.94)rotate(-2deg)}70%{transform:scale(1.03)rotate(1.5deg)}to{transform:scale(1)}}.floater{pointer-events:none;color:var(--blau);font-size:1.3rem;font-weight:900;animation:.9s ease-out forwards schweben;position:absolute}@keyframes schweben{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-70px)}}.ort-zeile{border:3px solid var(--blau);background:#fff;border-radius:10px;align-items:center;gap:10px;margin-bottom:10px;padding:8px 10px;display:flex}.ort-zeile svg{flex-shrink:0;width:52px;height:52px}.ort-info{flex:1;min-width:0}.ort-info .ort-name{color:var(--blau-dunkel);font-weight:900}.ort-info .ort-detail{color:#555;font-size:.78rem}.ort-info .ort-gesperrt{color:var(--rot);font-size:.78rem;font-weight:700}.ort-anzahl{color:var(--blau);text-align:center;min-width:34px;font-size:1.5rem;font-weight:900}.kauf-knopf{background:var(--blau);color:#fff;cursor:pointer;border:none;border-radius:8px;min-width:92px;padding:10px 12px;font-size:.85rem;font-weight:800}.kauf-knopf:disabled{cursor:default;background:#b8c4cf}.karten-raster{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;display:grid}.karte{border:3px solid var(--blau);background:#fff;border-radius:10px;flex-direction:column;gap:6px;padding:10px;display:flex}.karte .karte-name{color:var(--blau-dunkel);letter-spacing:.04em;font-size:1.05rem;font-weight:900}.karte .karte-rolle{background:var(--blau);color:#fff;text-transform:uppercase;letter-spacing:.05em;border-radius:99px;align-self:flex-start;padding:2px 7px;font-size:.68rem;font-weight:800}.karte .karte-text{color:#444;flex:1;font-size:.8rem}.karte .karte-preis{background:var(--gelb);color:var(--blau-dunkel);border:2px solid var(--blau-dunkel);box-shadow:2px 2px 0 var(--blau-dunkel);align-self:flex-end;padding:4px 10px;font-weight:900;transform:rotate(-3deg)}.karte button{background:var(--gelb);border:3px solid var(--blau-dunkel);color:var(--blau-dunkel);cursor:pointer;border-radius:8px;padding:9px;font-weight:900}.karte button:disabled{color:#999;cursor:default;background:#eee;border-color:#b8c4cf}.karte.gekauft{opacity:.55;border-style:dashed}.erfolg{color:#999;background:#fff;border:3px solid #ccc;border-radius:10px;align-items:center;gap:10px;margin-bottom:8px;padding:8px 10px;display:flex}.erfolg.frei{border-color:var(--gelb);color:inherit;background:#fffbe6}.erfolg .erfolg-icon{font-size:1.4rem}.erfolg .erfolg-name{font-weight:800}.erfolg .erfolg-text{font-size:.78rem}.tabbar{background:var(--blau-dunkel);padding-bottom:var(--safe-bottom);display:flex;position:fixed;bottom:0;left:0;right:0}.tabbar button{color:#9db8d1;cursor:pointer;background:0 0;border:none;flex:1;padding:12px 4px 10px;font-size:.8rem;font-weight:800}.tabbar button .tab-icon{font-size:1.3rem;display:block}.tabbar button.aktiv{color:var(--gelb)}.toast{left:50%;bottom:calc(84px + var(--safe-bottom));background:var(--blau-dunkel);color:var(--gelb);border:2px solid var(--gelb);z-index:20;text-align:center;border-radius:99px;max-width:88vw;padding:10px 16px;font-weight:800;animation:3s forwards toastauf;position:fixed;transform:translate(-50%)}@keyframes toastauf{0%{opacity:0;transform:translate(-50%,16px)}8%,85%{opacity:1;transform:translate(-50%)}to{opacity:0}}dialog.klicka-dialog{border:4px solid var(--blau);text-align:center;border-radius:12px;width:88vw;max-width:320px;padding:18px}dialog.klicka-dialog::backdrop{background:#00285099}dialog.klicka-dialog h2{color:var(--blau);margin:0 0 8px}dialog.klicka-dialog button{background:var(--gelb);border:3px solid var(--blau-dunkel);color:var(--blau-dunkel);cursor:pointer;border-radius:8px;margin-top:12px;padding:10px 22px;font-weight:900}.io-bereich textarea{border:2px solid var(--blau);border-radius:8px;width:100%;min-height:70px;padding:6px;font-family:monospace;font-size:.75rem}.io-bereich button{background:var(--blau);color:#fff;cursor:pointer;border:none;border-radius:8px;margin:6px 6px 0 0;padding:9px 14px;font-weight:800}.warnbanner{background:var(--rot);color:#fff;text-align:center;padding:8px 14px;font-size:.8rem;font-weight:700}.doodle-fahne{transform-origin:0;animation:1.6s ease-in-out infinite flattern}@keyframes flattern{0%,to{transform:skewY(0)scaleX(1)}50%{transform:skewY(6deg)scaleX(.92)}}.doodle-markise{transform-origin:top;animation:3s ease-in-out infinite wippen}@keyframes wippen{0%,to{transform:rotate(0)}50%{transform:rotate(1.6deg)}}.doodle-hammer{transform-origin:53px 32px;animation:.9s ease-in-out infinite haemmern}@keyframes haemmern{0%,to{transform:rotate(0)}40%{transform:rotate(-28deg)}55%{transform:rotate(6deg)}}.doodle-dampf{animation:2.2s ease-in-out infinite dampfen}@keyframes dampfen{0%,to{opacity:.35;transform:translateY(0)}50%{opacity:1;transform:translateY(-2.5px)}}.doodle-welle{animation:2.8s ease-in-out infinite wellen}@keyframes wellen{0%,to{transform:translate(0)}50%{transform:translate(-5px)}}.doodle-boje{animation:2.4s ease-in-out infinite bojen}@keyframes bojen{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-3px)rotate(4deg)}}.doodle-licht{animation:1.8s ease-in-out infinite blinken}.doodle-licht-2{animation-delay:.9s}@keyframes blinken{0%,to{opacity:1}50%{opacity:.25}}@media (prefers-reduced-motion:reduce){.doodle-fahne,.doodle-markise,.doodle-hammer,.doodle-dampf,.doodle-welle,.doodle-boje,.doodle-licht{animation:none}}
