:root{--ink:#f3e9da;--ink-soft:#f3e9daa8;--amber:#e8a45c;--glass:#120d1880;--glass-strong:#0e0a14d1;--border:#ffdeb429;--serif:"Iowan Old Style", "Palatino Linotype", Palatino, Georgia, serif;--sans:system-ui, -apple-system, "Segoe UI", Roboto, sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body{overscroll-behavior:none;height:100%;color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent;background:#140e1c;overflow:hidden}#app{position:fixed;inset:0}canvas.scene{touch-action:none;width:100%;height:100%;display:block}#ui{pointer-events:none;z-index:10;-webkit-user-select:none;user-select:none;position:fixed;inset:0}#ui button,#ui .field,#ui .modal-backdrop,#ui .map-overlay{pointer-events:auto}.top-bar{top:max(16px, env(safe-area-inset-top));gap:10px;display:flex;position:absolute;left:16px}.icon-btn{width:48px;height:48px;color:var(--ink);background:var(--glass);border:1px solid var(--border);-webkit-backdrop-filter:blur(10px);cursor:pointer;border-radius:50%;font-size:20px;transition:transform .2s,background .2s}.icon-btn:hover{background:#281e3299;transform:translateY(-1px)}.hint{bottom:calc(96px + env(safe-area-inset-bottom));text-align:center;font-family:var(--serif);letter-spacing:.5px;color:var(--ink-soft);text-shadow:0 2px 12px #000c;font-size:15px;transition:opacity .4s;position:absolute;left:0;right:0}.action-bar{bottom:max(22px, env(safe-area-inset-bottom));flex-wrap:wrap;justify-content:center;gap:12px;padding:0 16px;display:flex;position:absolute;left:0;right:0}.btn{min-height:50px;font-family:var(--sans);letter-spacing:.3px;color:var(--ink);background:var(--glass);border:1px solid var(--border);-webkit-backdrop-filter:blur(12px);cursor:pointer;border-radius:26px;padding:0 22px;font-size:15px;font-weight:500;transition:transform .18s,background .2s,box-shadow .25s}.btn:hover{transform:translateY(-1px)}.btn-primary{background:#281c188c;border-color:#e8a45c66}.btn-flame{background:linear-gradient(#e8965052,#b45a2847);border-color:#ffb46e8c;box-shadow:0 0 22px #e88c4647}.btn-flame:hover{box-shadow:0 0 30px #ffa05080}.btn-ghost{color:var(--ink-soft);background:0 0;border-color:#ffffff24}.btn:disabled{opacity:.4;cursor:default;transform:none}.modal-backdrop{-webkit-backdrop-filter:blur(6px);background:#08060c8c;justify-content:center;align-items:center;padding:20px;animation:.4s fade;display:flex;position:absolute;inset:0}.modal{background:var(--glass-strong);border:1px solid var(--border);overflow-wrap:anywhere;border-radius:20px;width:min(440px,100%);max-height:86vh;padding:30px 28px 24px;animation:.45s cubic-bezier(.16,1,.3,1) rise;overflow-y:auto;box-shadow:0 24px 80px #0009}.modal-title{font-family:var(--serif);letter-spacing:.3px;color:var(--ink);font-size:24px;font-weight:500}.modal-sub{color:var(--ink-soft);margin:8px 0 20px;font-size:14px;line-height:1.5}.field{width:100%;font-size:16px;font-family:var(--sans);color:var(--ink);border:1px solid var(--border);background:#ffffff0d;border-radius:12px;outline:none;margin-bottom:14px;padding:13px 15px;transition:border .2s,background .2s;display:block}.field:focus{background:#ffffff14;border-color:#e8a45c99}.field.area{resize:none;line-height:1.55}.field::placeholder{color:#f3e9da59}.field.shake{border-color:#ff785ab3;animation:.45s shake}.modal-actions{justify-content:flex-end;gap:10px;margin-top:8px;display:flex}.modal.reader{text-align:center}.reader-photo{border:1px solid var(--border);object-fit:cover;border-radius:10px;max-width:180px;max-height:180px;margin:14px auto 4px;display:block}.reader-message{font-family:var(--serif);color:var(--ink);overflow-wrap:anywhere;white-space:pre-wrap;max-height:44vh;margin:18px 0;padding-right:4px;font-size:20px;line-height:1.6;overflow-y:auto}.reader-meta{color:var(--ink-soft);margin-bottom:20px;font-size:13px}.photo-row{align-items:center;gap:12px;margin-bottom:14px;display:flex}.photo-btn{flex:1}.photo-preview{object-fit:cover;border:1px solid var(--border);border-radius:8px;width:52px;height:52px}.form-error{color:#ffb38a;margin:0 0 12px;font-size:14px;line-height:1.45}.map-overlay{background:#0a0813;animation:.45s fade;position:absolute;inset:0}.world-map{background:#0a0813;width:100%;height:100%;position:absolute;inset:0}.world-map .leaflet-control-attribution{color:#f3e9da66;background:#0a0813b3}.world-map .leaflet-control-attribution a{color:#aec6f099}.world-map .leaflet-bar a{color:var(--ink);border-bottom-color:var(--border);background:#140e1ad9}.world-map .leaflet-bar a:hover{background:#281e32e6}.city-label{box-shadow:none;color:#c8d2f0b3;font-family:var(--sans);text-shadow:0 1px 4px #000000e6;background:0 0;border:none;padding:0;font-size:11px}.candle-tip{border:1px solid var(--border);color:var(--ink);font-family:var(--serif);background:#140e1ae6}.globe-labels{pointer-events:none;z-index:2;position:absolute;inset:0;overflow:hidden}.globe-label{pointer-events:auto;cursor:pointer;font-family:var(--sans);color:#e6e0d2c7;text-shadow:0 1px 4px #000000f2;white-space:nowrap;-webkit-user-select:none;user-select:none;font-size:11px;position:absolute;transform:translate(9px,-50%)}.globe-label:hover{color:#fff}.globe-tip{pointer-events:none;border:1px solid var(--border);color:var(--ink);font-family:var(--serif);white-space:nowrap;z-index:5;background:#140e1ae6;border-radius:8px;padding:3px 9px;font-size:13px;position:absolute}.map-legend{bottom:max(26px, env(safe-area-inset-bottom));text-align:center;font-family:var(--serif);color:var(--ink-soft);pointer-events:none;font-size:15px;position:absolute;left:0;right:0}.map-close{top:max(16px, env(safe-area-inset-top));position:absolute;right:16px}.city-chip{height:48px;font-family:var(--serif);letter-spacing:.3px;color:var(--ink);background:var(--glass);border:1px solid var(--border);-webkit-backdrop-filter:blur(10px);cursor:pointer;pointer-events:auto;white-space:nowrap;text-overflow:ellipsis;border-radius:24px;max-width:190px;padding:0 15px;font-size:14px;overflow:hidden}.city-chip:hover{background:#281e3299}.submap{top:max(80px, calc(env(safe-area-inset-top) + 72px));left:max(16px, env(safe-area-inset-left));background:var(--glass-strong);border:1px solid var(--border);z-index:25;border-radius:16px;width:300px;padding:12px 12px 14px;animation:.3s fade;position:absolute;box-shadow:0 12px 40px #00000080}.submap-title{font-family:var(--serif);color:var(--ink);text-align:center;margin-bottom:8px;font-size:16px}.submap-canvas{cursor:pointer;border-radius:10px;width:100%;height:auto;display:block}.submap-close{color:var(--ink-soft);cursor:pointer;background:0 0;border:none;font-size:16px;position:absolute;top:8px;right:12px}.touch-controls{pointer-events:none;z-index:8;position:absolute;inset:0}.joystick-base{left:max(26px, env(safe-area-inset-left));bottom:calc(40px + env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(6px);pointer-events:auto;touch-action:none;-webkit-user-select:none;user-select:none;background:radial-gradient(circle,#ffebd212,#140e1a47);border:1px solid #ffdeb438;border-radius:50%;width:132px;height:132px;transition:border-color .15s,background .15s;position:absolute}.joystick-base.active{border-color:#ffc88c80}.joystick-knob{background:#ffd6a066;border:1px solid #ffe0b899;border-radius:50%;width:58px;height:58px;margin:-29px 0 0 -29px;transition:transform 40ms linear;position:absolute;top:50%;left:50%;box-shadow:0 4px 16px #0006}.coords-chip{height:48px;font-family:var(--sans);letter-spacing:.2px;color:var(--ink);background:var(--glass);border:1px solid var(--border);-webkit-backdrop-filter:blur(10px);cursor:pointer;white-space:nowrap;border-radius:24px;padding:0 14px;font-size:12.5px}.coords-chip:hover{background:#281e3299}.toast{left:50%;bottom:calc(190px + env(safe-area-inset-bottom));text-align:center;max-width:min(420px,88vw);color:var(--ink);background:var(--glass-strong);border:1px solid var(--border);opacity:0;z-index:40;pointer-events:none;border-radius:16px;padding:13px 20px;font-size:14.5px;line-height:1.45;transition:opacity .4s,transform .4s;position:absolute;transform:translate(-50%,10px);box-shadow:0 12px 40px #00000080}.toast.show{opacity:1;transform:translate(-50%)}.modal-backdrop,.map-overlay{z-index:30}.map-close{z-index:1000}.auth-backdrop{z-index:3000}.reticle{pointer-events:none;z-index:9;border:1.5px solid #fff0dc80;border-radius:50%;width:26px;height:26px;margin:-13px 0 0 -13px;position:fixed;top:50%;left:50%;box-shadow:0 0 8px #00000080}.reticle-dot{background:#fff0dcd9;border-radius:50%;width:3px;height:3px;margin:-1.5px 0 0 -1.5px;position:absolute;top:50%;left:50%}.credit{right:max(10px, env(safe-area-inset-right));bottom:max(8px, env(safe-area-inset-bottom));font-family:var(--sans);letter-spacing:.4px;color:#e6dceb38;pointer-events:none;z-index:9;-webkit-user-select:none;user-select:none;font-size:10.5px;position:fixed}.icon-btn.on{background:#e8965066;border-color:#ffc88c99}.nav-hint{left:max(22px, env(safe-area-inset-left));bottom:calc(34px + env(safe-area-inset-bottom));font-family:var(--serif);color:var(--ink-soft);text-shadow:0 2px 12px #000c;pointer-events:none;font-size:15px;line-height:1.7;transition:opacity 1.6s;position:absolute}.nav-hint b{color:var(--ink);letter-spacing:2px;font-weight:600}.nav-hint.fade{opacity:.28}.share-grid{grid-template-columns:1fr 1fr;gap:10px;margin:16px 0 8px;display:grid}.share-btn{font-family:var(--sans);color:var(--ink);border:1px solid var(--border);cursor:pointer;background:#ffffff0d;border-radius:14px;align-items:center;gap:10px;padding:12px 14px;font-size:14.5px;transition:background .15s,transform .1s;display:flex}.share-btn:hover{background:#ffffff1a;transform:translateY(-1px)}.share-icon{font-size:18px}.account-chip{top:max(16px, env(safe-area-inset-top));z-index:11;height:48px;font-family:var(--sans);color:var(--ink);background:var(--glass);border:1px solid var(--border);-webkit-backdrop-filter:blur(10px);cursor:pointer;pointer-events:auto;white-space:nowrap;border-radius:24px;padding:0 16px;font-size:14px;position:absolute;right:16px}.account-chip:hover{background:#281e3299}.auth-toggle{width:100%;color:var(--ink-soft);font-family:var(--sans);cursor:pointer;text-underline-offset:3px;background:0 0;border:none;margin-top:14px;font-size:13.5px;text-decoration:underline;display:block}.auth-toggle:hover{color:var(--ink)}.form-error.ok{color:#9fdcc0}.admin-chip{background:#281c1899;border-color:#e8a45c73;right:188px}.modal.admin{width:min(640px,100%)}.admin-body{text-align:left;max-height:62vh;margin:8px 0 6px;overflow-y:auto}.admin-summary{color:var(--ink-soft);margin-bottom:12px;font-size:13px}.admin-user{border-top:1px solid var(--border);padding:12px 0}.admin-user-head{flex-wrap:wrap;align-items:baseline;gap:8px;margin-bottom:8px;display:flex}.admin-nick{font-family:var(--serif);color:var(--ink);font-size:16px}.admin-badge{color:var(--amber);background:#e8a45c40;border:1px solid #e8a45c80;border-radius:8px;padding:2px 7px;font-size:10.5px}.admin-email{color:var(--ink-soft);font-size:13px}.admin-joined{color:#f3e9da66;margin-left:auto;font-size:12px}.admin-candles{flex-direction:column;gap:6px;padding-left:4px;display:flex}.admin-candle{background:#ffffff0a;border-radius:10px;align-items:center;gap:10px;padding:7px 10px;display:flex}.admin-candle-text{flex-direction:column;flex:1;min-width:0;display:flex}.admin-for{color:var(--ink);font-size:14px}.admin-msg{color:var(--ink-soft);text-overflow:ellipsis;white-space:nowrap;font-size:12.5px;overflow:hidden}.admin-go{flex-shrink:0;min-height:36px;padding:0 14px}.admin-empty{color:#f3e9da66;padding-left:4px;font-size:12.5px}.vignette{pointer-events:none;z-index:5;opacity:0;background:radial-gradient(circle,#0000 18%,#000000b8 78%);transition:opacity 1.6s;position:absolute;inset:0}.vignette.active{opacity:1}.hidden{display:none!important}@media (width<=680px){.top-bar{left:max(8px, env(safe-area-inset-left));top:max(8px, env(safe-area-inset-top));flex-wrap:wrap;gap:6px;max-width:calc(100vw - 100px)}.icon-btn{width:42px;height:42px;font-size:17px}.city-chip{max-width:96px;height:42px;padding:0 10px;font-size:12px}.coords-chip{text-overflow:ellipsis;max-width:150px;height:42px;padding:0 10px;font-size:11px;overflow:hidden}.account-chip{height:42px;top:max(8px, env(safe-area-inset-top));padding:0 12px;font-size:12.5px;right:8px}.admin-chip{right:8px;top:calc(max(8px, env(safe-area-inset-top)) + 50px)}.joystick-base{width:108px;height:108px;left:max(14px, env(safe-area-inset-left));bottom:calc(26px + env(safe-area-inset-bottom))}.joystick-knob{width:48px;height:48px;margin:-24px 0 0 -24px}.hint{bottom:calc(154px + env(safe-area-inset-bottom));font-size:14px}.action-bar{bottom:max(16px, env(safe-area-inset-bottom));justify-content:flex-end;gap:8px;padding:0 10px 0 130px}.submap{width:min(280px,86vw);top:max(94px, calc(env(safe-area-inset-top) + 86px))}}@keyframes fade{0%{opacity:0}}@keyframes rise{0%{opacity:0;transform:translateY(18px)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-7px)}75%{transform:translate(7px)}}
