:root{--surface: #F7F1E5;--surface-alt: #EDE1CF;--surface-card: #FDF9F2;--primary: #1F7A8C;--primary-soft: #D4ECF0;--primary-strong: #0F5C6D;--primary-dark: #0A4A57;--accent: #D87A39;--accent-soft: #F1C49F;--color-background: var(--surface);--color-background-alt: var(--surface-alt);--color-card: var(--surface-card);--color-primary: var(--primary);--color-primary-hover: var(--primary-strong);--color-primary-light: var(--primary-soft);--color-primary-active: var(--primary-strong);--color-accent: var(--accent);--color-accent-light: var(--accent-soft);--color-accent-hover: #C66A30;--text-primary: var(--primary-strong);--text-secondary: var(--primary);--text-muted: #8B8680;--text-on-primary: var(--surface-card);--text-on-accent: var(--primary-strong);--text-on-surface: var(--primary-strong);--border-light: var(--surface-alt);--border-medium: #D8CDB8;--border-strong: var(--primary-soft);--border-primary: var(--primary);--color-success: #10B981;--color-success-light: #D1FAE5;--color-success-dark: #0D8B63;--color-warning: var(--accent);--color-warning-light: var(--accent-soft);--color-error: #EF4444;--color-error-light: #FEE2E2;--color-error-dark: #C53030;--color-info: var(--primary);--color-info-light: var(--primary-soft);--opacity-disabled: .5;--opacity-muted: .7;--opacity-subtle: .8;--opacity-overlay: .9;--opacity-backdrop: .95;--btn-primary-bg: var(--primary);--btn-primary-text: var(--text-on-primary);--btn-primary-border: var(--primary);--btn-primary-hover-bg: var(--primary-strong);--btn-primary-hover-border: var(--primary-strong);--btn-secondary-bg: var(--surface-card);--btn-secondary-text: var(--text-primary);--btn-secondary-border: var(--border-medium);--btn-secondary-hover-bg: var(--surface-alt);--btn-accent-bg: var(--accent);--btn-accent-text: var(--text-on-accent);--btn-accent-border: var(--accent);--btn-accent-hover-bg: var(--color-accent-hover);--btn-success-bg: var(--color-success);--btn-success-text: var(--text-on-primary);--btn-success-border: var(--color-success);--btn-success-hover-bg: #0d9567;--input-bg: var(--surface-card);--input-border: var(--border-medium);--input-text: var(--text-primary);--input-placeholder: var(--text-muted);--input-focus-border: var(--primary);--input-focus-shadow: var(--primary-soft);--panel-bg: var(--surface-card);--panel-border: var(--border-light);--panel-header-bg: var(--surface-alt);--panel-shadow: rgba(31, 122, 140, .1);--control-bg: var(--surface-card);--control-bg-backdrop: rgba(247, 241, 229, .95);--control-border: var(--border-light);--control-shadow: var(--panel-shadow);--control-active-bg: var(--primary);--control-active-text: var(--text-on-primary);--control-hover-bg: var(--surface-alt);--timeline-bg: var(--surface-card);--timeline-track: var(--surface-alt);--timeline-fill: var(--primary);--timeline-handle: var(--primary-strong);--timeline-text: var(--text-primary)}.bg-surface{background-color:var(--surface)}.bg-surface-alt{background-color:var(--surface-alt)}.bg-surface-card{background-color:var(--surface-card)}.bg-primary{background-color:var(--primary)}.bg-primary-soft{background-color:var(--primary-soft)}.bg-accent{background-color:var(--accent)}.bg-accent-soft{background-color:var(--accent-soft)}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-on-primary{color:var(--text-on-primary)}.text-on-accent{color:var(--text-on-accent)}.border-light{border-color:var(--border-light)}.border-medium{border-color:var(--border-medium)}.border-primary{border-color:var(--border-primary)}*{box-sizing:border-box;margin:0;padding:0}body{--header-h: 51px;--footer-h: 180px;--edge-gap: 8px;--details-width: 400px;--right-offset: 0px;font-family:Arbutus Slab,serif;font-size:12px;line-height:1.2;color:var(--text-primary, #333);background-color:var(--color-background, #F7F1E5);height:100vh;overflow:hidden;padding-top:var(--header-h);padding-bottom:var(--footer-h);transition:padding-bottom .3s ease,padding-top .1s ease;margin:0}body:has(#app-footer.and-mode){--footer-h: 240px}body:has(#app-footer.collapsed){--footer-h: 0px}body.footer-collapsed{--footer-h: 0px}body.footer-and-mode{--footer-h: 240px}body:has(#header-bar.collapsed){--header-h: 0px}body.header-collapsed{--header-h: 0px}#app-main{display:flex;flex-direction:row;flex:1;min-height:0}#app-container{width:100%;height:100vh;position:relative;overflow-y:hidden;overflow-x:visible;display:flex;flex-direction:column}#app-footer{position:fixed;bottom:0;left:0;right:0;width:100%;height:180px;background:var(--surface-card);border-top:2px solid var(--border-medium);box-shadow:0 -4px 12px #1f7a8c14;z-index:1500;display:flex;flex-direction:column;transition:height .3s ease,transform .1s ease}#app-footer.and-mode{height:240px}#app-footer.collapsed{transform:translateY(100%)}.footer-status-row{display:flex;height:24px;border-top:1px solid var(--border-light);background:var(--surface-alt)}#status-bar{flex:0 0 auto;padding:6px 12px;font-size:12px;color:var(--text-muted);border-right:1px solid var(--border-light)}#attribution{flex:1;padding:6px 12px;font-size:12px;color:var(--text-muted);text-align:right}.mode-container{display:none;width:100%;height:100%;overflow-x:visible;overflow-y:hidden}#source-mode,#surnames-mode{display:flex;overflow-x:visible;overflow-y:hidden}.mode-surnames,.mode-sources{display:flex;flex-direction:row;overflow-x:visible;overflow-y:hidden}#map{position:absolute;top:0;left:0;right:0;bottom:0;width:100%;height:100%;z-index:0}#map-container{position:fixed;top:0;left:0;right:0;bottom:var(--footer-h);overflow:visible}#map-top-center-controls{position:absolute;top:20px;left:50%;transform:translate(-50%);z-index:1000;display:flex;flex-direction:column;align-items:center}.toggle-buttons-group{background:var(--surface-card);border-radius:5px;box-shadow:0 2px 5px var(--panel-shadow);margin-top:10px}.toggle-buttons-container{display:flex;border-radius:4px;overflow:hidden}.toggle-button{padding:5px 10px;background:var(--btn-secondary-bg);border:1px solid var(--btn-secondary-border);cursor:pointer;font-family:inherit;font-size:12px;color:var(--btn-secondary-text);transition:all .1s ease}.toggle-button.active{background:var(--btn-primary-bg);color:var(--btn-primary-text);border-color:var(--btn-primary-border);font-weight:700}.toggle-button:hover:not(.active){background:var(--btn-secondary-hover-bg)}#zoom-controls-placer{margin-bottom:10px}#zoom-controls-placer .leaflet-control-zoom{border:none;box-shadow:0 2px 5px #0000001a}#zoom-controls-placer .leaflet-control-zoom a{width:36px;height:36px;line-height:36px;font-size:18px}#left-sidebar,#main-pane-left{position:fixed;top:calc(var(--header-h) + var(--edge-gap));bottom:calc(var(--footer-h) + var(--edge-gap));left:var(--edge-gap);width:20%;height:auto;z-index:1000;background:var(--surface-card);box-shadow:0 0 10px var(--panel-shadow);overflow-y:auto;transition:transform .3s ease}#main-pane-right,#right-sidebar{position:absolute;top:.3%;right:.3%;width:20%;height:auto;z-index:1000;background:var(--surface-card);box-shadow:0 0 10px var(--panel-shadow);overflow-y:auto;transform:translate(100%);transition:transform .1s ease}#main-pane-right #pane.active{transform:translate(0)}.info-pane{height:100%;display:flex;flex-direction:column}.pane-section{padding:5px;border-bottom:1px solid var(--border-light)}#pane-top{position:relative;flex:0 0 auto;background:var(--surface-alt)}#pane-bottom{flex:1 1 auto;overflow-y:auto}.pane-close{position:absolute;top:10px;right:10px;width:30px;height:30px;border-radius:50%;background:var(--surface-alt);border:none;color:var(--text-primary);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .3s ease}.pane-close:hover{background:var(--border-medium)}.source-marker-icon,.surname-marker-icon{background:transparent!important;border:none!important}.source-icon-inner,.surname-icon-inner{border-radius:50%;transition:all .2s ease}.highlighted .source-icon-inner,.highlighted .surname-icon-inner{box-shadow:0 0 0 2px var(--surface-card),0 0 0 4px var(--accent)}.source-popup,.surname-popup{max-width:200px;max-height:200px;overflow-y:auto;line-height:1.2;font-size:12px}.source-popup h3,.surname-popup h3{margin-bottom:2px;font-size:14px;color:var(--text-primary)}.source-author,.surname-origin{font-style:italic;margin-bottom:5px;color:var(--text-secondary)}.source-date{color:var(--text-muted);font-size:14px;margin-bottom:8px}.source-type,.surname-type{display:inline-block;padding:3px 6px;background:var(--surface-alt);color:var(--text-primary);border-radius:3px;margin-top:5px;font-size:12px}.view-details{display:block;margin-top:5px;text-align:right;color:var(--color-primary);text-decoration:none;font-size:12px}.tags-container{margin-top:10px;display:flex;flex-wrap:wrap}.tag{background:var(--surface-alt);color:var(--text-primary);padding:4px 8px;border-radius:4px;font-size:12px;margin-right:5px;margin-bottom:5px}body.modal-open{overflow:hidden}#header-bar,.header-bar{position:fixed!important;top:0;left:0;right:0;width:100%;height:50px;display:flex!important;align-items:center;background:var(--control-bg, #FDF9F2)!important;border-bottom:2px solid var(--control-border, #D4C4A0)!important;box-shadow:var(--control-shadow, 0 4px 12px rgba(31, 122, 140, .08))!important;transition:transform .1s ease;min-height:40px!important;flex-shrink:0;z-index:1500!important;padding:16px 24px}.header-content{display:flex!important;align-items:center;justify-content:space-between;width:100%!important;gap:20px;transition:opacity .3s ease}.header-controls-group{display:flex!important;align-items:center;gap:16px;flex:1;justify-content:center}.header-buttons{display:flex!important;align-items:center;gap:8px;flex-shrink:0}.header-logo{display:flex!important;align-items:center;flex-shrink:0}.header-logo .logo{color:var(--text-primary, #333)!important;font-weight:800;font-size:14px}#shapefile-control-container,#mode-control-container,#country-control-container,#layer-control-container{display:flex!important;align-items:center;gap:6px;min-height:32px;flex-shrink:1;min-width:0}#shapefile-control-container .map-control,#mode-control-container .map-control,#country-control-container .map-control,#layer-control-container .map-control{position:static!important;margin:0!important;box-shadow:none!important;border-radius:4px!important;flex-shrink:1;min-width:0}#mode-control-container .mode-control .mode-btn{min-width:60px!important;max-width:70px!important;padding:6px 8px!important;font-size:12px!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}#shapefile-control-container .shapefile-control .shapefile-toggle-btn{min-width:55px!important;max-width:65px!important;padding:6px 8px!important;font-size:12px!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}#country-control-container .country-control{max-width:90px!important;min-width:90px!important;position:relative}#country-control-container .country-control .country-control-header{padding:6px 10px!important;font-size:12px!important;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}#country-control-container .country-control h4{font-size:12px!important;margin:0!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}#country-control-container .country-control .country-control-content{position:absolute!important;top:100%!important;left:0!important;min-width:200px!important;max-height:300px!important;background:var(--control-bg, #FDF9F2)!important;border:1px solid var(--control-border, #D4C4A0)!important;border-radius:4px!important;box-shadow:var(--control-shadow, 0 4px 12px rgba(31, 122, 140, .08))!important;z-index:2000!important;overflow-y:auto!important;display:none!important}#country-control-container .country-control:not(.collapsed) .country-control-content{display:block!important}#layer-control-container .layer-control{max-width:85px!important;position:relative}#layer-control-container .layer-control .layer-control-inline{position:relative;display:block!important}#layer-control-container .layer-control .layer-trigger{display:flex;align-items:center;justify-content:center;gap:6px;padding:6px 12px;background:var(--control-bg, #FDF9F2);border:1px solid var(--control-border, #D4C4A0);border-radius:var(--radius-small, 6px);cursor:pointer;font-size:12px;font-weight:500;color:var(--text, #2E2720);transition:all .2s ease;text-align:center;line-height:1.2;white-space:nowrap;min-width:85px}#layer-control-container .layer-control:hover .layer-trigger{background:var(--surface-alt, #EDE1CF);border-color:var(--primary, #4A90E2)}#layer-control-container .layer-control .layer-dropdown{position:absolute;top:100%;left:0;margin-top:4px;background:var(--control-bg, #FDF9F2);border:1px solid var(--control-border, #D4C4A0);border-radius:var(--radius-medium, 8px);box-shadow:var(--shadow-dropdown, 0 4px 6px rgba(0,0,0,.05), 0 2px 4px rgba(0,0,0,.1));padding:12px;min-width:200px;z-index:2000;display:none}#layer-control-container .layer-control:hover .layer-dropdown{display:block}#layer-control-container .layer-control .layer-items{display:flex;flex-direction:column;gap:8px}#layer-control-container .layer-control .layer-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:var(--radius-small, 6px);cursor:pointer;transition:background .2s ease;font-size:12px;color:var(--text, #2E2720)}#layer-control-container .layer-control .layer-item:hover{background:var(--surface-alt, #EDE1CF)}#layer-control-container .layer-control .layer-checkbox{width:14px;height:14px;border:1px solid var(--control-border, #D4C4A0);border-radius:3px;position:relative;background:var(--control-bg, #FDF9F2);flex-shrink:0}#layer-control-container .layer-control .layer-checkbox.checked{background:var(--primary, #4A90E2);border-color:var(--primary, #4A90E2)}#layer-control-container .layer-control .layer-checkbox.checked:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:10px;font-weight:700}.header-expand-toggle{position:absolute;bottom:-30px;left:50%;transform:translate(-50%);background:var(--surface-card, #FDF9F2);border:1px solid var(--border-medium, #D4C4A0);border-top:none;border-radius:0 0 8px 8px;cursor:pointer;padding:8px 20px 6px;transition:all .3s ease;z-index:1600;min-width:100px;text-align:center;box-shadow:0 2px 8px #1f7a8c26;display:flex;align-items:center;justify-content:center}.header-expand-toggle:hover{background:var(--surface-alt, #F0F0F0);box-shadow:0 4px 12px #1f7a8c33;transform:translate(-50%) translateY(2px)}.header-expand-toggle:focus{outline:none;box-shadow:0 0 0 2px var(--input-focus-shadow, rgba(31, 122, 140, .25))}.header-toggle-icon{font-size:14px;color:var(--text-secondary, #1F7A8C);transition:transform .1s ease;display:inline-block;-webkit-user-select:none;user-select:none}#header-bar.collapsed,.header-bar.collapsed{transform:translateY(-100%)}#header-bar.collapsed .header-toggle-icon,.header-bar.collapsed .header-toggle-icon{transform:rotate(180deg)}@media (max-width: 768px){.header-content{flex-direction:column;gap:12px;align-items:stretch}.header-controls-group{justify-content:center;flex-wrap:wrap;gap:12px}.header-buttons{justify-content:center}.header-expand-toggle{top:4px;right:4px;width:28px;height:20px}}.list-view-container,#list-view-container,.details-container{background:var(--surface-card);border:1px solid var(--border-light);border-radius:8px;box-shadow:0 0 10px var(--panel-shadow);color:var(--text-primary)}.list-view-container,#list-view-container{display:flex;width:15%;height:auto;overflow-y:auto;overflow-x:visible;z-index:900;position:fixed;left:calc(20.3% + var(--edge-gap, 0px));top:calc(var(--header-h) + var(--edge-gap, 0px));bottom:calc(var(--footer-h) + var(--edge-gap, 0px));transition:transform .3s ease,left .3s ease;flex-direction:column;font-size:14px;line-height:1.4}.list-view-toggle-tab{position:fixed;top:calc(var(--header-h, 51px) + 80px);left:calc(20.3% + var(--edge-gap, 0px) + 15%);width:30px;height:60px;background:var(--control-bg, #FDF9F2);border:1px solid var(--control-border, #D4C4A0);border-left:none;border-radius:0 8px 8px 0;box-shadow:2px 0 8px #1f7a8c1a;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:850;transition:all .3s ease,left .3s ease}.list-view-toggle-tab:hover{background:var(--accent-soft, #F1C49F);transform:translate(2px);box-shadow:4px 0 12px #d87a3926}.list-view-toggle-tab:focus{outline:none;box-shadow:0 0 0 2px #d87a3940}.list-view-toggle-tab .toggle-icon{font-size:18px;font-weight:700;color:var(--accent, #D87A39);transition:transform .3s ease;-webkit-user-select:none;user-select:none}.list-view-container.collapsed,#list-view-container.collapsed{transform:translate(calc(-100% - var(--edge-gap, 0px)));border-radius:0;border:none}#app-main.list-view-collapsed #list-view-toggle .toggle-icon{transform:rotate(180deg)}.mode-container:has(.list-view-container.collapsed) #map{left:0;width:100%}.mode-container.list-view-collapsed #map{left:0;width:100%}.list-view-container.active{display:block;width:20%;height:auto;overflow-y:auto;background:var(--surface-card);box-shadow:0 0 10px var(--panel-shadow);z-index:900}.list-view-container .list-item h4,.list-view-container .list-item p{font-size:14px}.list-view-container .list-info{font-size:13px}.list-view-container .list-item h3,.list-view-container .surname-title,.list-view-container .source-title{font-size:14px;line-height:1.3;margin:0 0 6px;font-weight:600}.details-container{position:fixed;top:calc(var(--header-h) + var(--edge-gap, 0px));right:var(--edge-gap, 0px);bottom:calc(var(--footer-h) + var(--edge-gap, 0px));width:min(var(--details-width),92vw);max-width:calc(100vw - (2 * var(--edge-gap, 0px)));height:auto;z-index:1400;transform:translate(calc(100% + var(--edge-gap, 0px)));transition:transform .3s ease;display:flex;flex-direction:column;overflow:hidden;padding:0}.details-container.active{transform:translate(0)}.details-content{flex:1 1 auto;padding:24px 20px;overflow-y:auto;min-height:0}.details-container>#details-placeholder{display:flex;flex-direction:column;flex:1 1 auto;min-height:0;overflow:hidden}.details-container .panel{display:flex;flex-direction:column;flex:1 1 auto;min-height:0}.details-container .panel-header{flex:0 0 auto}.details-container .panel-content{flex:1 1 auto;min-height:0;overflow-y:auto;max-height:none}.details-header{padding:18px 20px 12px;background:#f5f5f5;border-bottom:1px solid #eee;display:flex;align-items:center;justify-content:space-between}.surname-title{font-size:1.5em;font-weight:700;margin:0}.close-button{background:none;border:none;font-size:1.5em;cursor:pointer;color:#888;margin-left:0}.panel-close-button{position:absolute;top:8px;right:12px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background .2s ease,color .2s ease;z-index:2}.panel-close-button:hover,.panel-close-button:focus-visible{background:#00000014;color:#333}.surname-details-panel .panel-header>h3,.source-details-panel .panel-header>h3{display:none}.details-view .details-content{padding:0;margin-top:12px}.alternate-surnames,.surname-metadata,.surname-description,.surname-location,.surname-relationships,.surname-sources{margin-bottom:18px}.metadata-item{margin-bottom:6px;font-size:1em}.metadata-label{font-weight:700;margin-right:6px}.metadata-value{color:#444}.journey-toggle{margin-bottom:18px}.journey-toggle button{background:#38f;color:#fff;border:none;border-radius:4px;padding:6px 14px;cursor:pointer;font-size:1em}.surname-description h3,.surname-location h3,.surname-relationships h3,.surname-sources h3{font-size:1.1em;margin-bottom:6px;margin-top:0}.surname-description p,.surname-location p,.relationship-description{margin:0 0 6px;color:#333}.surname-location .coordinates{font-size:.95em;color:#666}.show-on-map-btn{background:#38f;color:#fff;border:none;border-radius:4px;padding:5px 12px;cursor:pointer;font-size:.95em;margin-top:6px}.surname-relationships ul,.surname-sources ul{padding-left:18px;margin:0}.related-surname{color:#38f;text-decoration:underline;cursor:pointer}.relationship-type{color:#888;font-size:.95em}.relationship-description{font-size:.95em;color:#666;margin-left:10px}.surname-sources ul{list-style-type:disc}.surname-sources a{color:#38f;text-decoration:underline}.leaflet-top.leaflet-right{top:20px}.position-top-left{top:20px;left:20px}.position-top-center{top:20px;left:50%;transform:translate(-50%)}.map-control{display:flex;position:absolute}body:has(.details-container.active){--right-offset: calc(var(--details-width) + var(--edge-gap, 0px))}.map-control.layer-control,.map-control.zoom-control{right:calc(var(--right-offset, 0px) + 20px);transition:right .3s ease}@media (max-width: 700px){.details-container{width:100vw;left:0;right:0;top:var(--header-h);bottom:var(--footer-h);height:auto;border-radius:12px 12px 0 0;box-shadow:0 -2px 12px #0000002e}.details-content{padding:16px 8px}}@media screen and (max-width: 768px){#left-sidebar{width:min(320px,calc(100vw - (2 * var(--edge-gap, 0px))));height:calc(100vh - var(--header-h) - var(--footer-h));position:fixed;top:calc(var(--header-h) + var(--edge-gap, 0px));bottom:calc(var(--footer-h) + var(--edge-gap, 0px));transform:translate(0)}#left-sidebar.collapsed{transform:translate(calc(-100% - var(--edge-gap, 0px)))}#main-pane-right{transform:translate(100%)}.list-view-container{width:100%;height:100%}.details-container{width:100%}}.journey-controls{background:var(--control-bg);border:1px solid var(--control-border);border-radius:6px;padding:12px;box-shadow:var(--control-shadow);display:flex;flex-direction:column;gap:12px;min-width:200px}.inline-journey-controls{display:flex;align-items:center;gap:8px;background:var(--control-bg-backdrop);border:1px solid var(--control-border);border-radius:4px;padding:6px 12px;box-shadow:var(--control-shadow)}.journey-toggle-btn{background:var(--btn-secondary-bg);color:var(--btn-secondary-text);border:1px solid var(--btn-secondary-border);border-radius:4px;padding:8px 12px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:6px;min-width:80px}.journey-toggle-btn:hover{background:var(--btn-secondary-hover-bg);border-color:var(--border-medium);transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.journey-toggle-btn:active{transform:translateY(0);box-shadow:0 1px 2px #0000001a}.journey-toggle-btn:focus{outline:none;box-shadow:0 0 0 2px var(--input-focus-shadow)}.journey-toggle-btn.active{background:var(--control-active-bg);color:var(--control-active-text);border-color:var(--control-active-bg)}.journey-toggle-btn:before{content:"🗺️";font-size:14px}.layer-btn{background:var(--control-bg);color:var(--text-primary);border:1px solid var(--control-border);border-radius:4px;padding:8px 12px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:70px;white-space:nowrap}.layer-btn:hover{background:var(--control-hover-bg);border-color:var(--border-medium)}.layer-btn:focus{outline:none;box-shadow:0 0 0 2px var(--input-focus-shadow)}.layer-btn.active{background:var(--control-active-bg);color:var(--control-active-text);border-color:var(--control-active-bg);font-weight:600}.layer-btn:disabled,.layer-btn.placeholder{opacity:var(--opacity-disabled);cursor:not-allowed;background:var(--control-bg);color:var(--text-muted)}.layer-btn:disabled:hover,.layer-btn.placeholder:hover{background:var(--control-bg);border-color:var(--control-border);transform:none}.layer-control-inline{display:flex;align-items:center;gap:4px;background:var(--control-bg-backdrop);border:1px solid var(--control-border);border-radius:6px;padding:8px;box-shadow:var(--control-shadow);flex-wrap:wrap}.layer-control-inline .layer-btn{border-radius:3px;padding:6px 10px;font-size:12px;min-width:60px}.layer-control-inline .layer-btn:not(:last-child){margin-right:2px}@media (max-width: 768px){.journey-controls{min-width:160px;padding:10px;gap:10px}.inline-journey-controls{padding:4px 8px;gap:6px}.journey-toggle-btn,.layer-btn{padding:6px 8px;font-size:12px;min-width:60px}.layer-control-inline{padding:6px;gap:3px}.layer-control-inline .layer-btn{padding:5px 8px;font-size:11px;min-width:50px}}.map-control.mode-control{background:#fff;border-radius:4px;box-shadow:0 2px 5px #0000001a;overflow:hidden;top:20px;left:58%;transform:translate(-50%);flex-direction:row}.map-control.mode-control.position-top-center{left:58%!important;transform:translate(-50%)!important}.mode-control .mode-btn{min-width:80px;height:40px;background:#fff;border:none;cursor:pointer;font-size:14px;font-weight:500;color:#333;transition:all .2s ease;display:flex;align-items:center;justify-content:center;line-height:1;padding:0 16px;border-right:1px solid #eee}.mode-control .mode-btn:last-child{border-right:none}.mode-control .mode-btn:hover:not(.active):not(:disabled){background:#f0f0f0;color:#000}.mode-control .mode-btn:active:not(.active):not(:disabled){background:#e0e0e0}.mode-control .mode-btn.active{background:#38f;color:#fff;font-weight:600}.mode-control .mode-btn:disabled{opacity:.5;cursor:not-allowed;color:#999}.mode-control .mode-btn:disabled:hover{background:#fff;color:#999}.mode-control.disabled{opacity:.6;pointer-events:none}.map-control.shapefile-control{background:#fff;border-radius:4px;box-shadow:0 2px 5px #0000001a;overflow:hidden;flex-direction:row;top:70px;left:58%;transform:translate(-50%)}.map-control.shapefile-control.position-top-left{left:58%!important;transform:translate(-50%)!important}.shapefile-control .shapefile-toggle-btn{min-width:90px;height:40px;background:#fff;border:none;cursor:pointer;font-size:14px;font-weight:500;color:#333;transition:all .2s ease;border-right:1px solid #eee}.shapefile-control .shapefile-toggle-btn:last-child{border-right:none}.shapefile-control .shapefile-toggle-btn.active{background:#38f;color:#fff;font-weight:700}.shapefile-control .shapefile-toggle-btn:hover:not(.active){background:#f5f5f5}.shapefile-control.disabled{opacity:.6;pointer-events:none}.map-control.country-control{background:#fff;border-radius:4px;box-shadow:0 2px 5px #0000001a;overflow:hidden;flex-direction:column;min-width:180px;max-width:240px}.country-control-header{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:#f8f9fa;border-bottom:1px solid #eee}.country-control-header h4{margin:0;font-size:16px;font-weight:600;color:#333}.country-control-toggle{background:none;border:none;cursor:pointer;font-size:12px;color:#666;padding:2px 4px;border-radius:2px;transition:all .2s ease}.country-control-toggle:hover{background:#0000001a}.country-control-content{max-height:300px;overflow-y:auto}.country-control .country-toggle-btn{width:100%;padding:8px 12px;background:#fff;border:none;cursor:pointer;font-size:13px;font-weight:500;color:#333;text-align:left;transition:all .2s ease;border-bottom:1px solid #eee}.country-control .country-toggle-btn:last-child{border-bottom:none}.country-control .country-toggle-btn.active{background:#38f;color:#fff;font-weight:700}.country-control .country-toggle-btn:hover:not(.active){background:#f5f5f5}.country-control.disabled{opacity:.6;pointer-events:none}@media (max-width: 768px){.map-control.mode-control,.map-control.shapefile-control{left:58%;transform:translate(-50%)}.shapefile-control .shapefile-toggle-btn{min-width:70px;font-size:13px;padding:0 12px}.country-control{min-width:140px;max-width:180px}.country-control .country-toggle-btn{font-size:12px;padding:6px 10px}}.map-control.layer-control{background:#fff;border-radius:4px;box-shadow:0 2px 5px #0000001a;overflow:visible;top:20px;right:20px;flex-direction:column;min-width:180px;max-width:250px;max-height:none}.map-control.zoom-control{background:#fff;border-radius:4px;box-shadow:0 2px 5px #0000001a;overflow:hidden;bottom:20px;right:20px;flex-direction:column}.zoom-control button,.layer-control button{width:40px;height:40px;background:#fff;border:none;cursor:pointer;font-size:18px;font-weight:700;color:#333;transition:all .2s ease;display:flex;align-items:center;justify-content:center;line-height:1}.zoom-control button:first-child,.layer-control button:first-child{border-bottom:1px solid #eee}.zoom-control button:hover:not(:disabled),.layer-control button:hover:not(:disabled){background:#f0f0f0;color:#000}.zoom-control button:active:not(:disabled),.layer-control button:active:not(:disabled){background:#e0e0e0}.zoom-control button:disabled,.layer-control button:disabled{opacity:.5;cursor:not-allowed;color:#999}.zoom-control button:disabled:hover,.layer-control button:disabled:hover{background:#fff;color:#999}.zoom-control .zoom-in{font-size:20px}.zoom-control .zoom-out{font-size:24px;line-height:.8}.layer-control-header{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:#f8f9fa;border-bottom:1px solid #e9ecef;cursor:pointer}.layer-control-header h3{margin:0;font-size:14px;font-weight:600;color:#333}.layer-control-toggle{background:none;border:none;font-size:12px;cursor:pointer;color:#666;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center}.layer-control-toggle:hover{color:#333}.layer-control-content{padding:8px 0;max-height:200px;overflow-y:auto;overflow-x:hidden;position:relative;scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:#ccc #f8f9fa}.layer-control-content::-webkit-scrollbar{width:6px}.layer-control-content::-webkit-scrollbar-track{background:#f8f9fa;border-radius:3px}.layer-control-content::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px;transition:background .2s ease}.layer-control-content::-webkit-scrollbar-thumb:hover{background:#999}.layer-control-content:before,.layer-control-content:after{content:"";position:absolute;left:0;right:6px;height:8px;pointer-events:none;opacity:0;transition:opacity .3s ease;z-index:1}.layer-control-content:before{top:0;background:linear-gradient(to bottom,white,transparent)}.layer-control-content:after{bottom:0;background:linear-gradient(to top,white,transparent)}.layer-control-content.scrollable-top:before{opacity:1}.layer-control-content.scrollable-bottom:after{opacity:1}.base-layers,.overlay-layers{margin-bottom:8px}.base-layers:last-child,.overlay-layers:last-child{margin-bottom:0}.base-layers h4,.overlay-layers h4{margin:0 0 4px;padding:0 12px;font-size:12px;font-weight:600;color:#666;text-transform:uppercase}.layer-option{display:flex;align-items:center;padding:6px 12px;cursor:pointer;transition:background-color .2s ease}.layer-option:hover{background-color:#f8f9fa}.layer-option input{margin:0 8px 0 0;cursor:pointer}.layer-option label{margin:0;font-size:13px;color:#333;cursor:pointer;flex:1}.layer-option input:checked+label{font-weight:500;color:#007bff}.map-control.map-legend{background:#fff;border-radius:4px;box-shadow:0 2px 5px #0000001a;overflow:hidden;bottom:20px;left:20px;flex-direction:column;min-width:180px;max-width:300px;max-height:400px}.legend-header{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:#f8f9fa;border-bottom:1px solid #e9ecef;cursor:pointer}.legend-header h3{margin:0;font-size:14px;font-weight:600;color:#333}.legend-toggle{background:none;border:none;font-size:12px;cursor:pointer;color:#666;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center}.legend-toggle:hover{color:#333}.legend-content{overflow-y:auto;overflow-x:hidden}.legend-items{padding:8px}.legend-item{display:flex;align-items:center;padding:6px 8px;margin:2px 0;border-radius:3px;transition:background .2s ease}.legend-item:hover{background:#f8f9fa}.legend-symbol{width:20px;height:20px;margin-right:10px;border-radius:2px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px}.legend-symbol.color-symbol{border:1px solid #ddd}.legend-symbol.icon-symbol{background:transparent;border:none;font-size:16px}.legend-symbol.gradient-symbol{border:1px solid #ddd}.legend-symbol.pattern-symbol{background-repeat:repeat;background-size:contain;border:1px solid #ddd}.legend-symbol.custom-symbol{background:transparent;border:none}.legend-label{flex:1;font-size:13px;color:#333;line-height:1.3;word-wrap:break-word}.scale-labels{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:#666;margin-top:4px;padding:0 4px}.scale-labels .min-label,.scale-labels .max-label{background:#ffffffe6;padding:2px 4px;border-radius:2px;font-weight:500}.map-control.terrain-control{background:var(--control-bg, #FDF9F2);border-radius:6px;box-shadow:0 2px 8px #0f5c6d26;padding:12px;min-width:240px;max-width:260px;bottom:80px;right:20px;flex-direction:column;gap:12px;z-index:1000}.terrain-control-group{display:flex;flex-direction:column;gap:6px}.terrain-control .control-label{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--text-primary, #0F5C6D);margin-bottom:4px}.terrain-control .control-value{color:var(--accent-color, #C73E1D);font-weight:600}.terrain-slider{width:100%;height:4px;border-radius:2px;background:#0f5c6d33;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.terrain-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--primary-color, #0F5C6D);cursor:pointer;transition:all .2s ease}.terrain-slider::-webkit-slider-thumb:hover{background:var(--primary-hover, #0A4455);transform:scale(1.1)}.terrain-slider::-webkit-slider-thumb:active{transform:scale(.95)}.terrain-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--primary-color, #0F5C6D);cursor:pointer;border:none;transition:all .2s ease}.terrain-slider::-moz-range-thumb:hover{background:var(--primary-hover, #0A4455);transform:scale(1.1)}.terrain-slider::-moz-range-thumb:active{transform:scale(.95)}.terrain-preset-buttons{display:flex;gap:3px}.terrain-preset-btn{flex:1;padding:6px 4px;background:#fff;border:1px solid rgba(15,92,109,.2);border-radius:3px;color:var(--text-primary, #0F5C6D);font-family:Arbutus Slab,serif;font-size:10px;font-weight:500;cursor:pointer;transition:all .2s ease;text-align:center}.terrain-preset-btn:hover:not(.active){background:var(--control-hover-bg, #F7F1E5);border-color:var(--primary-color, #0F5C6D);transform:translateY(-1px)}.terrain-preset-btn:active{transform:translateY(0)}.terrain-preset-btn.active{background:var(--primary-color, #0F5C6D);color:var(--control-active-text, #FDF9F2);border-color:var(--primary-color, #0F5C6D);font-weight:600}.terrain-preset-btn:focus{outline:none;box-shadow:0 0 0 2px var(--input-focus-shadow, rgba(15, 92, 109, .3))}.map-control.map-style-control{background:var(--control-bg, #FDF9F2);border-radius:6px;box-shadow:0 2px 8px #0f5c6d26;padding:10px 12px;min-width:240px;max-width:260px;bottom:80px;right:280px;flex-direction:column;gap:8px;z-index:1000}.map-style-control .control-label{font-size:11px;color:var(--text-primary, #0F5C6D);margin-bottom:2px;font-weight:500}.map-style-buttons{display:flex;gap:3px}.map-style-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px 4px;background:#fff;border:1px solid rgba(15,92,109,.2);border-radius:3px;color:var(--text-primary, #0F5C6D);font-family:Arbutus Slab,serif;font-size:9px;font-weight:500;cursor:pointer;transition:all .2s ease;min-height:50px}.map-style-icon{font-size:16px;line-height:1}.map-style-label{font-size:9px;text-align:center;line-height:1.2}.map-style-btn:hover:not(.active):not(:disabled){background:var(--control-hover-bg, #F7F1E5);border-color:var(--primary-color, #0F5C6D);transform:translateY(-1px)}.map-style-btn:active{transform:translateY(0)}.map-style-btn.active{background:var(--accent-color, #C73E1D);color:var(--control-active-text, #FDF9F2);border-color:var(--accent-color, #C73E1D);font-weight:600}.map-style-btn:disabled{opacity:.5;cursor:not-allowed}.map-style-btn:focus{outline:none;box-shadow:0 0 0 2px var(--input-focus-shadow, rgba(15, 92, 109, .3))}.map-style-control.loading{opacity:.7;pointer-events:none}.map-style-loading{font-size:10px;color:var(--text-muted, #666);text-align:center;padding:4px 0}.map-style-control.disabled{opacity:.6;pointer-events:none}.map-control.view3d-control{background:#fff;border-radius:4px;box-shadow:0 2px 5px #0000001a;overflow:hidden;top:70px;left:20px;flex-direction:row;z-index:1000}.view3d-btn-group{display:flex}.view3d-btn{min-width:50px;height:40px;background:#fff;border:none;cursor:pointer;font-size:13px;font-weight:500;color:#333;transition:all .2s ease;padding:0 14px;border-right:1px solid #eee}.view3d-btn:last-child{border-right:none}.view3d-btn:hover:not(.active):not(:disabled){background:#f0f0f0;color:#000}.view3d-btn:active:not(.active):not(:disabled){background:#e0e0e0}.view3d-btn.active{background:#38f;color:#fff;font-weight:600}.view3d-btn:disabled,.view3d-btn.unavailable{opacity:.5;cursor:not-allowed;color:#999}.view3d-btn:disabled:hover{background:#fff;color:#999}@media (max-width: 768px){.map-control.terrain-control,.map-control.map-style-control{min-width:200px;max-width:220px;padding:10px}.terrain-control-group{gap:5px}.terrain-preset-btn,.map-style-btn{font-size:9px;padding:5px 3px}.map-style-icon{font-size:14px}.map-style-label{font-size:8px}.view3d-btn{min-width:45px;padding:0 10px;font-size:12px}}.sidebar-toggle{position:fixed;top:calc(var(--header-h, 51px) + 20px);left:calc(20% + var(--edge-gap, 8px) - 15px);width:30px;height:60px;background:var(--control-bg, #FDF9F2);border:1px solid var(--control-border, #D4C4A0);border-left:none;border-radius:0 8px 8px 0;cursor:pointer;z-index:1001;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:2px 0 8px #1f7a8c1a}.sidebar-toggle:hover{background:var(--surface-alt, #EDE1CF);transform:translate(2px);box-shadow:4px 0 12px #1f7a8c26}.sidebar-toggle:focus{outline:none;box-shadow:0 0 0 2px var(--input-focus-shadow, rgba(31, 122, 140, .25))}.toggle-icon{font-size:18px;font-weight:700;color:var(--text-secondary, #1F7A8C);transition:transform .3s ease;-webkit-user-select:none;user-select:none}.sidebar.collapsed{transform:translate(calc(-100% - var(--edge-gap, 8px)))}body.sidebar-collapsed .sidebar-toggle{left:0!important}body.sidebar-collapsed .sidebar-toggle .toggle-icon{transform:rotate(180deg)}.sidebar{transition:transform .3s ease}#app-main:has(.sidebar.collapsed) #app-container{margin-left:0}#app-main:has(.sidebar.collapsed) .list-view-container{left:0!important}#app-main:has(.sidebar.collapsed) .list-view-container:not(.collapsed){left:var(--edge-gap, 0px)!important}#app-main:has(.sidebar.collapsed) .list-view-toggle-tab{left:calc(var(--edge-gap, 0px) + 15%)!important}#app-main:has(.list-view-container.collapsed):not(:has(.sidebar.collapsed)) .list-view-toggle-tab{left:calc(20% + var(--edge-gap, 0px))!important}#app-main:has(.sidebar.collapsed):has(.list-view-container.collapsed) .list-view-toggle-tab{left:0!important}body.sidebar-collapsed #app-container{margin-left:0}.panel{margin-bottom:15px;border-radius:4px;overflow:hidden;box-shadow:0 1px 4px #0000001a;background:#fff}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:10px 15px;background:#f5f5f5;cursor:pointer;position:relative}.source-list-panel .panel-header,.surname-list-panel .panel-header{position:relative;cursor:default}.source-list-panel .panel-title,.surname-list-panel .panel-title{flex:1;margin-right:10px}.panel-title{font-weight:700;font-size:16px}.panel-toggle,.collapse-button{border:none;background:none;font-size:18px;cursor:pointer;transition:transform .3s ease;padding:4px 8px;border-radius:4px;margin-left:auto}.panel-toggle:hover,.collapse-button:hover{background:#0000001a}.panel-toggle.collapsed{transform:rotate(-90deg)}.panel-content{padding:15px;transition:max-height .3s ease,padding .3s ease;overflow-y:auto;overflow-x:hidden;max-height:1000px}.panel.collapsed .panel-content{max-height:0!important;padding-top:0;padding-bottom:0;opacity:0}.panel{transition:all .3s ease}.panel .panel-content{transition:max-height .3s ease,padding .3s ease,opacity .3s ease}.filter-container{margin-bottom:20px}.filter-container .controls{margin-bottom:10px}.filter-select{width:100%;padding:8px;border:1px solid #ddd;border-radius:4px;font-family:inherit}.filter-form{display:flex;flex-direction:column;gap:15px}.filter-section{border-bottom:1px solid #eee;padding-bottom:15px}.filter-section-title{font-weight:700;margin-bottom:10px}.filter-control{margin-bottom:10px}.filter-actions{display:flex;justify-content:space-between;margin-top:15px}.text-filter-input,.range-filter-input,.date-filter-input{width:100%;padding:8px;border:1px solid #ddd;border-radius:4px}.category-filter-checkbox{margin-right:8px}.checkbox-wrapper{display:flex;align-items:center;margin-bottom:8px}.apply-filters-btn{padding:8px 16px;background:#38f;color:#fff;border:none;border-radius:4px;cursor:pointer}.reset-filters-btn{padding:8px 16px;background:#f0f0f0;border:none;border-radius:4px;cursor:pointer}#searchInput{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;font-family:inherit;margin-bottom:10px}.view-toggle-container{display:flex;align-items:center;margin-top:10px}.view-toggle-container input[type=checkbox]{margin-right:5px}.view-toggle-container label{margin-right:15px;font-size:14px}.time-label-container{margin-bottom:15px}.time-label{font-size:14px;margin-bottom:5px}.timeline-controls{padding:10px 0}#timeline-container{padding:0 10px}#legend-container{margin-top:20px;padding:10px;background:#f9f9f9;border-radius:4px}#legend-title{font-weight:700;margin-bottom:10px}.legend-item{display:flex;align-items:center;margin-bottom:5px}.legend-color{width:16px;height:16px;border-radius:50%;margin-right:8px}.legend-label{font-size:14px}.list-view{height:100%}.list-header{padding:10px 15px;background:#f5f5f5;position:sticky;top:0;z-index:10}.list-info{font-size:14px;color:#666}.list-items{padding:10px}.list-item{padding:10px;border-bottom:1px solid #eee;cursor:pointer;transition:background .2s ease}.list-item:hover{background:#f9f9f9}.list-item.active{background:#e6f0ff}.list-items{padding:10px 0}.list-item{padding:15px;border-bottom:1px solid #eee}.list-item:last-child{border-bottom:none}.list-item h4{margin-bottom:10px}.list-item p{margin-bottom:5px;font-size:14px}.control-group{display:flex;background:#fff;border:1px solid #e0e0e0;border-radius:6px;padding:16px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;box-shadow:0 2px 4px #0000001a;transition:all .2s ease}.control-group:hover{box-shadow:0 4px 8px #00000026}.control-group.orientation-horizontal{flex-direction:column}.control-group.orientation-horizontal .control-group-content{display:flex;flex-direction:row}.control-group.orientation-vertical{flex-direction:column}.control-group.orientation-vertical .control-group-content{display:flex;flex-direction:column}.control-group.spacing-none .control-group-content{gap:0}.control-group.spacing-small .control-group-content{gap:8px}.control-group.spacing-medium .control-group-content{gap:16px}.control-group.spacing-large .control-group-content{gap:24px}.control-group.align-start .control-group-content{align-items:flex-start}.control-group.align-center .control-group-content{align-items:center}.control-group.align-end .control-group-content{align-items:flex-end}.control-group.align-stretch .control-group-content{align-items:stretch}.control-group.wrap .control-group-content{flex-wrap:wrap}.control-group.size-small{padding:12px;font-size:14px}.control-group.size-medium{padding:16px;font-size:16px}.control-group.size-large{padding:20px;font-size:18px}.control-group-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #f0f0f0}.control-group-title{margin:0;font-size:1.1em;font-weight:600;color:#333}.control-group-collapse{background:none;border:1px solid #ddd;padding:4px 8px;border-radius:4px;cursor:pointer;font-size:12px;color:#666;transition:all .2s ease;min-width:24px;text-align:center}.control-group-collapse:hover{background:#f5f5f5;border-color:#ccc}.control-group-collapse:focus{outline:none;box-shadow:0 0 0 2px #007bff40}.control-group.collapsed .control-group-content{display:none}.control-group.collapsed{padding-bottom:8px}.control-group-content{flex:1}.control-item{display:flex;align-items:center;position:relative;transition:opacity .2s ease}.control-item.disabled{opacity:.6;pointer-events:none}.control-label{font-weight:500;color:#555;margin:0 8px 0 0;cursor:pointer;white-space:nowrap}.control-item.size-small .control-label{font-size:12px;margin:0 6px 0 0}.control-item.size-medium .control-label{font-size:14px;margin:0 8px 0 0}.control-item.size-large .control-label{font-size:16px;margin:0 10px 0 0}.control-item .control-label:last-child{margin:0 0 0 8px}.control-item.size-small input,.control-item.size-small select,.control-item.size-small textarea,.control-item.size-small button{padding:4px 8px;font-size:12px}.control-item.size-medium input,.control-item.size-medium select,.control-item.size-medium textarea,.control-item.size-medium button{padding:6px 12px;font-size:14px}.control-item.size-large input,.control-item.size-large select,.control-item.size-large textarea,.control-item.size-large button{padding:8px 16px;font-size:16px}.control-item input,.control-item select,.control-item textarea{border:1px solid #ddd;border-radius:4px;background:#fff;color:#333;transition:border-color .2s ease,box-shadow .2s ease}.control-item input:focus,.control-item select:focus,.control-item textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.control-item input:disabled,.control-item select:disabled,.control-item textarea:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.control-item button{background:#007bff;color:#fff;border:1px solid #007bff;border-radius:4px;cursor:pointer;transition:all .2s ease;font-weight:500}.control-item button:hover{background:#0056b3;border-color:#0056b3}.control-item button:focus{outline:none;box-shadow:0 0 0 2px #007bff40}.control-item button:disabled{background:#6c757d;border-color:#6c757d;cursor:not-allowed}.control-item button.secondary{background:#fff;color:#007bff;border-color:#007bff}.control-item button.secondary:hover{background:#f8f9fa}.control-btn,#help-btn,#settings-btn{background:#fff!important;border:1px solid #ddd!important;border-radius:6px;padding:8px 12px!important;font-size:14px!important;font-weight:500;color:#333!important;cursor:pointer;transition:all .2s ease;display:inline-flex!important;align-items:center;justify-content:center;min-width:36px!important;height:36px!important}.control-btn:hover{background:#f5f5f5;border-color:#bbb;color:#000}.control-btn:active{background:#e5e5e5;transform:translateY(1px)}.control-item input[type=checkbox],.control-item input[type=radio]{margin:0 8px 0 0;transform:scale(1.1)}.control-group.disabled{opacity:.6;pointer-events:none;background:#f8f9fa}.control-item.error input,.control-item.error select,.control-item.error textarea{border-color:#dc3545;box-shadow:0 0 0 2px #dc354540}.control-item.warning input,.control-item.warning select,.control-item.warning textarea{border-color:#ffc107;box-shadow:0 0 0 2px #ffc10740}.control-item.success input,.control-item.success select,.control-item.success textarea{border-color:#28a745;box-shadow:0 0 0 2px #28a74540}.search-input,.text-search-input{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;background:#fff;color:#333;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.search-input:focus,.text-search-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.search-input::placeholder,.text-search-input::placeholder{color:#999}.search-btn{background:#007bff;color:#fff;border:1px solid #007bff;border-radius:4px;padding:8px 16px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;margin-left:8px}.search-btn:hover{background:#0056b3;border-color:#0056b3}.search-btn:focus{outline:none;box-shadow:0 0 0 2px #007bff40}.search-input-container{display:flex;align-items:center;gap:8px;width:100%}.search-filter{padding:6px 12px;border:1px solid #ddd;border-radius:4px;font-size:13px;background:#fff;color:#333;cursor:pointer;transition:all .2s ease}.search-filter:hover{background:#f5f5f5;border-color:#bbb}.search-filter.active{background:#007bff;color:#fff;border-color:#007bff}.form-group{display:flex;flex-direction:column;margin-bottom:20px;padding:16px;border:1px solid #e0e0e0;border-radius:6px;background:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.form-group>label{font-weight:600;color:#333;margin-bottom:12px;font-size:14px}.checkbox-group{display:flex;align-items:center;margin-bottom:12px;gap:8px}.checkbox-group:last-child{margin-bottom:0}.checkbox-group input[type=checkbox]{margin:0;transform:scale(1.1);cursor:pointer}.checkbox-group label{margin:0;font-weight:500;color:#555;cursor:pointer;font-size:14px}.checkbox-group input[type=checkbox]:focus{outline:none;box-shadow:0 0 0 2px #007bff40}.filter-controls{display:flex;flex-direction:column;background:#fff;border:1px solid #e0e0e0;border-radius:6px;padding:16px;gap:16px}.filter-group{display:flex;flex-direction:column;border:1px solid #f0f0f0;border-radius:4px;padding:12px;background:#fafafa}.filter-group-title{font-weight:600;color:#333;margin:0 0 12px;font-size:14px;padding-bottom:8px;border-bottom:1px solid #e0e0e0}.dropdown-filter{display:flex;flex-direction:column;margin-bottom:16px}.dropdown-filter label{font-weight:500;color:#555;margin-bottom:6px;font-size:14px}.dropdown-filter select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;background:#fff;color:#333;font-size:14px;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease}.dropdown-filter select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.dropdown-filter select:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.range-filter{display:flex;flex-direction:column;margin-bottom:16px}.range-filter label{font-weight:500;color:#555;margin-bottom:8px;font-size:14px;display:flex;justify-content:space-between;align-items:center}.range-slider{height:6px;background:#e0e0e0;border-radius:3px;position:relative;cursor:pointer;transition:background-color .2s ease}.range-slider:hover{background:#d0d0d0}.range-slider:focus{outline:none;box-shadow:0 0 0 2px #007bff40}.range-value{font-weight:600;color:#007bff;font-size:13px;background:#f8f9fa;padding:2px 8px;border-radius:3px;border:1px solid #e0e0e0}.date-range-control{display:flex;flex-direction:column;gap:12px;padding:12px;border:1px solid #e0e0e0;border-radius:4px;background:#fff;margin-bottom:16px}.date-range-control label{font-weight:500;color:#555;font-size:14px;margin-bottom:4px}.date-range-control input[type=number],.date-range-control input[type=date]{padding:8px 12px;border:1px solid #ddd;border-radius:4px;background:#fff;color:#333;font-size:14px;transition:border-color .2s ease,box-shadow .2s ease}.date-range-control input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.date-range-control input:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.period-range-control{display:flex;flex-direction:column;gap:12px;padding:12px;border:1px solid #e0e0e0;border-radius:4px;background:#fff;margin-bottom:16px}.period-range-control label{font-weight:500;color:#555;font-size:14px;margin-bottom:4px}.period-range-control select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;background:#fff;color:#333;font-size:14px;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease}.period-range-control select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.filter-panel-container{display:flex;flex-direction:column;background:#fff;border:1px solid #e0e0e0;border-radius:6px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.filter-panel-container .panel-header{background:#f8f9fa;border-bottom:1px solid #e0e0e0;padding:12px 16px;font-weight:600;color:#333}.filter-panel-container .panel-body{padding:16px;flex:1}.selected{background:#e3f2fd!important;border-color:#007bff!important;color:#007bff}.selected:hover{background:#bbdefb!important}.toggle-filter{display:flex;align-items:center;gap:12px;padding:12px 16px;border:1px solid #e0e0e0;border-radius:4px;background:#fff;cursor:pointer;transition:background-color .2s ease,border-color .2s ease}.toggle-filter:hover{background:#f8f9fa;border-color:#ccc}.toggle-filter.active{background:#e3f2fd;border-color:#007bff;color:#007bff}.toggle-filter input[type=checkbox]{margin:0;transform:scale(1.2);cursor:pointer}.toggle-filter label{font-weight:500;color:#555;cursor:pointer;margin:0;flex:1;font-size:14px}.toggle-filter.active label{color:#007bff;font-weight:600}.preferences-form{display:flex;flex-direction:column;background:#fff;border:1px solid #e0e0e0;border-radius:6px;padding:20px;max-width:500px;gap:20px}.preferences-form h3{margin:0 0 16px;color:#333;font-size:16px;font-weight:600;padding-bottom:8px;border-bottom:1px solid #e0e0e0}.preferences-form .form-section{display:flex;flex-direction:column;gap:12px}.preferences-form .form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:8px;padding-top:16px;border-top:1px solid #e0e0e0}.preferences-form .form-actions button{padding:8px 16px;border:1px solid #ddd;border-radius:4px;background:#fff;color:#333;font-size:14px;cursor:pointer;transition:all .2s ease;font-weight:500}.preferences-form .form-actions button:hover{background:#f8f9fa;border-color:#ccc}.preferences-form .form-actions button.primary{background:#007bff;color:#fff;border-color:#007bff}.preferences-form .form-actions button.primary:hover{background:#0056b3;border-color:#0056b3}.prompt-dialog{display:flex;flex-direction:column;padding:20px;background:#fff;border-radius:6px;min-width:300px;gap:16px}.prompt-dialog p{margin:0;color:#555;line-height:1.5;font-size:14px}.prompt-input{padding:10px 12px;border:1px solid #ddd;border-radius:4px;background:#fff;color:#333;font-size:14px;transition:border-color .2s ease,box-shadow .2s ease;width:100%;box-sizing:border-box}.prompt-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.prompt-input::placeholder{color:#999}@media (prefers-color-scheme: dark){.control-group{background:#2d2d2d;border-color:#404040;color:#e0e0e0}.control-group:hover{box-shadow:0 4px 8px #0000004d}.control-group-header{border-bottom-color:#404040}.control-group-title{color:#e0e0e0}.control-group-collapse{background:#404040;border-color:#555;color:#e0e0e0}.control-group-collapse:hover{background:#505050;border-color:#666}.control-label{color:#b0b0b0}.control-item input,.control-item select,.control-item textarea{background:#404040;border-color:#555;color:#e0e0e0}.control-item input:focus,.control-item select:focus,.control-item textarea:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.control-item input:disabled,.control-item select:disabled,.control-item textarea:disabled{background:#2d2d2d;color:#666}.control-item button.secondary{background:#404040;color:#007bff;border-color:#007bff}.control-item button.secondary:hover{background:#505050}.control-group.disabled{background:#1a1a1a}.form-group{background:#2d2d2d;border-color:#404040;color:#e0e0e0}.form-group>label{color:#e0e0e0}.checkbox-group label{color:#b0b0b0}.filter-controls{background:#2d2d2d;border-color:#404040}.filter-group{background:#1a1a1a;border-color:#404040}.filter-group-title{color:#e0e0e0;border-bottom-color:#404040}.dropdown-filter label{color:#b0b0b0}.dropdown-filter select{background:#404040;border-color:#555;color:#e0e0e0}.dropdown-filter select:focus{border-color:#007bff}.dropdown-filter select:disabled{background:#2d2d2d;color:#666}.range-filter label{color:#b0b0b0}.range-slider{background:#404040}.range-slider:hover{background:#505050}.range-value{background:#404040;border-color:#555;color:#007bff}.date-range-control{background:#2d2d2d;border-color:#404040}.date-range-control label{color:#b0b0b0}.date-range-control input{background:#404040;border-color:#555;color:#e0e0e0}.date-range-control input:focus{border-color:#007bff}.date-range-control input:disabled{background:#2d2d2d;color:#666}.period-range-control{background:#2d2d2d;border-color:#404040}.period-range-control label{color:#b0b0b0}.period-range-control select{background:#404040;border-color:#555;color:#e0e0e0}.period-range-control select:focus{border-color:#007bff}.filter-panel-container{background:#2d2d2d;border-color:#404040}.filter-panel-container .panel-header{background:#1a1a1a;border-bottom-color:#404040;color:#e0e0e0}.selected{background:#1a237e!important;border-color:#007bff!important;color:#90caf9}.selected:hover{background:#283593!important}.toggle-filter{background:#2d2d2d;border-color:#404040;color:#e0e0e0}.toggle-filter:hover{background:#404040;border-color:#555}.toggle-filter.active{background:#1a237e;border-color:#007bff;color:#90caf9}.toggle-filter label{color:#b0b0b0}.toggle-filter.active label{color:#90caf9}.preferences-form{background:#2d2d2d;border-color:#404040}.preferences-form h3{color:#e0e0e0;border-bottom-color:#404040}.preferences-form .form-actions{border-top-color:#404040}.preferences-form .form-actions button{background:#404040;border-color:#555;color:#e0e0e0}.preferences-form .form-actions button:hover{background:#505050;border-color:#666}.preferences-form .form-actions button.primary{background:#007bff;border-color:#007bff;color:#fff}.preferences-form .form-actions button.primary:hover{background:#0056b3;border-color:#0056b3}.prompt-dialog{background:#2d2d2d}.prompt-dialog p{color:#b0b0b0}.prompt-input{background:#404040;border-color:#555;color:#e0e0e0}.prompt-input:focus{border-color:#007bff}.prompt-input::placeholder{color:#777}}.item-list{display:flex;flex-direction:column;gap:8px}.item-title{font-size:16px;font-weight:600;color:#333;margin:0 0 4px;line-height:1.3}.item-subtitle{font-size:14px;color:#666;margin:0 0 8px;line-height:1.4}.item-content{display:flex;flex-direction:column;flex:1;gap:4px}.item-actions{display:flex;gap:8px;margin-top:8px;align-items:center}.detail-item{display:flex;flex-direction:column;margin-bottom:12px;padding:8px 0;border-bottom:1px solid #f0f0f0}.detail-item:last-child{border-bottom:none;margin-bottom:0}.detail-label{font-size:12px;font-weight:600;color:#777;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.detail-value{font-size:14px;color:#333;line-height:1.4}.source-detail{display:flex;flex-direction:column;background:#fff;border:1px solid #e0e0e0;border-radius:6px;padding:20px;gap:16px;max-width:600px}.source-details{display:flex;flex-direction:column;gap:12px}.source-title{font-size:18px;font-weight:700;color:#333;margin:0 0 8px;line-height:1.3}.source-description{color:#555;line-height:1.6;margin:8px 0}.source-description h3{font-size:14px;font-weight:600;color:#333;margin:0 0 8px}.source-description p{margin:0}.source-metadata{display:flex;flex-direction:column;gap:8px;padding:12px;background:#f8f9fa;border-radius:4px;border:1px solid #e9ecef}.source-author-year,.source-year-published,.source-year-subject{font-size:13px;color:#666;padding:4px 8px;background:#f8f9fa;border-radius:3px;border:1px solid #e9ecef;margin:2px 0}.source-language,.source-publisher,.source-place,.source-pages,.source-volume,.source-issue{font-size:13px;color:#555;margin:4px 0}.source-location{padding:8px 12px;background:#e3f2fd;border-radius:4px;border:1px solid #bbdefb;margin:8px 0}.source-location-text{font-size:13px;color:#1976d2}.source-citation{font-family:Georgia,serif;font-style:italic;color:#555;padding:12px;background:#f8f9fa;border-left:4px solid #007bff;margin:12px 0;border-radius:0 4px 4px 0}.source-category-location,.source-category-palestine,.source-category-region,.source-category-secondary,.source-category-bilad,.source-category-kinship,.source-category-panel{display:inline-block;padding:4px 8px;margin:2px 4px 2px 0;border-radius:3px;font-size:12px;font-weight:500}.source-category-location{background:#e8f5e8;color:#2e7d32;border:1px solid #c8e6c9}.source-category-palestine{background:#fff3e0;color:#f57c00;border:1px solid #ffcc02}.source-category-region{background:#f3e5f5;color:#7b1fa2;border:1px solid #ce93d8}.source-category-secondary{background:#e1f5fe;color:#0277bd;border:1px solid #81d4fa}.source-category-bilad{background:#fce4ec;color:#c2185b;border:1px solid #f8bbd9}.source-category-kinship{background:#e0f2f1;color:#00695c;border:1px solid #80cbc4}.surname-detail{display:flex;flex-direction:column;background:#fff;border:1px solid #e0e0e0;border-radius:6px;padding:20px;gap:16px;max-width:600px}.surname-alternate-names{font-size:14px;color:#666;font-style:italic;margin:4px 0}.surname-attribution,.surname-category,.surname-ethnicity,.surname-sect,.surname-period,.surname-region{font-size:13px;padding:4px 8px;margin:2px 0;border-radius:3px;border:1px solid #e9ecef;background:#f8f9fa}.surname-coordinates,.surname-locations{padding:8px 12px;background:#e8f5e8;border-radius:4px;border:1px solid #c8e6c9;color:#2e7d32;font-size:13px;margin:4px 0}.surname-journey-steps{display:flex;flex-direction:column;gap:8px;margin:12px 0}.surname-note{padding:12px;background:#fff8e1;border-radius:4px;border:1px solid #ffecb3;color:#f57c00;font-size:13px;line-height:1.4;margin:8px 0}.surname-references{display:flex;flex-direction:column;gap:4px;margin:12px 0;padding:12px;background:#f8f9fa;border-radius:4px;border:1px solid #e9ecef}@media (prefers-color-scheme: dark){.item-title{color:#e0e0e0}.item-subtitle{color:#b0b0b0}.detail-item{border-bottom-color:#404040}.detail-label{color:#888}.detail-value{color:#e0e0e0}.source-detail,.surname-detail{background:#2d2d2d;border-color:#404040}.source-title{color:#e0e0e0}.source-description{color:#b0b0b0}.source-description h3{color:#e0e0e0}.source-metadata,.source-author-year,.source-year-published,.source-year-subject,.surname-attribution,.surname-category,.surname-ethnicity,.surname-sect,.surname-period,.surname-region,.surname-references{background:#404040;border-color:#555;color:#e0e0e0}.source-language,.source-publisher,.source-place,.source-pages,.source-volume,.source-issue{color:#b0b0b0}.source-location{background:#1a237e;border-color:#3949ab}.source-location-text{color:#90caf9}.source-citation{background:#404040;color:#b0b0b0;border-left-color:#007bff}.surname-coordinates,.surname-locations{background:#1b5e20;border-color:#388e3c;color:#a5d6a7}.surname-note{background:#3e2723;border-color:#5d4037;color:#ffb74d}}.pagination{display:flex;justify-content:center;align-items:center;gap:4px;margin:20px 0;padding:16px}.pagination-prev,.pagination-next{display:flex;align-items:center;padding:8px 12px;background:#fff;border:1px solid #ddd;border-radius:4px;color:#555;text-decoration:none;font-size:14px;font-weight:500;transition:all .2s ease;cursor:pointer;min-width:80px;justify-content:center}.pagination-prev:hover,.pagination-next:hover{background:#f8f9fa;border-color:#007bff;color:#007bff}.pagination-prev:disabled,.pagination-next:disabled{background:#f5f5f5;color:#999;border-color:#e0e0e0;cursor:not-allowed}.pagination-page{display:flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:8px;background:#fff;border:1px solid #ddd;border-radius:4px;color:#555;text-decoration:none;font-size:14px;font-weight:500;transition:all .2s ease;cursor:pointer}.pagination-page:hover{background:#f8f9fa;border-color:#007bff;color:#007bff}.pagination-page.active{background:#007bff;color:#fff;border-color:#007bff}.pagination-page.active:hover{background:#0056b3;border-color:#0056b3}.tabs-container{display:flex;flex-direction:column;background:#fff;border:1px solid #e0e0e0;border-radius:6px;overflow:hidden}.tabs-header{display:flex;background:#f8f9fa;border-bottom:1px solid #e0e0e0}.tabs-list{display:flex;margin:0;padding:0;list-style:none}.tab-item{position:relative}.tab-link{display:block;padding:12px 20px;color:#666;text-decoration:none;font-weight:500;font-size:14px;transition:all .2s ease;cursor:pointer;background:none;border:none;border-bottom:2px solid transparent}.tab-link:hover{color:#007bff;background:#f0f8ff}.tab-link.active{color:#007bff;background:#fff;border-bottom-color:#007bff}.tabs-content{padding:20px;background:#fff}.tab-content{display:none}.tab-content.active{display:block}.timeline-container{display:flex;flex-direction:column;background:#fff;border:1px solid #e0e0e0;border-radius:6px;padding:16px;margin:16px 0}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #e0e0e0}.timeline-title{font-size:16px;font-weight:600;color:#333;margin:0}.timeline-range{display:flex;align-items:center;gap:12px;margin:16px 0}.timeline-slider{flex:1;height:8px;background:#e0e0e0;border-radius:4px;position:relative;cursor:pointer;transition:background-color .2s ease}.timeline-slider:hover{background:#d0d0d0}.timeline-slider:before{content:"";position:absolute;top:50%;left:0;transform:translateY(-50%);height:12px;width:12px;background:#007bff;border-radius:50%;border:2px solid white;box-shadow:0 2px 4px #0003;cursor:grab;transition:all .2s ease}.timeline-slider:active:before{cursor:grabbing;transform:translateY(-50%) scale(1.1)}.list-container{display:flex;flex-direction:column;background:#fff;border:1px solid #e0e0e0;border-radius:6px;overflow:hidden}.list-title{padding:16px 20px;background:#f8f9fa;border-bottom:1px solid #e0e0e0;font-size:16px;font-weight:600;color:#333;margin:0}.list-content{flex:1;padding:0;max-height:400px;overflow-y:auto}.list-controls{display:flex;justify-content:space-between;align-items:center;padding:12px 20px;background:#f8f9fa;border-bottom:1px solid #e0e0e0;gap:12px}.list-footer{padding:12px 20px;background:#f8f9fa;border-top:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center;font-size:14px;color:#666}.sidebar{display:flex;flex-direction:column;background:#fff;border:1px solid #e0e0e0;border-radius:6px;width:300px;max-height:calc(100vh - 100px);overflow:hidden}#left-sidebar.sidebar{max-height:none}.sidebar-active{border-color:#007bff;box-shadow:0 4px 12px #007bff26}.sidebar-section{display:flex;flex-direction:column;border-bottom:1px solid #e0e0e0;padding:16px}.sidebar-section:last-child{border-bottom:none}.sidebar-section h3{margin:0 0 12px;font-size:14px;font-weight:600;color:#333;text-transform:uppercase;letter-spacing:.5px}.no-results{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;color:#666;background:#f8f9fa;border-radius:6px;border:1px dashed #ddd}.no-results:before{content:"🔍";font-size:48px;margin-bottom:12px;opacity:.5}@media (prefers-color-scheme: dark){.pagination-prev,.pagination-next,.pagination-page{background:#404040;border-color:#555;color:#e0e0e0}.pagination-prev:hover,.pagination-next:hover,.pagination-page:hover{background:#505050;border-color:#007bff;color:#90caf9}.pagination-page.active{background:#007bff;color:#fff}.tabs-container,.timeline-container,.list-container,.sidebar{background:#2d2d2d;border-color:#404040}.tabs-header,.list-title,.list-controls,.list-footer{background:#1a1a1a;border-color:#404040;color:#e0e0e0}.tab-link{color:#b0b0b0}.tab-link:hover{color:#90caf9;background:#1a237e}.tab-link.active{color:#90caf9;background:#2d2d2d;border-bottom-color:#007bff}.tabs-content{background:#2d2d2d}.timeline-title{color:#e0e0e0}.timeline-slider{background:#404040}.timeline-slider:hover{background:#505050}.sidebar-section h3{color:#e0e0e0}.no-results{background:#1a1a1a;border-color:#404040;color:#b0b0b0}}.btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 16px;border:1px solid var(--btn-secondary-border);border-radius:4px;background:var(--btn-secondary-bg);color:var(--btn-secondary-text);font-size:14px;font-weight:500;font-family:inherit;line-height:1.5;text-decoration:none;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none;outline:none}.btn:hover{background:var(--btn-secondary-hover-bg);border-color:var(--border-medium);transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.btn:active{transform:translateY(0);box-shadow:0 1px 2px #0000001a}.btn:focus{box-shadow:0 0 0 2px var(--input-focus-shadow)}.btn:disabled{opacity:var(--opacity-disabled);cursor:not-allowed;transform:none;box-shadow:none}.btn-success{background:var(--btn-success-bg);color:var(--btn-success-text);border-color:var(--btn-success-border)}.btn-success:hover{background:var(--btn-success-hover-bg);border-color:var(--btn-success-hover-bg)}.btn-success:focus{box-shadow:0 0 0 2px #10b98140}.show-journey,.show-migration-path{background:var(--btn-success-bg);color:var(--btn-success-text);border:none;border-radius:4px;padding:8px 16px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:6px;margin:10px 0;min-width:140px}.show-journey:hover,.show-migration-path:hover{background:var(--btn-success-hover-bg);transform:translateY(-1px);box-shadow:0 2px 6px #10b9814d}.show-journey:active,.show-migration-path:active{transform:translateY(0);box-shadow:0 1px 3px #10b98133}.show-journey:focus,.show-migration-path:focus{outline:none;box-shadow:0 0 0 2px #10b98140}.show-journey:before{content:"🗺️";font-size:16px}.show-migration-path:before{content:"📍";font-size:16px}.alert-dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border:1px solid #ddd;border-radius:8px;padding:24px;box-shadow:0 4px 12px #00000026;min-width:320px;max-width:500px;z-index:10000;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.confirm-dialog{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border:1px solid #ddd;border-radius:8px;padding:24px;box-shadow:0 4px 12px #00000026;min-width:350px;max-width:500px;z-index:10000;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.error-content{display:flex;flex-direction:column;align-items:center;padding:32px 24px;text-align:center;background:#fff5f5;border:1px solid #fed7d7;border-radius:8px;color:#c53030}.error-icon{width:48px;height:48px;color:#e53e3e;margin-bottom:16px;flex-shrink:0}.loading-content{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;text-align:center;color:#666;background:#fff;border-radius:8px}.logo{display:flex;align-items:center;font-size:18px;font-weight:600;color:#333;text-decoration:none;transition:opacity .2s ease}.logo:hover{opacity:.8}.map-controls{position:absolute;top:16px;right:16px;display:flex;flex-direction:column;gap:8px;z-index:650;pointer-events:none}.map-controls.top-center{top:16px;left:58%;right:auto;transform:translate(-50%)}.map-controls.top-left{top:70px;left:30%;right:auto;transform:translate(-50%)}.map-controls.top-left-lower{top:130px;left:30%;right:auto;transform:translate(-50%)}.map-controls.bottom-center{top:auto;bottom:50px;left:50%;right:auto;transform:translate(-50%)}.map-controls>*{pointer-events:auto}.map-toolbar{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #ddd;border-radius:6px;padding:8px 12px;box-shadow:0 2px 4px #0000001a}.layer-hidden-banner{position:absolute;top:0;left:0;right:0;background:#fff3cd;border:1px solid #ffeaa7;color:#856404;padding:8px 16px;text-align:center;font-size:14px;font-weight:500;z-index:1500}.journey-step{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fff;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;transition:all .2s ease;position:relative}.journey-step:hover{background:#f8f9fa;border-color:#007bff}.journey-step.active{background:#e3f2fd;border-color:#1976d2;color:#1976d2}.journey-step-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#333;color:#fff;padding:8px 12px;border-radius:4px;font-size:12px;white-space:nowrap;margin-bottom:8px;opacity:0;visibility:hidden;transition:all .2s ease;z-index:1001}.journey-step-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:#333}.journey-step:hover .journey-step-tooltip{opacity:1;visibility:visible}.toggle-input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:14px;color:#333}.toggle-slider{position:relative;display:inline-block;width:44px;height:24px;background:#ccc;border-radius:24px;transition:background .2s ease}.toggle-slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform .2s ease;box-shadow:0 2px 4px #0003}.toggle-input:checked+.toggle-label .toggle-slider{background:#007bff}.toggle-input:checked+.toggle-label .toggle-slider:before{transform:translate(20px)}.toggle-text{font-size:14px;color:#333;font-weight:500}.legend-container{display:flex;flex-direction:column;background:#fff;border:1px solid #e0e0e0;border-radius:6px;padding:16px;gap:12px;min-width:200px}.legend-title{font-size:16px;font-weight:600;color:#333;margin-bottom:8px;border-bottom:1px solid #eee;padding-bottom:8px}.legend-marker{display:flex;align-items:center;gap:8px;font-size:14px;color:#555;padding:4px 0}.legend-marker:before{content:"";width:16px;height:16px;border-radius:50%;background:currentColor;flex-shrink:0}.popup-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e0e0e0;background:#f8f9fa;font-size:16px;font-weight:600;color:#333}.popup-body{padding:20px;max-height:400px;overflow-y:auto}.popup-content{display:flex;flex-direction:column;gap:12px;font-size:14px;line-height:1.5;color:#555}.popup-details-btn{background:#007bff;color:#fff;border:none;border-radius:4px;padding:8px 16px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease;margin-top:12px;align-self:flex-start}.popup-details-btn:hover{background:#0056b3}.details-title{font-size:18px;font-weight:600;color:#333;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid #007bff}.section-title{font-size:16px;font-weight:600;color:#333;margin-bottom:12px;margin-top:20px}.section-title:first-child{margin-top:0}.panel-controls{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;background:#f8f9fa;border-bottom:1px solid #e0e0e0}.panel-footer{display:flex;align-items:center;justify-content:center;padding:16px;background:#f8f9fa;border-top:1px solid #e0e0e0;gap:12px}.sort-controls{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #ddd;border-radius:6px;padding:8px 12px}.sort-direction{background:none;border:none;cursor:pointer;padding:4px;color:#666;transition:color .2s ease}.sort-direction:hover{color:#007bff}.sort-direction.asc:after{content:"↑"}.sort-direction.desc:after{content:"↓"}.alternate-names{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.related-name{display:inline-block;background:#e8f4fd;color:#1976d2;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;text-decoration:none;transition:all .2s ease}.related-name:hover{background:#1976d2;color:#fff}.location-detail{display:flex;flex-direction:column;gap:8px;padding:12px;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:6px;font-size:14px}.source-place-type{background:#fff3e0;color:#ef6c00;border:1px solid #ffcc02;display:inline-block;padding:4px 8px;margin:2px 4px 2px 0;border-radius:3px;font-size:12px;font-weight:500}.source-region{background:#f3e5f5;color:#7b1fa2;border:1px solid #ce93d8;display:inline-block;padding:4px 8px;margin:2px 4px 2px 0;border-radius:3px;font-size:12px;font-weight:500}.effectivelyEnabled{opacity:1;pointer-events:auto;transition:opacity .2s ease}.resizing{cursor:nw-resize;-webkit-user-select:none;user-select:none}.resizing *{pointer-events:none;-webkit-user-select:none;user-select:none}@media (prefers-color-scheme: dark){.alert-dialog,.confirm-dialog{background:#2d2d2d;border-color:#444;color:#e0e0e0;box-shadow:0 4px 12px #0000004d}.error-content{background:#3d1a1a;border-color:#8b2635;color:#ff6b6b}.loading-content{background:#2d2d2d;color:#b0b0b0}.logo{color:#e0e0e0}.map-toolbar{background:#2d2d2d;border-color:#444;color:#e0e0e0}.layer-hidden-banner{background:#3d3424;border-color:#8b7635;color:#f5dc69}.journey-step{background:#2d2d2d;border-color:#444;color:#e0e0e0}.journey-step:hover{background:#3a3a3a;border-color:#1a73e8}.journey-step.active{background:#1e3a5f;border-color:#4fc3f7;color:#4fc3f7}.toggle-label,.toggle-text{color:#e0e0e0}.legend-container{background:#2d2d2d;border-color:#444;color:#e0e0e0}.legend-title{color:#e0e0e0;border-color:#444}.legend-marker{color:#b0b0b0}.popup-header{background:#2d2d2d;border-color:#444;color:#e0e0e0}.popup-body{background:#2d2d2d;color:#e0e0e0}.popup-content{color:#b0b0b0}.details-title,.section-title{color:#e0e0e0}.panel-controls,.panel-footer{background:#2d2d2d;border-color:#444}.sort-controls{background:#2d2d2d;border-color:#444;color:#e0e0e0}.sort-direction{color:#b0b0b0}.sort-direction:hover{color:#4fc3f7}.related-name{background:#1e3a5f;color:#4fc3f7}.related-name:hover{background:#4fc3f7;color:#1e3a5f}.location-detail{background:#2d2d2d;border-color:#444;color:#e0e0e0}.source-place-type{background:#3d2f1a;color:#ffcc02;border-color:#8b6914}.source-region{background:#3d1a3d;color:#ce93d8;border-color:#7b1fa2}}.notification-container{position:fixed;z-index:9000;display:grid;gap:.5rem;max-width:min(420px,92vw)}.notification-container.top-right{top:.75rem;right:.75rem}.notification-container.bottom-center{bottom:.75rem;left:50%;transform:translate(-50%)}.notification{position:relative;pointer-events:auto;background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:16px;box-shadow:0 4px 12px #0000001a;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.4;max-width:100%;word-wrap:break-word;transform:translate(100%);opacity:0;transition:all .3s ease}.notification.visible{transform:translate(0);opacity:1}.notification.closing{transform:translate(100%);opacity:0}.notification.info{border-left:4px solid #2196F3;background:#e3f2fd}.notification.success{border-left:4px solid #4CAF50;background:#e8f5e8}.notification.warning{border-left:4px solid #FF9800;background:#fff3e0}.notification.error{border-left:4px solid #F44336;background:#ffebee}.notification-content{display:flex;flex-direction:column;gap:8px}.notification-icon{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;font-size:16px;margin-right:8px;flex-shrink:0}.notification-title{font-weight:600;color:#333;font-size:15px;margin:0}.notification-message{color:#666;margin:0;flex-grow:1}.notification-actions{display:flex;gap:8px;margin-top:8px;justify-content:flex-end}.notification-action{padding:6px 12px;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;transition:all .2s ease}.notification-action.primary{background:#2196f3;color:#fff}.notification-action.primary:hover{background:#1976d2}.notification-action.secondary{background:#f5f5f5;color:#666}.notification-action.secondary:hover{background:#e0e0e0}.notification-action.danger{background:#f44336;color:#fff}.notification-action.danger:hover{background:#d32f2f}.notification-close{position:absolute;top:8px;right:8px;background:none;border:none;font-size:20px;color:#999;cursor:pointer;padding:4px;line-height:1;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.notification-close:hover{background:#0000001a;color:#666}.notification-container.top-left .notification,.notification-container.bottom-left .notification{transform:translate(-100%)}.notification-container.top-left .notification.visible,.notification-container.bottom-left .notification.visible{transform:translate(0)}.notification-container.top-left .notification.closing,.notification-container.bottom-left .notification.closing{transform:translate(-100%)}.notification-container.top-center .notification,.notification-container.bottom-center .notification{transform:translateY(-100%)}.notification-container.top-center .notification.visible,.notification-container.bottom-center .notification.visible{transform:translateY(0)}.notification-container.top-center .notification.closing,.notification-container.bottom-center .notification.closing{transform:translateY(-100%)}.notification-container.bottom-center .notification,.notification-container.bottom-center .notification.closing{transform:translateY(100%)}.modal{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1000;display:none;opacity:0;transition:opacity .3s ease}.modal.visible{display:block;opacity:1}.modal-backdrop{position:absolute;top:0;left:0;width:100%;height:100%;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-content{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:8px;box-shadow:0 10px 30px #0000004d;max-width:90vw;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;opacity:0;transform:translate(-50%,-50%) scale(.9);transition:all .3s ease}.modal-content.visible{opacity:1;transform:translate(-50%,-50%) scale(1)}.modal-content.size-small{width:400px;min-height:200px}.modal-content.size-medium{width:600px;min-height:300px}.modal-content.size-large{width:800px;min-height:400px}.modal-content.size-fullscreen{width:95vw;height:95vh;max-width:none;max-height:none}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e0e0e0;flex-shrink:0}.modal-title{margin:0;font-size:18px;font-weight:600;color:#333}.modal-close{background:none;border:none;font-size:24px;color:#666;cursor:pointer;padding:4px;line-height:1;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.modal-close:hover{background:#f5f5f5;color:#333}.modal-body{flex:1;padding:24px;overflow-y:auto;color:#666;line-height:1.6}.modal-body p{margin:0 0 16px}.modal-body p:last-child{margin-bottom:0}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid #e0e0e0;flex-shrink:0}.modal-footer:empty{display:none}.modal-button{padding:10px 20px;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;background:#fff;color:#333;min-width:80px}.modal-button:hover{background:#f8f9fa;border-color:#ccc}.modal-button.primary{background:#007bff;color:#fff;border-color:#007bff}.modal-button.primary:hover{background:#0056b3;border-color:#0056b3}.modal-button.secondary{background:#6c757d;color:#fff;border-color:#6c757d}.modal-button.secondary:hover{background:#545b62;border-color:#545b62}.modal-button.danger{background:#dc3545;color:#fff;border-color:#dc3545}.modal-button.danger:hover{background:#c82333;border-color:#c82333}.modal.loading .modal-content{position:relative}.modal-loading{position:absolute;top:0;left:0;width:100%;height:100%;background:#ffffffe6;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10}.modal-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}.modal-loading-text{margin-top:12px;color:#666;font-size:14px}.modal-content.draggable .modal-header{cursor:move}.modal.dragging .modal-content{transition:none}.modal-content.resizable{position:relative}.modal-resize-handle{position:absolute;background:transparent;z-index:10}.modal-resize-handle.modal-resize-n{top:0;left:0;width:100%;height:8px;cursor:n-resize}.modal-resize-handle.modal-resize-s{bottom:0;left:0;width:100%;height:8px;cursor:s-resize}.modal-resize-handle.modal-resize-e{top:0;right:0;width:8px;height:100%;cursor:e-resize}.modal-resize-handle.modal-resize-w{top:0;left:0;width:8px;height:100%;cursor:w-resize}.modal-resize-handle.modal-resize-ne{top:0;right:0;width:8px;height:8px;cursor:ne-resize}.modal-resize-handle.modal-resize-nw{top:0;left:0;width:8px;height:8px;cursor:nw-resize}.modal-resize-handle.modal-resize-se{bottom:0;right:0;width:8px;height:8px;cursor:se-resize}.modal-resize-handle.modal-resize-sw{bottom:0;left:0;width:8px;height:8px;cursor:sw-resize}.confirm-modal .modal-body,.alert-modal .modal-body{padding:24px;text-align:center}.prompt-modal .modal-body{padding:24px}.prompt-modal input{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;margin-top:12px}.prompt-modal input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.modal-container{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1000;pointer-events:none}.modal-container.active{pointer-events:auto}.modal-btn{background:#007bff;color:#fff;border:1px solid #007bff;border-radius:4px;padding:8px 16px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;margin:0 4px}.modal-btn:hover{background:#0056b3;border-color:#0056b3}.modal-btn:focus{outline:none;box-shadow:0 0 0 2px #007bff40}.modal-btn.secondary{background:#6c757d;border-color:#6c757d}.modal-btn.secondary:hover{background:#545b62;border-color:#545b62}.timeline-wrapper{display:flex;flex-direction:column;height:100%;gap:8px}.timeline-header{display:flex;flex-direction:column;gap:8px;padding:8px;background:rgba(var(--color-surface-rgb),.1);border-radius:6px;border:1px solid rgba(var(--color-border-rgb),.3)}.timeline-mode-controls{display:flex;align-items:center;gap:8px}.timeline-mode-controls input[type=checkbox]{margin:0}.timeline-mode-controls label{font-weight:500;color:var(--color-text);cursor:pointer}.timeline-type-controls{display:flex;gap:16px;align-items:center}.timeline-type-controls input[type=radio]{margin:0}.timeline-type-controls label{display:flex;align-items:center;gap:4px;cursor:pointer;font-size:.9em;color:var(--color-text-secondary);transition:color .2s ease}.timeline-type-controls input[type=radio]:checked+label{color:var(--color-text);font-weight:500}.timeline-content-wrapper{flex:1;display:flex;flex-direction:column;min-height:0}.timeline-scrubber{display:flex;flex-direction:column;gap:6px;height:100%;padding:4px 0}.timeline-content{display:flex;flex-direction:row;gap:16px;flex-wrap:nowrap;align-items:stretch;height:100%;min-height:0}.timeline-scrubber-wrapper{flex:1;min-width:180px;display:flex;flex-direction:column;gap:3px;min-height:0}.timeline-scrubber__header{display:flex;justify-content:space-between;align-items:center;font-size:12px;font-weight:600;color:var(--timeline-text)}.timeline-scrubber__title{text-transform:uppercase;letter-spacing:.04em;font-size:11px;color:var(--text-muted)}.timeline-scrubber__slider{width:100%;height:20px;margin:8px 0}.timeline-scrubber__values{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--text-secondary);gap:8px;margin-top:3px;padding:0 2px}.timeline-scrubber__value{display:flex;flex-direction:column;gap:2px;text-align:center;min-width:60px}.timeline-scrubber__value--playhead{font-weight:600;color:var(--timeline-fill);text-align:center}.timeline-scrubber__value-label{text-transform:uppercase;letter-spacing:.04em;font-size:9px;color:var(--text-muted)}.timeline-scrubber__value-number{font-size:11px}.timeline-scrubber .noUi-target{border:none;background:var(--timeline-track);box-shadow:none;border-radius:9999px;height:6px}.timeline-scrubber .noUi-connect{background:var(--timeline-fill);border-radius:9999px}.timeline-scrubber .noUi-handle{width:20px;height:20px;top:-7px;border-radius:50%;border:3px solid var(--timeline-handle);background:var(--surface-card);box-shadow:0 2px 8px #0000004d;cursor:grab;transition:all .2s ease}.timeline-scrubber .noUi-handle:before,.timeline-scrubber .noUi-handle:after{display:none}.timeline-scrubber .noUi-handle:hover{transform:scale(1.1);box-shadow:0 3px 12px #0006}.timeline-scrubber .noUi-handle:focus-visible{outline:none;box-shadow:0 0 0 4px #2563eb59}.timeline-scrubber .noUi-handle.noUi-active{cursor:grabbing;transform:scale(1.05)}@media (prefers-color-scheme: dark){.timeline-scrubber__header{color:#e2e8f0}.timeline-scrubber__title,.timeline-scrubber__values,.timeline-scrubber__value-label{color:#a0aec0}.timeline-scrubber .noUi-target{background:#4a5568}.timeline-scrubber .noUi-handle{background:#1a202c;border-color:#63b3ed;box-shadow:0 2px 6px #00000073}.timeline-scrubber .noUi-connect{background:#63b3ed}}.timeline-main-container{flex:1;display:flex;flex-direction:column;padding:12px 16px 8px;min-height:0}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;height:32px;flex-shrink:0}.timeline-footer-title{font-size:13px;font-weight:600;color:var(--text-primary);margin:0}.timeline-transport-controls{display:flex;gap:4px;align-items:center}.and-toggle{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;margin-left:12px;padding-left:12px;border-left:1px solid var(--border-light)}.and-toggle:hover{color:var(--text-primary);transform:scale(1.05)}.and-toggle input{margin:0}.timeline-type-selector{display:flex;gap:16px;margin-bottom:10px;height:24px;flex-shrink:0;transform:translate(0);opacity:1;transition:transform .3s ease,opacity .3s ease}.timeline-type-selector label{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-secondary);cursor:pointer}#app-footer.and-mode .timeline-type-selector{transform:translate(-20px);opacity:0;pointer-events:none}.timeline-container{flex:1;position:relative;min-height:80px;transition:min-height .3s cubic-bezier(.4,0,.2,1)}#app-footer.and-mode .timeline-container{min-height:140px}.timeline-slider-wrapper{position:absolute;left:0;right:0;height:70px;opacity:0;transform:translateY(10px);transition:all .3s cubic-bezier(.4,0,.2,1);pointer-events:none}.timeline-slider-wrapper.timeline-active{opacity:1;transform:translateY(0);pointer-events:auto}.timeline-slider-wrapper.timeline-focus{box-shadow:0 0 0 2px rgba(var(--primary-rgb, 67, 56, 202),.25);border-radius:12px;background:rgba(var(--primary-rgb, 67, 56, 202),.05)}#app-footer.and-mode .timeline-year-published{top:0;opacity:1;transform:translateY(0)}#app-footer.and-mode .timeline-year-subject{top:70px;opacity:1;transform:translateY(0)}.timeline-slider-wrapper.timeline-active:after{content:"";position:absolute;right:-8px;top:50%;transform:translateY(-50%);width:3px;height:16px;background:var(--primary);border-radius:2px;opacity:0;transition:opacity .2s ease}#app-footer.and-mode .timeline-slider-wrapper.timeline-active:after{opacity:1}.timeline-expand-toggle{position:absolute;top:-30px;left:50%;transform:translate(-50%);background:var(--surface-card);border:1px solid var(--border-medium);border-bottom:none;border-radius:8px 8px 0 0;cursor:pointer;padding:6px 20px 8px;transition:all .3s ease;z-index:1600;min-width:100px;text-align:center;box-shadow:0 -2px 8px #1f7a8c26}.collapsed-timeline-info{position:absolute;bottom:100%;left:0;right:0;height:30px;background:var(--surface-card);border-top:1px solid var(--border-medium);display:flex;align-items:center;justify-content:space-between;padding:0 16px;font-size:11px;color:var(--text-secondary);opacity:0;transition:opacity .3s ease}#app-footer.collapsed .collapsed-timeline-info{opacity:1}.collapsed-left{display:flex;align-items:center;gap:8px}.collapsed-play-btn{width:20px;height:20px;border-radius:50%;border:none;background:var(--color-success);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:10px}.collapsed-timeline-state{font-size:11px;color:var(--text-primary)}.collapsed-source-count{font-size:10px;color:var(--text-muted)}.timeline-expand-toggle:hover{background:var(--surface-alt);box-shadow:0 -4px 12px #1f7a8c33;transform:translate(-50%) translateY(-2px)}.timeline-toggle-icon{font-size:14px;color:var(--text-secondary);transition:transform .3s ease;display:inline-block}#app-footer.collapsed .timeline-toggle-icon{transform:rotate(180deg)}.timeline-error{display:flex;align-items:center;justify-content:center;padding:20px;color:var(--text-error, #dc2626);background:var(--bg-error-soft, #fef2f2);border:1px solid var(--border-error, #fecaca);border-radius:6px;font-size:14px;text-align:center}.timeline-placeholder{display:flex;align-items:center;justify-content:center;padding:20px;color:var(--text-muted, #9ca3af);background:var(--bg-surface-alt, #f9fafb);border:1px dashed var(--border-light, #e5e7eb);border-radius:6px;font-size:14px;text-align:center}.timeline-placeholder-note{font-style:italic}.timeline-summary{display:flex;flex-direction:column;gap:4px;margin-top:4px}.timeline-row{display:flex;justify-content:space-between;align-items:center;padding:4px 8px;background:var(--bg-surface-alt, #f9fafb);border:1px solid var(--border-light, #e5e7eb);border-radius:3px;font-size:11px}.timeline-row:hover{background:var(--bg-surface, #ffffff);border-color:var(--border-medium, #d1d5db)}.snapshot-btn{width:28px;height:20px;font-size:10px;border-radius:4px;border:1px solid var(--border-medium);background:var(--btn-secondary-bg);color:var(--btn-secondary-text);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;-webkit-user-select:none;user-select:none}.snapshot-btn:hover:not(:disabled){background:var(--btn-secondary-hover-bg);transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.snapshot-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 2px #0000001a}.snapshot-btn:focus-visible{box-shadow:0 0 0 2px var(--input-focus-shadow, rgba(31, 122, 140, .25))}.snapshot-btn:disabled{opacity:var(--opacity-disabled, .5);cursor:not-allowed;background:var(--btn-secondary-bg, var(--surface-card));transform:none;box-shadow:none}.snapshot-btn.active{background:var(--btn-primary-bg, var(--primary));color:var(--btn-primary-text, var(--text-on-primary));border-color:var(--btn-primary-border, var(--primary))}.snapshot-btn.active:hover{background:var(--btn-primary-hover-bg, var(--primary-strong));border-color:var(--btn-primary-hover-border, var(--primary-strong))}.snapshot-btn--play-pause{background:var(--color-success);color:#fff;border-color:var(--color-success);font-weight:600}.snapshot-btn--stop{background:var(--color-warning);color:var(--text-on-accent);border-color:var(--color-warning)}.snapshot-btn--record{background:var(--color-error);color:#fff;border-color:var(--color-error)}.footer-header-container{flex:1;display:flex;flex-direction:row;align-items:stretch;gap:12px;padding:8px 16px;min-height:0;overflow:hidden}.timeline-header-container{flex:1;display:flex;flex-direction:column;min-height:0}.snapshot-controller-container{flex:0 0 auto;display:flex;align-items:center;justify-content:center;min-width:200px}.snapshot-controller-container .snapshot-controls-buttons{display:flex;gap:6px;align-items:center;padding:8px 12px;background:rgba(var(--color-surface-rgb),.05);border-radius:8px;border:1px solid rgba(var(--color-border-rgb),.2)}.snapshot-controller-container .transport-controls,.snapshot-controller-container .action-controls{display:flex;gap:2px}.snapshot-controller-container .transport-controls{margin-right:8px;padding-right:8px;border-right:1px solid rgba(var(--color-border-rgb),.3)}.timeline-footer-content{width:100%;flex:1;display:flex;flex-direction:column;justify-content:center;gap:4px;min-height:0;overflow:hidden}@media screen and (max-width: 600px){.timeline-content{flex-direction:column;gap:8px}.timeline-scrubber-wrapper{min-width:auto}.timeline-scrubber__values{font-size:11px;gap:4px}.timeline-scrubber__value{flex:1}.timeline-scrubber__header{display:none}#timeline-footer{padding:8px 16px 4px}.timeline-footer-title{font-size:12px}.timeline-expand-toggle{top:-30px;padding:6px 12px 3px;min-width:60px}.timeline-content{gap:16px}.timeline-scrubber-wrapper{min-width:160px}.snapshot-controls-container{margin-bottom:8px}.snapshot-controls-buttons{gap:4px;padding:6px 8px}.snapshot-btn{width:28px;height:28px;font-size:12px}.snapshot-btn--beginning,.snapshot-btn--end{font-size:10px}}.custom-marker-icon{border:none!important;position:relative!important;background:transparent!important;overflow:visible!important;pointer-events:auto!important}.leaflet-marker-icon.custom-marker-icon,.leaflet-div-icon.custom-marker-icon{background-image:none!important}.custom-marker-icon:before,.custom-marker-icon:after{display:none!important;content:none!important}.custom-marker-icon img{border:none!important;border-radius:0!important;box-shadow:none!important;background:none!important;max-width:none!important;max-height:none!important;margin:0!important;padding:0!important;display:block!important;position:relative!important;z-index:1!important}.leaflet-div-icon.custom-marker-icon{background:transparent!important;border:none!important;background-image:none!important;overflow:visible!important}.leaflet-marker-icon.custom-marker-icon:before,.leaflet-marker-icon.custom-marker-icon:after{display:none!important}.custom-cluster-icon{background:transparent!important;border:none!important;transition:all .2s ease;transform-origin:center center}.cluster-icon{position:relative;display:flex;align-items:center;justify-content:center;transition:transform .2s ease,opacity .2s ease}.cluster-icon svg.cluster-border{position:absolute;top:0;left:0;width:100%;height:100%;filter:drop-shadow(2px 2px 4px rgba(0,0,0,.2));transition:transform .2s ease;z-index:0}.cluster-icon:hover svg.cluster-border{transform:scale(1.05)}.cluster-icon img.cluster-image{position:absolute;z-index:1;pointer-events:none}.cluster-icon .cluster-badge{z-index:2;transition:transform .2s ease}.cluster-icon:hover .cluster-badge{transform:scale(1.1)}.cluster-icon:hover{cursor:pointer}.cluster-icon .cluster-count{position:relative;z-index:1;font-size:14px;font-weight:700;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.8),-1px -1px 2px rgba(0,0,0,.8),1px -1px 2px rgba(0,0,0,.8),-1px 1px 2px rgba(0,0,0,.8);pointer-events:none}.cluster-small .cluster-count{font-size:12px}.cluster-medium .cluster-count{font-size:14px}.cluster-large .cluster-count{font-size:16px}.source-marker-highlighted{z-index:1000!important;opacity:1!important}.source-marker-highlighted div{filter:brightness(1.2) contrast(1.1);transform:scale(1.1);transition:all .2s ease}.marker-with-border{background:transparent!important;border:none!important;overflow:visible!important;pointer-events:auto!important}.icon-with-border{position:relative!important;display:flex!important;align-items:center!important;justify-content:center!important;width:100%!important;height:100%!important;pointer-events:auto!important}.icon-with-border svg.icon-border{position:absolute!important;top:0!important;left:0!important;width:100%!important;height:100%!important;filter:drop-shadow(1px 1px 2px rgba(0,0,0,.2));transition:transform .2s ease;z-index:0!important;pointer-events:none!important}.icon-with-border:hover svg.icon-border{transform:scale(1.08)}.icon-with-border img.bordered-icon-image{position:absolute!important;top:50%!important;left:50%!important;transform:translate(-50%,-50%)!important;z-index:1!important;pointer-events:none!important;max-width:none!important;max-height:none!important;border:none!important;background:none!important;display:block!important}.icon-badge{position:absolute!important;z-index:2!important;transition:transform .2s ease;pointer-events:none!important}.icon-badge:hover{transform:scale(1.1)}.marker-with-border:hover{cursor:pointer!important}.custom-overlap-cluster-icon{cursor:pointer;transition:transform .2s ease}.custom-overlap-cluster-icon:hover{transform:scale(1.05)}.icon-badge.overlap-multiplier{background:linear-gradient(135deg,#ff6b35,#f7931e)!important;border:2px solid #fff!important;box-shadow:0 3px 8px #0006!important;animation:pulse-gentle 2s infinite}.icon-badge.overlap-multiplier span{color:#fff!important;font-weight:900!important;text-shadow:1px 1px 2px rgba(0,0,0,.5)}@keyframes pulse-gentle{0%,to{box-shadow:0 3px 8px #0006}50%{box-shadow:0 3px 12px #ff6b3599}}.source-overlap .icon-badge.overlap-multiplier{background:linear-gradient(135deg,#2196f3,#1976d2)!important}.surname-overlap .icon-badge.overlap-multiplier{background:linear-gradient(135deg,#9c27b0,#7b1fa2)!important}.mixed-overlap .icon-badge.overlap-multiplier{background:linear-gradient(135deg,#666,#424242)!important}.leaflet-marker-icon{transition:transform .3s ease}.marker-cluster-spiderfy .leaflet-marker-icon{animation:spiderfy-appear .3s ease-out}@keyframes spiderfy-appear{0%{opacity:0;transform:scale(.3)}to{opacity:1;transform:scale(1)}}.spider-leg{stroke-dasharray:1000;stroke-dashoffset:1000;animation:draw-line .3s ease-out forwards}@keyframes draw-line{to{stroke-dashoffset:0}}.boundary-constrained-cluster{position:relative}.boundary-constrained-cluster:after{content:"";position:absolute;bottom:-2px;right:-2px;width:8px;height:8px;background:#4caf50;border-radius:50%;border:1px solid #fff;box-shadow:0 1px 3px #0000004d;animation:boundary-pulse 2s infinite}@keyframes boundary-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.2);opacity:.7}}.cluster-reclustering{animation:recluster-fade .3s ease-in-out}@keyframes recluster-fade{0%{opacity:1}50%{opacity:.3;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.cluster-small,.cluster-medium,.cluster-large{transition:all .3s ease}.custom-cluster-icon:hover,.custom-overlap-cluster-icon:hover{z-index:10000!important;filter:brightness(1.1);transition:all .2s ease}.boundary-cluster-control{position:fixed;z-index:1000;background:#fff;border-radius:6px;box-shadow:0 2px 10px #00000026;padding:8px;display:flex;align-items:center;gap:8px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:12px;transition:all .2s ease}.boundary-cluster-top-right{top:20px;right:20px}.boundary-cluster-top-left{top:20px;left:20px}.boundary-cluster-bottom-right{bottom:20px;right:20px}.boundary-cluster-bottom-left{bottom:20px;left:20px}.boundary-cluster-toggle{background:transparent;border:1px solid #ddd;border-radius:4px;padding:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#666;transition:all .2s ease;width:32px;height:32px}.boundary-cluster-toggle:hover{background:#f5f5f5;border-color:#999;color:#333}.boundary-cluster-toggle.enabled{border-color:#4caf50;color:#4caf50}.boundary-cluster-toggle.active{background:#4caf50;border-color:#4caf50;color:#fff}.boundary-cluster-toggle.disabled{border-color:#ddd;color:#ccc;cursor:not-allowed}.boundary-cluster-toggle.disabled:hover{background:transparent;border-color:#ddd;color:#ccc}.boundary-cluster-status{width:8px;height:8px;border-radius:50%;transition:background-color .2s ease}.boundary-cluster-status.disabled{background:#ddd}.boundary-cluster-status.enabled{background:#ff9800}.boundary-cluster-status.active{background:#4caf50;box-shadow:0 0 4px #4caf5080;animation:cluster-status-pulse 2s infinite}.boundary-cluster-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#000c;color:#fff;padding:6px 10px;border-radius:4px;font-size:11px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .2s ease;margin-bottom:8px}.boundary-cluster-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:#000c}.boundary-cluster-control:hover .boundary-cluster-tooltip{opacity:1}@keyframes cluster-status-pulse{0%,to{opacity:1}50%{opacity:.7}}@media (max-width: 768px){.boundary-cluster-control{padding:6px;scale:.9}.boundary-cluster-toggle{width:28px;height:28px;padding:5px}}#view3d-control-container{display:flex!important;align-items:center;gap:6px;margin:0 4px;transition:all .3s ease}#view3d-control-container .map-control{position:static!important;margin:0!important;box-shadow:none!important;background:transparent!important;border:none!important;padding:0!important}.view3d-control .view3d-btn-group{display:flex;gap:0;background:var(--surface, #FDF9F2);border:1px solid var(--control-border, #D4C4A0);border-radius:6px;overflow:hidden;box-shadow:0 2px 4px #0000001a}.view3d-control .view3d-btn{min-width:35px!important;max-width:40px!important;padding:6px 10px!important;height:32px!important;font-size:12px!important;font-weight:600!important;font-family:Arbutus Slab,serif!important;background:transparent;color:var(--text-secondary, #5A5A5A);border:none;border-right:1px solid var(--control-border, #D4C4A0);cursor:pointer;transition:all .2s ease;position:relative;white-space:nowrap;text-transform:uppercase;letter-spacing:.5px}.view3d-control .view3d-btn:last-child{border-right:none}.view3d-control .view3d-btn.active{background:var(--primary, #4A90E2);color:var(--text-on-primary, #FFFFFF);box-shadow:inset 0 2px 4px #00000026}.view3d-control .view3d-btn:not(.active):hover:not(:disabled){background:var(--surface-hover, #F5EDD9);color:var(--primary, #4A90E2)}.view3d-control .view3d-btn:disabled{opacity:.5;cursor:not-allowed}.view3d-control .view3d-btn.unavailable{opacity:.6;background:repeating-linear-gradient(45deg,transparent,transparent 10px,rgba(0,0,0,.03) 10px,rgba(0,0,0,.03) 20px)}.view3d-control.disabled{opacity:.6;pointer-events:none}#map-3d-container{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;display:none}#map-3d-container.active{display:block}#map.view-3d-active{display:none}.terrain-controls{position:absolute;bottom:20px;right:20px;background:var(--surface, #FDF9F2);border:1px solid var(--control-border, #D4C4A0);border-radius:8px;padding:12px;box-shadow:0 2px 8px #00000026;width:240px;z-index:1000;display:none}.terrain-controls.active{display:block}.terrain-control-group{margin-bottom:12px}.terrain-control-group:last-child{margin-bottom:0}.terrain-control-label{font-size:11px;color:var(--text-primary, #0F5C6D);margin-bottom:6px;display:flex;justify-content:space-between;align-items:center;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.terrain-control-value{color:var(--primary, #4A90E2);font-weight:700}.terrain-slider{width:100%;height:4px;border-radius:2px;background:var(--control-border, #D4C4A0);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.terrain-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--primary, #4A90E2);cursor:pointer;box-shadow:0 2px 4px #0003}.terrain-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--primary, #4A90E2);cursor:pointer;box-shadow:0 2px 4px #0003;border:none}.compass-control{position:absolute;top:80px;right:20px;width:80px;height:80px;background:var(--surface, #FDF9F2);border-radius:50%;box-shadow:0 2px 8px #00000026;border:2px solid var(--control-border, #D4C4A0);cursor:grab;z-index:1000;-webkit-user-select:none;user-select:none;display:none}.compass-control.active{display:block}.compass-control:active{cursor:grabbing}.compass-inner{width:100%;height:100%;position:relative;border-radius:50%;transition:transform .1s ease}.compass-needle{position:absolute;width:3px;height:30px;background:linear-gradient(to bottom,var(--error, #C73E1D) 0%,var(--error, #C73E1D) 50%,var(--primary, #4A90E2) 50%,var(--primary, #4A90E2) 100%);left:50%;top:10px;transform:translate(-50%);border-radius:1px;pointer-events:none}.compass-direction{position:absolute;font-size:10px;font-weight:700;color:var(--text-primary, #0F5C6D);pointer-events:none;font-family:Arbutus Slab,serif}.compass-n{top:8px;left:50%;transform:translate(-50%);color:var(--error, #C73E1D)}.compass-e{right:8px;top:50%;transform:translateY(-50%)}.compass-s{bottom:8px;left:50%;transform:translate(-50%)}.compass-w{left:8px;top:50%;transform:translateY(-50%)}@media (max-width: 768px){#view3d-control-container{margin:0 2px}.view3d-control .view3d-btn{min-width:30px!important;max-width:35px!important;padding:6px 8px!important;font-size:11px!important}.terrain-controls{width:200px;padding:10px}.compass-control{width:60px;height:60px;top:60px;right:10px}.compass-needle{height:22px;top:8px}.compass-direction{font-size:9px}}@media (max-width: 480px){.view3d-control .view3d-btn{min-width:28px!important;max-width:32px!important;font-size:10px!important;padding:5px 6px!important;height:28px!important}.terrain-controls{bottom:60px;right:10px;width:180px}}.map-3d-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--surface, #FDF9F2);padding:20px;border-radius:8px;box-shadow:0 4px 12px #00000026;text-align:center;z-index:1000}.map-3d-loading-spinner{width:40px;height:40px;margin:0 auto 10px;border:3px solid var(--control-border, #D4C4A0);border-top-color:var(--primary, #4A90E2);border-radius:50%;animation:spin 1s linear infinite}.map-3d-loading-text{color:var(--text-primary, #0F5C6D);font-size:14px;font-family:Arbutus Slab,serif}#map-3d-container{z-index:400}#map,#map-3d-container{transition:opacity .3s ease}.view3d-error-message{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--surface, #FDF9F2);border:2px solid var(--error, #C73E1D);border-radius:8px;padding:20px;max-width:400px;box-shadow:0 4px 12px #0003;z-index:10000}.view3d-error-title{color:var(--error, #C73E1D);font-size:16px;font-weight:700;margin-bottom:10px;font-family:Arbutus Slab,serif}.view3d-error-text{color:var(--text-primary, #0F5C6D);font-size:14px;line-height:1.5}#loading-indicator{position:absolute;top:0;left:0;width:100%;height:100%;background:#fffc;z-index:2000;display:flex;flex-direction:column;align-items:center;justify-content:center}.loading-spinner{width:50px;height:50px;border:5px solid #f3f3f3;border-top:5px solid #3388ff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}.loading-message{font-size:18px;font-weight:700}.spinner{width:24px;height:24px;border:3px solid #f3f3f3;border-top:3px solid #3388ff;border-radius:50%;animation:spin 1s linear infinite;display:inline-block}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}#loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#ffffffe6;z-index:2000;display:flex;flex-direction:column;align-items:center;justify-content:center}#loading-message{margin-top:20px;font-size:18px}#loading-message.error{color:#d32f2f}#status-message{position:fixed;bottom:20px;left:50%;transform:translate(-50%);padding:10px 20px;border-radius:4px;box-shadow:0 2px 5px #0003;z-index:1500;max-width:80%;text-align:center}.status-info{background:#e3f2fd;color:#0d47a1}.status-warning{background:#fff3e0;color:#e65100}.status-error{background:#ffebee;color:#c62828}.error-container{position:absolute;top:20px;left:50%;transform:translate(-50%);z-index:2000;background:#fff;padding:20px;border-radius:4px;box-shadow:0 0 10px #0000001a;text-align:center;max-width:80%}.error-message{color:#d32f2f;font-weight:700}.empty-state{color:#888;text-align:center;margin-top:40px}:focus-visible{outline:2px solid var(--accent, #2563eb);outline-offset:2px}.is-hidden{display:none!important}.is-open{display:block!important}.placeholder{opacity:var(--opacity-disabled);cursor:not-allowed;background:var(--surface-alt)!important;color:var(--text-muted)!important;border-color:var(--border-light)!important;pointer-events:none;-webkit-user-select:none;user-select:none;position:relative}.placeholder:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:repeating-linear-gradient(45deg,transparent,transparent 4px,var(--border-light) 4px,var(--border-light) 8px);opacity:.3;pointer-events:none;border-radius:inherit}.placeholder:hover{transform:none!important;box-shadow:none!important}.placeholder-text{color:var(--text-muted);font-style:italic;font-weight:400}.placeholder-text:before{content:"⚬ ";opacity:.5}@media (prefers-color-scheme: dark){.placeholder{background:#1a1a1a!important;color:#666!important;border-color:#333!important}.placeholder:before{background:repeating-linear-gradient(45deg,transparent,transparent 4px,#333 4px,#333 8px)}.placeholder-text{color:#666}}@media (max-width: 768px){#header-bar,.header-bar{height:80px;min-height:80px;padding:12px 16px}.header-content{flex-direction:column;gap:12px;align-items:stretch}.header-logo .logo{font-size:16px}.header-controls-group{justify-content:center;flex-wrap:wrap;gap:12px}.header-buttons{justify-content:center}.header-expand-toggle{bottom:-25px;padding:6px 12px 4px;min-width:60px}body{--header-h: 80px;--footer-h: 70px;padding-top:80px;padding-bottom:70px}body:has(#app-footer.and-mode){--footer-h: 110px}body.footer-and-mode{--footer-h: 110px}#app-footer{height:70px}#app-footer.and-mode{height:110px}#app-footer.collapsed{transform:translateY(calc(100% - 30px))}body{--footer-h: 90px;padding-bottom:90px;transition:padding-bottom .3s ease}body.footer-and-mode{--footer-h: 130px;padding-bottom:130px}body:has(#app-footer.collapsed){padding-bottom:30px}body:has(#header-bar.collapsed){padding-top:30px}.list-view-toggle-tab,.list-view-container.collapsed .list-view-toggle-tab{top:130px}.header-bar .map-control.mode-control .mode-btn,.header-bar .map-control.shapefile-control .shapefile-toggle-btn{min-width:60px;font-size:12px;padding:0 8px;height:36px}.header-bar .map-control.country-control{min-width:140px;max-width:160px}}@media (max-width: 480px){.header-bar{height:90px}body{--header-h: 90px;--footer-h: 70px;padding-top:90px;padding-bottom:70px}body:has(#app-footer.and-mode){--footer-h: 110px}body.footer-and-mode{--footer-h: 110px}.snapshot-controls-container{padding:4px 8px}.snapshot-btn{width:20px;height:14px;font-size:8px}.timeline-main-container{padding:4px 12px}#app-footer{grid-template-columns:1fr;grid-template-rows:auto auto auto;grid-template-areas:"timeline" "controls" "status attribution";height:90px}#app-footer.and-mode{height:130px}.snapshot-controls-container{border-right:none;border-top:1px solid var(--border-light);justify-content:center;flex-direction:row}.snapshot-controls-buttons{flex-direction:row;gap:8px}#status-bar,#attribution{padding:4px 12px;font-size:11px}.timeline-type-selector{gap:12px}.timeline-type-selector label{font-size:10px}.list-view-toggle-tab,.list-view-container.collapsed .list-view-toggle-tab{top:50px}.header-logo{grid-column:1;grid-row:1;justify-content:center}.header-controls{grid-column:2;grid-row:1;justify-content:center}.header-left{grid-column:1;grid-row:2;justify-content:center}.header-center{grid-column:1 / -1;grid-row:2;justify-content:center}.header-right{grid-column:2;grid-row:2;justify-content:center}.header-layers{grid-column:1 / -1;grid-row:3;justify-content:center}.header-logo .logo{font-size:14px}.header-controls .control-btn{width:28px;height:28px;font-size:12px}}@media screen and (max-width: 768px){.timeline-type-selector{gap:12px}.timeline-type-selector label{font-size:10px}#left-sidebar{width:min(320px,calc(100vw - (2 * var(--edge-gap, 0px))));height:calc(100vh - var(--header-h) - var(--footer-h));position:fixed;top:calc(var(--header-h) + var(--edge-gap, 0px));bottom:calc(var(--footer-h) + var(--edge-gap, 0px));overflow-y:auto;transform:translate(0)}#left-sidebar.collapsed{transform:translate(calc(-100% - var(--edge-gap, 0px)))}#main-pane-right{transform:translate(100%)}.list-view-container{width:100%;height:100%}.details-container{width:100%}}@media (max-width: 768px){.mode-control .mode-btn{min-width:70px;font-size:13px;padding:0 12px}}@media (max-width: 768px){.map-control.map-legend{left:10px;bottom:10px;min-width:160px;max-width:250px}.legend-header h3{font-size:13px}.legend-label{font-size:12px}}@media (max-width: 768px){.layer-control-content{max-height:250px}.layer-option{padding:8px 12px}.layer-option label{font-size:14px}.layer-control-content::-webkit-scrollbar{width:8px}}@media (max-width: 700px){.details-container.active~* .map-control.layer-control,.details-container.active~* .map-control.zoom-control,body:has(.details-container.active) .map-control.layer-control,body:has(.details-container.active) .map-control.zoom-control,.list-view-active .map-control.layer-control,.list-view-active .map-control.zoom-control{right:20px;bottom:80px}}@media (max-width: 700px){.details-container{width:100vw;left:0;right:0;height:60vh;top:auto;bottom:0;border-radius:12px 12px 0 0;box-shadow:0 -2px 12px #0000002e}.details-content{padding:16px 8px}}@media (max-width: 768px){.control-group.orientation-horizontal .control-group-content{flex-direction:column}.control-group{padding:12px}.control-item{flex-direction:column;align-items:flex-start}.control-label{margin:0 0 4px!important}.control-item input,.control-item select,.control-item textarea,.control-item button{width:100%;max-width:none}}@media (max-width: 768px){.notification-container{max-width:calc(100vw - 40px);margin:0 20px}.notification-container.top-left,.notification-container.bottom-left{left:20px;right:20px;max-width:none}.notification-container.top-right,.notification-container.bottom-right{right:20px;left:20px;max-width:none}.notification-container.top-center,.notification-container.bottom-center{left:20px;right:20px;transform:none;max-width:none}.notification{padding:12px;font-size:13px}.notification-title{font-size:14px}.notification-close{top:6px;right:6px;width:24px;height:24px;font-size:18px}}@media (max-width: 768px){.modal-content{width:95vw!important;max-width:95vw;margin:20px;max-height:calc(100vh - 40px)}.modal-content.size-small,.modal-content.size-medium,.modal-content.size-large{width:95vw!important}.modal-header{padding:16px 20px}.modal-title{font-size:16px}.modal-body{padding:20px}.modal-footer{padding:16px 20px;flex-direction:column}.modal-button{width:100%;margin-bottom:8px}.modal-button:last-child{margin-bottom:0}}@media (prefers-color-scheme: dark){.control-group{background:#2d2d2d;border-color:#404040;color:#e0e0e0}.control-group:hover{box-shadow:0 4px 8px #0000004d}.control-group-header{border-bottom-color:#404040}.control-group-title{color:#e0e0e0}.control-group-collapse{background:#404040;border-color:#555;color:#e0e0e0}.control-group-collapse:hover{background:#505050;border-color:#666}.control-label{color:#b0b0b0}.control-item input,.control-item select,.control-item textarea{background:#404040;border-color:#555;color:#e0e0e0}.control-item input:focus,.control-item select:focus,.control-item textarea:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.control-item input:disabled,.control-item select:disabled,.control-item textarea:disabled{background:#2d2d2d;color:#666}.control-item button.secondary{background:#404040;color:#007bff;border-color:#007bff}.control-item button.secondary:hover{background:#505050}.control-group.disabled{background:#1a1a1a}}@media (prefers-color-scheme: dark){.notification{background:#2d2d2d;border-color:#404040;color:#e0e0e0}.notification.info{background:#1e3a5f;border-left-color:#64b5f6}.notification.success{background:#2e5d32;border-left-color:#81c784}.notification.warning{background:#5d4037;border-left-color:#ffb74d}.notification.error{background:#5d2a2a;border-left-color:#e57373}.notification-title{color:#e0e0e0}.notification-message,.notification-close{color:#b0b0b0}.notification-close:hover{background:#ffffff1a;color:#e0e0e0}.notification-action.secondary{background:#404040;color:#e0e0e0}.notification-action.secondary:hover{background:#505050}}@media (prefers-color-scheme: dark){.modal-content{background:#2d2d2d;color:#e0e0e0}.modal-header{border-bottom-color:#404040}.modal-title{color:#e0e0e0}.modal-close{color:#b0b0b0}.modal-close:hover{background:#404040;color:#e0e0e0}.modal-body{color:#b0b0b0}.modal-footer{border-top-color:#404040}.modal-button{background:#404040;border-color:#555;color:#e0e0e0}.modal-button:hover{background:#505050;border-color:#666}.modal-loading{background:#2d2d2de6}.modal-spinner{border-color:#555;border-top-color:#007bff}.modal-loading-text{color:#b0b0b0}.prompt-modal input{background:#404040;border-color:#555;color:#e0e0e0}.prompt-modal input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40}}.noUi-target,.noUi-target *{-webkit-touch-callout:none;-webkit-tap-highlight-color:rgba(0,0,0,0);-webkit-user-select:none;-ms-touch-action:none;touch-action:none;-ms-user-select:none;-moz-user-select:none;user-select:none;-moz-box-sizing:border-box;box-sizing:border-box}.noUi-target{position:relative}.noUi-base,.noUi-connects{width:100%;height:100%;position:relative;z-index:1}.noUi-connects{overflow:hidden;z-index:0}.noUi-connect,.noUi-origin{will-change:transform;position:absolute;z-index:1;top:0;right:0;height:100%;width:100%;-ms-transform-origin:0 0;-webkit-transform-origin:0 0;-webkit-transform-style:preserve-3d;transform-origin:0 0;transform-style:flat}.noUi-txt-dir-rtl.noUi-horizontal .noUi-origin{left:0;right:auto}.noUi-vertical .noUi-origin{top:-100%;width:0}.noUi-horizontal .noUi-origin{height:0}.noUi-handle{-webkit-backface-visibility:hidden;backface-visibility:hidden;position:absolute}.noUi-touch-area{height:100%;width:100%}.noUi-state-tap .noUi-connect,.noUi-state-tap .noUi-origin{-webkit-transition:transform .3s;transition:transform .3s}.noUi-state-drag *{cursor:inherit!important}.noUi-horizontal{height:18px}.noUi-horizontal .noUi-handle{width:34px;height:28px;right:-17px;top:-6px}.noUi-vertical{width:18px}.noUi-vertical .noUi-handle{width:28px;height:34px;right:-6px;bottom:-17px}.noUi-txt-dir-rtl.noUi-horizontal .noUi-handle{left:-17px;right:auto}.noUi-target{background:#fafafa;border-radius:4px;border:1px solid #D3D3D3;box-shadow:inset 0 1px 1px #f0f0f0,0 3px 6px -5px #bbb}.noUi-connects{border-radius:3px}.noUi-connect{background:#3fb8af}.noUi-draggable{cursor:ew-resize}.noUi-vertical .noUi-draggable{cursor:ns-resize}.noUi-handle{border:1px solid #D9D9D9;border-radius:3px;background:#fff;cursor:default;box-shadow:inset 0 0 1px #fff,inset 0 1px 7px #ebebeb,0 3px 6px -3px #bbb}.noUi-active{box-shadow:inset 0 0 1px #fff,inset 0 1px 7px #ddd,0 3px 6px -3px #bbb}.noUi-handle:before,.noUi-handle:after{content:"";display:block;position:absolute;height:14px;width:1px;background:#e8e7e6;left:14px;top:6px}.noUi-handle:after{left:17px}.noUi-vertical .noUi-handle:before,.noUi-vertical .noUi-handle:after{width:14px;height:1px;left:6px;top:14px}.noUi-vertical .noUi-handle:after{top:17px}[disabled] .noUi-connect{background:#b8b8b8}[disabled].noUi-target,[disabled].noUi-handle,[disabled] .noUi-handle{cursor:not-allowed}.noUi-pips,.noUi-pips *{-moz-box-sizing:border-box;box-sizing:border-box}.noUi-pips{position:absolute;color:#999}.noUi-value{position:absolute;white-space:nowrap;text-align:center}.noUi-value-sub{color:#ccc;font-size:10px}.noUi-marker{position:absolute;background:#ccc}.noUi-marker-sub,.noUi-marker-large{background:#aaa}.noUi-pips-horizontal{padding:10px 0;height:80px;top:100%;left:0;width:100%}.noUi-value-horizontal{-webkit-transform:translate(-50%,50%);transform:translate(-50%,50%)}.noUi-rtl .noUi-value-horizontal{-webkit-transform:translate(50%,50%);transform:translate(50%,50%)}.noUi-marker-horizontal.noUi-marker{margin-left:-1px;width:2px;height:5px}.noUi-marker-horizontal.noUi-marker-sub{height:10px}.noUi-marker-horizontal.noUi-marker-large{height:15px}.noUi-pips-vertical{padding:0 10px;height:100%;top:0;left:100%}.noUi-value-vertical{-webkit-transform:translate(0,-50%);transform:translateY(-50%);padding-left:25px}.noUi-rtl .noUi-value-vertical{-webkit-transform:translate(0,50%);transform:translateY(50%)}.noUi-marker-vertical.noUi-marker{width:5px;height:2px;margin-top:-1px}.noUi-marker-vertical.noUi-marker-sub{width:10px}.noUi-marker-vertical.noUi-marker-large{width:15px}.noUi-tooltip{display:block;position:absolute;border:1px solid #D9D9D9;border-radius:3px;background:#fff;color:#000;padding:5px;text-align:center;white-space:nowrap}.noUi-horizontal .noUi-tooltip{-webkit-transform:translate(-50%,0);transform:translate(-50%);left:50%;bottom:120%}.noUi-vertical .noUi-tooltip{-webkit-transform:translate(0,-50%);transform:translateY(-50%);top:50%;right:120%}.noUi-horizontal .noUi-origin>.noUi-tooltip{-webkit-transform:translate(50%,0);transform:translate(50%);left:auto;bottom:10px}.noUi-vertical .noUi-origin>.noUi-tooltip{-webkit-transform:translate(0,-18px);transform:translateY(-18px);top:auto;right:28px}.leaflet-cluster-anim .leaflet-marker-icon,.leaflet-cluster-anim .leaflet-marker-shadow{-webkit-transition:-webkit-transform .3s ease-out,opacity .3s ease-in;-moz-transition:-moz-transform .3s ease-out,opacity .3s ease-in;-o-transition:-o-transform .3s ease-out,opacity .3s ease-in;transition:transform .3s ease-out,opacity .3s ease-in}.leaflet-cluster-spider-leg{-webkit-transition:-webkit-stroke-dashoffset .3s ease-out,-webkit-stroke-opacity .3s ease-in;-moz-transition:-moz-stroke-dashoffset .3s ease-out,-moz-stroke-opacity .3s ease-in;-o-transition:-o-stroke-dashoffset .3s ease-out,-o-stroke-opacity .3s ease-in;transition:stroke-dashoffset .3s ease-out,stroke-opacity .3s ease-in}.marker-cluster-small{background-color:#b5e28c99}.marker-cluster-small div{background-color:#6ecc3999}.marker-cluster-medium{background-color:#f1d35799}.marker-cluster-medium div{background-color:#f0c20c99}.marker-cluster-large{background-color:#fd9c7399}.marker-cluster-large div{background-color:#f1801799}.leaflet-oldie .marker-cluster-small{background-color:#b5e28c}.leaflet-oldie .marker-cluster-small div{background-color:#6ecc39}.leaflet-oldie .marker-cluster-medium{background-color:#f1d357}.leaflet-oldie .marker-cluster-medium div{background-color:#f0c20c}.leaflet-oldie .marker-cluster-large{background-color:#fd9c73}.leaflet-oldie .marker-cluster-large div{background-color:#f18017}.marker-cluster{background-clip:padding-box;border-radius:20px}.marker-cluster div{width:30px;height:30px;margin-left:5px;margin-top:5px;text-align:center;border-radius:15px;font:12px Helvetica Neue,Arial,Helvetica,sans-serif}.marker-cluster span{line-height:30px}
