:root{font-family: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}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;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}}.designation-controls{margin-top:10px}.designation-controls label{display:block;margin-bottom:5px;font-weight:700}.designation-buttons{display:flex;gap:5px}.designation-button{padding:5px 10px;border:1px solid #ccc;border-radius:4px;background:#fff;cursor:pointer;font-size:16px}.designation-button:hover{background:#f0f0f0}.designation-button.selected{background:#e0e0e0;border-color:#999}.custom-alliance-dropdown{position:relative;width:100%;min-width:150px}.dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;background:#fff;border:1px solid #ccc;border-radius:4px;cursor:pointer;-webkit-user-select:none;user-select:none}.dropdown-header:hover{border-color:#999}.selected-alliance{display:flex;align-items:center;gap:8px}.dropdown-arrow{font-size:10px;color:#666}.dropdown-options{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:#fff;border:1px solid #ccc;border-radius:4px;box-shadow:0 2px 8px #00000026;z-index:1000;max-height:200px;overflow-y:auto}.dropdown-option{display:flex;align-items:center;gap:8px;padding:6px 8px;cursor:pointer;-webkit-user-select:none;user-select:none}.dropdown-option:hover{background:#f5f5f5}.dropdown-option.selected{background:#e8e8e8}.dropdown-option svg{flex-shrink:0}.alliance-select-container{position:relative;display:flex;align-items:center;gap:8px}.alliance-select{flex:1;min-width:120px;padding:4px 24px 4px 8px;border:1px solid #ccc;border-radius:4px;background:#fff;font-size:14px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.alliance-select:focus{outline:none;border-color:#4a90e2;box-shadow:0 0 0 2px #4a90e233}.alliance-option{display:flex;align-items:center;gap:8px;padding:4px 8px}.alliance-color-preview{display:inline-block;width:16px;height:16px;border-radius:2px;border:1px solid rgba(0,0,0,.1);vertical-align:middle;margin-right:8px}.selected-alliance-preview{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:4px;overflow:hidden}.selected-alliance-preview svg{border-radius:2px}.territory-map-container{width:100%;height:100%;min-height:500px;border:1px solid #ccc;border-radius:4px;overflow:hidden;position:relative}.territory-map{position:relative;width:100%;height:100%}.territory{position:absolute;border:1px solid rgba(0,0,0,.2);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;text-align:center}.territory:hover{filter:brightness(1.1)}.territory.selected{filter:brightness(1.2);stroke-width:3}.territory-info{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;padding:2px}.territory-name{font-size:14px;font-weight:700;color:#000;text-shadow:1px 1px 1px rgba(255,255,255,.8);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:90%}.territory-buff{font-size:11px;color:#000;text-shadow:1px 1px 1px rgba(255,255,255,.8);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:90%}.territory-label{font-size:12px;fill:#333;pointer-events:none;-webkit-user-select:none;user-select:none}.territory-buff-name{font-size:10px;font-weight:700;fill:#000;text-shadow:1px 1px 1px rgba(255,255,255,.8);pointer-events:none}.territory-buff-value{font-size:8px;fill:#000;text-shadow:1px 1px 1px rgba(255,255,255,.8);pointer-events:none}.territory-level{font-size:14px;font-weight:700;fill:#000;text-shadow:1px 1px 1px rgba(255,255,255,.8);pointer-events:none}.grid line{stroke:#0000001a}.alliance-stats-panel{position:fixed;right:20px;top:20px;z-index:1000;display:flex;flex-direction:column;align-items:flex-end}.toggle-button{padding:8px 16px;background-color:#2c3e50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;margin-bottom:10px}.toggle-button:hover{background-color:#34495e}.stats-content{background-color:#fffffff2;padding:12px;border-radius:8px;box-shadow:0 2px 8px #0000001a;max-height:calc(100vh - 100px);overflow-y:auto;width:400px}.alliance-stat-entry{margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid #eee}.alliance-stat-entry:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.alliance-stat-header{display:flex;align-items:center;gap:8px;font-size:12px;min-width:0}.alliance-name{font-weight:700;font-family:monospace;white-space:nowrap}.territory-count{color:#666;font-size:11px;padding:2px 4px;background-color:#f0f0f0;border-radius:4px;white-space:nowrap;margin-left:4px}.buff-totals{display:flex;gap:4px;margin-left:auto;flex-shrink:0;flex-wrap:wrap}.buff-total{background-color:#f5f5f5;padding:2px 4px;border-radius:4px;font-size:11px;display:flex;align-items:center;gap:2px;white-space:nowrap}.territory-configurator{padding:1rem;background-color:#f5f5f5;border-radius:8px;box-shadow:0 2px 4px #0000001a}.configurator-section{margin-bottom:1.5rem;padding:1rem;background-color:#fff;border-radius:6px;box-shadow:0 1px 3px #0000000d}.configurator-section h2{margin:0 0 1rem;font-size:1.1rem;color:#333}.buff-colors-list{display:flex;flex-direction:column;gap:.75rem}.buff-item{display:flex;align-items:center;justify-content:space-between;padding:.5rem;background-color:#f8f8f8;border-radius:4px}.buff-name{font-size:.9rem;color:#444}.color-blocks{display:flex;gap:.5rem;align-items:center}.color-block{width:24px;height:24px;border-radius:4px;border:1px solid #ddd}.color-block.preview{pointer-events:none}.color-block.picker{cursor:pointer;padding:0;background:none}.territory-controls{display:flex;flex-direction:column;gap:1rem}.control-group{display:flex;flex-direction:column;gap:.5rem}.control-group label{font-size:.9rem;color:#666}.control-group select,.control-group input[type=number]{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;background-color:#fff;color:#333;transition:border-color .2s,box-shadow .2s}.control-group select:focus,.control-group input[type=number]:focus{outline:none;border-color:#4a90e2;box-shadow:0 0 0 2px #4a90e233}.control-group input[type=number]{-moz-appearance:textfield}.control-group input[type=number]::-webkit-outer-spin-button,.control-group input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.config-actions{display:flex;gap:.5rem;margin-bottom:1rem}.export-button,.reset-button{flex:1;padding:.75rem;border:none;border-radius:4px;font-size:.9rem;cursor:pointer;transition:background-color .2s}.export-button{background-color:#4a90e2;color:#fff}.export-button:hover{background-color:#357abd}.reset-button{background-color:#dc3545;color:#fff}.reset-button:hover{background-color:#c82333}.file-input-group{margin-top:1rem;display:flex;gap:.5rem;align-items:center}.choose-file{padding:.5rem 1rem;background-color:#f0f0f0;border-radius:4px;font-size:.9rem;color:#666;cursor:pointer}.no-file{font-size:.9rem;color:#999}.color-config{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:10px;padding:15px;background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px}.color-picker{display:flex;align-items:center;margin-bottom:10px;gap:10px}.color-picker label{min-width:100px;font-weight:700}.color-picker input[type=color]{width:50px;height:30px;padding:0;border:none;border-radius:4px;cursor:pointer}.color-preview{width:30px;height:30px;border-radius:4px;border:1px solid #ccc}.territory-selection{position:relative;min-height:500px;background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.territory-grid{position:relative;width:100%;height:100%}.territory{position:absolute;border:1px solid rgba(0,0,0,.2);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.territory-details{margin-bottom:20px;padding:15px;background-color:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.buff-config{display:flex;flex-direction:column;gap:10px}.buff-config label{display:flex;align-items:center;gap:10px}.buff-config select,.buff-config input[type=number]{padding:5px;border:1px solid #ccc;border-radius:4px;width:100px}.config-actions button{padding:8px 16px;background-color:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer}.config-actions input[type=file]{padding:8px;border:1px solid #ccc;border-radius:4px}.alliance-stats{display:flex;gap:8px;align-items:center;font-size:12px;color:#666;margin:0 8px;white-space:nowrap}.alliance-stats .influence{font-weight:700;color:#4a90e2;padding:2px 4px;background-color:#4a90e21a;border-radius:4px;cursor:help}.alliance-stats .territory-count{color:#666;padding:2px 4px;background-color:#f0f0f0;border-radius:4px;font-size:11px;cursor:help}.alliance-stats .buff-stat{padding:2px 4px;background-color:#f5f5f5;border-radius:4px;font-family:monospace;cursor:help}[title]{position:relative;cursor:help}[title]:hover:before{content:attr(title);position:absolute;bottom:100%;left:50%;transform:translate(-50%);padding:4px 8px;background-color:#000c;color:#fff;font-size:12px;border-radius:4px;white-space:pre-line;z-index:1000;max-width:300px;text-align:left}.alliance-item{display:flex;align-items:center;gap:4px;padding:4px 8px;background-color:#f5f5f5;border-radius:4px;min-width:0}.alliance-name{flex:0 1 auto;min-width:100px;padding:4px;border:1px solid #ccc;border-radius:4px;font-size:12px;overflow:hidden;text-overflow:ellipsis}.alliance-controls{display:flex;align-items:center;gap:8px;margin-right:8px}.alliance-legend{width:24px;height:24px;border-radius:4px;cursor:pointer;overflow:hidden}.pattern-preview{width:24px;height:24px;border-radius:4px;overflow:hidden}.pattern-selector{padding:4px 8px;border:1px solid #ccc;border-radius:4px;background:#fff;font-size:14px;cursor:pointer}.new-alliance-controls{display:flex;align-items:center;gap:8px;margin-right:8px}.focus-alliance{padding:4px 8px;background-color:#4a90e2;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px;transition:background-color .2s}.focus-alliance:hover{background-color:#357abd}.focus-alliance.focused{background-color:#2c3e50}.focus-alliance.focused:hover{background-color:#1a2530}.timeline-container{background-color:#fff;border-radius:4px;padding:12px;margin-bottom:16px}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.timeline-header h3{margin:0;font-size:16px;color:#333}.timeline-days{display:flex;gap:8px;flex-wrap:wrap}.timeline-day{display:flex;align-items:center;gap:4px;position:relative}.timeline-day.new-day{min-width:120px;height:32px}.timeline-day.new-day .date-picker-overlay{position:static;margin-top:0;height:100%;display:flex;align-items:center}.timeline-day.new-day .date-input{height:100%}.day-button{padding:6px 12px;border:1px solid #ddd;border-radius:4px;background-color:#fff;cursor:pointer;font-size:14px;color:#333;transition:all .2s ease;display:flex;align-items:center;gap:8px}.day-button:hover{background-color:#f5f5f5}.timeline-day.selected .day-button{background-color:#4caf50;color:#fff;border-color:#4caf50}.edit-date-button{padding:2px;border:none;background:none;cursor:pointer;opacity:.6;display:flex;align-items:center;justify-content:center;color:inherit}.edit-date-button:hover{opacity:1}.date-picker-overlay{position:absolute;top:100%;left:0;margin-top:4px;z-index:100;background-color:#fff;border-radius:4px;box-shadow:0 2px 8px #00000026;padding:4px}.date-input{padding:4px;border:1px solid #ddd;border-radius:4px;font-size:14px;width:130px}.remove-day-button{width:24px;height:24px;border:none;border-radius:50%;background-color:#f44;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;padding:0;line-height:1}.remove-day-button:hover{background-color:#c00}.add-day-button{padding:6px;border:none;border-radius:4px;background-color:#4caf50;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}.add-day-button:hover{background-color:#45a049}.add-day-button svg{width:20px;height:20px}.day-label{cursor:text;padding:2px 4px;border-radius:2px;transition:background-color .2s ease}.day-label:hover{background-color:#0000000d}.label-input{background:none;border:none;outline:none;font-size:inherit;font-family:inherit;color:inherit;width:100px;padding:0}.timeline-day.selected .label-input{color:#fff}.timeline-day.selected .day-label:hover{background-color:#ffffff1a}#root{width:100vw;height:100vh;margin:0;padding:0;overflow:hidden}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.app{width:100vw;height:100vh;overflow:hidden;position:relative;color-scheme:light;background-color:#fff}.map-container{width:100vw;height:100vh;position:relative;overflow:hidden;touch-action:none;-webkit-overflow-scrolling:touch}.config-container{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:1200px;max-height:90vh;background-color:#fff;border-radius:8px;box-shadow:0 2px 20px #0003;z-index:1000;display:none;overflow-y:auto}.config-container.visible{display:block}.buff-colors-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:8px;flex:1;background-color:#fff;padding:8px;border-radius:4px}.buff-item{display:flex;align-items:center;gap:8px;padding:4px 8px;background-color:#f5f5f5;border-radius:4px;white-space:nowrap}.buff-name{flex:1;font-size:14px}.color-blocks{display:flex;align-items:center;position:relative}.color-block{width:16px;height:16px;border-radius:2px}.color-block.preview{border:2px solid currentColor}.color-block.picker{position:absolute;top:0;left:0;width:20px;height:20px;opacity:0;cursor:pointer;z-index:1}.color-config{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;padding:10px;background-color:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.color-picker{display:flex;align-items:center;gap:8px}.color-picker label{min-width:80px;font-size:12px;font-weight:700}.color-picker input[type=color]{width:40px;height:25px;padding:0;border:none;border-radius:4px;cursor:pointer}.color-preview{width:25px;height:25px;border-radius:4px;border:1px solid #ccc}.territory-details{padding:8px;background-color:#fff;border-radius:4px}.territory-details h3{margin:0 0 8px;font-size:14px}.buff-config{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.buff-config label{display:flex;align-items:center;gap:4px;font-size:12px;white-space:nowrap}.buff-config select,.buff-config input[type=number]{width:60px;padding:2px 4px;border:1px solid #ddd;border-radius:2px;font-size:12px}.config-actions{display:flex;gap:4px;margin-top:8px}.config-actions button{padding:4px 8px;font-size:12px;border:none;border-radius:4px;cursor:pointer;background-color:#4caf50;color:#fff}.config-actions button:hover{background-color:#45a049}.config-actions input[type=file]{padding:6px;border:1px solid #ccc;border-radius:4px;font-size:12px}.territory-grid{position:relative;width:100%;height:100%;min-height:500px;touch-action:none;transform-origin:0 0;will-change:transform}.territory{position:absolute;border:1px solid rgba(0,0,0,.2);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;touch-action:none;user-select:none;-webkit-user-select:none}.territory:hover{border-color:#000;box-shadow:0 0 5px #0000004d}.territory.selected{border:2px solid #000;box-shadow:0 0 10px #00000080}.territory-name{font-size:12px;color:#000;text-shadow:1px 1px 1px rgba(255,255,255,.8)}.alliance-configurator{flex:1;background-color:#fff;padding:8px;border-radius:4px;min-width:0;overflow-x:auto}.alliance-configurator h3{display:none}.alliance-list{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.alliance-item{display:flex;align-items:center;gap:8px;padding:8px;background-color:#f5f5f5;border-radius:4px;min-width:200px}.alliance-color{width:24px;height:24px;border-radius:4px;border:1px solid #ddd}.alliance-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.alliance-color-picker{width:20px;height:20px;padding:0;border:none;cursor:pointer}.delete-alliance{padding:4px 8px;background-color:#f44;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:12px}.delete-alliance:hover{background-color:#c00}.add-alliance{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-top:8px}.new-alliance-name{flex:1;min-width:200px}.new-alliance-color{width:40px;height:40px;border-radius:4px;border:1px solid #ddd;cursor:pointer}.add-alliance-button{padding:8px 16px;background-color:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;white-space:nowrap}.add-alliance-button:hover{background-color:#45a049}.map-controls{padding:8px;background-color:#fff;border-radius:4px;margin-bottom:8px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.control-group{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.map-controls label{display:inline-flex;align-items:center;gap:4px;font-size:14px;cursor:pointer;white-space:nowrap;margin:0}.map-controls input[type=checkbox]{margin:0;width:16px;height:16px}.map-actions{display:flex;gap:4px;margin-left:auto}.icon-button{width:32px;height:32px;padding:6px;background-color:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center}.icon-button:hover{background-color:#45a049}.icon-button:active{transform:translateY(0)}.icon-button svg{width:20px;height:20px}.alliance-visibility{display:flex;align-items:center;gap:4px}.alliance-visibility input[type=checkbox]{margin:0;cursor:pointer}.map-header{display:flex;align-items:center;justify-content:flex-end;gap:16px;padding:8px}.map-header label{display:flex;align-items:center;gap:8px;font-size:14px;cursor:pointer;white-space:nowrap}.map-header input[type=checkbox]{width:16px;height:16px;cursor:pointer;margin:0}.icon-button.danger{background-color:#f44;color:#fff}.icon-button.danger:hover{background-color:red}.app-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background-color:#f5f5f5;border-bottom:1px solid #ddd}.header-controls{display:flex;gap:1rem}.toggle-edit,.toggle-borders{display:flex;align-items:center;gap:.5rem;cursor:pointer}.toggle-edit input,.toggle-borders input{width:16px;height:16px;cursor:pointer}.territory-popup{min-width:250px}.territory-info h3{margin:0 0 1rem;font-size:1.2rem}.territory-details{display:flex;flex-direction:column;gap:.5rem}.detail-row{display:flex;justify-content:space-between;align-items:center}.detail-label{font-weight:500;color:#666}.detail-value{color:#333}.level-input,.alliance-select,.buff-select,.buff-input{padding:4px 8px;border:1px solid #ddd;border-radius:4px;font-size:14px}.alliance-select,.buff-select{min-width:120px}.buff-input{width:60px}@media (max-width: 768px){#root,.app,.map-container{width:100vw;height:100vh;padding:0;margin:0;overflow:hidden}.floating-menu,.config-container{width:100%;height:100%;max-height:none;top:0;left:0;transform:none;border-radius:0}.floating-menu-content{padding:15px;height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch}.territory-map-container{width:100vw;height:100vh;border:none;margin:0;padding:0}.territory-grid{min-height:100vh}.map-controls{position:fixed;bottom:16px;right:16px;z-index:900}.zoom-controls{display:flex;flex-direction:column;gap:8px}.floating-menu-button{width:40px;height:40px;font-size:20px;right:15px}.config-button{bottom:15px}.alliances-button{bottom:65px}.timeline-button{bottom:115px}.map-controls{position:sticky;top:0;z-index:100;background-color:#fffffff2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 1px 3px #0000001a}.zoom-controls{bottom:8px;right:8px}.zoom-button{width:36px;height:36px;font-size:18px}.territory-name,.territory-level{font-size:10px}.territory-buff-value{font-size:9px}.map-header{padding:4px;gap:8px;flex-wrap:wrap}.map-actions{gap:4px}.buff-legend-toggle{display:block}.buff-colors-list{display:none;max-height:0;overflow:hidden;transition:max-height .3s ease-out}.buff-colors-list.expanded{display:grid;max-height:300px;overflow-y:auto}.territory-popup{position:fixed!important;left:50%!important;top:50%!important;transform:translate(-50%,-50%)!important;width:90%!important;max-width:300px;max-height:80vh;overflow-y:auto;z-index:1000;background:#fff;border-radius:8px;box-shadow:0 2px 10px #0003}.territory-popup .territory-details{padding:12px}.territory-popup select,.territory-popup input{width:100%;padding:8px;margin:4px 0;height:36px}.territory-popup label{display:block;margin-top:8px}.territory-popup .close-button{position:absolute;right:8px;top:8px;width:32px;height:32px;background:none;border:none;font-size:20px;cursor:pointer}.floating-menu{width:calc(100% - 32px);max-width:none}.timeline-container{left:16px}.menu-backdrop{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#0000004d;z-index:998}.menu-backdrop.visible{display:block}}input[type=text],input[type=color],select{color-scheme:light;background-color:#fff;color:#000}@media (prefers-color-scheme: dark){.app,.config-container,.buff-colors-list,.alliance-configurator,.territory-details,input[type=text],input[type=color],select{color-scheme:light;background-color:#fff;color:#000}}.zoom-controls{position:fixed;bottom:16px;right:16px;z-index:900}.zoom-button{width:40px;height:40px;border-radius:50%;background-color:#fff;border:1px solid #ddd;display:flex;align-items:center;justify-content:center;cursor:pointer;user-select:none;-webkit-user-select:none;touch-action:manipulation}.zoom-button:active{background-color:#f5f5f5}.buff-legend-toggle{display:none;width:100%;padding:8px;background-color:#fff;border:1px solid #ddd;border-radius:4px;text-align:left;font-size:14px;cursor:pointer;margin-bottom:4px}.buff-legend-toggle:after{content:"▼";float:right;transition:transform .3s ease}.buff-legend-toggle.collapsed:after{transform:rotate(-90deg)}.floating-menu-button{position:fixed;width:48px;height:48px;border-radius:50%;background-color:#fff;border:1px solid #ddd;box-shadow:0 2px 4px #0000001a;cursor:pointer;z-index:901;display:flex;align-items:center;justify-content:center;font-size:24px;right:20px}.config-button{bottom:20px}.alliances-button{bottom:80px}.timeline-button{bottom:140px}.floating-menu{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:1200px;max-height:90vh;background-color:#fff;border-radius:8px;box-shadow:0 2px 20px #0003;z-index:1000;display:none;overflow-y:auto}.floating-menu.visible{display:block}.floating-menu-content{padding:20px;box-sizing:border-box}.menu-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:999;display:none}.menu-backdrop.visible{display:block}.floating-menu-header{position:sticky;top:0;background-color:#fff;padding:15px 0;margin-bottom:20px;border-bottom:1px solid #ddd;display:flex;justify-content:space-between;align-items:center;z-index:1}.floating-menu-title{font-size:1.5rem;font-weight:700}.floating-menu-close{background:none;border:none;font-size:24px;cursor:pointer;padding:5px 10px;color:#666}.floating-menu-close:hover{color:#000}.menu-section{background-color:#fff;border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.menu-section h3{margin-top:0;margin-bottom:15px;font-size:1.2rem;color:#333}.settings-controls{display:flex;flex-direction:column;gap:10px}.settings-controls label{display:flex;align-items:center;gap:8px;cursor:pointer}.slider-control{margin-top:5px}.slider-control label{display:flex;flex-direction:column;gap:5px}.slider-control span{font-size:14px;color:#666}.opacity-slider{width:100%;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ddd;outline:none;border-radius:2px}.opacity-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;background:#4caf50;border-radius:50%;cursor:pointer}.opacity-slider::-moz-range-thumb{width:16px;height:16px;background:#4caf50;border-radius:50%;cursor:pointer;border:none}.opacity-slider:hover::-webkit-slider-thumb{background:#45a049}.opacity-slider:hover::-moz-range-thumb{background:#45a049}.map-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}.action-button{padding:10px 15px;border:1px solid #ddd;border-radius:4px;background-color:#fff;cursor:pointer;font-size:14px;transition:all .2s ease}.action-button:hover{background-color:#f5f5f5}.action-button.danger{color:#dc3545;border-color:#dc3545}.action-button.danger:hover{background-color:#dc3545;color:#fff}.floating-menu-button:hover{transform:scale(1.1);transition:transform .2s ease}@media (max-width: 768px){.floating-menu,.config-container{width:100%;height:100%;max-height:none;border-radius:0}.floating-menu-content{padding:15px;height:100%;overflow-y:auto}.floating-menu-button{width:40px;height:40px;font-size:20px;right:15px}.config-button{bottom:15px}.alliances-button{bottom:65px}.timeline-button{bottom:115px}.zoom-controls{bottom:12px;right:12px}}.timeline-day{padding:12px;margin-bottom:12px;background-color:#fff;border:1px solid #ddd;border-radius:8px;transition:all .2s ease;cursor:pointer;position:relative}.timeline-day:hover{border-color:#bbb;box-shadow:0 2px 4px #0000001a}.timeline-day.selected{border:2px solid #4CAF50;box-shadow:0 0 0 1px #4caf50;background-color:#f8fff8}.timeline-day-content{display:flex;justify-content:space-between;align-items:center;gap:8px}.timeline-day-content span{flex:1;font-size:14px;color:#333}.timeline-day-actions{display:flex;gap:4px;align-items:center}.timeline-day-actions button{padding:4px 8px;border:none;border-radius:4px;background-color:transparent;cursor:pointer;transition:background-color .2s;color:#666}.timeline-day-actions button:hover{background-color:#f0f0f0;color:#333}.timeline-day-actions .edit-button{color:#1976d2}.timeline-day-editor{margin-top:8px;padding-top:8px;border-top:1px solid #eee;display:flex;gap:8px;align-items:center}.timeline-day-editor input{padding:4px 8px;border:1px solid #ccc;border-radius:4px;font-size:14px;color:#000;background-color:#fff}.timeline-day-editor .date-input{width:120px}.timeline-day-editor .label-input{width:100px}
