*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;overflow:hidden}body{font-family:Avenir Next,Segoe UI,-apple-system,system-ui,sans-serif}.app{width:100%;height:100%;position:relative}.map-canvas{width:100%;height:100%;display:block;background:radial-gradient(circle at 50% 40%,#fff,#f7f4ec 70%,#f1ecdf);touch-action:none;user-select:none;-webkit-user-select:none}.toolbar{position:absolute;top:16px;left:16px;max-width:calc(100vw - 280px);display:flex;flex-wrap:wrap;align-items:center;gap:8px;background:#ffffffeb;border:1px solid #e2ddd0;border-radius:12px;padding:8px 12px;box-shadow:0 4px 18px #281e0a14}.toolbar .brand{font-weight:700;font-size:14px;color:#334155;margin-right:6px}.toolbar button{font:inherit;font-size:13px;font-weight:600;color:#334155;background:#fff;border:1px solid #d8d2c2;border-radius:8px;padding:6px 12px;cursor:pointer;transition:background .15s,border-color .15s}.toolbar button:hover:not(:disabled){background:#f0fdf4;border-color:#86efac}.toolbar button:disabled{opacity:.4;cursor:default}.hints{position:absolute;bottom:14px;left:50%;transform:translate(-50%);font-size:12px;color:#857f6e;background:#ffffffd9;border-radius:10px;padding:6px 14px;white-space:nowrap}.toolbar .divider{width:1px;height:20px;background:#e2ddd0}.toolbar button.active{background:#eef2ff;border-color:#818cf8}.map-canvas.linking{cursor:crosshair}.popover{position:absolute;top:64px;left:16px;background:#fff;border:1px solid #e2ddd0;border-radius:12px;padding:12px;box-shadow:0 8px 28px #281e0a24;max-width:340px}.popover-title{font-size:12px;font-weight:600;color:#64748b;margin-bottom:8px}.emoji-grid{display:grid;grid-template-columns:repeat(10,30px);gap:2px}.emoji-grid button{font-size:18px;background:none;border:none;border-radius:6px;padding:3px;cursor:pointer}.emoji-grid button:hover{background:#f1f5f9}.swatch-grid{display:grid;grid-template-columns:repeat(6,34px);gap:6px}.swatch-grid button{width:34px;height:34px;border-radius:8px;border:2px solid rgba(0,0,0,.08);cursor:pointer}.swatch-grid button:hover{transform:scale(1.1)}.popover-clear{margin-top:10px;font:inherit;font-size:12px;font-weight:600;color:#64748b;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:5px 10px;cursor:pointer}.zoom-controls{position:absolute;right:16px;bottom:56px;display:flex;align-items:center;gap:2px;background:#fffffff0;border:1px solid #e2ddd0;border-radius:12px;padding:4px;box-shadow:0 4px 18px #281e0a1a}.zoom-controls button{font:inherit;font-size:17px;font-weight:700;color:#334155;background:transparent;border:none;border-radius:8px;width:34px;height:32px;cursor:pointer;display:flex;align-items:center;justify-content:center}.zoom-controls button:hover{background:#f0fdf4}.zoom-controls .zoom-level{font-size:12px;width:46px;color:#64748b}.searchbar{position:absolute;top:16px;right:16px;display:flex;align-items:center;gap:8px;background:#ffffffeb;border:1px solid #e2ddd0;border-radius:12px;padding:8px 12px;box-shadow:0 4px 18px #281e0a14}.searchbar input{font:inherit;font-size:13px;border:none;outline:none;background:transparent;width:160px;color:#334155}.search-count{font-size:12px;font-weight:700;color:#0f9d58;min-width:28px;text-align:right}.search-count.none{color:#b91c1c}.share-popover{width:340px}.share-note{font-size:13px;line-height:1.5;color:#6b7280;margin-bottom:12px}.share-row{display:flex;gap:8px;margin-bottom:10px}.share-row input{flex:1;font:inherit;font-size:12px;border:1px solid #e2e8f0;border-radius:8px;padding:8px 10px;color:#334155;min-width:0}.video-panel{position:absolute;right:16px;bottom:104px;width:min(400px,calc(100vw - 32px));background:#1e293b;border-radius:14px;overflow:hidden;box-shadow:0 16px 48px #00000059;z-index:40}.video-panel-bar{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;color:#e2e8f0;font-size:12px;font-weight:600}.video-panel-bar button{background:none;border:none;color:#94a3b8;font-size:14px;cursor:pointer}.video-panel-bar button:hover{color:#fff}.video-panel iframe{display:block;width:100%;aspect-ratio:16 / 9;border:none}.shared-topbar{position:absolute;top:16px;left:16px;background:#ffffffeb;border:1px solid #e2ddd0;border-radius:12px;padding:10px 16px;font-weight:700;color:#1e293b;box-shadow:0 4px 18px #281e0a14}.shared-cta{position:absolute;bottom:14px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:14px;font-size:13px;color:#57534e;background:#fffffff0;border:1px solid #e2ddd0;border-radius:12px;padding:8px 10px 8px 16px;box-shadow:0 4px 18px #281e0a1a;white-space:nowrap}.shared-empty{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;text-align:center;padding:24px;background:radial-gradient(circle at 50% 0%,#fff,#f7f4ec 60%,#f1ecdf)}.shared-empty h1{font-size:24px;color:#1e293b}.shared-empty p{color:#6b7280}.link-banner{position:absolute;top:64px;left:50%;transform:translate(-50%);background:#1e293b;color:#fff;font-size:13px;font-weight:600;border-radius:10px;padding:8px 16px;box-shadow:0 6px 20px #0003}.save-state{font-size:12px;font-weight:600;color:#94a3b8;padding:0 4px;white-space:nowrap}.save-state.error{color:#b91c1c}.lang-switcher{font:inherit;font-size:13px;font-weight:600;color:#334155;background:#fff;border:1px solid #d8d2c2;border-radius:8px;padding:6px 8px;cursor:pointer}.auth-top{display:flex;align-items:center;justify-content:space-between;width:100%;padding:0 24px}.auth-panel{position:relative;display:flex;align-items:center;gap:10px}.auth-badge{font-size:12px;font-weight:700;border-radius:999px;padding:5px 12px}.auth-badge.local{background:#f1f5f9;color:#64748b}.auth-badge.cloud{background:#ecfdf5;color:#0f9d58}.auth-email{font-size:13px;color:#64748b}.auth-btn{font:inherit;font-size:13px;font-weight:600;color:#334155;background:#fff;border:1px solid #d8d2c2;border-radius:8px;padding:7px 14px;cursor:pointer}.auth-btn.primary{background:#0f9d58;border-color:#0f9d58;color:#fff}.auth-btn:disabled{opacity:.6}.auth-form{position:absolute;top:44px;right:0;z-index:10;width:280px;background:#fff;border:1px solid #e2ddd0;border-radius:14px;padding:16px;box-shadow:0 10px 32px #281e0a29;display:flex;flex-direction:column;gap:10px}.auth-tabs{display:flex;gap:6px}.auth-tabs button{flex:1;font:inherit;font-size:12px;font-weight:700;padding:6px;border:none;border-radius:8px;background:#f1f5f9;color:#64748b;cursor:pointer}.auth-tabs button.on{background:#dcfce7;color:#0f9d58}.auth-form input{font:inherit;font-size:13px;border:1px solid #e2e8f0;border-radius:8px;padding:8px 10px;outline:none}.auth-form input:focus{border-color:#86efac}.auth-msg{font-size:12px;color:#b45309;background:#fffbeb;border-radius:8px;padding:8px 10px}.home-header-row{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.home-error{color:#b91c1c;font-size:13px;margin-top:8px}.map-loading{color:#94a3b8;font-size:14px;align-self:center;padding:20px}.landing{width:100%;height:100%;overflow-y:auto;background:radial-gradient(circle at 50% 0%,#fff,#f7f4ec 60%,#f1ecdf);color:#1e293b}.landing-nav{display:flex;align-items:center;justify-content:space-between;padding:20px clamp(24px,6vw,72px)}.landing-logo{font-weight:800;font-size:17px}.landing-nav-actions{display:flex;gap:10px}.cta-btn{font:inherit;font-size:14px;font-weight:700;color:#fff;background:#0f9d58;border:none;border-radius:10px;padding:10px 18px;cursor:pointer;box-shadow:0 4px 14px #0f9d584d;transition:transform .12s,box-shadow .12s}.cta-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #0f9d5866}.cta-btn.big{font-size:16px;padding:14px 26px;border-radius:12px}.cta-btn.full{width:100%}.ghost-btn{font:inherit;font-size:14px;font-weight:600;color:#334155;background:transparent;border:1px solid #d8d2c2;border-radius:10px;padding:10px 18px;cursor:pointer}.ghost-btn.big{font-size:15px;padding:14px 22px;border-radius:12px}.ghost-btn:hover{background:#ffffffb3}.hero{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;padding:clamp(30px,6vh,80px) clamp(24px,6vw,72px);max-width:1280px;margin:0 auto}@media(max-width:860px){.hero{grid-template-columns:1fr}}.hero-copy h1{font-size:clamp(34px,4.5vw,54px);line-height:1.1;letter-spacing:-.02em}.hero-copy h1 em{font-style:normal;background:linear-gradient(100deg,#0f9d58,#2f6fed,#8b5cf6);-webkit-background-clip:text;background-clip:text;color:transparent}.hero-copy p{margin-top:18px;font-size:17px;line-height:1.6;color:#57534e;max-width:52ch}.hero-actions{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap}.hero-visual{background:#fff;border:1px solid #eae5d8;border-radius:20px;box-shadow:0 20px 60px #281e0a1f;padding:12px}.static-map{width:100%;height:auto;display:block}.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;padding:40px clamp(24px,6vw,72px);max-width:1280px;margin:0 auto}.feature{background:#fff;border:1px solid #eae5d8;border-radius:16px;padding:24px}.feature-icon{font-size:30px}.feature h3{margin:12px 0 8px;font-size:16px}.feature p{font-size:14px;line-height:1.55;color:#6b7280}.buzan{padding:60px clamp(24px,6vw,72px);max-width:1080px;margin:0 auto;text-align:center}.buzan h2{font-size:28px}.buzan-rules{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;margin-top:28px;text-align:left}.rule{background:#f0fdf4;border:1px solid #d1fae5;border-radius:14px;padding:20px;font-size:14px;line-height:1.6;color:#374151}.rule b{display:block;color:#0f766e;margin-bottom:6px}.cta-band{text-align:center;padding:70px 24px}.cta-band h2{font-size:30px;margin-bottom:24px}.landing-footer{text-align:center;padding:28px;font-size:13px;color:#94a3b8;border-top:1px solid #eae5d8}.auth-page{width:100%;height:100%;overflow-y:auto;background:radial-gradient(circle at 50% 0%,#fff,#f7f4ec 60%,#f1ecdf);display:flex;flex-direction:column;align-items:center}.auth-home-link{font:inherit;font-weight:800;font-size:16px;color:#1e293b;background:none;border:none;cursor:pointer;padding:24px;align-self:flex-start}.auth-card{width:min(400px,calc(100vw - 48px));background:#fff;border:1px solid #eae5d8;border-radius:20px;box-shadow:0 20px 60px #281e0a1f;padding:36px;margin-top:4vh}.auth-card h1{font-size:24px;color:#1e293b}.auth-sub{margin:8px 0 24px;font-size:14px;color:#6b7280}.auth-card form{display:flex;flex-direction:column;gap:16px}.auth-card label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:600;color:#374151}.auth-card input{font:inherit;font-size:14px;border:1px solid #e2e8f0;border-radius:10px;padding:11px 12px;outline:none}.auth-card input:focus{border-color:#86efac}.auth-switch{margin-top:20px;font-size:13px;color:#6b7280;text-align:center}.auth-switch button{font:inherit;font-size:13px;font-weight:700;color:#0f9d58;background:none;border:none;cursor:pointer;padding:0}.home-logo{font:inherit;font-size:28px;font-weight:800;color:#1e293b;background:none;border:none;cursor:pointer;padding:0}.home{width:100%;height:100%;overflow-y:auto;background:radial-gradient(circle at 50% 0%,#fff,#f7f4ec 60%,#f1ecdf);padding:48px clamp(24px,8vw,96px)}.home-header h1{font-size:28px;color:#1e293b}.home-header p{color:#857f6e;margin-top:6px;margin-bottom:32px}.map-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px}.map-card{position:relative;background:#fff;border:1px solid #e6e1d3;border-radius:16px;padding:20px;min-height:140px;cursor:pointer;box-shadow:0 3px 12px #281e0a0f;transition:transform .12s,box-shadow .12s;display:flex;flex-direction:column;justify-content:flex-end}.map-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #281e0a1f}.card-dots{position:absolute;top:18px;left:20px;display:flex;gap:5px}.card-dots span{width:14px;height:8px;border-radius:5px;display:inline-block}.card-title{font-weight:700;font-size:16px;color:#1e293b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card-date{font-size:12px;color:#94a3b8;margin-top:4px}.card-delete{position:absolute;top:10px;right:10px;width:26px;height:26px;border-radius:50%;border:none;background:transparent;color:#cbd5e1;font-size:13px;cursor:pointer}.map-card:hover .card-delete{color:#64748b}.card-delete:hover{background:#fee2e2;color:#b91c1c!important}.new-card{font:inherit;font-weight:700;font-size:15px;color:#0f9d58;background:#f0fdf4;border:2px dashed #86efac;align-items:center;justify-content:center;gap:6px}.new-card:hover{background:#dcfce7}.new-plus{font-size:34px;line-height:1}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1e1e1473;display:flex;align-items:center;justify-content:center;z-index:50}.modal{width:min(460px,calc(100vw - 48px));background:#fff;border-radius:20px;padding:28px;box-shadow:0 24px 70px #0000004d}.modal h2{font-size:19px;color:#1e293b}.modal-sub{margin:8px 0 18px;font-size:13px;line-height:1.55;color:#6b7280}.modal input{width:100%;font:inherit;font-size:14px;border:1px solid #e2e8f0;border-radius:10px;padding:11px 12px;outline:none}.modal input:focus{border-color:#86efac}.modal-error{margin-top:10px;font-size:13px;color:#b91c1c;background:#fef2f2;border-radius:8px;padding:8px 12px}.modal-progress{margin-top:12px;font-size:13px;font-weight:600;color:#0f9d58;display:flex;align-items:center;gap:8px}.spinner{width:14px;height:14px;border:2px solid #bbf7d0;border-top-color:#0f9d58;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}.doc-card{color:#1d4ed8;background:#eff6ff;border-color:#93c5fd}.doc-card:hover{background:#dbeafe}.doc-card .yt-sub{color:#3b82f6}.doc-file-btn{display:block;text-align:center;font-size:13px;font-weight:700;color:#1d4ed8;background:#eff6ff;border:2px dashed #93c5fd;border-radius:10px;padding:12px;cursor:pointer;margin-bottom:10px}.doc-file-btn:hover{background:#dbeafe}.doc-textarea{width:100%;min-height:120px;font:inherit;font-size:13px;border:1px solid #e2e8f0;border-radius:10px;padding:10px 12px;outline:none;resize:vertical}.doc-textarea:focus{border-color:#86efac}.note-popover{width:340px}.note-popover textarea{width:100%;min-height:130px;font:inherit;font-size:13px;border:1px solid #e2e8f0;border-radius:10px;padding:10px 12px;outline:none;resize:vertical;margin-bottom:10px}.note-popover textarea:focus{border-color:#86efac}.study-card{text-align:center}.study-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.study-head h2{font-size:17px}.study-progress{font-size:12px;font-weight:700;color:#94a3b8}.study-crumbs{font-size:12px;color:#94a3b8;margin-bottom:8px}.study-word{font-size:28px;font-weight:800;color:#1e293b;margin:10px 0}.study-question{font-size:14px;color:#6b7280;margin-bottom:16px}.study-answers{list-style:none;display:flex;flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:18px}.study-answers li{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:999px;padding:6px 14px;font-size:14px;font-weight:600;color:#166534}.study-card .modal-actions{justify-content:center}.yt-card{color:#b45309;background:#fffbeb;border-color:#fcd34d}.yt-card:hover{background:#fef3c7}.yt-sub{font-size:11px;font-weight:500;color:#d97706}.node-editor{width:100%;border:none;outline:2px solid #94a3b8;border-radius:6px;background:#fffffff2;padding:2px 6px;font-weight:600;color:#243041}
