@tailwind base;@tailwind components;@tailwind utilities;:root{--foreground-rgb:255,255,255;--background-start-rgb:5,5,10;--background-end-rgb:0,0,0}body{color:rgb(var(--foreground-rgb));-webkit-user-select:none;user-select:none;background:#000;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;overflow:hidden}button,a{-webkit-tap-highlight-color:transparent}input,textarea{-webkit-user-select:text;user-select:text}.page{width:100vw;height:100vh;position:relative;overflow:hidden}.scene-background{width:100%;height:100%;position:fixed;top:0;left:0}.ui-overlay{z-index:40;pointer-events:none;flex-direction:column;align-items:flex-start;width:100%;height:100%;padding:20px;display:flex;position:absolute;top:0;left:0}.ui-card-container{pointer-events:auto;flex-direction:column;align-items:flex-start;gap:10px;display:flex}.toggle-card-button{color:#52fffb;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;border:1px solid #52fffb;border-radius:20px;padding:6px 12px;font-family:JetBrains Mono,monospace;font-size:11px;transition:all .2s}.toggle-card-button:hover{background:#52fffb26}.ui-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);opacity:1;transform-origin:0 0;background:#000000bf;border:1px solid #52fffb4d;border-radius:16px;width:100%;max-width:320px;height:auto;padding:16px 16px 40px;transition:all .4s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden;box-shadow:0 8px 32px #00000080}.ui-card.minimized{cursor:pointer;background:#000;border:1px solid #52fffb4d;border-radius:24px;width:auto;max-width:none;margin-top:6px;margin-left:6px;padding:8px 16px}.ui-card.minimized .ui-header{margin-bottom:0}.ui-card.minimized h1{margin:0;font-size:1.2rem;line-height:1}.collapse-button{color:#52fffb99;cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:4px;transition:all .2s;display:flex;position:absolute;bottom:10px;right:10px}.collapse-button:hover{color:#52fffb;background:#52fffb1a}.collapse-button svg{width:20px;height:20px}@media (max-width:768px){.ui-overlay{justify-content:flex-start;padding:12px}.ui-card{background:#000000d9;width:100%;max-width:70%;padding:14px}.ui-header h1{font-size:1.5rem}}.ui-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.ui-header h1{color:#fff;letter-spacing:-1px;text-shadow:0 0 10px #52fffb4d;margin:0;font-family:JetBrains Mono,monospace;font-size:1.5rem;font-weight:700}.avatar-link img{border:2px solid #52fffb;border-radius:50%;transition:transform .2s}.avatar-link:hover img{transform:scale(1.1)rotate(5deg)}.description{color:#ccc;white-space:normal;max-width:calc(100% - 40px);margin-bottom:12px;font-size:.8rem;line-height:1.4}.username-form{gap:8px;width:100%;margin-bottom:10px;display:flex}.username-input{color:#fff;background:#ffffff1a;border:1px solid #fff3;border-radius:6px;outline:none;flex:1;min-width:0;padding:8px 10px;font-family:JetBrains Mono,monospace;font-size:.9rem;transition:all .2s}.username-input:focus{background:#ffffff26;border-color:#52fffb;box-shadow:0 0 0 2px #52fffb33}.username-form button{color:#000;cursor:pointer;white-space:nowrap;background:#fff;border:none;border-radius:6px;padding:0 16px;font-family:JetBrains Mono,monospace;font-size:.9rem;font-weight:700;transition:all .2s}.town-sign{background:#000000bf;border:2px solid #ffffffe6;border-radius:14px;align-items:center;gap:8px;padding:3px 10px;font-family:JetBrains Mono,monospace;display:flex}.town-sign-avatar{object-fit:cover;border:2px solid #52fffb;border-radius:50%;width:32px;height:32px}.town-sign-text{flex-direction:column;line-height:1.1;display:flex}.town-sign-cityname{color:#e6fffb;align-self:flex-start;margin-top:10px;font-size:15px}.town-sign-name{color:#e6fffb;margin-top:3px;font-size:11px}.town-sign-tagline{color:#7afbd0;opacity:.95;align-self:flex-end;margin-top:10px;margin-bottom:3px;font-size:8px}.username-form button:hover{background:#52fffb;transform:translateY(-1px);box-shadow:0 4px 12px #52fffb4d}.username-form button:disabled{opacity:.6;cursor:wait;box-shadow:none;transform:none}.error{color:#ff6b6b;background:#ff6b6b1a;border:1px solid #ff6b6b33;border-radius:4px;margin-bottom:10px;padding:6px 10px;font-size:.75rem}.hint{color:#888;border-top:1px solid #ffffff1a;max-width:calc(100% - 40px);margin-top:10px;padding-top:10px;font-size:.75rem}.hint ul{color:#aaa;margin:4px 0 0;padding-left:16px}.city-container{width:100%;height:100%;position:relative}.city-canvas{outline:none;width:100%;height:100%}.settings-button{color:#52fffb;cursor:pointer;z-index:50;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:auto;background:#02090773;border:1px solid #52fffb;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s;display:flex;position:absolute;top:16px;right:16px;box-shadow:0 0 15px #52fffb66}.settings-button svg{width:18px;height:18px}.settings-button:hover{background:#52fffb26;transform:rotate(30deg);box-shadow:0 0 15px #52fffb4d}.settings-button:focus,.flyover-toggle-button:focus,.record-button:focus,.snapshot-button:focus{outline:none}.settings-menu{z-index:49;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);pointer-events:auto;background:#020907e6;border:1px solid #52fffb;border-radius:12px;min-width:180px;padding:14px 14px 12px;position:absolute;top:60px;right:16px;box-shadow:0 4px 20px #00000080}.settings-row{color:#e0ffe0;justify-content:space-between;align-items:center;gap:6px;margin-bottom:12px;font-family:JetBrains Mono,monospace;font-size:11px;display:flex}.settings-row:last-child{margin-bottom:0}.settings-section-label{letter-spacing:.04em;text-transform:uppercase;color:#e2fff6cc;border-top:1px solid #52fffb33;margin-top:10px;margin-bottom:6px;padding-top:4px;font-family:JetBrains Mono,monospace;font-size:10px}.theme-select{color:#52fffb;cursor:pointer;background:#0000004d;border:1px solid #52fffb;border-radius:4px;outline:none;width:100px;padding:3px 6px;font-family:JetBrains Mono,monospace;font-size:10px}.settings-menu input[type=text]{color:#e8fffb;background:#0000004d;border:1px solid #52fffb;border-radius:4px;outline:none;flex:1;min-width:0;padding:4px 6px;font-family:JetBrains Mono,monospace;font-size:10px}.settings-menu input[type=range]{flex:1}.settings-menu input[type=text]:focus{background:#00000073;box-shadow:0 0 0 1px #52fffb66}.theme-select:hover{background:#52fffb1a}.settings-customize-button{color:#52fffb;cursor:pointer;text-align:center;background:#52fffb1f;border:1px solid #52fffb;border-radius:6px;width:100%;margin-top:6px;padding:7px 10px;font-family:JetBrains Mono,monospace;font-size:11px}.settings-customize-button:hover{background:#52fffb33}.flyover-toggle-button{color:#52fffb;cursor:pointer;z-index:50;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:auto;background:#02090773;border:1px solid #52fffb;border-radius:20px;padding:8px 16px;font-family:JetBrains Mono,monospace;font-size:12px;transition:all .2s;position:absolute;bottom:20px;left:20px;transform:none;box-shadow:0 0 12px #52fffb80}.flyover-toggle-button:hover{background:#52fffb26;box-shadow:0 0 15px #52fffb4d}.flyover-toggle-button--active{background:#52fffb33;box-shadow:0 0 10px #52fffb66}.record-button{color:#fff;cursor:pointer;z-index:50;pointer-events:auto;background:#ff2a2a;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s;display:flex;position:absolute;bottom:20px;right:20px;box-shadow:0 0 10px #ff2a2a66}.record-button:disabled{opacity:.5;cursor:not-allowed}.record-button:hover:not(:disabled){background:#ff4d4d;transform:scale(1.1);box-shadow:0 0 20px #ff2a2a99}.snapshot-button{color:#52fffb;cursor:pointer;z-index:50;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:auto;background:#02090773;border:1px solid #52fffb;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s;display:flex;position:absolute;bottom:20px;right:75px}.snapshot-button:hover{background:#52fffb26;transform:scale(1.1);box-shadow:0 0 15px #52fffb4d}.city-commit-label{color:#fff;pointer-events:none;z-index:20;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000c;border:1px solid #52fffb;border-radius:8px;flex-direction:column;align-items:center;gap:4px;padding:12px 20px;font-family:JetBrains Mono,monospace;font-size:14px;display:flex;position:absolute;bottom:90px;left:50%;transform:translate(-50%);box-shadow:0 4px 20px #00000080}.city-commit-label-date{color:#8b949e;font-size:12px}.city-commit-label-count{color:#52fffb;font-size:16px;font-weight:700}.export-overlay{z-index:100;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);pointer-events:auto;background:#000c;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:absolute;top:0;left:0}.export-modal{background:#0d1117;border:1px solid #30363d;border-radius:12px;width:90%;max-width:400px;padding:24px;box-shadow:0 8px 32px #0009}.export-modal-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.export-modal-title{color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:18px;font-weight:700}.export-modal-close{color:#8b949e;cursor:pointer;background:0 0;border:none;padding:0;font-size:24px;line-height:1}.export-modal-close:hover{color:#fff}.export-modal-text{color:#8b949e;margin-bottom:24px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:14px;line-height:1.5}.export-aspect-options{color:#8b949e;align-items:center;gap:12px;margin-bottom:16px;font-size:12px;display:flex}.export-aspect-options label{cursor:pointer;align-items:center;gap:4px;display:flex}.export-aspect-label{font-weight:600}.export-modal-actions{flex-direction:column;gap:12px;display:flex}.export-webm-button,.export-mp4-button{cursor:pointer;border:1px solid #f0f6fc1a;border-radius:6px;width:100%;padding:10px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:14px;font-weight:600;transition:all .2s}.export-webm-button{color:#c9d1d9;background:0 0}.export-webm-button:hover{background:#f0f6fc1a;border-color:#8b949e}.export-mp4-button{color:#fff;background:#238636;border:1px solid #f0f6fc1a}.export-mp4-button:hover{background:#2ea043}.export-mp4-button--converting{cursor:wait;background:#1f6feb}.export-progress{color:#8b949e;align-items:center;gap:8px;margin-top:4px;font-size:12px;display:flex}.export-spinner{border:2px solid #f0f6fc33;border-top-color:#c9d1d9;border-radius:50%;width:14px;height:14px;animation:.8s linear infinite export-spinner-spin}@keyframes export-spinner-spin{to{transform:rotate(360deg)}}.control-panel-overlay{z-index:59;pointer-events:auto;background:0 0;width:100%;height:100%;position:fixed;top:0;left:0}.control-panel{z-index:60;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#e0ffe0;scrollbar-width:thin;scrollbar-color:#52fffb #0000004d;pointer-events:auto;background:#020907f2;border:1px solid #52fffb;border-radius:16px;width:100%;max-width:min(260px,80%);height:auto;max-height:50%;padding:20px;font-family:JetBrains Mono,monospace;position:fixed;top:50%;left:50%;overflow-y:auto;transform:translate(-50%,-50%);box-shadow:0 0 30px #000c}.control-panel-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.control-panel-title{text-transform:uppercase;color:#52fffb;letter-spacing:1px;margin:0;font-size:14px}.control-panel-close{color:#b0ffd0;cursor:pointer;background:0 0;border:none;padding:0;font-size:20px;line-height:1}.control-panel-close:hover{color:#fff}@media (max-width:480px){.control-panel{max-width:80%}}.control-panel::-webkit-scrollbar{width:6px}.control-panel::-webkit-scrollbar-track{background:#0000004d}.control-panel::-webkit-scrollbar-thumb{background-color:#52fffb;border-radius:3px}.control-group{border-bottom:1px solid #52fffb33;margin-bottom:24px;padding-bottom:16px}.control-group:last-child{border-bottom:none}.control-group h3{text-transform:uppercase;color:#52fffb;letter-spacing:1px;border-bottom:1px solid #52fffb4d;margin:0 0 12px;padding-bottom:4px;font-size:14px}.control-group label{color:#b0ffd0;flex-direction:column;margin-bottom:12px;font-size:12px;display:flex}.control-group input[type=range]{-webkit-appearance:none;background:0 0;width:100%;margin-top:6px}.control-group input[type=range]::-webkit-slider-runnable-track{background:#52fffb4d;border-radius:2px;width:100%;height:4px}.control-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;cursor:pointer;background:#52fffb;border-radius:50%;width:14px;height:14px;margin-top:-5px;box-shadow:0 0 5px #52fffb80}.control-group input[type=color]{cursor:pointer;background:0 0;border:1px solid #52fffb4d;border-radius:4px;width:100%;height:30px;margin-top:6px}.copy-button{color:#000;cursor:pointer;background:#52fffb;border:none;border-radius:4px;width:100%;margin-top:10px;padding:8px;font-weight:700;transition:background .2s}.copy-button:hover{background:#8ffffd}.waitlist-overlay{z-index:110;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);pointer-events:auto;background:#000c;justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:fixed;top:0;left:0}.waitlist-modal{background:#0d1117;border:1px solid #30363d;border-radius:12px;width:90%;max-width:360px;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;box-shadow:0 8px 32px #0009}.waitlist-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.waitlist-title{color:#fff;margin:0;font-size:18px}.waitlist-close{color:#8b949e;cursor:pointer;background:0 0;border:none;padding:0;font-size:24px;line-height:1}.waitlist-close:hover{color:#fff}.waitlist-text{color:#8b949e;margin:0 0 12px;font-size:14px;line-height:1.5}.waitlist-form{flex-direction:column;gap:8px;margin-bottom:10px;display:flex}.waitlist-input{color:#fff;background:#ffffff0d;border:1px solid #ffffff26;border-radius:6px;outline:none;flex:1;min-width:0;padding:8px 10px;font-size:.9rem}.waitlist-input:focus{border-color:#52fffb;box-shadow:0 0 0 2px #52fffb4d}.waitlist-submit{color:#000;cursor:pointer;white-space:nowrap;background:#52fffb;border:none;border-radius:6px;align-self:flex-end;padding:0 16px;font-size:.9rem;font-weight:600;transition:all .2s}.waitlist-submit:hover{background:#8ffffd;transform:translateY(-1px);box-shadow:0 4px 12px #52fffb4d}.waitlist-submit:disabled{opacity:.6;cursor:wait;box-shadow:none;transform:none}.waitlist-success{color:#3fb950;background:#3fb9501a;border:1px solid #3fb9504d;border-radius:4px;margin:0;padding:6px 10px;font-size:.8rem}
