*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--cream: #F5F0E8;--cream-dark: #EDE5D4;--cream-darker: #DDD3BC;--coral: #E8614A;--coral-dark: #C94D38;--coral-light: #F2A090;--brown-dark: #3A2B1E;--brown-mid: #5C4033;--brown-light: #8B6D5A;--brown-faint: #C4B09A;--border: #D4C5B0;--text-main: #3A2B1E;--text-muted: #7A6750;--shadow: 0 2px 12px rgba(58,43,30,.1);--shadow-lg: 0 6px 24px rgba(58,43,30,.14);--radius: 10px;--radius-sm: 6px}html,body,#root{height:100%;overflow:hidden}body{background:var(--cream);color:var(--text-main);font-family:Playfair Display,Georgia,serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.region-bar{display:flex;align-items:center;justify-content:center;gap:6px;padding:5px 24px;background:var(--cream-dark);border-bottom:1.5px solid var(--border);flex-shrink:0}.region-tab{padding:3px 14px;border-radius:14px;border:1.5px solid transparent;background:transparent;color:var(--text-muted);font-size:11.5px;font-family:Playfair Display,serif;font-weight:400;letter-spacing:.04em;cursor:pointer;transition:color .15s,background .15s,border-color .15s;white-space:nowrap}.region-tab:hover{color:var(--brown-dark);border-color:var(--border);background:var(--cream)}.region-tab--active{background:var(--coral);border-color:var(--coral);color:#fff;font-weight:600}.region-tab--active:hover{background:var(--coral-dark);border-color:var(--coral-dark)}.city-search{position:relative;flex:1;max-width:580px;margin:0 12px;display:flex;flex-direction:row;align-items:stretch;gap:6px}.search-mode-tabs{display:flex;flex-shrink:0;border:1.5px solid var(--border);border-radius:20px;overflow:hidden;background:var(--cream)}.smt-btn{display:flex;align-items:center;font-size:10.5px;font-family:Playfair Display,serif;padding:0 13px;border:none;border-radius:0;background:transparent;color:var(--text-muted);cursor:pointer;letter-spacing:.04em;transition:background .15s,color .15s;white-space:nowrap}.smt-btn+.smt-btn{border-left:1.5px solid var(--border)}.smt-btn:hover:not(.smt-btn--on-cities):not(.smt-btn--on-sites){background:var(--cream-dark);color:var(--brown-dark)}.smt-btn--on-cities{background:var(--coral);color:#fff}.smt-btn--on-cities+.smt-btn{border-left-color:#e8614a59}.smt-btn--on-sites{background:#c9960d;color:#fff}.city-search-item.site-item.on-map .csi-name{color:#c9960d}.csi-badge--site{border-color:#d4a017!important;color:#c9960d!important}.city-search-item.site-item.on-map .csi-badge{color:#c9960d;border-color:#d4a017}.city-search-wrap{position:relative;display:flex;align-items:center;flex:1;min-width:0}.city-search-icon{position:absolute;left:12px;color:var(--brown-faint);pointer-events:none;display:flex;align-items:center}.city-search-input{width:100%;padding:7px 32px 7px 34px;border:1.5px solid var(--border);border-radius:20px;background:var(--cream-dark);font-family:Playfair Display,serif;font-size:13px;color:var(--text-main);outline:none;transition:border-color .15s,background .15s,box-shadow .15s}.city-search-input::placeholder{color:var(--brown-faint);font-style:italic}.city-search-input:focus{border-color:var(--coral-light);background:#fff;box-shadow:0 0 0 3px #e8614a1a}.city-search-x{position:absolute;right:10px;background:none;border:none;font-size:18px;line-height:1;color:var(--brown-faint);cursor:pointer;padding:2px 4px;transition:color .15s}.city-search-x:hover{color:var(--coral)}.city-search-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--cream);border:1.5px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:300;list-style:none;overflow:hidden;max-height:300px;overflow-y:auto}.city-search-item{display:flex;align-items:center;gap:8px;padding:9px 14px;cursor:pointer;border-bottom:1px solid var(--cream-dark);transition:background .1s}.city-search-item:last-child{border-bottom:none}.city-search-item:hover:not(.disabled){background:var(--cream-dark)}.city-search-item.on-map{background:#e8614a0d}.city-search-item.disabled{opacity:.45;cursor:not-allowed}.csi-name{font-size:13px;font-weight:600;font-family:Playfair Display,serif;color:var(--text-main);flex-shrink:0}.city-search-item.on-map .csi-name{color:var(--coral)}.csi-meta{flex:1;font-size:11px;font-style:italic;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.csi-badge{flex-shrink:0;font-size:10.5px;font-family:Playfair Display,serif;color:var(--brown-faint);border:1px solid var(--border);border-radius:10px;padding:1px 8px;transition:color .15s,border-color .15s}.city-search-item:hover:not(.disabled) .csi-badge{color:var(--coral);border-color:var(--coral-light)}.city-search-item.on-map .csi-badge{color:var(--coral);border-color:var(--coral-light)}.city-search-empty{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--cream);border:1.5px solid var(--border);border-radius:var(--radius);padding:11px 14px;font-size:12px;font-style:italic;color:var(--text-muted);box-shadow:var(--shadow);z-index:300}.map-empty-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:Playfair Display,serif;font-size:15px;font-style:italic;color:var(--brown-faint);pointer-events:none;text-align:center;opacity:.7}.app-header{display:grid;grid-template-columns:auto 1fr auto;align-items:center;padding:0 24px;height:56px;background:var(--cream);border-bottom:1.5px solid var(--border);flex-shrink:0;z-index:10}.header-left{display:flex;align-items:baseline;gap:12px}.app-title{font-size:26px;font-weight:700;color:var(--coral);letter-spacing:-.5px;font-style:italic}.app-subtitle{font-size:12px;color:var(--text-muted);font-weight:400;letter-spacing:.08em;text-transform:uppercase}.header-right{display:flex;align-items:center;gap:10px}.header-hint{font-size:12px;color:var(--text-muted);font-style:italic}.clear-btn{padding:4px 12px;background:transparent;border:1.5px solid var(--coral);color:var(--coral);border-radius:20px;font-size:11px;font-family:Playfair Display,serif;cursor:pointer;transition:background .18s,color .18s;letter-spacing:.03em}.clear-btn:hover{background:var(--coral);color:#fff}.app-main{display:flex;flex:1;overflow:hidden;min-height:0}.map-area{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--cream);min-width:0}.map-container{position:relative;flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:8px}.world-map-svg{width:100%;height:100%;max-height:calc(100vh - 166px)}.map-legend{position:absolute;bottom:14px;left:18px;display:flex;flex-direction:column;gap:4px;background:#f5f0e8e0;border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.legend-title{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px}.legend-dots{display:flex;gap:12px}.legend-item{display:flex;align-items:center;gap:4px;font-size:10px;color:var(--text-muted)}.legend-item svg{flex-shrink:0}.selection-ring{animation:pulse-ring 1.8s ease-in-out infinite}@keyframes pulse-ring{0%{r:12;opacity:.7}50%{r:16;opacity:.3}to{r:12;opacity:.7}}.site-selection-ring{animation:pulse-diamond 1.8s ease-in-out infinite}@keyframes pulse-diamond{0%{opacity:.7}50%{opacity:.15}to{opacity:.7}}.side-panel{width:320px;min-width:280px;max-width:360px;display:flex;flex-direction:column;background:var(--cream-dark);border-left:1.5px solid var(--border);overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--brown-faint) transparent}.side-panel--comparison{width:400px;max-width:440px}.side-panel--empty{justify-content:center;align-items:center}.side-panel-empty-content{text-align:center;padding:32px 24px;color:var(--text-muted)}.side-panel-empty-icon{font-size:36px;margin-bottom:16px;opacity:.35;color:var(--coral)}.side-panel-empty-content h3{font-size:18px;color:var(--brown-mid);margin-bottom:10px;font-style:italic}.side-panel-empty-content p{font-size:13px;line-height:1.6;margin-bottom:8px}.side-panel-empty-content strong{color:var(--coral)}.comparison-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;border-bottom:1px solid var(--border);background:var(--cream);flex-shrink:0}.comparison-title{font-size:14px;font-weight:700;color:var(--coral)}.comparison-era{font-size:11px;color:var(--text-muted);font-style:italic}.cards-container{display:flex;flex-direction:column;gap:0}.cards-container--grid{flex-direction:column}.city-card{padding:20px 18px;border-bottom:1px solid var(--border);background:var(--cream-dark);transition:background .15s}.city-card:last-child{border-bottom:none}.city-card--compact{padding:14px 16px}.city-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.city-card-name{font-size:22px;font-weight:700;color:var(--coral);line-height:1.1;font-style:italic}.city-card--compact .city-card-name{font-size:18px}.city-card-era{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:2px}.city-card-close{background:none;border:none;font-size:20px;color:var(--brown-faint);cursor:pointer;line-height:1;padding:2px 4px;border-radius:4px;transition:color .15s,background .15s;flex-shrink:0}.city-card-close:hover{color:var(--coral);background:#e8614a1a}.city-card-highlight{font-size:12px;font-style:italic;color:var(--brown-mid);line-height:1.5;background:#e8614a12;border-left:3px solid var(--coral-light);padding:7px 10px;border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin-bottom:14px}.city-card--compact .city-card-highlight{display:none}.city-card-section{margin-bottom:11px}.city-card-section:last-child{margin-bottom:0}.city-card-label{display:block;font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:3px}.city-card-value{font-size:13px;color:var(--text-main);font-weight:600}.city-card-status{font-weight:400;font-style:italic;color:var(--brown-mid);font-size:12.5px}.pop-bar-wrapper{display:flex;align-items:center;gap:8px}.pop-bar-track{flex:1;height:7px;background:var(--cream-darker);border-radius:4px;overflow:hidden}.pop-bar-fill{height:100%;background:linear-gradient(90deg,var(--coral-light),var(--coral));border-radius:4px;transition:width .4s cubic-bezier(.4,0,.2,1);min-width:3px}.pop-bar-label{font-size:11px;font-weight:700;color:var(--brown-mid);min-width:36px;text-align:right}.city-card-events{list-style:none;display:flex;flex-direction:column;gap:4px}.city-card-events li{font-size:12px;color:var(--text-main);line-height:1.4;padding-left:14px;position:relative}.city-card-events li:before{content:"–";position:absolute;left:2px;color:var(--coral-light);font-weight:700}.events-more{color:var(--text-muted)!important;font-style:italic;font-size:11px!important}.events-more:before{content:""!important}.site-card{padding:20px 18px;border-bottom:1px solid var(--border);background:#fffdf5;transition:background .15s}.site-card:last-child{border-bottom:none}.site-card--compact{padding:14px 16px}.site-card-badge{display:inline-flex;align-items:center;gap:4px;font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#c9960d;background:#d4a0171a;border:1px solid rgba(212,160,23,.28);border-radius:10px;padding:2px 8px;margin-bottom:5px}.site-card-name{font-size:22px;font-weight:700;color:#c9960d;line-height:1.1;font-style:italic}.site-card--compact .site-card-name{font-size:18px}.site-card-period{font-size:11px;color:var(--text-muted);letter-spacing:.06em;margin-top:2px;font-style:italic}.site-card-description{font-size:12px;font-style:italic;color:var(--brown-mid);line-height:1.5;background:#d4a01712;border-left:3px solid rgba(212,160,23,.5);padding:7px 10px;border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin-bottom:14px}.app-footer{flex-shrink:0;border-top:1.5px solid var(--border);background:var(--cream);z-index:10;display:flex;align-items:stretch}.timeline-wrapper{flex:1;min-width:0;padding:10px 24px 12px;display:flex;flex-direction:column;gap:6px}.timeline-header{display:flex;align-items:center;justify-content:space-between}.timeline-year-display{display:flex;align-items:baseline;gap:10px}.timeline-year-number{font-size:22px;font-weight:700;color:var(--coral);font-style:italic;line-height:1;min-width:110px}.timeline-era-badge{font-size:11px;font-weight:600;color:var(--brown-mid);text-transform:uppercase;letter-spacing:.1em;background:var(--cream-dark);border:1px solid var(--border);border-radius:20px;padding:2px 10px}.timeline-hint{font-size:11px;color:var(--text-muted);font-style:italic}.timeline-era-labels{display:flex;width:100%}.era-label-cell{display:flex;flex-direction:column;align-items:center;padding:0 2px;min-width:0;border-left:1px solid var(--border);transition:color .25s}.era-label-cell:first-child{border-left:none}.era-label-text{font-size:10px;font-family:Playfair Display,serif;font-weight:400;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;transition:color .25s,font-weight .25s}.era-label-year{font-size:9px;color:var(--brown-faint);font-family:Playfair Display,serif}.era-label-cell--active .era-label-text{color:var(--coral);font-weight:700}.era-label-cell--active .era-label-year{color:var(--coral-light)}.timeline-track-container{position:relative;height:36px;display:flex;align-items:flex-start;cursor:pointer}.timeline-svg{display:block}.timeline-range{position:absolute;top:0;left:0;width:100%;height:36px;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:transparent;cursor:pointer;outline:none;margin:0;padding:0;z-index:2}.timeline-range::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:36px;background:transparent;border:none;cursor:ew-resize}.timeline-range::-moz-range-thumb{width:18px;height:36px;background:transparent;border:none;cursor:ew-resize}.timeline-range::-webkit-slider-runnable-track{background:transparent;height:36px}.timeline-range::-moz-range-track{background:transparent;height:36px}.music-player{flex-shrink:0;width:172px;border-left:1.5px solid var(--border);padding:10px 14px 10px 16px;display:flex;flex-direction:column;justify-content:center;gap:7px;position:relative;overflow:hidden}.music-player-top{display:flex;align-items:center;gap:6px}.music-player-note{color:var(--coral);opacity:.7;display:flex;align-items:center;flex-shrink:0}.music-player-label{font-size:11px;font-family:Playfair Display,serif;color:var(--text-muted);font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.music-player-controls{display:flex;align-items:center;gap:8px}.music-mute-btn{flex-shrink:0;width:28px;height:28px;border-radius:50%;border:1.5px solid var(--border);background:var(--cream-dark);color:var(--brown-mid);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s,border-color .15s;padding:0}.music-mute-btn:hover{background:var(--coral);color:#fff;border-color:var(--coral)}.music-mute-btn--muted{color:var(--brown-faint);border-color:var(--cream-darker)}.music-mute-btn--muted:hover{background:var(--coral);color:#fff;border-color:var(--coral)}.music-volume-slider{flex:1;height:3px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--cream-darker);border-radius:2px;outline:none;cursor:pointer;transition:opacity .2s}.music-volume-slider:disabled{opacity:.35;cursor:not-allowed}.music-volume-slider::-webkit-slider-thumb{-webkit-appearance:none;width:11px;height:11px;border-radius:50%;background:var(--coral);cursor:pointer;border:none;box-shadow:0 1px 3px #e8614a66;transition:transform .15s}.music-volume-slider:not(:disabled)::-webkit-slider-thumb:hover{transform:scale(1.25)}.music-volume-slider::-moz-range-thumb{width:11px;height:11px;border-radius:50%;background:var(--coral);cursor:pointer;border:none}.music-volume-slider::-webkit-slider-runnable-track{height:3px;background:linear-gradient(to right,var(--coral) calc(var(--vol, 50) * 1%),var(--cream-darker) calc(var(--vol, 50) * 1%));border-radius:2px}.music-playing-indicator{position:absolute;bottom:8px;right:12px;display:flex;align-items:flex-end;gap:2px;height:10px;opacity:.45}.music-playing-indicator span{display:block;width:3px;background:var(--coral);border-radius:1px;animation:eq-bounce 1.2s ease-in-out infinite}.music-playing-indicator span:nth-child(1){animation-delay:0s;animation-duration:1.1s}.music-playing-indicator span:nth-child(2){animation-delay:.2s;animation-duration:.9s}.music-playing-indicator span:nth-child(3){animation-delay:.4s;animation-duration:1.3s}.music-playing-indicator span:nth-child(4){animation-delay:.1s;animation-duration:1s}@keyframes eq-bounce{0%,to{height:3px}50%{height:10px}}.side-panel::-webkit-scrollbar{width:4px}.side-panel::-webkit-scrollbar-thumb{background:var(--brown-faint);border-radius:2px}.side-panel::-webkit-scrollbar-track{background:transparent}
