*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}:root{--sky:#c8dbe6;--text:#1a2332;--text2:#556;--text-light:#fff;--ui-bg:#ffffffeb;--ui-border:#0000001a;--ui-shadow:0 4px 20px #0000001f;--accent:#4a8030}[data-theme=dark]{--sky:#1a2332;--text:#d8dce0;--text2:#8a8e98;--text-light:#fff;--ui-bg:#1a2332f2;--ui-border:#ffffff14;--ui-shadow:0 4px 20px #0006;--accent:#6ab848}body{background:var(--sky);color:var(--text);min-height:100dvh;font-family:Segoe UI,system-ui,sans-serif;transition:background .3s;overflow:hidden}.auth{flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100dvh;display:flex}.auth h1{font-size:32px;font-weight:300}.auth h1 b{color:var(--accent);font-weight:700}.auth p{color:var(--text2);font-size:13px}.auth-btn{border:1px solid var(--ui-border);background:var(--ui-bg);color:var(--text);cursor:pointer;box-shadow:var(--ui-shadow);border-radius:10px;align-items:center;gap:10px;padding:12px 24px;font-size:14px;transition:all .15s;display:flex}.auth-btn:hover{transform:translateY(-2px)}.auth-btn svg{width:18px;height:18px}.hud{z-index:30;background:var(--ui-bg);border-bottom:1px solid var(--ui-border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);justify-content:space-between;align-items:center;padding:10px 16px;display:flex;position:fixed;top:0;left:0;right:0}.hud h1{font-size:15px;font-weight:600}.hud h1 b{color:var(--accent)}.hud-points{color:var(--accent);white-space:nowrap;background:#4a80301a;border-radius:8px;padding:4px 10px;font-size:12px;font-weight:700}.hud-search{border:1px solid var(--ui-border);width:100px;color:var(--text);background:0 0;border-radius:8px;outline:none;padding:6px 10px;font-family:inherit;font-size:12px;transition:width .2s}.hud-search:focus{border-color:var(--accent);width:160px}.hud-search::placeholder{color:var(--text2)}.hud-actions{gap:6px;display:flex}.hud-btn{border:1px solid var(--ui-border);background:var(--ui-bg);width:32px;height:32px;color:var(--text2);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;font-size:13px;transition:all .15s;display:flex}.hud-btn:hover{border-color:var(--accent);color:var(--accent)}.canvas-wrap{width:100%;height:100dvh;position:relative}#hexCanvas{width:100%;height:100%;display:block}.hex-label-3d{color:#fff;white-space:nowrap;pointer-events:none;text-shadow:0 1px 2px #0009,0 0 8px #0000004d;-webkit-user-select:none;user-select:none;letter-spacing:.02em;font-size:12px;font-weight:800}[data-theme=dark] .hex-label-3d{text-shadow:0 1px 2px #000c,0 0 10px #00000080}.hex-count-3d{color:#fff;pointer-events:none;-webkit-user-select:none;user-select:none;background:#e05040;border-radius:10px;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 5px;font-size:9px;font-weight:800;display:flex;box-shadow:0 2px 6px #e0504066}.sub-label-3d{color:#fff;text-align:center;text-overflow:ellipsis;white-space:nowrap;pointer-events:none;text-shadow:0 1px 2px #0009,0 0 6px #0000004d;-webkit-user-select:none;user-select:none;max-width:60px;font-size:10px;font-weight:700;overflow:hidden}[data-theme=dark] .sub-label-3d{text-shadow:0 1px 2px #000c,0 0 8px #00000080}.sub-label-3d.done{opacity:.5;text-decoration:line-through}.sub-check-3d{color:var(--accent);pointer-events:none;-webkit-user-select:none;user-select:none;font-size:18px}.sg-overlay{z-index:40;opacity:0;pointer-events:none;background:0 0;flex-direction:column;justify-content:space-between;transition:opacity .25s;display:flex;position:fixed;inset:0}.sg-overlay.show{opacity:1}.sg-overlay.show .sg-header,.sg-overlay.show .sg-input{pointer-events:all}.sg-header{background:var(--ui-bg);border-bottom:1px solid var(--ui-border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);align-items:center;gap:10px;padding:10px 16px;display:flex}.sg-back{border:1px solid var(--ui-border);width:32px;height:32px;color:var(--text);cursor:pointer;background:0 0;border-radius:8px;justify-content:center;align-items:center;font-size:16px;display:flex}.sg-title{cursor:pointer;border-radius:6px;flex:1;padding:2px 6px;font-size:14px;font-weight:600;transition:background .15s}.sg-title:hover{background:#0000000d}[data-theme=dark] .sg-title:hover{background:#ffffff0d}.sg-progress{color:var(--text2);font-size:11px}.sg-input{background:var(--ui-bg);border-top:1px solid var(--ui-border);padding:10px 16px;padding-bottom:max(10px,env(safe-area-inset-bottom));align-items:center;gap:8px;display:flex}.sg-input input{border:1px solid var(--ui-border);color:var(--text);background:0 0;border-radius:10px;outline:none;flex:1;padding:10px 12px;font-family:inherit;font-size:13px}.sg-input input:focus{border-color:var(--accent)}.sg-input input::placeholder{color:var(--text2)}.sg-input button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:10px;width:40px;height:40px;font-size:18px;font-weight:700;transition:transform .12s}.sg-input button:hover{transform:scale(1.05)}.fab{z-index:20;background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:50%;width:56px;height:56px;font-size:24px;font-weight:700;transition:transform .15s;position:fixed;bottom:24px;right:24px;box-shadow:0 4px 16px #00000040}.fab:hover{transform:scale(1.1)}.fab:active{transform:scale(.95)}.view-panel{z-index:32;background:var(--ui-bg);border:1px solid var(--ui-border);box-shadow:var(--ui-shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:10px;padding:10px 14px;font-size:12px;position:fixed;top:52px;right:8px}.view-panel label{cursor:pointer;color:var(--text);-webkit-user-select:none;user-select:none;align-items:center;gap:6px;display:flex}.view-panel input[type=checkbox]{accent-color:var(--accent);width:14px;height:14px}.qa-modal{z-index:50;background:#00000059;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.qa-modal.show{display:flex}.qa-sheet{background:var(--ui-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:18px;width:92%;max-width:480px;padding:28px 24px;box-shadow:0 8px 32px #00000040}.qa-sheet h3{margin-bottom:14px;font-size:17px;font-weight:700}.qa-sheet input{border:1px solid var(--ui-border);width:100%;color:var(--text);background:0 0;border-radius:12px;outline:none;margin-bottom:14px;padding:14px 16px;font-family:inherit;font-size:16px}.qa-sheet input:focus{border-color:var(--accent)}.qa-send{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:12px;width:100%;padding:14px;font-family:inherit;font-size:16px;font-weight:600}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0006;justify-content:center;align-items:center;animation:.18s ease-out modalFadeIn;display:flex;position:fixed;inset:0}.modal-card{background:var(--ui-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-radius:20px;width:88%;max-width:400px;padding:32px 28px 24px;animation:.22s ease-out modalSlideUp;box-shadow:0 12px 48px #0000004d}.modal-message{color:var(--text);text-align:center;margin-bottom:20px;font-size:16px;font-weight:600;line-height:1.5}.modal-input{border:2px solid var(--ui-border);width:100%;color:var(--text);background:0 0;border-radius:12px;outline:none;margin-bottom:20px;padding:14px 16px;font-family:inherit;font-size:16px;transition:border-color .15s}.modal-input:focus{border-color:var(--accent)}.modal-actions{gap:10px;display:flex}.modal-btn{cursor:pointer;border:none;border-radius:12px;flex:1;padding:13px 0;font-family:inherit;font-size:15px;font-weight:600;transition:all .12s}.modal-btn:active{transform:scale(.97)}.modal-btn-cancel{background:var(--ui-border);color:var(--text2)}.modal-btn-cancel:hover{background:#0000001f}[data-theme=dark] .modal-btn-cancel:hover{background:#ffffff1f}.modal-btn-ok{background:var(--accent);color:#fff;box-shadow:0 2px 8px #4a80304d}.modal-btn-ok:hover{filter:brightness(1.08)}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(12px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.creature-toggle{z-index:22;background:var(--ui-bg);width:48px;height:48px;color:var(--text);border:1px solid var(--ui-border);cursor:pointer;box-shadow:var(--ui-shadow);border-radius:50%;justify-content:center;align-items:center;font-size:20px;transition:transform .15s;display:flex;position:fixed;bottom:24px;left:24px}.creature-toggle:hover{transform:scale(1.1)}.creature-panel{z-index:24;background:var(--ui-bg);border:1px solid var(--ui-border);width:260px;box-shadow:var(--ui-shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);opacity:0;pointer-events:none;border-radius:14px;transition:all .2s ease-out;position:fixed;bottom:80px;left:24px;transform:translateY(8px)scale(.97)}.creature-panel.show{opacity:1;pointer-events:all;transform:translateY(0)scale(1)}.cp-header{border-bottom:1px solid var(--ui-border);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.cp-title{color:var(--text);font-size:13px;font-weight:700}.cp-count{color:var(--text2);background:var(--ui-border);border-radius:10px;padding:2px 8px;font-size:11px;font-weight:600}.cp-list{max-height:200px;padding:6px 0;overflow-y:auto}.cp-item{align-items:center;gap:8px;padding:8px 16px;transition:background .1s;display:flex}.cp-item:hover{background:#00000008}[data-theme=dark] .cp-item:hover{background:#ffffff08}.cp-emoji{flex-shrink:0;font-size:18px}.cp-name{color:var(--text);cursor:pointer;text-overflow:ellipsis;white-space:nowrap;border-radius:4px;flex:1;min-width:0;padding:2px 4px;font-size:12px;font-weight:600;overflow:hidden}.cp-name:hover{background:#0000000d}[data-theme=dark] .cp-name:hover{background:#ffffff0d}.cp-type{color:var(--text2);flex-shrink:0;font-size:10px}.cp-id{color:var(--text2);opacity:.6;flex-shrink:0;font-family:monospace;font-size:9px}.cp-edit-input{border:1px solid var(--accent);color:var(--text);background:0 0;border-radius:4px;outline:none;flex:1;min-width:0;padding:2px 4px;font-family:inherit;font-size:12px}.cp-remove{width:20px;height:20px;color:var(--text2);cursor:pointer;opacity:.4;background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;transition:opacity .15s;display:flex}.cp-remove:hover{opacity:1;color:#e05040}.cp-empty{text-align:center;color:var(--text2);padding:20px 16px;font-size:12px}.cp-add-bar{border-top:1px solid var(--ui-border);gap:6px;padding:10px 12px;display:flex}.cp-add-btn{border:1px solid var(--ui-border);color:var(--text);cursor:pointer;background:0 0;border-radius:8px;flex:1;padding:8px 0;font-family:inherit;font-size:11px;transition:all .12s}.cp-add-btn:hover{border-color:var(--accent);color:var(--accent)}.todo-toggle{z-index:22;background:var(--ui-bg);width:48px;height:48px;color:var(--text);border:1px solid var(--ui-border);cursor:pointer;box-shadow:var(--ui-shadow);border-radius:50%;justify-content:center;align-items:center;font-size:16px;transition:transform .15s;display:flex;position:fixed;bottom:24px;right:90px}.todo-toggle:hover{transform:scale(1.1)}.todo-toggle-icon{font-size:18px}.todo-toggle-badge{background:var(--accent);color:#fff;border-radius:9px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:0 4px;font-size:10px;font-weight:700;display:flex;position:absolute;top:-2px;right:-2px}.todo-panel{z-index:24;background:var(--ui-bg);border:1px solid var(--ui-border);width:300px;max-height:60vh;box-shadow:var(--ui-shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);opacity:0;pointer-events:none;border-radius:14px;flex-direction:column;transition:all .2s ease-out;display:flex;position:fixed;bottom:80px;right:24px;transform:translateY(8px)scale(.97)}.todo-panel.show{opacity:1;pointer-events:all;transform:translateY(0)scale(1)}.tp-header{border-bottom:1px solid var(--ui-border);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.tp-title{color:var(--text);font-size:13px;font-weight:700}.tp-count{color:var(--text2);font-size:11px;font-weight:600}.tp-filters{border-bottom:1px solid var(--ui-border);gap:4px;padding:8px 12px;display:flex}.tp-filter{border:1px solid var(--ui-border);color:var(--text2);cursor:pointer;background:0 0;border-radius:6px;padding:4px 10px;font-family:inherit;font-size:10px;transition:all .12s}.tp-filter.active{background:var(--accent);color:#fff;border-color:var(--accent)}.tp-list{flex:1;padding:4px 0;overflow-y:auto}.tp-item{align-items:center;gap:8px;padding:8px 12px;transition:background .1s;display:flex}.tp-item:hover{background:#00000008}[data-theme=dark] .tp-item:hover{background:#ffffff08}.tp-item.done .tp-text{opacity:.5;text-decoration:line-through}.tp-check{border:2px solid var(--ui-border);width:22px;height:22px;color:var(--accent);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:12px;transition:all .12s;display:flex}.tp-item.done .tp-check{background:var(--accent);color:#fff;border-color:var(--accent)}.tp-collapse{width:22px;height:22px;color:var(--text2);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:12px;display:flex}.tp-item.project .tp-text{font-weight:700}.tp-children{border-left:2px solid var(--ui-border);margin-left:22px;padding-left:0}.tp-item.child{padding-left:8px}.tp-item.child .tp-check{width:18px;height:18px;font-size:10px}.tp-content{flex:1;align-items:center;gap:6px;min-width:0;display:flex}.tp-text{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.tp-sub-count{color:var(--text2);background:var(--ui-border);border-radius:6px;flex-shrink:0;padding:1px 5px;font-size:9px;font-weight:600}.tp-delete{width:20px;height:20px;color:var(--text2);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;transition:opacity .15s;display:flex}.tp-item:hover .tp-delete{opacity:.4}.tp-delete:hover{color:#e05040;opacity:1!important}.tp-empty{text-align:center;color:var(--text2);padding:24px 16px;font-size:12px}.hide{display:none!important}
