.floating-toolbar{position:fixed;top:20px;left:20px;background:#fffffff2;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border-radius:16px;box-shadow:0 8px 32px #00000026;border:1px solid rgba(0,0,0,.1);padding:14px;max-width:300px;z-index:1000;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;transition:box-shadow .2s ease,transform .2s ease,opacity .2s ease}.floating-toolbar.expanded{opacity:1}.floating-toolbar.collapsed{background:transparent;border:none;box-shadow:none;padding:0}.toolbar-section h3,.toolbar-header h3{margin:0 0 16px;color:#333;font-size:16px;font-weight:600;text-align:center}.toolbar-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}.collapse-btn{background:transparent;border:none;color:#333;width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:18px;line-height:1}.collapse-btn:hover{background:#00000014}.status-indicator{background:#f8f9fa;border-radius:8px;padding:12px;margin-bottom:16px;text-align:center;border:1px solid #e9ecef}.status-enabled{color:#28a745;font-weight:600}.status-disabled{color:#dc3545;font-weight:600}.tool-group{margin-bottom:16px}.tool-group label{display:block;font-weight:600;color:#555;margin-bottom:8px;font-size:14px}.color-controls{position:relative}.color-preview{width:100%;height:36px;border-radius:10px;border:1px solid rgba(0,0,0,.15);cursor:pointer;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:12px;font-family:Courier New,monospace;transition:all .2s ease}.color-preview:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.color-picker-dropdown{position:absolute;top:calc(100% + 6px);left:0;background:#fff;border-radius:12px;box-shadow:0 12px 28px #00000026;border:1px solid rgba(0,0,0,.12);padding:10px;z-index:1001;max-height:260px;overflow:auto}.color-picker-dropdown.align-right{left:auto;right:0}.color-picker-dropdown.drop-up{bottom:calc(100% + 6px);top:auto;box-shadow:0 -12px 28px #00000026}.color-picker-dropdown:before{content:"";position:absolute;width:10px;height:10px;background:#fff;border-left:1px solid rgba(0,0,0,.12);border-top:1px solid rgba(0,0,0,.12);transform:rotate(45deg);top:-6px;left:16px}.color-picker-dropdown.drop-up:before{top:auto;bottom:-6px;transform:rotate(225deg)}.color-picker-dropdown.align-right:before{left:auto;right:16px}.color-palette{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;margin-bottom:12px}.color-swatch{width:32px;height:32px;border-radius:8px;border:1px solid rgba(0,0,0,.15);cursor:pointer;transition:all .2s ease}.color-swatch:hover{transform:translateY(-1px);border-color:#00000080}.color-swatch.selected{border-color:#667eea;border-width:2px;box-shadow:0 4px 10px #667eea59}.custom-color-section{display:flex;align-items:center;gap:8px;padding-top:12px;border-top:1px solid #eee}.custom-color-section label{margin:0;font-size:11px;color:#666}.custom-color-input{flex:1;height:28px;border-radius:8px;border:1px solid rgba(0,0,0,.15);cursor:pointer}.pixel-size-display{text-align:center}.fixed-size-info{background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;padding:10px 20px;font-size:14px;font-weight:600;color:#495057;font-family:Courier New,monospace}.chip-row{display:flex;gap:8px;margin-bottom:10px}.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:600;border:1px solid rgba(0,0,0,.12);background:#ffffffe6}.chip-success{color:#2e7d32;background:#2e7d3214;border-color:#2e7d3240}.chip-danger{color:#c62828;background:#c6282814;border-color:#c6282840}.chip-warn{color:#8a6d3b;background:#ffc1071f;border-color:#ffc10759}.section-label{font-weight:600;font-size:12px;color:#555;margin-bottom:6px}.meta-row{display:flex;justify-content:space-between;gap:8px;margin-top:12px;padding-top:10px;border-top:1px solid rgba(0,0,0,.08)}.meta-item{color:#666;font-weight:600;font-size:11px}.meta-item.mono{font-family:Courier New,monospace}.stats-section{background:#f8f9fa;border-radius:8px;padding:12px;font-size:12px}.stat-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.stat-item:last-child{margin-bottom:0}.stat-label{color:#666;font-weight:500}.stat-value{font-weight:600;color:#333;font-family:Courier New,monospace}.stat-value.enabled{color:#28a745}.stat-value.disabled{color:#dc3545}@media (max-width: 768px){.floating-toolbar{left:12px;right:auto;top:90px;max-width:280px}.color-palette{grid-template-columns:repeat(4,1fr)}.color-swatch{width:28px;height:28px}}.fab-toggle{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:50%;background:#fffffffa;border:1px solid rgba(0,0,0,.06);box-shadow:0 6px 20px #00000026;cursor:pointer;position:relative;transition:transform .15s ease,box-shadow .2s ease,background .2s ease}.fab-toggle:hover{transform:translateY(-1px);box-shadow:0 10px 28px #0000002e}.fab-icon{font-size:20px}.fab-swatch{position:absolute;bottom:6px;right:6px;width:16px;height:16px;border-radius:50%;border:2px solid white;box-shadow:0 2px 6px #0003}.fab-status{position:absolute;top:6px;right:6px;width:10px;height:10px;border-radius:50%;border:2px solid white}.fab-status.ready{background:#28a745}.fab-status.blocked{background:#dc3545}.energy-bar{position:fixed;top:90px;left:20px;z-index:900;transition:all .3s cubic-bezier(.4,0,.2,1)}.energy-bar.collapsed{width:auto}.energy-bar.expanded{width:280px}.energy-icon-container{cursor:pointer;display:flex;align-items:flex-start;gap:12px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(0,0,0,.1);border-radius:12px;padding:12px;box-shadow:0 4px 15px #0000001a;transition:all .3s cubic-bezier(.4,0,.2,1);flex-direction:row-reverse}.energy-icon-container:hover{transform:scale(1.02);box-shadow:0 6px 20px #00000026}.energy-icon{font-size:1.5rem;transition:color .3s ease;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));flex-shrink:0}.energy-details{opacity:0;animation:fadeInLeft .3s ease forwards;min-width:240px;flex:1}@keyframes fadeInLeft{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.energy-header{margin-bottom:12px;text-align:center}.energy-header h4{margin:0;color:#333;font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.energy-main-info{margin-bottom:16px}.energy-level{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.energy-percentage{font-size:1.2rem;font-weight:700;color:#333}.energy-text{font-weight:600;color:#666;font-size:.9rem}.energy-progress{width:100%;height:8px;background:#0000001a;border-radius:4px;overflow:hidden}.energy-fill{height:100%;border-radius:4px;transition:width .3s ease,background-color .3s ease}.energy-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px}.stat-item{display:flex;flex-direction:column;gap:2px}.stat-label{font-size:.7rem;color:#888;font-weight:500;text-transform:uppercase;letter-spacing:.3px}.stat-value{font-size:.8rem;color:#333;font-weight:600}@media (max-width: 768px){.energy-bar{position:fixed;inset:180px auto auto 12px}.energy-bar.expanded{width:260px}.energy-stats{grid-template-columns:1fr;gap:6px}}.social-links{position:fixed;left:20px;top:180px;z-index:900}.social-fab{width:44px;height:44px;border-radius:9999px;border:1px solid rgba(0,0,0,.1);background:#fffffff5;box-shadow:0 6px 20px #00000026;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px}.social-panel{margin-top:12px;background:#fffffffa;border:1px solid rgba(0,0,0,.12);border-radius:12px;padding:12px;width:280px;box-shadow:0 10px 30px #00000026;animation:fadeIn .18s ease-out}.social-header h4{margin:0 0 6px;font-size:14px;color:#111827}.social-header p{margin:0 0 12px;color:#6b7280;font-size:12px}.social-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.social-item{display:flex;align-items:center;gap:10px;padding:10px;border:1px solid rgba(0,0,0,.08);border-radius:10px;text-decoration:none;color:#111827;background:#fff;transition:transform .12s ease,box-shadow .15s ease,border-color .15s ease}.social-item:hover{transform:translateY(-1px);border-color:#0003;box-shadow:0 8px 18px #0000001a}.social-icon{font-size:20px}.social-name{font-weight:600;font-size:13px}@media (max-width: 768px){.social-links{inset:250px auto auto 12px}.social-panel{width:260px}}.info-panel{position:fixed;top:20px;right:20px;z-index:1100}.info-fab{width:44px;height:44px;border-radius:9999px;border:1px solid rgba(0,0,0,.1);background:#fffffff5;box-shadow:0 6px 20px #00000026;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px}.info-card{margin-top:12px;background:#fffffffa;border:1px solid rgba(0,0,0,.12);border-radius:12px;padding:14px;width:320px;max-height:calc(100vh - 120px);overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;box-shadow:0 10px 30px #00000026;animation:fadeIn .18s ease-out}.info-header h4{margin:0 0 6px;font-size:16px;color:#111827}.info-header p{margin:0 0 12px;color:#6b7280;font-size:12px}.info-section{margin-bottom:10px}.info-section h5{margin:0 0 6px;font-size:12px;color:#374151;text-transform:uppercase;letter-spacing:.3px}.info-section ul{margin:0;padding-left:16px;color:#374151;font-size:12px}.info-section li{margin-bottom:6px}.info-footer{margin-top:8px;padding-top:8px;border-top:1px solid rgba(0,0,0,.08);color:#6b7280;font-size:12px}@keyframes fadeIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.info-panel{right:12px;top:90px}.info-card{width:260px}}.map-container{position:fixed;inset:0;width:100vw;height:100vh;margin:0;padding:0;z-index:0}.map{width:100%;height:100%;background:#f8f9fa;margin:0;padding:0}.drawing-mode-indicator{position:fixed;bottom:20px;left:300px;background:#667eeae6;color:#fff;padding:10px 20px;border-radius:25px;font-size:.9rem;font-weight:500;z-index:700;box-shadow:0 4px 15px #667eea4d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.leaflet-control-zoom{border:none!important;box-shadow:0 4px 15px #00000026!important;border-radius:8px!important;overflow:hidden!important}.leaflet-bottom.leaflet-right{margin-bottom:20px!important;margin-right:20px!important}.leaflet-control-zoom a{background:#fffffff2!important;color:#333!important;border:1px solid rgba(0,0,0,.1)!important;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:40px!important;height:40px!important;line-height:40px!important;font-size:18px!important;font-weight:600!important;transition:all .2s ease!important}.leaflet-control-zoom a:hover{background:#fff!important;color:#667eea!important;transform:scale(1.05)!important}.leaflet-control-attribution{background:#fffc!important;color:#666!important;font-size:.8rem!important;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.pixel-cell{cursor:pointer!important;transition:all .2s ease!important}.pixel-cell:hover{opacity:.8!important;transform:scale(1.02)!important}.grid-line{pointer-events:none!important;z-index:100!important;transition:opacity .3s ease!important}.grid-line:hover{opacity:.6!important}.pixel-cell.snap-to-grid{border:1px solid rgba(0,0,0,.1)!important;box-shadow:0 0 2px #0000001a!important}.leaflet-rectangle.snap-to-grid{border-radius:0!important;transition:all .2s ease!important}.leaflet-rectangle.snap-to-grid:hover{transform:scale(1.02)!important;box-shadow:0 2px 8px #0003!important}.tile-pixel{cursor:pointer!important;transition:opacity .2s ease}.tile-pixel:hover{opacity:.8!important}.pixel-popup{background:#fffffff2!important;border-radius:8px!important;box-shadow:0 4px 12px #00000026!important;border:1px solid #e0e0e0!important}.pixel-popup .leaflet-popup-content{margin:8px 12px!important;line-height:1.4!important}.pixel-popup .leaflet-popup-content-wrapper{border-radius:8px!important}.pixel-popup .leaflet-popup-tip{background:#fffffff2!important;border:1px solid #e0e0e0!important}.tile-canvas-loading{pointer-events:none;opacity:.7}@keyframes pixelPlaced{0%{transform:scale(1);box-shadow:0 0 #ffffffb3}50%{transform:scale(1.1);box-shadow:0 0 0 10px #fff0}to{transform:scale(1);box-shadow:0 0 #fff0}}.tile-pixel.just-placed{animation:pixelPlaced .6s ease-out}@keyframes pixelOverwritten{0%{opacity:1}25%{opacity:.3}50%{opacity:1}75%{opacity:.3}to{opacity:1}}.tile-pixel.being-overwritten{animation:pixelOverwritten .8s ease-in-out}.pixel-box{cursor:pointer!important;transition:all .2s ease}.pixel-box:hover{opacity:.8!important}.pixel-box.selected{z-index:1000!important;animation:pixelBoxSelected .3s ease-out}@keyframes pixelBoxSelected{0%{transform:scale(1);filter:brightness(1)}50%{transform:scale(1.05);filter:brightness(1.2)}to{transform:scale(1);filter:brightness(1)}}.pixel-marker-popup-container{min-width:280px!important}.pixel-marker-popup{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif!important;font-size:13px!important;line-height:1.4!important}.pixel-marker-popup h4{margin:0 0 12px!important;color:#333!important;font-size:16px!important;border-bottom:1px solid #ddd!important;padding-bottom:8px!important}.pixel-info{display:flex!important;flex-direction:column!important;gap:8px!important}.leaflet-tile{image-rendering:pixelated;image-rendering:crisp-edges}.info-row{display:flex!important;flex-direction:column!important;gap:4px!important}.info-row strong{color:#555!important;font-size:12px!important;text-transform:uppercase!important;letter-spacing:.5px!important}.info-row code{background-color:#f5f5f5!important;padding:2px 6px!important;border-radius:3px!important;font-family:Courier New,monospace!important;font-size:11px!important;color:#333!important;border:1px solid #ddd!important}.pixel-actions{margin-top:12px!important;padding-top:12px!important;border-top:1px solid #ddd!important}.change-color-btn{width:100%!important;transition:all .2s ease!important;font-size:12px!important}.change-color-btn:hover{transform:scale(1.02)!important;box-shadow:0 2px 8px #0003!important}@keyframes pixelMarkerPlaced{0%{transform:scale(0);opacity:0}50%{transform:scale(1.3);opacity:.8}to{transform:scale(1);opacity:1}}@keyframes pixelMarkerUpdated{0%{transform:scale(1);filter:brightness(1)}50%{transform:scale(1.2);filter:brightness(1.3)}to{transform:scale(1);filter:brightness(1)}}.pixel-marker-placed{animation:pixelMarkerPlaced .5s ease-out}.pixel-marker-updated{animation:pixelMarkerUpdated .4s ease-out}.painted-pixel-seamless{transition:opacity .2s ease-in-out!important}.painted-pixel-seamless:hover{opacity:.9!important}.leaflet-interactive{transition:all .15s ease-in-out}@keyframes seamlessPixelPlacement{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.pixel-placed-animation{animation:seamlessPixelPlacement .3s ease-out}@media (max-width: 768px){.map{margin-left:0!important;width:100vw!important}.drawing-mode-indicator{left:16px;right:16px;bottom:90px;text-align:center}}.save-panel-container{position:absolute;bottom:20px;left:20px;z-index:1000}.save-panel{background:#111827eb;color:#f9fafb;border-radius:12px;border:1px solid rgba(255,255,255,.12);-webkit-backdrop-filter:blur(6px) saturate(120%);backdrop-filter:blur(6px) saturate(120%);box-shadow:0 10px 30px #00000059;font-family:Inter,sans-serif;min-width:300px;transition:all .2s ease}.save-panel.collapsed{min-width:auto}.save-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.12);cursor:pointer;color:#f9fafb}.save-panel-header-left,.save-panel-header-right{display:flex;align-items:center;gap:8px}.save-panel-pending{font-size:12px;color:#e5e7eb;background:#ffffff1f;padding:2px 8px;border-radius:9999px;font-weight:600}.save-panel-save-btn{padding:6px 8px;border-radius:6px;border:none;background:#9ca3af;color:#fff;font-weight:700}.save-panel-save-btn:enabled{background:#10b981;cursor:pointer}.save-panel-caret{color:#e5e7eb;transition:transform .2s ease}.save-panel-caret.rotated{transform:rotate(180deg)}.save-panel-body{padding:12px 14px;display:flex;flex-direction:column;gap:12px;color:#e5e7eb}.save-panel-stats{display:flex;gap:16px;font-size:15px;align-items:center}.save-panel-count{color:#fff}.save-panel-actions{display:flex;align-items:center;justify-content:space-between;gap:12px}.save-panel-save-cta{padding:10px 14px;border-radius:8px;border:none;background:#9ca3af;color:#fff;font-weight:700}.save-panel-save-cta:enabled{background:#10b981;cursor:pointer}.save-panel-autosave{display:flex;align-items:center;gap:6px;font-size:13px;color:#e5e7eb}.autosave-badge{background:#ffffff1a;color:#e5e7eb;padding:2px 8px;border-radius:9999px;font-weight:600}.autosave-badge.on{background:#10b9812e;color:#a7f3d0}@media (max-width: 768px){.save-panel-container{left:12px;right:12px;bottom:16px}.save-panel{min-width:0;width:calc(100vw - 24px)}.save-panel-stats{flex-wrap:wrap;gap:10px}}.guest-popup{position:absolute;top:100%;right:0;margin-top:10px;z-index:1000;animation:popupSlideIn .2s ease-out}@keyframes popupSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.popup-content{background:#fff;border-radius:12px;box-shadow:0 8px 25px #00000026;border:1px solid rgba(0,0,0,.1);min-width:280px;max-width:320px}.popup-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:12px 16px;border-radius:12px 12px 0 0;display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:.9rem}.popup-close{background:#fff3;border:none;color:#fff;font-size:18px;width:24px;height:24px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.popup-close:hover{background:#ffffff4d}.popup-body{padding:16px}.popup-body p{margin:0 0 12px;color:#666;text-align:center;font-size:.85rem;line-height:1.4}.popup-features{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.popup-features span{background:#667eea0d;padding:6px 10px;border-radius:6px;font-size:.8rem;color:#374151;text-align:center}.popup-signin-btn{width:100%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:10px 16px;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:transform .2s}.popup-signin-btn:hover{transform:translateY(-1px)}@media (max-width: 480px){.guest-popup{right:-20px}.popup-content{min-width:260px}}.menubar{position:fixed;top:20px;left:50%;transform:translate(-50%);height:45px;background:#fffffff2;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);border:1px solid rgba(0,0,0,.1);border-radius:25px;display:flex;align-items:center;justify-content:space-between;padding:0 20px;z-index:1000;box-shadow:0 8px 32px #00000026;transition:all .3s ease;min-width:400px;max-width:600px}.menubar-left{display:flex;align-items:center;gap:15px}.app-logo{width:28px;height:28px;border-radius:6px}.app-title{font-size:1.3rem;font-weight:700;color:#333;margin:0}.icon-btn{background:#667eea1a;color:#667eea;border:1px solid rgba(102,126,234,.2);padding:8px;border-radius:50%;cursor:pointer;font-size:16px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:40px;height:40px;min-width:40px}.icon-btn:hover{background:#667eea33;border-color:#667eea66;transform:scale(1.05)}.icon-btn.auth-btn{background:#ffc10726;border-color:#ffc1074d;color:#ffc107;font-size:18px;width:40px;height:40px;transition:all .3s ease}.icon-btn.auth-btn:hover{background:#ffc10740;border-color:#ffc10780;transform:scale(1.1);box-shadow:0 4px 12px #ffc1074d}.icon-btn.auth-btn.logout-btn{background:#f4433626;border-color:#f443364d;color:#f44336;font-size:18px;width:40px;height:40px}.icon-btn.auth-btn.logout-btn:hover{background:#f4433640;border-color:#f4433680;box-shadow:0 4px 12px #f443364d}.icon-btn.guest-btn{background:#ffc10726;border-color:#ffc1074d;color:#ff8c00}.icon-btn.guest-btn:hover{background:#ffc10740;border-color:#ffc10780;box-shadow:0 4px 12px #ffc1074d}.guest-button-container{position:relative}.menubar-right{display:flex;gap:15px;align-items:center;margin-left:auto}.user-info{font-size:.9rem;color:#666;font-weight:500;display:flex;align-items:center}.user-email{background:#667eea1a;padding:4px 8px;border-radius:4px;color:#667eea;font-weight:600;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.guest-badge{background:#ffc10726;padding:6px 12px;border-radius:20px;color:#ff8c00;font-weight:600;margin-right:8px;font-size:.85rem;border:1px solid rgba(255,193,7,.3);transition:all .2s ease;cursor:default}.guest-badge.clickable{cursor:pointer}.guest-badge.clickable:hover{background:#ffc10740;border-color:#ffc10799;transform:scale(1.05);box-shadow:0 4px 12px #ffc10733}button.guest-badge{background:#ffc10726;border:1px solid rgba(255,193,7,.3);color:#ff8c00;font-weight:600;padding:6px 12px;border-radius:20px;font-size:.85rem;transition:all .2s ease;cursor:pointer}button.guest-badge:hover{background:#ffc10740;border-color:#ffc10799;transform:scale(1.05);box-shadow:0 4px 12px #ffc10733}.guest-hint{font-size:.8rem;color:#999;font-style:italic}.location-status-indicator{background:#4ecdc41a;padding:8px;border-radius:50%;color:#4ecdc4;font-size:16px;font-weight:600;margin-left:10px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(78,205,196,.2);cursor:default}.location-btn{background:#4ecdc41a!important;color:#4ecdc4!important;border:1px solid rgba(78,205,196,.2)!important;transition:all .2s ease!important;width:40px!important;height:40px!important;font-size:18px!important}.location-btn:hover{background:#4ecdc433!important;border-color:#4ecdc466!important;transform:scale(1.05)!important}@media (max-width: 768px){.menubar{top:10px;left:10px;right:10px;transform:none;min-width:auto;max-width:none;padding:0 15px;flex-wrap:wrap;height:auto;min-height:60px;border-radius:16px}.app-title{font-size:1.2rem}.menubar-right{display:flex;gap:10px;order:2;margin-left:auto;flex-wrap:wrap;justify-content:flex-end}.menubar-right .icon-btn,.icon-btn.auth-btn{width:40px;height:40px;font-size:18px}.user-info{flex-direction:row;text-align:center;gap:10px}.guest-hint{display:none}.user-email{background:#667eea1a;padding:6px 10px;border-radius:20px;color:#667eea;font-weight:600;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.8rem}.guest-badge{background:#ffc1071a;padding:6px 10px;border-radius:20px;color:#ffc107;font-weight:600;font-size:.8rem}.location-status-indicator{margin-left:0;margin-top:0}}@media (max-width: 480px){.menubar{top:8px;left:8px;right:8px;padding:0 12px}.app-title{font-size:1.1rem}.menubar-right .icon-btn,.icon-btn.auth-btn{width:40px;height:40px;font-size:18px}}.map-location-controls{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1000;pointer-events:none;animation:locationCardSlideIn .3s ease-out}@keyframes locationCardSlideIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.location-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background:#0000004d;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:999;animation:backdropFadeIn .2s ease-out}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}.location-card{background:#fffffffa;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:24px;padding:24px;box-shadow:0 20px 60px #00000026,0 8px 32px #0000001a;border:1px solid rgba(255,255,255,.3);min-width:300px;text-align:center;pointer-events:auto;transition:all .3s cubic-bezier(.4,0,.2,1)}.location-card:hover{transform:translateY(-2px);box-shadow:0 12px 40px #00000026}.location-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid rgba(0,0,0,.1)}.header-left{display:flex;align-items:center;gap:12px}.location-header .location-icon{font-size:26px;color:#4ecdc4;transition:all .3s ease}.location-card:not(.has-location) .location-header .location-icon{animation:locationPulse 2s ease-in-out infinite}@keyframes locationPulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.location-header .location-title{font-size:18px;font-weight:600;color:#333}.close-location-btn{width:28px;height:28px;background:#0000001a;border:none;border-radius:50%;color:#666;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;flex-shrink:0}.close-location-btn:hover{background:#0003;color:#333;transform:scale(1.1)}.location-card.has-location .close-location-btn{background:#fff3;color:#fffc}.location-card.has-location .close-location-btn:hover{background:#ffffff4d;color:#fff}.location-content{display:flex;flex-direction:column;gap:15px}.location-status{text-align:center;padding:20px;background:#4ecdc40d;border-radius:12px;border:1px solid rgba(78,205,196,.1)}.loading-status{display:flex;align-items:center;justify-content:center;gap:12px;color:#666;font-size:14px}.loading-spinner{font-size:18px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.status-message{display:flex;align-items:center;justify-content:center;gap:12px;color:#666;font-size:14px}.status-icon{font-size:18px;color:#4ecdc4}.location-status:contains("⏳"){animation:loadingPulse 1.5s ease-in-out infinite}@keyframes loadingPulse{0%,to{opacity:.7}50%{opacity:1}}.location-action-btn{background:linear-gradient(135deg,#4ecdc4,#44a08d);color:#fff;border:none;padding:16px 32px;border-radius:14px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 6px 20px #4ecdc44d;font-size:15px;letter-spacing:.5px;width:100%}.location-action-btn:hover:not(:disabled){background:linear-gradient(135deg,#44a08d,#3d8b7a);transform:translateY(-2px);box-shadow:0 6px 20px #4ecdc466}.location-action-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.location-card.has-location{background:#6bcf7ff2;border-color:#6bcf7f4d}.location-card.has-location .location-header .location-title{color:#fff}.location-card.has-location .location-status{color:#ffffffe6}.location-card.has-location .location-action-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3)}.location-card.has-location .location-action-btn:hover{background:#ffffff4d}.location-info{display:flex;flex-direction:column;gap:8px;margin-bottom:15px}.location-coords{background:#ffffffe6;padding:16px;border-radius:12px;border:1px solid rgba(0,0,0,.1);transition:all .3s ease;display:grid;grid-template-columns:1fr 1fr;gap:12px}.location-coords:hover{background:#fff;transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.coord-label{font-size:11px;color:#666;text-transform:uppercase;font-weight:600;letter-spacing:.5px;margin-bottom:4px}.coord-value{font-family:Courier New,monospace;font-size:14px;color:#333;font-weight:700;background:#4ecdc41a;padding:8px 12px;border-radius:8px;border:1px solid rgba(78,205,196,.2)}.location-time{display:flex;align-items:center;gap:8px;font-size:12px;color:#666;background:#fffc;padding:8px 12px;border-radius:8px;border:1px solid rgba(0,0,0,.05);margin-top:12px}.time-icon{font-size:14px}.location-actions{display:flex;gap:12px;justify-content:center}.location-actions .btn{padding:12px 20px;font-size:13px;border-radius:10px;font-weight:600;transition:all .3s cubic-bezier(.4,0,.2,1);min-width:100px}.location-actions .btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #0003}.location-actions .btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.refresh-btn{background:linear-gradient(135deg,#4ecdc4,#44a08d);color:#fff}.clear-btn{background:linear-gradient(135deg,#ff6b6b,#ff8e8e);color:#fff}.location-error{background:#ff6b6b1a;border:1px solid rgba(255,107,107,.3);color:#d63031;padding:16px;border-radius:12px;font-size:13px;margin-bottom:16px;display:flex;flex-direction:column;gap:12px;align-items:center;text-align:center}.error-icon{font-size:20px}.error-message{font-weight:500;line-height:1.4}.error-retry-btn{background:#ff6b6b33;border:1px solid rgba(255,107,107,.4);color:#d63031;padding:8px 16px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}.error-retry-btn:hover:not(:disabled){background:#ff6b6b4d;border-color:#ff6b6b99}.error-retry-btn:disabled{opacity:.6;cursor:not-allowed}.location-toggle-btn{position:fixed;right:20px;bottom:100px;width:50px;height:50px;background:linear-gradient(135deg,#4ecdc4,#44a08d);border:none;border-radius:50%;color:#fff;font-size:20px;cursor:pointer;box-shadow:0 4px 15px #4ecdc44d;z-index:1001;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.location-toggle-btn:hover{background:linear-gradient(135deg,#44a08d,#3d8b7a);transform:translateY(-2px);box-shadow:0 6px 20px #4ecdc466}.location-toggle-btn:active{transform:translateY(0)}@media (max-width: 768px){.location-card{min-width:280px;max-width:calc(100vw - 40px);padding:15px}.location-header .location-title{font-size:16px}.location-status{font-size:13px}.location-action-btn{padding:10px 20px;font-size:14px}.location-actions .btn{padding:8px 12px;font-size:11px}.location-toggle-btn{right:10px;bottom:220px;width:45px;height:45px;font-size:18px}}@media (max-width: 480px){.location-card{min-width:260px;padding:12px}}.drawing-zone-info{position:fixed;top:200px;right:20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:15px;border-radius:12px;z-index:1002;max-width:250px;box-shadow:0 8px 25px #0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:opacity 1s ease-in-out}.drawing-zone-info h3{margin-bottom:10px;font-size:16px}.drawing-zone-info p{font-size:14px;line-height:1.4;opacity:.9}.zone-footer{margin-top:10px;font-size:12px;opacity:.8}.show-location-btn{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:8px 16px;border-radius:8px;cursor:pointer;font-size:12px;font-weight:600;margin-top:10px;width:100%;transition:all .3s ease}.show-location-btn:hover{background:#ffffff4d;transform:translateY(-1px)}@media (max-width: 768px){.drawing-zone-info{inset:auto 10px 120px;max-width:none;padding:12px}.drawing-zone-info h3{font-size:14px}.drawing-zone-info p{font-size:12px}}@media (max-width: 480px){.drawing-zone-info{bottom:100px;right:5px;left:5px}}.status-bar{position:fixed;bottom:20px;left:320px;right:20px;color:#000;padding:8px 12px;z-index:1002;font-size:13px;line-height:1.4;transition:all .3s ease}.status-content{display:flex;flex-direction:column;gap:8px;align-items:center;text-align:center}.status-text{font-weight:500;color:#000}.mouse-coordinates{font-family:Courier New,monospace;font-size:11px;color:#000;background:#4ecdc40d;padding:3px 6px;border-radius:4px;border:1px solid rgba(78,205,196,.1);font-weight:500}.status-bar.info{background:#4ecdc4e6;border-color:#4ecdc44d}.status-bar.warning{background:#ffc107e6;border-color:#ffc1074d;color:#333}.status-bar.error{background:#ff6b6be6;border-color:#ff6b6b4d}.status-bar.success{background:#6bcf7fe6;border-color:#6bcf7f4d}.status-bar.typing{animation:statusTyping .3s ease-out}@keyframes statusTyping{0%{opacity:.7;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.status-bar{bottom:10px;left:280px;right:10px;padding:10px 14px;font-size:13px}.status-content{gap:6px}.mouse-coordinates{font-size:11px;padding:3px 6px}}@media (max-width: 480px){.status-bar{bottom:5px;left:20px;right:5px;padding:8px 12px;font-size:12px}.mouse-coordinates{font-size:10px;padding:2px 5px}}@media (max-width: 768px) and (orientation: landscape){.status-bar{bottom:5px;left:10px;right:10px;padding:8px 12px}}@media (min-width: 769px){.status-bar{right:340px}}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.status-bar{border-width:.5px}}.app{width:100vw;height:100vh;overflow:hidden;position:relative;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;position:fixed;top:0;left:0;width:100vw;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;overflow:hidden;z-index:9999;margin:0;padding:0}.loading-screen:before{content:"";position:absolute;inset:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="50" cy="50" r="0.5" fill="rgba(255,255,255,0.1)"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>');opacity:.3;animation:float 6s ease-in-out infinite}.loading-spinner{width:80px;height:80px;border:4px solid rgba(255,255,255,.2);border-radius:50%;border-top-color:#fff;border-right-color:#fffc;border-bottom-color:#fff9;animation:spin 1.5s linear infinite;margin-bottom:30px;position:relative;z-index:2;box-shadow:0 0 30px #ffffff4d}.loading-spinner:after{content:"";position:absolute;inset:-8px;border:2px solid rgba(255,255,255,.1);border-radius:50%;animation:pulse 2s ease-in-out infinite}.loading-screen h1{font-size:3rem;font-weight:700;margin-bottom:15px;text-shadow:0 2px 10px rgba(0,0,0,.3);position:relative;z-index:2;animation:fadeInUp 1s ease-out .5s both}.loading-screen p{font-size:1.3rem;opacity:.9;margin-bottom:20px;position:relative;z-index:2;animation:fadeInUp 1s ease-out .8s both}.loading-screen .loading-dots{display:flex;gap:8px;position:relative;z-index:2;animation:fadeInUp 1s ease-out 1.1s both}.loading-dots span{width:8px;height:8px;border-radius:50%;background:#fff;animation:dots 1.4s ease-in-out infinite both}.loading-dots span:nth-child(1){animation-delay:0s}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.5}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes dots{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}.error-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:linear-gradient(135deg,#ff6b6b,#ee5a24);color:#fff;text-align:center;padding:20px}.error-screen h1{font-size:2.5rem;margin-bottom:1rem;color:#fff}.error-screen p{font-size:1.1rem;margin-bottom:1rem;max-width:600px;line-height:1.6}.error-screen a{color:#fff;text-decoration:underline;font-weight:600}.error-screen a:hover{color:#f8f9fa}.auth-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.auth-content{background:#fff;border-radius:12px;padding:40px;box-shadow:0 20px 40px #0000001a;max-width:500px;width:100%;text-align:center}.auth-header h1{font-size:2.5rem;margin-bottom:1rem;color:#333}.auth-header p{font-size:1.1rem;color:#666;margin-bottom:2rem}.auth-tabs{margin-bottom:2rem}.auth-tab{margin-bottom:1rem}.auth-footer{border-top:1px solid #eee;padding-top:1rem}.auth-footer p{color:#666;font-size:.9rem}.link-btn{background:none;border:none;color:#667eea;text-decoration:underline;cursor:pointer;font-size:.9rem}.link-btn:hover{color:#5a6fd8}.auth-btn-primary{background:linear-gradient(135deg,#667eea,#764ba2)!important;border:none!important;color:#fff!important;padding:12px 24px!important;border-radius:6px!important;font-weight:600!important;transition:all .2s ease!important}.auth-btn-primary:hover{transform:translateY(-1px)!important;box-shadow:0 4px 8px #00000026!important}.auth-card{box-shadow:none!important;border:none!important}html,body{margin:0;padding:0;width:100%;height:100%;overflow:hidden}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.btn:hover{transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
