:root{--dock-player-edge:clamp(0.5rem,1.5vmin,0.875rem);--dock-player-height:0rem;--map-control-gap:clamp(0.75rem,2svh,1.25rem);--map-control-clearance:calc(var(--dock-player-edge) + var(--dock-player-height) + var(--map-control-gap))}
html,body,#map{height:100%;margin:0;padding:0}
body{font-family:system-ui, -apple-system, "Helvetica Neue", Arial;color:#222;background:#161715}
#map{height:100vh;background:#161715}
.leaflet-tile-pane{filter:brightness(0.58) saturate(0.62) contrast(1.1)}
.leaflet-control-attribution{background:rgba(20,20,18,0.72)!important;color:#d8d3c8!important}
.leaflet-control-attribution a{color:#f0e7cf!important}
.auth-gate{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,0.6);z-index:9999}
.auth-gate.hidden{display:none}
.auth-box{background:#fff;padding:20px;border-radius:8px;min-width:280px}
.auth-box input{width:100%;margin-top:6px;padding:6px}

.leaflet-popup-content-wrapper{border-radius:8px;box-shadow:0 18px 45px rgba(34,31,25,0.22)}
.leaflet-popup-content{width:280px!important;margin:0}
.popup{overflow:hidden;border-radius:8px;background:#fffdf8}
.leaflet-popup-content img.marker-thumb{width:100%;aspect-ratio:1;object-fit:cover;display:block}
.popup-body{padding:14px 14px 12px}
.popup h3{margin:0 0 8px;font-size:1.08rem;line-height:1.25;color:#27231d}
.popup-category{display:inline-flex;max-width:100%;margin-bottom:8px;padding:3px 7px;border:1px solid #d8d0c2;border-radius:999px;color:#5e5649;background:#f3eee5;font-size:0.7rem;font-weight:700;letter-spacing:0.04em;text-transform:uppercase}
.popup-meta{display:grid;gap:5px;margin:0 0 10px;padding:0}
.popup-meta div{display:grid;grid-template-columns:68px minmax(0,1fr);gap:8px;align-items:baseline}
.popup-meta dt{color:#8a8173;font-size:0.68rem;font-weight:700;letter-spacing:0.04em;text-transform:uppercase}
.popup-meta dd{overflow:hidden;margin:0;color:#3f3930;font-size:0.78rem;text-overflow:ellipsis;white-space:nowrap}
.popup-tags{display:flex;flex-wrap:wrap;gap:5px;margin:0 0 10px}
.popup-tags span{max-width:100%;padding:3px 7px;border-radius:999px;color:#2f625e;background:#e7f0ed;font-size:0.72rem;line-height:1.25}
.popup .desc{margin:0;color:#504a40;font-size:0.92rem;line-height:1.55}
.popup-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:0 14px 14px}
.popup-play{width:100%;min-height:38px;border:0;border-radius:8px;background:#1f6f78;color:#fff;font-weight:700;cursor:pointer}
.popup-play:hover,.popup-play:focus-visible{background:#185a62;outline:none}
.popup-queue{width:100%;min-height:38px;border:1px solid #c9c1b4;border-radius:8px;background:#fffdf8;color:#3f3930;font-weight:700;cursor:pointer}
.popup-queue:hover,.popup-queue:focus-visible{background:#f3eee5;outline:none}

/* marker icon styling (image pins) */
.marker-img{width:48px;height:48px;border:2px solid #fff;border-radius:6px;box-shadow:0 0 0 3px rgba(31,111,120,0.32),0 10px 24px rgba(0,0,0,0.42);object-fit:cover;display:block}
.marker-default{width:24px;height:24px;border:3px solid #fff;border-radius:50%;background:#1f6f78;box-shadow:0 0 0 3px rgba(31,111,120,0.32),0 10px 24px rgba(0,0,0,0.42)}

.map-search{position:fixed;top:14px;left:14px;z-index:1000;width:min(340px,calc(100vw - 120px))}
.map-search input{box-sizing:border-box;width:100%;height:42px;border:1px solid rgba(255,255,255,0.18);border-radius:8px;padding:0 12px;background:rgba(25,26,24,0.9);box-shadow:0 14px 34px rgba(0,0,0,0.28);color:#fffdf8;outline:none}
.map-search input::placeholder{color:#b8b0a4}
.map-search input:focus{border-color:#8fc8bf;box-shadow:0 0 0 3px rgba(143,200,191,0.22),0 14px 34px rgba(0,0,0,0.28)}
.search-results{display:none;margin-top:8px;overflow:hidden;border:1px solid rgba(255,255,255,0.14);border-radius:8px;background:rgba(28,29,27,0.94);box-shadow:0 18px 42px rgba(0,0,0,0.34)}
.search-results.is-open{display:block}
.search-result{display:grid;width:100%;grid-template-columns:42px minmax(0,1fr);gap:10px;align-items:center;border:0;border-bottom:1px solid rgba(255,255,255,0.08);padding:9px 10px;background:transparent;color:#fffdf8;text-align:left;cursor:pointer}
.search-result:last-child{border-bottom:0}
.search-result:hover,.search-result:focus-visible{background:rgba(143,200,191,0.14);outline:none}
.search-result img,.search-fallback{width:42px;height:42px;border-radius:6px;object-fit:cover;background:#1f6f78}
.search-result strong{display:block;overflow:hidden;font-size:0.86rem;line-height:1.25;text-overflow:ellipsis;white-space:nowrap}
.search-result small{display:block;overflow:hidden;margin-top:3px;color:#bdb5aa;font-size:0.72rem;line-height:1.25;text-overflow:ellipsis;white-space:nowrap}
.search-empty{padding:12px;color:#c7beb1;font-size:0.84rem}

.sound-player{margin:0 14px 14px;padding:12px;border:1px solid #e2dbcf;border-radius:8px;background:#f8f5ee}
.player-main{display:flex;align-items:center;gap:10px}
.player-play{width:42px;height:42px;flex:0 0 42px;border:0;border-radius:50%;background:#1f6f78;color:#fff;font-size:0.9rem;font-weight:700;line-height:1;cursor:pointer}
.player-play:hover{background:#185a62}
.player-play:disabled{cursor:not-allowed;background:#a9a197}
.player-play:focus-visible{outline:3px solid rgba(31,111,120,0.28);outline-offset:2px}
.player-track{min-width:0;flex:1}
.player-title{overflow:hidden;margin-bottom:6px;color:#2d2922;font-size:0.82rem;font-weight:700;text-overflow:ellipsis;white-space:nowrap}
.player-seek{width:100%;height:16px;margin:0;accent-color:#1f6f78}
.player-time{display:flex;justify-content:space-between;margin-top:2px;color:#756d61;font-size:0.72rem;font-variant-numeric:tabular-nums}
.meter-panel{display:grid;grid-template-columns:10px 1fr;gap:8px;margin-top:10px}
.rms-meter{position:relative;overflow:hidden;width:10px;height:72px;border-radius:999px;background:#e3ded3}
.rms-meter span{position:absolute;right:0;bottom:0;left:0;width:100%;height:0;background:linear-gradient(0deg,#2f8f83,#d7b44a,#be493d)}
.spectrum-canvas{display:block;width:100%;height:72px;border-radius:6px;background:#f4f1eb}
.sound-player.is-playing{border-color:#bdd2cf;background:#f3f8f6}
.sound-player.has-error{border-color:#d9b8ad;background:#fff7f4}

.dock-player{position:fixed;right:var(--dock-player-edge);bottom:var(--dock-player-edge);left:var(--dock-player-edge);z-index:1200;display:grid;grid-template-columns:72px minmax(0,1fr) minmax(180px,320px);gap:14px;align-items:center;box-sizing:border-box;max-width:1120px;margin:0 auto;padding:12px;border:1px solid rgba(255,255,255,0.14);border-radius:8px;background:rgba(24,25,23,0.94);box-shadow:0 18px 48px rgba(0,0,0,0.42);backdrop-filter:blur(16px);color:#fffdf8}
.dock-player__thumb{width:72px;height:72px;border-radius:8px;background:#1f6f78 center/cover no-repeat}
.dock-player__thumb:not(.has-image)::before{content:"";display:block;width:28px;height:28px;margin:22px auto;border:3px solid rgba(255,255,255,0.76);border-radius:50%}
.dock-player__body{min-width:0}
.dock-player__meta{display:grid;grid-template-columns:minmax(0,1fr) 42px;gap:12px;align-items:center}
.dock-player__label{margin-bottom:3px;color:#8fc8bf;font-size:0.68rem;font-weight:800;letter-spacing:0.1em;text-transform:uppercase}
.dock-player h2{overflow:hidden;margin:0;color:#fffdf8;font-size:1rem;line-height:1.25;text-overflow:ellipsis;white-space:nowrap}
.dock-player p{overflow:hidden;margin:3px 0 0;color:#bdb5aa;font-size:0.78rem;line-height:1.3;text-overflow:ellipsis;white-space:nowrap}
.dock-player__play:disabled{background:#6f6a62;color:#bdb5aa}
.dock-player__controls{margin-top:8px}
.waveform-panel{margin-top:8px}
.waveform-panel canvas{display:block;width:100%;height:76px;border-radius:6px;background:#f4f1eb;cursor:pointer}
.dock-player__buttons{display:flex;flex-wrap:wrap;gap:6px;margin-top:9px}
.dock-player__buttons button,.dock-player__queue button{min-height:30px;border:1px solid rgba(255,255,255,0.14);border-radius:6px;background:rgba(255,255,255,0.08);color:#fffdf8;font-size:0.74rem;font-weight:700;cursor:pointer}
.dock-player__buttons button{padding:0 9px}
.dock-player__buttons button:hover,.dock-player__buttons button:focus-visible,.dock-player__queue button:hover,.dock-player__queue button:focus-visible{background:rgba(143,200,191,0.18);outline:none}
.dock-player__buttons button:disabled,.dock-player__queue button:disabled{cursor:not-allowed;color:#8c867c;background:rgba(255,255,255,0.04)}
.dock-player__buttons button.is-active{border-color:rgba(143,200,191,0.72);background:rgba(143,200,191,0.2);color:#c8f0e9}
.dock-player .player-seek{display:block}
.dock-player .player-time{color:#cfc7ba}
.dock-player__meter{margin-top:0}
.meter-stack{display:grid;gap:8px}
.stereo-canvas{display:block;width:100%;height:72px;border-radius:6px;background:#f4f1eb}
.dock-player__queue{display:none;margin-top:10px;overflow:hidden;border:1px solid rgba(255,255,255,0.12);border-radius:8px;background:rgba(0,0,0,0.18)}
.dock-player.is-queue-open .dock-player__queue{display:block}
.dock-player__queue-head{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-bottom:1px solid rgba(255,255,255,0.1);color:#fffdf8;font-size:0.78rem}
.dock-player__queue-head button{padding:0 8px}
.dock-player__queue ol{max-height:160px;margin:0;padding:0;overflow:auto;list-style:none}
.dock-player__queue li{display:grid;grid-template-columns:minmax(0,1fr) 32px;align-items:center;border-bottom:1px solid rgba(255,255,255,0.08)}
.dock-player__queue li:last-child{border-bottom:0}
.dock-player__queue li.is-current{background:rgba(143,200,191,0.12)}
.dock-player__queue .queue-empty{display:block;padding:10px;color:#bdb5aa;font-size:0.78rem}
.queue-track{display:block;width:100%;min-height:44px;padding:7px 10px!important;border:0!important;background:transparent!important;text-align:left}
.queue-track span,.queue-track small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.queue-track span{color:#fffdf8;font-size:0.78rem}
.queue-track small{margin-top:2px;color:#bdb5aa;font-size:0.68rem}
.queue-remove{width:26px;height:26px;min-height:26px!important;padding:0}
.dock-player.has-error{border-color:rgba(217,184,173,0.72)}
.map-page .leaflet-bottom{bottom:var(--map-control-clearance)}

@media (max-width:720px){
  :root{--dock-player-edge:clamp(0.5rem,2vmin,0.625rem)}
  .map-search{top:10px;left:10px;width:min(300px,calc(100vw - 20px))}
  .map-page .page-nav{top:60px;right:10px}
  .map-page .nav-link{padding:7px 10px;font-size:0.78rem}
  .dock-player{grid-template-columns:52px minmax(0,1fr);gap:8px;padding:9px;max-height:calc(100vh - var(--dock-player-edge) - var(--dock-player-edge));max-height:calc(100svh - var(--dock-player-edge) - var(--dock-player-edge));overflow:auto}
  .dock-player__thumb{width:52px;height:52px}
  .dock-player__thumb:not(.has-image)::before{width:20px;height:20px;margin:16px auto;border-width:2px}
  .dock-player__meta{grid-template-columns:minmax(0,1fr) 38px;gap:8px}
  .dock-player__label{margin-bottom:1px;font-size:0.6rem;letter-spacing:0.08em}
  .dock-player h2{font-size:0.88rem;line-height:1.18}
  .dock-player p{font-size:0.72rem;line-height:1.2}
  .dock-player__play{width:38px;height:38px;flex-basis:38px;font-size:0.82rem}
  .dock-player__buttons{gap:5px;margin-top:7px}
  .dock-player__buttons button{min-height:28px;padding:0 7px;font-size:0.68rem}
  .dock-player__controls{margin-top:7px}
  .player-seek{height:14px}
  .player-time{font-size:0.68rem}
  .waveform-panel{grid-column:1 / -1;margin-top:7px}
  .waveform-panel canvas{height:58px}
  .dock-player__meter{grid-column:1 / -1;grid-template-columns:10px minmax(0,1fr)}
  .meter-stack{grid-template-columns:1fr 1fr;gap:6px}
  .spectrum-canvas,.stereo-canvas{height:54px}
  .rms-meter{height:54px}
  .dock-player__queue{grid-column:1 / -1;margin-top:8px}
  .dock-player__queue ol{max-height:120px}
  .queue-track{min-height:40px;padding:6px 8px!important}
  .queue-track span{font-size:0.74rem}
  .queue-track small{font-size:0.64rem}
  .row{display:grid;grid-template-columns:1fr;gap:8px}
  #marker-list li{display:grid;grid-template-columns:1fr;align-items:start}
  .marker-actions{justify-content:flex-start}
}

@media (max-width:430px){
  .dock-player{grid-template-columns:44px minmax(0,1fr);gap:7px;padding:8px}
  .dock-player__thumb{width:44px;height:44px}
  .dock-player__thumb:not(.has-image)::before{width:17px;height:17px;margin:13px auto}
  .dock-player h2{font-size:0.82rem}
  .dock-player p{font-size:0.68rem}
  .dock-player__buttons{display:grid;grid-template-columns:repeat(3,1fr)}
  .dock-player__buttons button{width:100%;padding:0 4px;font-size:0.64rem}
  .meter-stack{grid-template-columns:1fr}
  .spectrum-canvas,.stereo-canvas{height:48px}
  .rms-meter{height:104px}
}

/* admin styles */
.admin-page{color-scheme:light;color:#222;background:#f7f6f2}
.admin-page .container{background:#f7f6f2}
.container{max-width:900px;margin:24px auto;padding:12px}
.row{display:flex;gap:12px}
label{display:block;margin:8px 0}
input,textarea,button{font:inherit}
.admin-page input,.admin-page textarea,.admin-page select{box-sizing:border-box;border:1px solid #b8b2a8;border-radius:6px;background:#fff;color:#222}
.admin-page input{padding:6px 8px}
.admin-page select{display:block;width:100%;margin-top:6px;padding:6px 8px}
.admin-page textarea{padding:8px}
.admin-page input::placeholder,.admin-page textarea::placeholder{color:#777}
.admin-page button{border:1px solid #8d867b;border-radius:6px;background:#fff;color:#222;cursor:pointer}
.admin-page button:hover{background:#eeebe4}
.admin-page button:focus-visible,.admin-page input:focus,.admin-page textarea:focus,.admin-page select:focus{outline:3px solid rgba(0,122,204,0.22);outline-offset:1px}
textarea{width:100%;height:120px}
.asset-tools,.form-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin:10px 0}
.asset-preview{display:flex;align-items:center;justify-content:center;box-sizing:border-box;width:100%;min-height:52px;margin-top:8px;border:1px solid #ded8ce;border-radius:8px;background:#fff}
.asset-preview--image{width:180px;max-width:100%;aspect-ratio:1;min-height:0;overflow:hidden}
.asset-preview--image img{display:block;width:100%;height:100%;border-radius:7px;object-fit:cover}
.asset-preview audio{width:100%;padding:8px}
.map-panel{margin:18px 0}
.map-panel h2{margin:0 0 8px;font-size:1rem}
#admin-map{height:320px;border:1px solid #cfc8bc;border-radius:8px}
.page-nav{position:fixed;top:14px;right:14px;z-index:1000;margin-bottom:12px}
.container .page-nav{position:static}
.nav-link{display:inline-block;padding:8px 12px;background:#007acc;color:#fff;border-radius:6px;text-decoration:none}
.nav-link:hover{background:#005fa3}
.muted{color:#666;font-size:0.9rem}
#marker-list{list-style:none;padding:0}
#marker-list li{display:flex;gap:10px;align-items:center;justify-content:space-between;padding:8px;border-bottom:1px solid #ded8ce;color:#222}
.marker-actions{display:flex;gap:6px;flex:0 0 auto}
.actions{margin-top:12px}
