*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#faf9f6;--bg-dark:#0d0d0d;--ink:#1a1a1a;--ink-light:#555;--ink-faint:#999;--paper:#fefefe;--border-color:#1a1a1a;--shadow:#00000014;--font-sketchy:"Architects Daughter", "Caveat", cursive;--font-mono:"Courier New", monospace;--radius-sketchy:3px;--border-width:2.5px}html,body{width:100%;height:100%;font-family:var(--font-sketchy);background-color:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;overflow-x:hidden}.sketchy-text{font-family:var(--font-sketchy);letter-spacing:.02em}.sketchy-text-small{font-family:var(--font-sketchy);color:var(--ink-light);letter-spacing:.01em;font-size:.85rem}.sketchy-border{border:var(--border-width) solid var(--border-color);border-radius:var(--radius-sketchy);box-shadow:2px 3px 0px var(--shadow), -1px -1px 0px var(--shadow), inset 0 0 0 .5px #00000008;position:relative}.sketchy-border:before{content:"";pointer-events:none;border:1.5px solid #0000000f;border-radius:5px;position:absolute;inset:-3px;transform:rotate(.3deg)}.sketchy-input-wrapper{position:relative}.sketchy-input{font-family:var(--font-sketchy);border:var(--border-width) solid var(--border-color);border-radius:var(--radius-sketchy);background:var(--paper);color:var(--ink);width:100%;box-shadow:2px 2px 0px var(--shadow);outline:none;padding:12px 16px;font-size:1rem;transition:box-shadow .2s}.sketchy-input:focus{box-shadow:3px 3px 0px #0000001f, inset 0 0 0 1px var(--border-color)}.sketchy-input::placeholder{color:var(--ink-faint);font-style:italic}.sketchy-input:disabled{opacity:.4;cursor:not-allowed;background:#f0f0f0}.sketchy-button{font-family:var(--font-sketchy);border:var(--border-width) solid var(--border-color);border-radius:var(--radius-sketchy);background:var(--paper);color:var(--ink);cursor:pointer;box-shadow:3px 3px 0px var(--shadow);text-transform:uppercase;letter-spacing:.05em;padding:10px 20px;font-size:1rem;font-weight:600;transition:all .15s;position:relative}.sketchy-button:hover{transform:translate(-1px,-1px);box-shadow:4px 4px #00000026}.sketchy-button:active{box-shadow:1px 1px 0px var(--shadow);transform:translate(1px,1px)}.sketchy-button:disabled{opacity:.35;cursor:not-allowed;box-shadow:2px 2px 0px var(--shadow);transform:none}.app-container{background:var(--bg);background-image:radial-gradient(circle at 20%,#00000003 0%,#0000 50%),radial-gradient(circle at 80% 20%,#00000004 0%,#0000 50%);flex-direction:column;align-items:center;width:100%;min-height:100vh;display:flex}.landing-page{background:var(--bg-dark);flex-direction:column;align-items:center;width:100%;min-height:100vh;display:flex;position:relative;overflow:hidden}.landing-header{text-align:center;z-index:10;padding:40px 20px 10px}.main-title{color:#f0f0f0;text-transform:uppercase;letter-spacing:.08em;text-shadow:2px 2px #ffffff0d;margin-bottom:8px;font-size:clamp(1.8rem,5vw,3.2rem);font-weight:700}.main-subtitle{color:#888;font-size:1rem;font-style:italic}.globe-container{z-index:5;width:100%;height:60vh;min-height:400px;max-height:600px;position:relative}.globe-tooltip{color:var(--ink);border:2px solid var(--border-color);border-radius:var(--radius-sketchy);font-family:var(--font-sketchy);letter-spacing:.05em;pointer-events:none;white-space:nowrap;background:#fffffff2;padding:8px 20px;font-size:1.1rem;font-weight:600;animation:.2s tooltip-pop;box-shadow:3px 3px #0000001a}@keyframes tooltip-pop{0%{opacity:0;transform:translate(-50%)translateY(-5px)scale(.95)}to{opacity:1;transform:translate(-50%)translateY(0)scale(1)}}.globe-loading{color:#888;flex-direction:column;justify-content:center;align-items:center;gap:16px;width:100%;height:60vh;display:flex}.loading-spinner{border:3px solid #333;border-top-color:#aaa;border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.city-list{z-index:10;flex-wrap:wrap;justify-content:center;gap:10px;max-width:700px;padding:20px;display:flex}.city-list-item{color:#ccc;text-align:center;background:#ffffff14;border-color:#555;flex:auto;min-width:80px;padding:8px 16px;font-size:.85rem;transition:all .2s}.city-list-item:hover{color:#fff;background:#ffffff26;border-color:#888;transform:translate(-1px,-1px)}.onboarding-overlay{background:var(--bg);z-index:200;justify-content:center;align-items:center;animation:.3s fade-in;display:flex;position:fixed;inset:0}.onboarding-exit{animation:.4s forwards fade-out}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes fade-out{0%{opacity:1}to{opacity:0}}.onboarding-card{background:var(--paper);text-align:center;width:90%;max-width:460px;padding:40px;animation:.4s card-enter}@keyframes card-enter{0%{opacity:0;transform:translateY(20px)rotate(-.5deg)}to{opacity:1;transform:translateY(0)rotate(0)}}.onboarding-title{text-transform:uppercase;letter-spacing:.08em;margin-bottom:30px;font-size:2rem;font-weight:700}.onboarding-section{margin-bottom:24px}.onboarding-label{text-transform:uppercase;letter-spacing:.1em;text-align:left;margin-bottom:10px;font-size:1rem;font-weight:600;display:block}.onboarding-error{color:#c33;font-family:var(--font-sketchy);text-align:left;margin-top:6px;font-size:.85rem}.color-grid{grid-template-columns:repeat(5,1fr);justify-items:center;gap:12px;margin-bottom:12px;display:grid}.color-swatch{border:2.5px solid var(--border-color);cursor:pointer;width:42px;height:42px;box-shadow:2px 2px 0px var(--shadow);border-radius:50%;transition:all .2s;position:relative}.color-swatch:hover{transform:scale(1.15);box-shadow:3px 3px #00000026}.color-swatch-active{box-shadow:0 0 0 3px var(--ink), 0 0 0 5px var(--paper);transform:scale(1.2)}.color-swatch-active:hover{transform:scale(1.25)}.color-hint{text-align:center;font-style:italic}.start-button{background:var(--ink);color:var(--paper);border-color:var(--ink);margin-top:10px;padding:14px 32px;font-size:1.2rem}.start-button:hover{background:#333}.chatroom-container{background:var(--bg);flex-direction:column;width:100%;max-width:640px;height:100dvh;margin:0 auto;padding:16px;display:flex;position:relative}.chatroom-header{background:var(--paper);align-items:center;gap:16px;margin-bottom:12px;padding:16px;display:flex}.back-button{flex-shrink:0;padding:8px 14px;font-size:.85rem}.header-info{text-align:center;flex:1}.city-title{text-transform:uppercase;letter-spacing:.1em;font-size:1.8rem;font-weight:700}.city-meta{margin-top:2px;font-size:.8rem}.status-open{color:#3a8a3a;font-weight:700}.status-closed{color:#c33;font-weight:700}.messages-container{background:var(--paper);flex:1;min-height:0;padding:16px;position:relative;overflow-y:auto}.messages-list{flex-direction:column;gap:12px;transition:filter .3s;display:flex}.messages-blurred{filter:blur(3px);opacity:.3;pointer-events:none}.message-bubble{border-radius:var(--radius-sketchy);border:1.5px solid #0000001a;gap:10px;max-width:85%;padding:10px 14px;animation:.25s msg-appear;display:flex;position:relative}@keyframes msg-appear{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.message-system{text-align:center;justify-content:center;max-width:100%;font-style:italic;background:#f5f5f5!important;border-color:#ddd!important}.message-avatar{width:32px;height:32px;font-family:var(--font-sketchy);color:var(--ink);background:#ffffff80;border:2px solid #888;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.9rem;font-weight:700;display:flex}.message-content{flex-direction:column;gap:2px;display:flex}.message-username{font-family:var(--font-sketchy);color:var(--ink);font-size:.85rem;font-weight:700}.message-text{font-family:var(--font-sketchy);color:var(--ink);word-break:break-word;font-size:.95rem;line-height:1.4}.message-text-system{font-family:var(--font-sketchy);color:var(--ink-light);font-size:.85rem}.closed-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:50;background:#faf9f6d9;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:20px;display:flex;position:absolute;inset:0}.closed-stamp{color:#c33;text-transform:uppercase;letter-spacing:.2em;opacity:.85;text-shadow:2px 2px #cc333326;border:6px solid #c33;padding:8px 30px;font-size:4rem;font-weight:700;transform:rotate(-8deg)}.countdown-display{text-align:center}.reopening-text{text-transform:uppercase;letter-spacing:.15em;color:var(--ink-light);margin-bottom:8px;font-size:1rem}.countdown-timer{font-family:var(--font-mono);color:var(--ink);letter-spacing:.1em;font-size:3rem;font-weight:700}.next-session{margin-top:8px;font-size:.8rem}.wait-text{margin-top:8px;font-style:italic}.input-area{background:var(--paper);align-items:center;gap:10px;margin-top:12px;padding:12px;display:flex;position:relative}.input-full{flex:1}.char-count{color:var(--ink-faint);font-size:.7rem;position:absolute;bottom:-18px;right:12px}.send-button,.emoji-button{padding:10px 14px;font-size:1.3rem;line-height:1}.emoji-hint{background:var(--paper);z-index:60;width:250px;margin-bottom:8px;padding:12px 16px;animation:.2s fade-in;position:absolute;bottom:100%;right:0}.user-indicator{justify-content:center;align-items:center;gap:8px;padding:10px 0 4px;display:flex}.user-indicator-dot{border:1.5px solid var(--ink);border-radius:50%;width:12px;height:12px}.messages-container::-webkit-scrollbar{width:6px}.messages-container::-webkit-scrollbar-track{background:0 0}.messages-container::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.messages-container::-webkit-scrollbar-thumb:hover{background:#aaa}@media (max-width:640px){.onboarding-card{padding:28px 20px}.onboarding-title{font-size:1.5rem}.city-title{font-size:1.4rem}.countdown-timer{font-size:2.2rem}.closed-stamp{padding:6px 20px;font-size:2.8rem}.globe-container{height:45vh;min-height:300px}.color-grid{grid-template-columns:repeat(5,1fr);gap:8px}.color-swatch{width:36px;height:36px}}@keyframes subtle-float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}body{background:var(--bg)!important}
