:root{--text:#1e293b;--text-heading:#0f172a;--text-muted:#64748b;--bg:#f8fafc;--door-vapaa:#52525b;--door-valmis:#15803d;--door-varattu:#b91c1c;color:var(--text);background-color:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-weight:400;line-height:1.5}*,:before,:after{box-sizing:border-box}body{height:100dvh;margin:0;overflow:hidden}#root{height:100dvh}button{font-family:inherit}.fit-text{text-align:center;flex-shrink:0;width:100%;display:block;overflow:hidden}.fit-text__inner{white-space:nowrap;text-align:center;max-width:100%;line-height:1.1;display:inline-block}.door-box{color:#fff;cursor:pointer;-webkit-tap-highlight-color:transparent;touch-action:manipulation;text-shadow:0 1px 2px #000c,0 2px 8px #00000080;border:none;border-radius:14px;flex-direction:column;flex:1;justify-content:space-between;align-items:stretch;gap:.5rem;min-width:0;height:100%;min-height:0;padding:1rem .5rem;transition:transform .15s,opacity .15s,background-color .25s;display:flex;box-shadow:inset 0 3px 6px #0003}.door-box--vapaa{background-color:var(--door-vapaa)}.door-box--valmis{background-color:var(--door-valmis)}.door-box--varattu{background-color:var(--door-varattu)}.door-box:active:not(:disabled){transform:scale(.96)}.door-box:disabled{cursor:wait;opacity:.85}.door-box--loading{animation:.8s ease-in-out infinite door-pulse}.door-box__label,.door-box__status{font-weight:700}@keyframes door-pulse{0%,to{opacity:1}50%{opacity:.75}}.app{height:100dvh;padding:env(safe-area-inset-top) .75rem env(safe-area-inset-bottom);box-sizing:border-box;flex-direction:column;justify-content:center;display:flex}.door-grid{flex:none;gap:.75rem;width:100%;height:66.6667dvh;min-height:0;display:flex}.app__message{height:66.6667dvh;color:var(--text-muted);flex:none;justify-content:center;align-items:center;font-size:.9375rem;display:flex}.app__error{bottom:calc(1rem + env(safe-area-inset-bottom));text-align:center;color:var(--door-varattu);margin:0;font-size:.875rem;position:fixed;left:1rem;right:1rem}
