:root{--font-sans: "Noto Sans", "Noto Sans Greek", "Segoe UI", "Helvetica Neue", Arial, sans-serif;--font-serif: "Noto Serif", "Noto Serif Greek", Georgia, serif;--search-control-height: 38px;--search-control-width: clamp(190px, 24vw, 240px);--info-fab-size: 40px;--info-fab-offset: 24px}body{font-family:var(--font-sans);margin:0;padding:0;background-color:var(--page-bg);color:var(--page-text);transition:background-color .3s ease,color .3s ease}#map{height:100vh;width:100%}.leaflet-popup-pane,.leaflet-popup{z-index:4000}#ui-controls{z-index:1500;display:flex;flex-direction:column;align-items:flex-end;gap:12px;padding:0 12px 0 0}.leaflet-popup-content-wrapper{background-color:var(--popup-bg);border-radius:10px;border:1px solid var(--popup-border)}.leaflet-popup-content{color:var(--popup-text);margin:0!important;padding:16px;width:clamp(260px,80vw,460px);box-sizing:border-box}.leaflet-popup-close-button{color:var(--popup-heading)!important}.popup-content h3{margin:0 0 4px;color:var(--popup-heading);font-size:.9rem;font-family:var(--font-serif)}.popup-content h4{margin:0 0 16px;color:var(--popup-subheading);font-style:italic;font-size:.85rem}.popup-content{display:flex;flex-direction:column;gap:4px;width:100%;max-width:100%;max-height:min(75vh,520px);overflow-x:hidden;overflow-y:auto;overscroll-behavior:contain;box-sizing:border-box}.popup-content p{margin:4px 0;font-size:11px;line-height:1.45}.popup-content p strong{color:var(--popup-strong)}.popup-content a{color:var(--popup-link);text-decoration:none}.popup-content a:hover{text-decoration:underline;color:var(--popup-link-hover)}.popup-image{width:100%;height:180px;object-fit:cover;border-radius:6px;margin-bottom:12px;background-color:var(--image-placeholder)}.popup-image--portrait{object-fit:contain}.popup-overview{display:flex;flex-direction:column;gap:12px}.popup-media{flex:0 0 auto;display:flex;justify-content:center}.popup-media .popup-image{height:clamp(180px,35vh,240px);box-shadow:0 6px 14px #0f172a2e}.popup-summary{display:flex;flex-direction:column;gap:8px;flex:1 1 auto;min-width:0;max-width:100%;overflow-wrap:anywhere;word-break:break-word}.popup-heading{display:flex;flex-direction:column;gap:4px}.popup-heading h3{margin:0;font-size:1rem;overflow-wrap:anywhere}.popup-nickname{margin:0;color:var(--popup-subheading);font-size:.8rem;font-style:italic;overflow-wrap:anywhere}.popup-meta{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.popup-meta__item{display:flex;align-items:center;gap:8px}.popup-meta__icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;flex:0 0 18px;color:var(--popup-subheading)}.popup-meta__icon svg{width:100%;height:100%}.popup-meta__value{font-size:.72rem;font-weight:500;line-height:1.2;color:var(--popup-strong);overflow-wrap:anywhere;word-break:break-word}.popup-details{flex:1 1 auto;overflow:visible;padding-top:2px;margin-top:0;border-top:1px solid var(--popup-border);display:flex;flex-direction:column;gap:12px}.bio{font-style:italic;color:var(--bio-color)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.popup-bio{--popup-bio-collapsed-height: 8rem;--popup-bio-line-clamp: 6;display:flex;flex-direction:column;gap:6px;position:relative}.popup-bio--interactive{cursor:pointer}.popup-bio--interactive:focus-visible{outline:2px solid var(--toggle-active-border);outline-offset:2px}.popup-bio__body{position:relative;transition:max-height .25s ease;overflow:hidden}.popup-bio[data-state=expanded] .popup-bio__body{max-height:none}.popup-bio[data-state=collapsed] .popup-bio__body{max-height:var(--popup-bio-collapsed-height)}.popup-bio .bio{margin:0}.popup-bio[data-state=collapsed] .bio{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:var(--popup-bio-line-clamp, 6);overflow:hidden;-webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,1) 60%,rgba(0,0,0,0) 100%);mask-image:linear-gradient(to bottom,#000 60%,#0000)}.popup-bio__body:after{content:"";position:absolute;inset:auto 0 0;height:2.5rem;pointer-events:none;background:linear-gradient(to bottom,rgba(0,0,0,0),var(--popup-bg));opacity:0;transition:opacity .2s ease}.popup-bio--interactive[data-state=collapsed] .popup-bio__body:after{opacity:1}#ui-controls .leaflet-control{position:relative}#ui-controls .leaflet-control+.leaflet-control{margin-top:8px}#search-container{display:flex;flex-direction:column;gap:6px;width:var(--search-control-width);max-width:100%;margin-left:auto}.search-control-row{display:flex;align-items:stretch;gap:8px;flex-wrap:nowrap;width:100%}.search-control-row .search-input-wrapper{flex:1 1 auto;min-width:0}#search-input,#theme-select{width:250px;padding:8px 12px;font-size:15px;color:var(--search-text);background-color:var(--search-bg);border:1px solid var(--search-border);border-radius:5px;box-shadow:0 1px 5px var(--control-shadow);outline:none;transition:width .3s ease-in-out,border-color .3s ease,background-color .3s ease;font-family:var(--font-sans);height:var(--search-control-height);box-sizing:border-box}#search-input::placeholder{color:var(--search-placeholder)}.search-input-wrapper{position:relative}.search-control-row #search-input{width:100%}#search-input{padding-right:36px}#info-fab{position:fixed;bottom:var(--info-fab-offset);left:var(--info-fab-offset);width:var(--info-fab-size);height:var(--info-fab-size);border-radius:50%;border:none;background-color:var(--search-focus-border);color:#fff;font-size:1rem;font-weight:600;font-family:var(--font-sans);line-height:1;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 10px 18px #0f172a33;transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease;-webkit-tap-highlight-color:transparent;z-index:1900}#info-fab:hover{transform:translateY(-1px) scale(1.02);box-shadow:0 12px 20px #0f172a40}#info-fab:active{transform:scale(.98);box-shadow:0 6px 12px #0f172a33}#info-fab:focus-visible{outline:2px solid rgba(15,23,42,.4);outline-offset:3px}#info-fab i{pointer-events:none;-webkit-user-select:none;user-select:none}#info-panel{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#0f172a73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:4500;opacity:0;pointer-events:none;transition:opacity .25s ease;padding:16px}#info-panel.info-panel--visible{opacity:1;pointer-events:auto}.info-panel__content{width:clamp(260px,80vw,460px);max-height:min(80vh,520px);overflow-y:auto;background-color:var(--popup-bg);color:var(--popup-text);border-radius:12px;border:1px solid var(--popup-border);box-shadow:0 18px 40px #0f172a59;padding:20px 24px;display:flex;flex-direction:column;gap:16px;outline:none}.info-panel__title{margin:0;font-size:1rem;font-family:var(--font-serif);color:var(--popup-heading)}.info-panel__logo,.info-panel__banner{width:100%;height:auto;display:block}.info-panel__caption{margin:8px 0 0;font-size:.85rem;color:var(--bio-color);text-align:center}.info-panel__body{margin:0;font-style:italic;color:var(--bio-color);font-size:.95rem;line-height:1.5}.info-panel__list{margin:0;padding-left:1.25rem;color:var(--popup-text);font-size:.95rem;line-height:1.5;display:flex;flex-direction:column;gap:6px}.info-panel__list li{list-style:disc}#search-clear{position:absolute;top:50%;right:10px;transform:translateY(-50%);background:none;border:none;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:var(--search-placeholder);cursor:pointer;opacity:0;pointer-events:none;transition:opacity .2s ease,color .2s ease}#search-clear span{font-size:14px;line-height:1}#search-clear:hover,#search-clear:focus{color:var(--search-text)}#search-clear:focus-visible{outline:2px solid var(--search-focus-border);outline-offset:2px}#search-container.has-value #search-clear{opacity:1;pointer-events:auto}#search-input:focus,#theme-select:focus{border-color:var(--search-focus-border)}#theme-select{margin-top:8px;cursor:pointer;appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--search-text) 50%),linear-gradient(135deg,var(--search-text) 50%,transparent 50%);background-position:calc(100% - 18px) calc(50% - 2px),calc(100% - 12px) calc(50% - 2px);background-size:6px 6px,6px 6px;background-repeat:no-repeat}#theme-select option{background-color:var(--search-bg);color:var(--search-text)}#suggestions-box{position:absolute;top:100%;left:0;right:0;background-color:var(--suggestion-bg);border:1px solid var(--search-border);border-top:none;border-radius:0 0 5px 5px;max-height:200px;overflow-y:auto;display:none;z-index:1001}.suggestion-item{padding:8px 12px;color:var(--suggestion-text);cursor:pointer;font-size:14px}.suggestion-item:hover{background-color:var(--suggestion-hover-bg)}.popup-relations{display:flex;flex-direction:column;gap:6px;margin-top:6px}.popup-relations h5{margin:0;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:var(--popup-subheading);font-weight:400}.relation-group{display:flex;flex-direction:column;gap:4px}.relation-group__label{font-size:.75rem;font-weight:600;color:var(--popup-subheading)}.relation-list{display:flex;flex-wrap:wrap;gap:6px}.popup-relations .relation-tag{display:inline-block;background-color:var(--relations-bg);color:var(--relations-text);padding:3px 8px;margin:0;border-radius:12px;font-size:.65rem;cursor:pointer;transition:background-color .2s ease,color .2s ease}.popup-relations .relation-tag:hover{background-color:var(--relations-hover)}@media(min-width:600px){.relation-group{flex-direction:row;align-items:baseline;gap:8px;flex-wrap:wrap}.relation-group__label{min-width:90px}}#relations-toggle{width:30px;height:30px;background-color:var(--toggle-bg);border:1px solid var(--toggle-border);border-radius:5px;color:var(--toggle-text);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 1px 5px var(--control-shadow);transition:border-color .3s ease,background-color .3s ease}@media(min-width:600px){.popup-overview{flex-direction:row;align-items:flex-start}.popup-media{flex:0 0 140px;justify-content:flex-start}.popup-media .popup-image{height:clamp(160px,32vh,260px)}}#relations-toggle.active{border-color:var(--toggle-active-border)}#relations-toggle svg{width:20px;height:20px}.leaflet-home-bar{box-shadow:none;background:transparent;border:none}.leaflet-home-bar .leaflet-control-home{width:var(--info-fab-size);height:var(--info-fab-size);background-color:var(--search-focus-border);border:none;border-radius:50%!important;color:#fff;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;cursor:pointer;box-shadow:0 10px 18px #0f172a33;transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease;padding:0;overflow:visible}.leaflet-home-bar .leaflet-control-home:hover,.leaflet-home-bar .leaflet-control-home:focus-visible{transform:translateY(-1px) scale(1.02);box-shadow:0 12px 20px #0f172a40;background-color:var(--search-focus-border)}.leaflet-home-bar .leaflet-control-home:active{transform:scale(.98);box-shadow:0 6px 12px #0f172a33}.leaflet-home-bar .leaflet-control-home i{pointer-events:none;-webkit-user-select:none;user-select:none;font-size:1rem}@media(max-width:600px){:root{--search-control-height: 34px;--search-control-width: clamp(150px, 60vw, 200px);--info-fab-size: 36px;--info-fab-offset: 16px}#search-input,#theme-select{width:100%;font-size:16px}.search-control-row{flex-wrap:wrap}}@media(orientation:portrait){:root{--search-control-width: clamp(160px, 42vw, 210px)}}.theme-shadow{--page-bg: #111827;--page-text: #F9FAFB;--popup-bg: #1F2937;--popup-border: #4B5563;--popup-text: #D1D5DB;--popup-heading: #F9FAFB;--popup-subheading: #9CA3AF;--popup-strong: #9CA3AF;--popup-link: #60A5FA;--popup-link-hover: #93C5FD;--image-placeholder: #4B5563;--bio-color: #9CA3AF;--search-text: #F9FAFB;--search-bg: #374151;--search-border: #4B5563;--search-placeholder: #9CA3AF;--search-focus-border: #60A5FA;--suggestion-bg: #374151;--suggestion-text: #D1D5DB;--suggestion-hover-bg: #4B5563;--relations-bg: #374151;--relations-text: #A5B4FC;--relations-hover: #4B5563;--toggle-bg: #374151;--toggle-border: #4B5563;--toggle-active-border: #60A5FA;--toggle-text: #D1D5DB;--control-shadow: rgba(0, 0, 0, .4)}.theme-lavey{--page-bg: #1C1B1A;--page-text: #F2F1E8;--popup-bg: #282726;--popup-border: #403E3C;--popup-text: #E6E2D1;--popup-heading: #FFFCF0;--popup-subheading: #CE5D97;--popup-strong: #DA702C;--popup-link: #4385BE;--popup-link-hover: #8B7EC8;--image-placeholder: #343331;--bio-color: #CE5D97;--search-text: #F2F1E8;--search-bg: #343331;--search-border: #4C4A48;--search-placeholder: #B7B1A8;--search-focus-border: #DA702C;--suggestion-bg: #343331;--suggestion-text: #E6E2D1;--suggestion-hover-bg: #403E3C;--relations-bg: #403E3C;--relations-text: #D0A215;--relations-hover: #4C4A48;--toggle-bg: #343331;--toggle-border: #4C4A48;--toggle-active-border: #DA702C;--toggle-text: #F2F1E8;--control-shadow: rgba(16, 15, 15, .5)}.theme-stirner{--page-bg: #F2F1E8;--page-text: #1C1B1A;--popup-bg: #FFFCF0;--popup-border: #E6E2D1;--popup-text: #282726;--popup-heading: #1C1B1A;--popup-subheading: #4385BE;--popup-strong: #879A39;--popup-link: #DA702C;--popup-link-hover: #D14D41;--image-placeholder: #E6E2D1;--bio-color: #575653;--search-text: #1C1B1A;--search-bg: #E6E2D1;--search-border: #DAD1BD;--search-placeholder: #575653;--search-focus-border: #4385BE;--suggestion-bg: #FFFCF0;--suggestion-text: #282726;--suggestion-hover-bg: #E6E2D1;--relations-bg: #E6E2D1;--relations-text: #DA702C;--relations-hover: #D0A215;--toggle-bg: #E6E2D1;--toggle-border: #D0A215;--toggle-active-border: #4385BE;--toggle-text: #1C1B1A;--control-shadow: rgba(34, 29, 24, .15)}.theme-karl{--page-bg: #100F0F;--page-text: #F2F1E8;--popup-bg: #1C1B1A;--popup-border: #3AA99F;--popup-text: #E6E2D1;--popup-heading: #F2F1E8;--popup-subheading: #3AA99F;--popup-strong: #879A39;--popup-link: #3AA99F;--popup-link-hover: #4385BE;--image-placeholder: #282726;--bio-color: #8B7EC8;--search-text: #F2F1E8;--search-bg: #282726;--search-border: #3AA99F;--search-placeholder: #8B7EC8;--search-focus-border: #8B7EC8;--suggestion-bg: #282726;--suggestion-text: #E6E2D1;--suggestion-hover-bg: #343331;--relations-bg: #1C1B1A;--relations-text: #3AA99F;--relations-hover: #343331;--toggle-bg: #282726;--toggle-border: #3AA99F;--toggle-active-border: #879A39;--toggle-text: #F2F1E8;--control-shadow: rgba(12, 12, 12, .55)}
