.App{width:100vw;height:100vh;position:relative;overflow:hidden;font-family:Arial,sans-serif}.top-ad{position:fixed;top:0;left:50%;transform:translate(-50%);z-index:200;background:#fffffff2;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.sidebar-ad{position:fixed;top:50%;right:10px;transform:translateY(-50%);z-index:150}.bottom-mobile-ad{position:fixed;bottom:0;left:50%;transform:translate(-50%);z-index:200;background:#fffffff2;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}@media (max-width: 1024px){.sidebar-ad{display:none}}@media (min-width: 769px){.bottom-mobile-ad{display:none}}@media (max-width: 768px){.top-ad{position:relative;transform:none;left:auto;margin-bottom:10px}}.App>canvas{width:100%;height:100%;display:block}.App.loading-state{background:linear-gradient(135deg,#1e3c72,#2a5298);display:flex;align-items:center;justify-content:center;color:#fff}.loading-container{text-align:center;padding:2rem;background:#ffffff1a;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a;max-width:400px;width:90%}.loading-spinner{font-size:3rem;animation:spin 2s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container h2{margin:1rem 0;font-size:1.5rem;color:#fff}.loading-container p{margin:1rem 0;color:#fffc}.loading-bar{width:100%;height:6px;background:#fff3;border-radius:3px;overflow:hidden;margin-top:1rem}.loading-progress{height:100%;background:linear-gradient(90deg,#4facfe,#00f2fe);border-radius:3px;animation:loading 2s ease-in-out infinite}@keyframes loading{0%{width:0%}50%{width:70%}to{width:100%}}.App.error-state{background:linear-gradient(135deg,#ff6b6b,#ee5a52);display:flex;align-items:center;justify-content:center;color:#fff}.error-container{text-align:center;padding:2rem;background:#ffffff1a;border-radius:20px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);box-shadow:0 8px 32px #0000001a;max-width:400px;width:90%}.error-container h2{margin:1rem 0;color:#fff}.error-container p{margin:1rem 0;color:#ffffffe6}.error-container button{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.8rem 1.5rem;border-radius:10px;cursor:pointer;font-size:1rem;margin-top:1rem;transition:all .3s ease}.error-container button:hover{background:#ffffff4d;transform:translateY(-2px)}.camera-controls-info{position:fixed;bottom:10px;left:50%;transform:translate(-50%);background:#000000b3;color:#fff;padding:.5rem 1rem;border-radius:20px;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);font-size:.8rem;z-index:1000;pointer-events:none;opacity:.8;transition:opacity .3s ease}.camera-controls-info:hover{opacity:1}.distance-display{position:fixed;bottom:30px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#2c3e50,#34495e);border-radius:16px;box-shadow:0 20px 40px #0000004d;padding:20px;color:#fff;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);z-index:1000;min-width:280px;text-align:center;animation:slideUp .3s ease-out}.distance-display.live{background:linear-gradient(135deg,#27ae60,#2ecc71);border-color:#2ecc714d;box-shadow:0 20px 40px #2ecc714d;animation:pulse 2s infinite}.distance-display.final{background:linear-gradient(135deg,#3498db,#2980b9);border-color:#3498db4d;box-shadow:0 20px 40px #3498db4d}.distance-content{display:flex;align-items:center;gap:15px}.distance-icon{font-size:2rem;opacity:.8}.distance-info{flex:1;text-align:left}.distance-value{font-size:1.8rem;font-weight:700;margin-bottom:5px;text-shadow:0 2px 4px rgba(0,0,0,.3)}.distance-value .unit{font-size:1rem;font-weight:400;opacity:.9;margin-left:5px}.distance-details{font-size:.9rem;opacity:.8;margin-bottom:5px}.distance-status{font-size:.8rem;font-weight:700;color:#ffffffe6;text-transform:uppercase;letter-spacing:.5px}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes pulse{0%,to{transform:translate(-50%) scale(1)}50%{transform:translate(-50%) scale(1.02)}}@media (max-width: 768px){.distance-display{bottom:20px;left:20px;right:20px;transform:none;min-width:auto}.distance-content{gap:10px}.distance-icon{font-size:1.5rem}.distance-value{font-size:1.4rem}}.measurement-controls{background:#0003;border-radius:12px;padding:15px;margin-bottom:20px;border:1px solid rgba(255,255,255,.1)}.measurement-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.measurement-header h4{margin:0;font-size:1rem;color:#ecf0f1}.measurement-badge{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;font-size:.7rem;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}.measurement-buttons{display:flex;gap:10px;margin-bottom:15px}.measure-btn{flex:1;background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;padding:10px;border-radius:8px;font-weight:700;cursor:pointer;transition:all .3s ease;font-size:.9rem}.measure-btn:hover{background:linear-gradient(135deg,#2980b9,#21618c);transform:translateY(-2px);box-shadow:0 8px 20px #3498db4d}.measure-btn.active{background:linear-gradient(135deg,#e74c3c,#c0392b);animation:pulse 2s infinite}.measure-btn.active:hover{background:linear-gradient(135deg,#c0392b,#a93226)}.btn-clear-measurements{background:linear-gradient(135deg,#95a5a6,#7f8c8d);color:#fff;border:none;padding:10px 15px;border-radius:8px;font-weight:700;cursor:pointer;transition:all .3s ease;font-size:.8rem}.btn-clear-measurements:hover{background:linear-gradient(135deg,#7f8c8d,#34495e);transform:translateY(-2px)}.measurement-instructions{background:#3498db33;border:1px solid rgba(52,152,219,.3);border-radius:8px;padding:12px;margin-bottom:15px;text-align:center}.measurement-instructions p{margin:0 0 5px;font-weight:700;color:#3498db;font-size:.9rem}.measurement-instructions small{color:#ffffffb3;font-size:.75rem}.live-distance{background:linear-gradient(135deg,#27ae60,#2ecc71);border-radius:12px;padding:15px;margin-bottom:15px;text-align:center;box-shadow:0 4px 15px #2ecc714d}.distance-display{display:flex;align-items:baseline;justify-content:center;gap:5px;margin-bottom:5px}.distance-value{font-size:2rem;font-weight:700;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.3)}.distance-unit{font-size:1rem;font-weight:700;color:#ffffffe6}.distance-breakdown{font-size:.8rem;color:#fffc}.measurement-tips{background:#f1c40f1a;border:1px solid rgba(241,196,15,.3);border-radius:8px;padding:12px}.measurement-tips h5{margin:0 0 8px;font-size:.9rem;color:#f1c40f}.measurement-tips ul{margin:0;padding-left:16px;font-size:.8rem;line-height:1.4}.measurement-tips li{margin-bottom:4px;color:#fffc}.measurement-tips kbd{background:#fff3;padding:2px 6px;border-radius:4px;font-family:monospace;font-size:.7rem;font-weight:700;color:#fff;border:1px solid rgba(255,255,255,.3)}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@media (max-width: 768px){.measurement-buttons{flex-direction:column}.live-distance{padding:12px}.distance-value{font-size:1.5rem}}.floating-menu{position:fixed;top:50%;right:20px;transform:translateY(-50%);z-index:98;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.menu-toggle{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;width:56px;height:56px;color:#fff;font-size:1.4rem;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 20px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center}.menu-toggle:hover{transform:scale(1.1);box-shadow:0 12px 30px #0006}.floating-menu.expanded .menu-toggle{background:linear-gradient(135deg,#e74c3c,#c0392b)}.menu-content{position:absolute;right:70px;top:50%;transform:translateY(-50%);background:linear-gradient(135deg,#2c3e50,#34495e);border-radius:16px;box-shadow:0 20px 40px #0000004d;padding:20px;min-width:300px;max-width:350px;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);animation:slideInRight .3s ease-out;max-height:calc(100vh - 100px);overflow-y:auto}.menu-header{text-align:center;margin-bottom:20px;border-bottom:2px solid rgba(255,255,255,.2);padding-bottom:15px}.menu-header h3{margin:0;font-size:1.3rem;color:#3498db;font-weight:700}.menu-section{margin-bottom:25px}.menu-section h4{margin:0 0 15px;font-size:1rem;color:#ecf0f1;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:8px}.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.action-btn{background:linear-gradient(135deg,#27ae60,#2ecc71);border:none;border-radius:8px;padding:12px;color:#fff;font-weight:700;cursor:pointer;transition:all .3s ease;font-size:.9rem;border:1px solid rgba(255,255,255,.2)}.action-btn:hover{background:linear-gradient(135deg,#2ecc71,#27ae60);transform:translateY(-2px);box-shadow:0 8px 20px #2ecc714d}.utility-buttons{display:grid;grid-template-columns:1fr 1fr;gap:10px}.utility-btn{background:linear-gradient(135deg,#3498db,#2980b9);border:none;border-radius:8px;padding:10px;color:#fff;font-weight:700;cursor:pointer;transition:all .3s ease;font-size:.8rem;border:1px solid rgba(255,255,255,.2)}.utility-btn:hover{background:linear-gradient(135deg,#2980b9,#21618c);transform:translateY(-2px);box-shadow:0 6px 15px #3498db4d}.tutorial-btn{background:linear-gradient(135deg,#e74c3c,#c0392b)!important;grid-column:1 / -1;text-align:center}.tutorial-btn:hover{background:linear-gradient(135deg,#c0392b,#a93226)!important;box-shadow:0 6px 15px #e74c3c4d!important}.menu-footer{text-align:center;padding-top:15px;border-top:1px solid rgba(255,255,255,.1);color:#ffffffb3;font-size:.75rem;line-height:1.4}.menu-content::-webkit-scrollbar{width:6px}.menu-content::-webkit-scrollbar-track{background:#ffffff1a;border-radius:3px}.menu-content::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:3px}.menu-content::-webkit-scrollbar-thumb:hover{background:#ffffff80}@keyframes slideInRight{0%{opacity:0;transform:translateY(-50%) translate(20px)}to{opacity:1;transform:translateY(-50%) translate(0)}}@media (max-width: 768px){.floating-menu{top:auto;bottom:20px;right:20px;transform:none}.menu-content{position:fixed;right:20px;bottom:80px;top:auto;transform:none;width:calc(100vw - 40px);max-width:350px}.quick-actions,.utility-buttons{grid-template-columns:1fr}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid rgba(255,255,255,.1);flex-wrap:wrap;gap:10px}.current-tool-indicator{font-size:.9rem;color:#ecf0f1;order:2;flex:1;text-align:center}.modal-header h3{margin:0;color:#3498db;font-size:1.4rem}.modal-content{padding:15px}.tools-section,.settings-section,.layer-section,.export-section,.drawing-instructions{margin-bottom:20px}.tools-section h4,.settings-section h4,.layer-section h4,.export-section h4{margin:0 0 15px;color:#ecf0f1;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:8px}.tool-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:8px}.tool-btn{background:linear-gradient(135deg,#9b59b6,#8e44ad);border:none;border-radius:6px;padding:10px 6px;color:#fff;font-weight:700;cursor:pointer;transition:all .3s ease;font-size:.75rem;border:1px solid rgba(255,255,255,.2);text-align:center;min-height:45px;display:flex;align-items:center;justify-content:center}.tool-btn:hover{background:linear-gradient(135deg,#8e44ad,#7d3c98);transform:translateY(-2px);box-shadow:0 6px 15px #9b59b64d}.tool-btn.active{background:linear-gradient(135deg,#e74c3c,#c0392b);box-shadow:0 6px 15px #e74c3c4d;border:2px solid #fff;transform:scale(1.05)}.setting-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;flex-wrap:wrap;gap:10px}.setting-row label{color:#ecf0f1;font-weight:500;min-width:120px}.setting-row input[type=color]{width:50px;height:30px;border:none;border-radius:4px;cursor:pointer}.setting-row input[type=range]{flex:1;min-width:100px}.setting-row select{background:#34495e;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:4px;padding:5px}.layer-buttons,.export-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:10px}.settings-section{margin-bottom:30px}.setting-item{margin-bottom:20px;padding:15px;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.setting-item label{display:flex;align-items:center;gap:10px;font-weight:600;color:#3498db;margin-bottom:5px}.setting-item input[type=checkbox]{width:18px;height:18px;accent-color:#3498db}.setting-item p{margin:0;color:#fffc;font-size:.9rem;line-height:1.4}.setting-buttons,.danger-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px}.utility-btn.active{background:linear-gradient(135deg,#e74c3c,#c0392b)!important;box-shadow:0 6px 15px #e74c3c4d!important}.btn{background:linear-gradient(135deg,#3498db,#2980b9);border:none;border-radius:6px;padding:10px 15px;color:#fff;font-weight:600;cursor:pointer;transition:all .3s ease;text-align:center;border:1px solid rgba(255,255,255,.2)}.btn:hover{transform:translateY(-2px);box-shadow:0 6px 15px #3498db4d}.btn.btn-primary{background:linear-gradient(135deg,#27ae60,#2ecc71)}.btn.btn-primary:hover{box-shadow:0 6px 15px #2ecc714d}.btn.btn-secondary{background:linear-gradient(135deg,#95a5a6,#7f8c8d)}.btn.btn-secondary:hover{box-shadow:0 6px 15px #95a5a64d}.btn.btn-warning{background:linear-gradient(135deg,#f39c12,#e67e22)}.btn.btn-warning:hover{box-shadow:0 6px 15px #f39c124d}.btn.btn-danger{background:linear-gradient(135deg,#e74c3c,#c0392b)}.btn.btn-danger:hover{box-shadow:0 6px 15px #e74c3c4d}.btn.btn-small{padding:8px 12px;font-size:.8rem}.btn.btn-tiny{padding:5px 8px;font-size:.7rem;min-width:30px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInLeft{0%{opacity:0;transform:translateY(-50%) translate(-20px)}to{opacity:1;transform:translateY(-50%) translate(0)}}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:300px}}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.drawing-tools-modal::-webkit-scrollbar,.advanced-settings-modal::-webkit-scrollbar{width:8px}.drawing-tools-modal::-webkit-scrollbar-track,.advanced-settings-modal::-webkit-scrollbar-track{background:#ffffff1a;border-radius:4px}.drawing-tools-modal::-webkit-scrollbar-thumb,.advanced-settings-modal::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:4px}.drawing-tools-modal::-webkit-scrollbar-thumb:hover,.advanced-settings-modal::-webkit-scrollbar-thumb:hover{background:#ffffff80}@media (max-width: 768px){.floating-menu{top:auto;bottom:20px;right:20px;transform:none}.menu-content{position:fixed;right:20px;bottom:80px;top:auto;transform:none;width:calc(100vw - 40px);max-width:350px}.quick-actions,.utility-buttons{grid-template-columns:1fr}.floating-drawing-toolbar{top:auto;bottom:100px;left:10px;right:10px;transform:none;min-width:auto;max-width:none}.toolbar-header{padding:10px 12px}.tool-name{font-size:.8rem}.quick-tools{justify-content:center}.quick-tool{width:32px;height:32px;font-size:1rem}.advanced-settings-overlay{padding:10px;align-items:flex-start}.advanced-settings-modal{width:auto;max-width:95vw;min-width:320px;max-height:80vh;margin:10px 0 0}}@media (max-width: 480px){.floating-drawing-toolbar{bottom:80px;left:5px;right:5px}.toolbar-content{padding:10px}.quick-tools{gap:6px}.quick-tool{width:28px;height:28px;font-size:.9rem}.quick-settings{gap:8px;padding:6px}.advanced-settings-overlay{padding:5px}.advanced-settings-modal{width:100%;max-width:100vw;max-height:90vh;border-radius:8px;min-width:auto}}.floating-drawing-toolbar{position:fixed;top:50%;left:20px;transform:translateY(-50%);z-index:999;background:linear-gradient(135deg,#2c3e50,#34495e);border-radius:12px;box-shadow:0 8px 25px #0000004d;border:1px solid rgba(255,255,255,.1);color:#fff;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:slideInLeft .3s ease-out;min-width:200px;max-width:300px}.toolbar-header{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;border-bottom:1px solid rgba(255,255,255,.1)}.current-tool-display{display:flex;align-items:center;gap:8px;flex:1}.tool-icon{font-size:1.2rem}.tool-name{font-size:.9rem;font-weight:600;color:#3498db}.toolbar-controls{display:flex;gap:5px}.expand-btn,.close-btn{background:#ffffff1a;border:none;border-radius:4px;color:#fff;width:24px;height:24px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;font-size:.8rem}.expand-btn:hover,.close-btn:hover{background:#fff3;transform:scale(1.1)}.close-btn:hover{background:#e74c3c}.toolbar-content{padding:15px;animation:slideDown .2s ease-out}.quick-tools{display:flex;gap:8px;margin-bottom:15px;flex-wrap:wrap}.quick-tool{background:linear-gradient(135deg,#9b59b6,#8e44ad);border:none;border-radius:6px;width:36px;height:36px;color:#fff;font-size:1.1rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.2)}.quick-tool:hover{background:linear-gradient(135deg,#8e44ad,#7d3c98);transform:translateY(-2px);box-shadow:0 4px 12px #9b59b64d}.quick-tool.active{background:linear-gradient(135deg,#e74c3c,#c0392b);border-color:#fff;box-shadow:0 4px 12px #e74c3c66;transform:scale(1.1)}.quick-settings{display:flex;align-items:center;gap:10px;margin-bottom:12px;padding:8px;background:#0003;border-radius:6px}.setting-item{display:flex;align-items:center}.setting-item input[type=color]{width:32px;height:32px;border:none;border-radius:4px;cursor:pointer;background:none}.setting-item label{display:flex;align-items:center;gap:5px;font-size:1rem;cursor:pointer}.setting-item input[type=checkbox]{width:16px;height:16px;accent-color:#3498db}.clear-btn{background:linear-gradient(135deg,#e67e22,#d35400);border:none;border-radius:4px;width:32px;height:32px;color:#fff;font-size:1rem;cursor:pointer;transition:all .2s ease}.clear-btn:hover{background:linear-gradient(135deg,#d35400,#ca6f1e);transform:scale(1.1)}.drawing-hint{font-size:.8rem;color:#ffffffb3;text-align:center;font-style:italic}.advanced-settings-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:10500;background:#0006;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .3s ease-out;padding:20px;box-sizing:border-box;pointer-events:auto}.advanced-settings-modal{position:relative;z-index:10501;background:linear-gradient(135deg,#2c3e50,#34495e);border-radius:12px;box-shadow:0 20px 40px #00000080;color:#fff;width:auto;max-width:500px;min-width:400px;max-height:85vh;overflow-y:auto;border:1px solid rgba(255,255,255,.1);animation:modalSlideIn .3s ease-out;margin:10px 0 0;pointer-events:auto}@media (prefers-contrast: high){.menu-toggle,.action-btn,.utility-btn,.tool-btn,.btn,.menu-content,.drawing-tools-modal,.advanced-settings-modal{border:2px solid white}}.tutorial-settings-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10001;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.tutorial-settings-modal{background:linear-gradient(135deg,#fff,#f8f9fa);border-radius:15px;box-shadow:0 20px 60px #0000004d;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;border:1px solid rgba(255,255,255,.2)}.tutorial-settings-header{display:flex;justify-content:space-between;align-items:center;padding:20px 25px;border-bottom:1px solid #e9ecef;background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff;border-radius:15px 15px 0 0}.tutorial-settings-header h3{margin:0;font-size:1.3rem;font-weight:700}.close-btn{background:#fff3;border:none;color:#fff;font-size:1.2rem;width:30px;height:30px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.close-btn:hover{background:#ffffff4d;transform:scale(1.1)}.tutorial-settings-content{padding:25px}.tutorial-option{margin-bottom:25px;padding:20px;background:#4aacfe0d;border-radius:10px;border:1px solid rgba(74,172,254,.1);transition:all .3s ease}.tutorial-option:hover{background:#4aacfe14;border-color:#4aacfe33;transform:translateY(-2px)}.tutorial-option h4{margin:0 0 10px;color:#2a5298;font-size:1.1rem}.tutorial-option p{margin:0 0 15px;color:#666;line-height:1.5}.status-enabled{color:#28a745;font-weight:700;margin-bottom:10px}.status-disabled{color:#dc3545;font-weight:700;margin-bottom:10px}.tutorial-info{background:#28a7450d;border:1px solid rgba(40,167,69,.1);border-radius:10px;padding:20px}.tutorial-info h4{margin:0 0 15px;color:#28a745;font-size:1.1rem}.tutorial-info p{margin:0 0 10px;color:#666}.tutorial-info ul{margin:10px 0 0;padding-left:20px;color:#666}.tutorial-info li{margin-bottom:5px;line-height:1.4}.btn{padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;transition:all .3s ease;text-decoration:none;display:inline-block;text-align:center}.btn:hover{transform:translateY(-2px);box-shadow:0 5px 15px #0003}.btn-primary{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#3d8bfe,#00d4e6)}.btn-success{background:linear-gradient(135deg,#28a745,#20c997);color:#fff}.btn-success:hover{background:linear-gradient(135deg,#218838,#1fa384)}.btn-warning{background:linear-gradient(135deg,#ffc107,#ff8c00);color:#fff}.btn-warning:hover{background:linear-gradient(135deg,#e0a800,#e67300)}@media (max-width: 600px){.tutorial-settings-modal{margin:20px;width:calc(100% - 40px)}.tutorial-settings-header,.tutorial-settings-content{padding:15px 20px}.tutorial-option{padding:15px;margin-bottom:20px}}:root{--primary-color: #635bff;--primary-hover: #5a54d6;--success-color: #00d924;--success-hover: #00c220;--danger-color: #fa5252;--danger-hover: #f03e3e;--warning-color: #fd7e14;--warning-hover: #e8590c;--neutral-100: #f8f9fa;--neutral-200: #e9ecef;--neutral-300: #ced4da;--neutral-400: #6c757d;--neutral-500: #495057;--neutral-600: #343a40;--neutral-700: #212529;--border-radius: 8px;--border-radius-lg: 12px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1), 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07), 0 2px 4px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1), 0 4px 6px rgba(0, 0, 0, .05);--transition: all .2s cubic-bezier(.4, 0, .2, 1)}.combat-ui{position:fixed;left:20px;top:20px;width:min(380px,calc(100vw - 40px));background:#fff;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--neutral-200);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;color:var(--neutral-700);max-height:calc(100vh - 40px);overflow:hidden;z-index:100;display:flex;flex-direction:column;transition:var(--transition)}.spell-area-controls-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;display:flex;align-items:center;justify-content:center}.modal-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{position:relative;background:#fff;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);max-width:500px;width:calc(100vw - 40px);max-height:calc(100vh - 40px);overflow:hidden;display:flex;flex-direction:column}.modal-header{padding:20px;border-bottom:1px solid var(--neutral-200);display:flex;justify-content:space-between;align-items:center;background:var(--neutral-100)}.modal-header h3{margin:0;color:var(--neutral-700);font-size:18px;font-weight:600}.modal-body{padding:20px;overflow-y:auto;flex:1}.modal-footer{padding:20px;border-top:1px solid var(--neutral-200);display:flex;gap:10px;justify-content:flex-end;background:var(--neutral-100)}.area-info{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding:10px;background:var(--neutral-100);border-radius:var(--border-radius)}.area-type{font-weight:600;color:var(--neutral-600);font-size:14px}.area-color{width:20px;height:20px;border-radius:50%;border:2px solid white;box-shadow:var(--shadow-sm)}.size-controls h4,.rotation-controls h4{margin:0 0 15px;color:var(--neutral-600);font-size:16px;font-weight:600}.quick-size-buttons{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.control-row{margin-bottom:15px}.control-row label{display:block;margin-bottom:8px;font-weight:500;color:var(--neutral-600);font-size:14px}.control-row input[type=range]{width:100%;height:6px;border-radius:3px;background:var(--neutral-200);outline:none;-webkit-appearance:none}.control-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--primary-color);cursor:pointer;box-shadow:var(--shadow-sm)}.control-row input[type=range]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--primary-color);cursor:pointer;border:none;box-shadow:var(--shadow-sm)}.rotation-controls{margin-top:20px;padding-top:20px;border-top:1px solid var(--neutral-200)}.rotation-buttons{display:flex;gap:10px}.combat-ad-section{margin-top:20px;padding-top:20px;border-top:1px solid var(--neutral-200);text-align:center}.combat-square-ad{margin:0 auto;max-width:300px}@media (max-width: 768px){.combat-ad-section{display:none}}.combat-ui.collapsed .combat-ad-section{display:none}.entity-card.flying{border-left:4px solid #4ecdc4;background:linear-gradient(135deg,#4ecdc40d,#fff)}.flying-indicator{margin-left:8px;font-size:12px;color:#4ecdc4;font-weight:600}.editable-stat{cursor:pointer;transition:var(--transition);padding:2px 4px;border-radius:4px}.editable-stat:hover{background:var(--neutral-200);color:var(--primary-color)}.edit-tools-panel{margin-top:15px;padding:15px;border:1px solid var(--neutral-200);border-radius:var(--border-radius);background:var(--neutral-100)}.edit-tools-header h4{margin:0 0 10px;font-size:14px;color:var(--neutral-600)}.edit-tools-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}.edit-tools-grid .btn{font-size:12px;padding:6px 8px;text-align:left}.flying-controls{margin-top:15px;padding-top:15px;border-top:1px solid var(--neutral-300)}.flying-controls h5{margin:0 0 10px;font-size:13px;color:var(--neutral-600)}.height-control{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.height-control label{font-size:12px;font-weight:500;color:var(--neutral-600);white-space:nowrap}.height-control input{width:70px;padding:4px 6px;border:1px solid var(--neutral-300);border-radius:4px;font-size:12px}.height-control .btn{font-size:12px;padding:4px 12px}@media (max-width: 768px){.edit-tools-grid{grid-template-columns:1fr}.height-control{flex-direction:column;align-items:stretch}.height-control input{width:100%}}.combat-fab{position:fixed;bottom:20px;left:20px;width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--primary-color) 0%,#7c3aed 100%);color:#fff;border:none;font-size:24px;cursor:pointer;z-index:1000;box-shadow:0 4px 12px #635bff66,0 2px 6px #0000001a;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.combat-fab:hover{background:linear-gradient(135deg,var(--primary-hover) 0%,#6d28d9 100%);transform:scale(1.1);box-shadow:0 6px 16px #635bff80,0 3px 8px #00000026}.combat-fab:active{transform:scale(1.05)}.mobile-toggle{display:none;position:absolute;top:16px;right:16px;background:var(--primary-color);color:#fff;border:none;border-radius:6px;width:36px;height:36px;font-size:16px;cursor:pointer;z-index:101;box-shadow:var(--shadow-sm)}.mobile-toggle:hover{background:var(--primary-hover)}.combat-ui.collapsed{transform:translate(-100%)}.combat-ui.collapsed .mobile-toggle{transform:translate(calc(100% + 20px));position:fixed;left:8px;top:8px}.combat-ui-content{flex:1;overflow-y:auto;padding:24px}.combat-ui-content::-webkit-scrollbar{width:6px}.combat-ui-content::-webkit-scrollbar-track{background:var(--neutral-100)}.combat-ui-content::-webkit-scrollbar-thumb{background:var(--neutral-300);border-radius:3px}.combat-ui-content::-webkit-scrollbar-thumb:hover{background:var(--neutral-400)}.combat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--neutral-200)}.combat-header h2{margin:0;font-size:20px;font-weight:600;color:var(--neutral-700);display:flex;align-items:center;gap:8px}.combat-controls{display:flex;gap:8px;flex-wrap:wrap;align-items:center;justify-content:flex-start}.combat-controls .btn{max-width:160px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:0 1 auto;min-width:0}.combat-controls .btn:last-child{flex-shrink:1}.round-info{background:var(--primary-color);color:#fff;padding:4px 12px;border-radius:16px;font-size:14px;font-weight:500}.section-header{display:flex;justify-content:space-between;align-items:center;margin:24px 0 16px}.section-header h3{margin:0;font-size:16px;font-weight:600;color:var(--neutral-700)}.initiative-tracker{margin-bottom:24px}.initiative-help{margin-bottom:12px;font-size:13px;color:var(--neutral-400)}.initiative-list{display:flex;flex-direction:column;gap:8px}.initiative-item{display:flex;align-items:center;padding:12px 14px;background:var(--neutral-100);border-radius:var(--border-radius);border:1px solid var(--neutral-200);transition:var(--transition);position:relative}.initiative-item:hover{background:var(--neutral-200);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.initiative-item.current{background:linear-gradient(135deg,#635bff,#7c3aed);color:#fff;border-color:var(--primary-color);box-shadow:var(--shadow-md)}.initiative-item.current:hover{background:linear-gradient(135deg,var(--primary-hover) 0%,#6d28d9 100%)}.initiative-item.player:before,.entity-card.player:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--success-color);border-radius:var(--border-radius) 0 0 var(--border-radius)}.initiative-item.enemy:before,.entity-card.enemy:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--danger-color);border-radius:var(--border-radius) 0 0 var(--border-radius)}.initiative-item.npc:before,.entity-card.npc:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--warning-color);border-radius:var(--border-radius) 0 0 var(--border-radius)}.initiative-number{background:#0000000d;padding:6px 10px;border-radius:6px;font-weight:600;margin-right:12px;min-width:36px;text-align:center;font-size:14px}.initiative-item.current .initiative-number{background:#fff3;color:#fff}.initiative-number.clickable{cursor:pointer;transition:var(--transition)}.initiative-number.clickable:hover{background:#0000001a;transform:scale(1.05)}.entity-info{flex:1;min-width:0}.entity-info .entity-name{font-size:14px;font-weight:600;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.entity-info .entity-type{font-size:12px;color:var(--neutral-400);text-transform:capitalize}.initiative-item.current .entity-info .entity-type{color:#fffc}.entity-hp{font-weight:600;font-size:13px;color:var(--neutral-500);white-space:nowrap}.initiative-item.current .entity-hp{color:#ffffffe6}.initiative-controls{display:flex;flex-direction:column;gap:2px;margin-left:8px}.initiative-controls .btn{width:24px;height:24px;padding:0;display:flex;align-items:center;justify-content:center;font-size:12px;line-height:1;border-radius:4px}.entity-list{display:flex;flex-direction:column;gap:8px}.entity-card{background:var(--neutral-100);border-radius:var(--border-radius);padding:16px;border:1px solid var(--neutral-200);transition:var(--transition);position:relative}.entity-card:hover{background:var(--neutral-200);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.entity-card.selected{border-color:var(--primary-color);background:#635bff0d;box-shadow:0 0 0 1px #635bff1a}.entity-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.entity-card-header .entity-name{font-weight:600;font-size:15px;color:var(--neutral-700);flex:1}.entity-actions{display:flex;gap:4px}.entity-stats{font-size:12px;color:var(--neutral-500);margin-bottom:8px}.stat-line{font-size:12px;color:var(--neutral-400)}.debuff-form{margin-top:8px;padding:8px;background:var(--neutral-100);border-radius:var(--border-radius);border:1px solid var(--neutral-200)}.debuff-form input{width:100%;padding:4px 8px;border:1px solid var(--neutral-300);border-radius:4px;font-size:12px;margin-bottom:6px}.debuff-actions{display:flex;gap:4px;justify-content:flex-end}.condition-tag{background:var(--danger-color);color:#fff;padding:2px 6px;border-radius:12px;font-size:10px;font-weight:500;display:inline-flex;align-items:center;gap:4px;margin:2px}.condition-remove{background:none;border:none;color:#fff;cursor:pointer;font-size:12px;line-height:1;padding:0;margin-left:2px}.condition-remove:hover{background:#fff3;border-radius:50%}.add-entity-form{background:var(--neutral-100);border-radius:var(--border-radius);padding:16px;margin-bottom:16px;border:1px solid var(--neutral-200)}.form-row{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.form-row:last-child{margin-bottom:0}.form-row input,.form-row select{flex:1;min-width:120px;background:#fff;border:1px solid var(--neutral-300);border-radius:var(--border-radius);padding:8px 12px;color:var(--neutral-700);font-size:14px;transition:var(--transition);box-sizing:border-box}.form-row input[type=number]{flex:0 0 100px;max-width:100px}.form-row input::placeholder{color:var(--neutral-400)}.form-row input:focus,.form-row select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #635bff1a}.form-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.stats-row{display:flex;gap:8px;flex-wrap:wrap}.stat-input{display:flex;flex-direction:column;flex:1;min-width:80px}.stat-input label{font-size:12px;font-weight:500;color:var(--neutral-500);margin-bottom:4px;white-space:nowrap}.stat-input input{padding:6px 8px;font-size:13px;text-align:center;min-width:0}.form-row:has(label:first-child){align-items:center}.form-row>label:first-child{font-size:13px;font-weight:500;color:var(--neutral-600);min-width:60px;margin-right:8px}.model-upload{flex-direction:column;gap:8px}.file-input{padding:8px;border:2px dashed var(--neutral-300);border-radius:var(--border-radius);background:var(--neutral-100);cursor:pointer;text-align:center;transition:var(--transition)}.file-input:hover{border-color:var(--primary-color);background:#635bff0d}.file-info{display:flex;justify-content:space-between;align-items:center;padding:6px 8px;background:var(--success-color);color:#fff;border-radius:var(--border-radius);font-size:12px}.selected-entity{background:var(--neutral-100);border-radius:var(--border-radius);padding:16px;margin-bottom:24px;border:1px solid var(--neutral-200)}.selected-entity h3{margin:0 0 12px;font-size:16px;font-weight:600;color:var(--neutral-700)}.entity-details{display:flex;flex-direction:column;gap:8px}.stat-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--neutral-200);font-size:14px}.stat-row:last-child{border-bottom:none}.stat-row span:first-child{color:var(--neutral-500);font-weight:500}.stat-row span:last-child{font-weight:600;color:var(--neutral-700)}.spell-controls{margin-bottom:24px}.spell-buttons{display:grid;grid-template-columns:1fr 1fr;gap:8px}.btn{background:var(--primary-color);border:none;border-radius:var(--border-radius);padding:8px 16px;color:#fff;font-weight:500;cursor:pointer;transition:var(--transition);font-size:14px;display:inline-flex;align-items:center;justify-content:center;gap:6px;text-decoration:none;font-family:inherit}.btn:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn:disabled:hover{background:var(--primary-color);transform:none;box-shadow:none}.btn-secondary{background:var(--neutral-500)}.btn-secondary:hover{background:var(--neutral-600)}.btn-danger{background:var(--danger-color)}.btn-danger:hover{background:var(--danger-hover)}.btn-warning{background:var(--warning-color)}.btn-warning:hover{background:var(--warning-hover)}.btn-success{background:var(--success-color)}.btn-success:hover{background:var(--success-hover)}.btn-magic{background:linear-gradient(135deg,#8b5cf6,#a78bfa);color:#fff}.btn-magic:hover{background:linear-gradient(135deg,#7c3aed,#8b5cf6)}.btn-small{padding:6px 12px;font-size:13px}.btn-tiny{padding:4px 8px;font-size:12px;border-radius:6px}.simple-combat-info{background:linear-gradient(135deg,var(--primary-color) 0%,#7c3aed 100%);color:#fff;border-radius:var(--border-radius);padding:16px;margin-top:16px}.simple-combat-info h4{margin:0 0 8px;font-size:14px;font-weight:500;opacity:.9}.current-entity-display{margin:8px 0 12px;font-size:16px;font-weight:600}.current-entity-display .entity-name{color:#fff}.current-entity-display .entity-type{color:#fffc;font-size:13px;margin-left:8px;font-weight:400}.quick-start-tips{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border-radius:var(--border-radius);padding:20px;margin-top:24px}.quick-start-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.quick-start-tips h3{margin:0;font-size:16px;font-weight:600}.quick-start-toggle{text-align:center;margin-top:24px}.quick-start-tips ol{margin:0 0 16px;padding-left:20px}.quick-start-tips li{margin-bottom:6px;line-height:1.4;font-size:14px}.quick-start-tips p{margin:0;font-weight:500;background:#ffffff26;padding:12px;border-radius:var(--border-radius);text-align:center;font-size:13px}.combat-ui.no-entities .entity-management{border:2px dashed var(--neutral-300);background:var(--neutral-100);border-radius:var(--border-radius);padding:24px;text-align:center}.combat-ui.no-entities .entity-management h3{color:var(--neutral-500);margin-bottom:12px}.combat-ui.no-entities .entity-management:before{content:"👥";font-size:32px;display:block;margin-bottom:12px}.conditions{display:flex;flex-direction:column;gap:8px}.condition-list{display:flex;flex-wrap:wrap;gap:4px}.condition-tag{background:var(--danger-color);color:#fff;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:500}@media (max-width: 768px){.combat-ui{left:8px;top:8px;right:8px;width:auto;max-width:none;max-height:calc(100vh - 16px);transition:transform .3s ease}.combat-fab{bottom:16px;left:16px;width:52px;height:52px;font-size:22px}.mobile-toggle{display:flex;align-items:center;justify-content:center}.combat-ui-content{padding:60px 12px 12px}.combat-header{flex-direction:column;gap:8px;align-items:stretch;margin-bottom:16px;padding-bottom:12px}.combat-header h2{font-size:18px}.combat-controls{justify-content:center;flex-direction:column;gap:6px}.combat-controls .btn{width:100%;text-align:center;max-width:none;font-size:12px;padding:8px 12px}.section-header{margin:16px 0 12px}.section-header h3{font-size:14px}.spell-buttons{grid-template-columns:1fr;gap:6px}.form-row{flex-direction:column;gap:6px}.form-row input,.form-row select{min-width:auto;width:100%}.form-row input[type=number]{flex:none;max-width:none;width:100%}.initiative-item{padding:8px 10px}.initiative-number{min-width:32px;padding:4px 8px;font-size:13px}.entity-info .entity-name{font-size:13px}.entity-info .entity-type{font-size:11px}.entity-hp{font-size:12px}.entity-card{padding:12px}.entity-card-header .entity-name{font-size:14px}.btn{font-size:13px;padding:6px 12px}.btn-small{font-size:12px;padding:4px 8px}.btn-tiny{font-size:11px;padding:3px 6px}}@media (max-width: 480px){.combat-ui{left:8px;top:8px;right:8px;max-height:calc(100vh - 16px)}.combat-ui-content{padding:12px}.section-header{margin:16px 0 12px}}@keyframes slideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.entity-card{animation:slideIn .3s ease-out}.initiative-item.current{animation:pulse 3s infinite}.btn:focus-visible,.form-row input:focus-visible,.form-row select:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.save-load-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1001;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease-out}.save-load-menu-modal{background:#fff;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);max-width:600px;width:calc(100vw - 40px);max-height:calc(100vh - 40px);overflow:hidden;display:flex;flex-direction:column}.modal-tabs{display:flex;border-bottom:1px solid var(--neutral-200);background:var(--neutral-100)}.tab-button{flex:1;padding:16px;background:none;border:none;color:var(--neutral-500);font-weight:500;cursor:pointer;transition:var(--transition);border-bottom:2px solid transparent;font-size:14px}.tab-button:hover{background:var(--neutral-200);color:var(--neutral-700)}.tab-button.active{color:var(--primary-color);border-bottom-color:var(--primary-color);background:#fff}.save-tab,.load-tab,.export-tab{padding:24px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:var(--neutral-700)}.form-group input,.form-group textarea{width:100%;padding:12px;border:1px solid var(--neutral-300);border-radius:var(--border-radius);font-size:14px;transition:var(--transition);font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #635bff1a}.form-group textarea{resize:vertical;min-height:80px}.save-buttons{display:flex;gap:12px;margin-top:20px}.save-buttons .btn{flex:1}.encounters-list{max-height:400px;overflow-y:auto}.no-encounters{text-align:center;padding:40px 20px;color:var(--neutral-500)}.no-encounters p{margin:8px 0}.encounter-item{display:flex;justify-content:space-between;align-items:flex-start;padding:16px;border:1px solid var(--neutral-200);border-radius:var(--border-radius);margin-bottom:12px;background:#fff;transition:var(--transition)}.encounter-item:hover{box-shadow:var(--shadow-sm);border-color:var(--neutral-300)}.encounter-info{flex:1;margin-right:16px}.encounter-info h4{margin:0 0 8px;color:var(--neutral-700);font-size:16px;font-weight:600}.encounter-info p{margin:0 0 8px;color:var(--neutral-500);font-size:14px;line-height:1.4}.encounter-meta{display:flex;gap:16px;font-size:12px;color:var(--neutral-400)}.encounter-actions{display:flex;gap:8px;flex-shrink:0}.export-section,.import-section{margin-bottom:24px;padding:20px;background:var(--neutral-100);border-radius:var(--border-radius);border:1px solid var(--neutral-200)}.export-section h4,.import-section h4{margin:0 0 12px;color:var(--neutral-700);font-size:16px;font-weight:600}.export-section p,.import-section p{margin:0 0 16px;color:var(--neutral-500);font-size:14px;line-height:1.4}.export-buttons{display:flex;gap:12px;margin-top:16px}.export-buttons .btn{flex:1}@media (max-width: 768px){.save-load-menu-modal{width:calc(100vw - 20px);max-height:calc(100vh - 20px)}.modal-tabs{flex-direction:column}.tab-button{text-align:left;border-bottom:1px solid var(--neutral-200);border-right:none}.tab-button.active{border-bottom-color:var(--neutral-200);border-left:3px solid var(--primary-color)}.save-tab,.load-tab,.export-tab{padding:16px}.save-buttons,.export-buttons{flex-direction:column}.encounter-item{flex-direction:column;align-items:stretch}.encounter-info{margin-right:0;margin-bottom:12px}.encounter-actions{justify-content:flex-end}.encounter-meta{flex-direction:column;gap:4px}}@media (prefers-contrast: high){:root{--neutral-100: #ffffff;--neutral-200: #e0e0e0;--neutral-300: #c0c0c0;--neutral-400: #808080;--neutral-500: #404040;--neutral-600: #202020;--neutral-700: #000000}.save-load-menu-modal,.encounter-item,.export-section,.import-section{border:2px solid black}.tab-button.active{background:#f0f0f0}}.notes-panel{position:fixed;top:20px;left:420px;z-index:150;transition:all .3s cubic-bezier(.4,0,.2,1)}.notes-panel.collapsed{width:auto}.notes-panel.expanded{width:350px;max-height:80vh}.notes-toggle{background:var(--primary-color);color:#fff;border:none;border-radius:var(--border-radius);padding:12px 15px;font-size:14px;font-weight:600;cursor:pointer;box-shadow:var(--shadow-md);transition:var(--transition);display:flex;align-items:center;gap:5px;position:relative}.notes-toggle:hover{background:var(--primary-hover);transform:translateY(-2px)}.note-count{background:#fff3;border-radius:10px;padding:2px 6px;font-size:11px;font-weight:700}.notes-panel.expanded .notes-toggle{border-radius:var(--border-radius) var(--border-radius) 0 0;margin-bottom:0}.notes-content{background:#fff;border-radius:0 0 var(--border-radius) var(--border-radius);box-shadow:var(--shadow-lg);border:1px solid var(--neutral-200);border-top:none;overflow:hidden;display:flex;flex-direction:column;max-height:calc(80vh - 50px)}.notes-header{padding:15px;border-bottom:1px solid var(--neutral-200);display:flex;justify-content:space-between;align-items:center;background:var(--neutral-100)}.notes-header h3{margin:0;font-size:16px;color:var(--neutral-700)}.note-form{padding:15px;border-bottom:1px solid var(--neutral-200);background:var(--neutral-50)}.note-title-input{width:100%;padding:8px 12px;border:1px solid var(--neutral-300);border-radius:var(--border-radius);font-size:14px;margin-bottom:10px;font-weight:600}.note-content-input{width:100%;padding:8px 12px;border:1px solid var(--neutral-300);border-radius:var(--border-radius);font-size:13px;resize:vertical;font-family:inherit;margin-bottom:15px}.note-form-controls{display:flex;justify-content:space-between;align-items:center;gap:10px}.color-picker{display:flex;gap:5px}.color-option{width:20px;height:20px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:var(--transition)}.color-option:hover{transform:scale(1.1)}.color-option.selected{border-color:var(--neutral-600);transform:scale(1.15)}.form-actions{display:flex;gap:5px}.notes-list{flex:1;overflow-y:auto;padding:10px}.no-notes{text-align:center;padding:40px 20px;color:var(--neutral-500)}.no-notes p{margin:0 0 5px;font-size:16px}.no-notes small{font-size:13px}.note-item{margin-bottom:10px;padding:12px;border-radius:var(--border-radius);border:1px solid rgba(0,0,0,.1);position:relative;transition:var(--transition)}.note-item:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.note-item.pinned{border-left:4px solid var(--warning-color);box-shadow:var(--shadow-sm)}.note-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.note-title{margin:0;font-size:14px;font-weight:600;color:var(--neutral-700);flex:1;display:flex;align-items:center;gap:5px}.pin-icon{font-size:12px}.note-actions{display:flex;gap:2px;opacity:.7;transition:var(--transition)}.note-item:hover .note-actions{opacity:1}.note-content{margin-bottom:8px;color:var(--neutral-600);font-size:13px;line-height:1.4}.note-content p{margin:0 0 4px}.note-timestamp{font-size:11px;color:var(--neutral-500);text-align:right}.note-edit{width:100%}.note-edit-actions{display:flex;gap:5px;justify-content:flex-end;margin-top:10px}@media (max-width: 768px){.notes-panel{left:10px;right:auto;top:10px}.notes-panel.expanded{width:calc(100vw - 40px);max-width:300px}}@media (max-width: 1024px) and (min-width: 769px){.notes-panel{left:20px;top:100px}}@media (max-width: 768px){.note-form-controls{flex-direction:column;align-items:stretch}.color-picker{justify-content:center;margin-bottom:10px}.form-actions{justify-content:stretch}.form-actions .btn{flex:1}}.notes-list::-webkit-scrollbar{width:6px}.notes-list::-webkit-scrollbar-track{background:var(--neutral-200);border-radius:3px}.notes-list::-webkit-scrollbar-thumb{background:var(--neutral-400);border-radius:3px}.notes-list::-webkit-scrollbar-thumb:hover{background:var(--neutral-500)}html,body,#root{width:100%;height:100%;margin:0;padding:0;overflow:hidden}
