:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Hiragino Sans,Hiragino Kaku Gothic ProN,Yu Gothic,Meiryo,sans-serif;line-height:1.5;font-weight:400;color-scheme:light}*,*:before,*:after{box-sizing:border-box}html{min-width:320px}body{margin:0;padding:0;box-sizing:border-box;background:radial-gradient(circle at 12% 8%,#ffffffeb 0,#fff0 28%),linear-gradient(135deg,#f1fdff,#bdefff 44%,#f8fdff);min-height:100vh;color:#12384f;overflow-x:hidden}.App{min-height:100vh;min-width:0}.container{width:100%;max-width:1680px;margin:0 auto;padding:14px 18px 18px;box-sizing:border-box;display:flex;flex-direction:column;height:100vh;min-height:0;min-width:0}.map-wrapper{width:100%;height:100%;position:relative;touch-action:none;overscroll-behavior:contain;min-width:0}.map-wrapper svg{display:block;max-width:100%}.japan-map-svg{width:100%;height:100%;cursor:grab;touch-action:none;overscroll-behavior:contain}.japan-map-svg.is-dragging{cursor:grabbing}.prefecture-path{outline:none;transition:fill .2s ease}.prefecture-path:hover{fill-opacity:.8}.map-loading{width:100%;height:100%;min-height:100%;border-radius:8px;background:linear-gradient(180deg,#ffffffbd,#ccf6ff80),linear-gradient(135deg,#effdfffa,#aceaf88a);position:relative;overflow:hidden}.map-loading:after{content:"";position:absolute;left:0;right:0;bottom:0;height:32%;background:linear-gradient(180deg,#afe8f700,#7ad8f038)}.app-header{display:grid;grid-template-columns:minmax(230px,.85fr) minmax(360px,1.15fr) auto;align-items:center;gap:14px;padding:10px 0 14px;position:relative;z-index:20;min-width:0}.brand-block{min-width:0}h1{font-family:inherit;font-size:1.75rem;font-weight:700;background:linear-gradient(135deg,#008fc2,#12b7de 52%,#48dce7);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 10px 35px rgba(36,168,211,.22);margin:0 0 2px;line-height:1.2}.stats-bar{display:flex;justify-content:flex-end;gap:10px;margin:0;flex-wrap:wrap}.progress-stat{box-sizing:border-box;width:158px;min-width:0;padding:9px 16px;border:1px solid rgba(36,172,216,.34);border-radius:12px;background:#ffffffad;backdrop-filter:blur(10px);box-shadow:0 12px 32px #2aa5cd1f;display:grid;justify-items:center;text-align:center}.progress-label{color:#087ea4;font-size:.72rem;font-weight:900;line-height:1}.progress-number{color:#12384f;font-size:1.42rem;font-weight:900;line-height:1.08;margin-top:4px;font-variant-numeric:tabular-nums;display:flex;align-items:baseline;justify-content:center;width:100%}.progress-number span{color:#0aa4ca;font-size:.88rem;margin-left:4px}@media(max-width:1180px){.app-header{grid-template-columns:1fr auto;align-items:stretch}.header-filter{grid-column:1 / -1;grid-row:2}.stats-bar{justify-content:flex-end}}@media(max-width:720px){.app-header{grid-template-columns:1fr}.stats-bar{justify-content:flex-start}}.main-content{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:16px;margin-top:4px;flex:1 1 auto;min-height:0;min-width:0;overflow:hidden}@media(max-width:1100px){.container{height:auto;min-height:100vh;overflow:visible}.main-content{grid-template-columns:1fr;min-height:auto;overflow:visible}.map-container{height:68vh;min-height:520px}.sidebar{max-height:none}}@media(max-width:720px){.container{padding:10px;max-width:100vw;overflow-x:hidden}.app-header{gap:10px;padding:6px 0 10px;width:100%;max-width:calc(100vw - 20px)}h1{font-size:1.36rem;line-height:1.15;white-space:nowrap}.progress-stat{width:100%;padding:8px 12px;grid-template-columns:minmax(0,1fr) auto;align-items:center;justify-items:start;text-align:left}.progress-number{justify-content:flex-end;margin-top:0;font-size:1.28rem}.main-content{gap:12px;width:100%;max-width:calc(100vw - 20px)}.map-container{width:100%;max-width:calc(100vw - 20px);height:58vh;min-height:390px;max-height:520px;padding:8px;border-radius:12px}}.map-container{position:relative;box-sizing:border-box;background:linear-gradient(180deg,#ffffff9e,#cbf5ff66);border-radius:14px;padding:14px;border:1px solid rgba(65,178,218,.28);overflow:hidden;height:100%;min-height:0;min-width:0;box-shadow:inset 0 1px #ffffffb8,0 18px 50px #2aa5cd29}.zoom-controls{position:absolute;left:14px;bottom:14px;z-index:7;display:flex;flex-direction:column;gap:8px;pointer-events:auto}.zoom-controls .filter-btn{width:44px;height:44px;padding:0;border-radius:12px;background:#ffffffc2;color:#11617d;backdrop-filter:blur(8px)}.okinawa-inset{position:absolute;top:56px;left:14px;z-index:5;width:260px;height:190px;border:1px solid rgba(255,122,89,.46);border-radius:8px;background:#effcffd6;box-shadow:0 18px 42px #2aa5cd24;overflow:hidden;backdrop-filter:blur(10px);transform-origin:top left;transition:opacity .18s ease,transform .18s ease,visibility .18s ease}.okinawa-inset.is-hidden{opacity:0;visibility:hidden;pointer-events:none;transform:translateY(-8px) scale(.92)}@media(max-width:720px){.zoom-controls{left:8px;bottom:8px;gap:6px}.zoom-controls .filter-btn{width:40px;height:40px;border-radius:10px}.okinawa-inset{top:12px;left:8px;width:min(40vw,160px);height:min(28vw,112px);border-radius:7px}}.point-status{color:#087ea4;font-size:.72rem;font-weight:900}.point-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.point-tags span{border:1px solid rgba(54,173,211,.22);border-radius:999px;color:#23708c;font-size:.7rem;padding:4px 8px;background:#ffffff80}.water-quality-card,.water-quality-empty{margin-top:12px;border-radius:14px;border:1px solid rgba(54,173,211,.22);background:#ffffff94;padding:12px}.water-quality-title{display:flex;justify-content:space-between;gap:8px;color:#12384f;font-weight:900;margin-bottom:10px}.water-quality-title small{color:#087ea4;font-weight:700}.reference-card{border-color:#36add342;background:#cff6ff8c}.reference-title{color:#0b789b}.water-grid{display:grid;grid-template-columns:72px 1fr;gap:6px 10px;align-items:baseline}.water-grid span{color:#0583ad;font-weight:900;font-size:.78rem}.water-grid strong{color:#102f43;font-size:.9rem;font-variant-numeric:tabular-nums}.record-memo{border-top:1px solid rgba(54,173,211,.18);padding-top:9px;line-height:1.55}.record-note{border:1px solid rgba(255,159,64,.28);border-radius:8px;background:#fff5e4b8;color:#8a5a11;font-size:.74rem;font-weight:800;line-height:1.55;padding:8px 9px}.record-note+.record-memo{border-top:0;padding-top:0}.water-quality-empty{color:#23708c;font-size:.85rem;font-weight:700}.custom-tooltip{background:#f7fdfff5!important;border:1px solid rgba(54,173,211,.4);border-radius:10px!important;padding:12px 16px!important;opacity:1!important;backdrop-filter:blur(10px);z-index:1000}.tooltip-content h3{font-weight:700;color:#0286b0;margin:0 0 5px;font-size:1rem}.tooltip-content p{color:#456b7c;font-size:.8rem;margin:0}.tooltip-content span{display:inline-block;margin-top:8px;padding:3px 8px;border-radius:4px;font-size:.75rem;background:#36add324;color:#0b789b}.sidebar{box-sizing:border-box;background:#ffffff94;border-radius:14px;padding:16px;border:1px solid rgba(65,178,218,.28);max-height:100%;min-height:0;min-width:0;overflow-y:auto;display:flex;flex-direction:column;gap:16px;box-shadow:0 18px 50px #2aa5cd24;backdrop-filter:blur(12px)}@media(max-width:720px){.sidebar{width:100%;max-width:calc(100vw - 20px);padding:12px;border-radius:12px;gap:12px}.sidebar h2{font-size:1rem;margin-bottom:10px}}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:#fff6;border-radius:3px}.sidebar::-webkit-scrollbar-thumb{background:#36add36b;border-radius:3px}.sidebar h2{font-family:inherit;font-size:1.05rem;color:#087ea4;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid rgba(54,173,211,.22);margin-top:0}.section-heading-row{display:flex;align-items:center;justify-content:flex-start;gap:10px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid rgba(54,173,211,.22)}.section-heading-row h2{margin:0;padding:0;border:0}.ranking-list{display:flex;flex-direction:column;gap:8px}.ranking-item{width:100%;border:1px solid rgba(0,127,168,.22);border-radius:10px;background:#ffffff80;color:#12384f;cursor:pointer;display:grid;grid-template-columns:28px minmax(0,1fr) 50px;gap:8px;align-items:center;padding:8px;text-align:left;font:inherit;transition:border-color .2s,background .2s,transform .2s}.ranking-item:hover{border-color:#007fa880;background:#ffffffbd;transform:translateY(-1px)}.ranking-item.top-rank{border-color:#b08a006b;background:linear-gradient(135deg,#ffffffc2,#fff4be6b)}.ranking-rank{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;background:#007fa8;color:#fff;font-size:.82rem;font-weight:900;box-shadow:0 7px 18px #007fa833}.top-rank .ranking-rank{background:#b08a00;box-shadow:0 7px 18px #b08a002e}.ranking-main{min-width:0;display:flex;flex-direction:column;gap:2px}.ranking-main strong{color:#10384f;font-size:.82rem;line-height:1.25}.ranking-main em{color:#2f667c;font-size:.66rem;font-style:normal;font-weight:800;line-height:1.25}.ranking-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:3px;margin-top:2px}.ranking-metrics small{border-radius:999px;background:#007fa81c;color:#075c78;font-size:.57rem;font-weight:900;padding:2px 4px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:clip}.ranking-bar{height:4px;width:100%;border-radius:999px;background:#007fa821;overflow:hidden;margin-top:4px}.ranking-bar i{display:block;height:100%;min-width:12%;border-radius:inherit;background:linear-gradient(90deg,#007fa8,#1cc7db)}.top-rank .ranking-bar i{background:linear-gradient(90deg,#b08a00,#ffbd2d)}.ranking-score{display:flex;flex-direction:column;align-items:flex-end;line-height:1}.ranking-score strong{color:#007fa8;font-size:1.1rem;font-weight:900;font-variant-numeric:tabular-nums}.top-rank .ranking-score strong{color:#8d6e00}.ranking-score small{color:#4b7b8d;font-size:.58rem;font-weight:900;margin-top:3px}@media(max-width:720px){.ranking-list{gap:7px}.ranking-item{grid-template-columns:26px minmax(0,1fr) 44px;gap:7px;padding:7px}.ranking-rank{width:26px;height:26px;font-size:.78rem}.ranking-main strong{font-size:.78rem}.ranking-main em{font-size:.62rem}.ranking-metrics{gap:2px}.ranking-metrics small{font-size:.52rem;padding:2px 3px}.ranking-score strong{font-size:.98rem}}.data-copyright{margin:auto 0 0;padding-top:12px;border-top:1px solid rgba(54,173,211,.18);color:#4b7b8d;font-size:.64rem;font-weight:700;line-height:1.55}.selected-detail-focus{scroll-margin-top:12px;outline:none}.selected-detail-focus:focus,.selected-detail-focus:focus-visible{outline:none}.selected-detail{margin-bottom:0;padding:14px;border:1px solid rgba(54,173,211,.26);border-left:4px solid #78909c;border-radius:12px;background:#ffffffa3;box-shadow:0 18px 42px #2aa5cd1f}.selected-detail.kind-meisui{border-left-color:#31d9ff}.selected-detail.kind-hidden{border-left-color:#ff7a59}.selected-detail-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.selected-detail h2{margin:2px 0 0;padding:0;border:0;color:#14384f;font-family:inherit;font-size:1.1rem;line-height:1.25}.selected-detail p{margin:8px 0 0;color:#42687b;font-size:.82rem}.selected-detail .water-quality-card,.selected-detail .water-quality-empty{margin-top:12px}@media(max-width:720px){.selected-detail{padding:12px;border-radius:12px}.selected-detail h2{font-size:1rem}.selected-detail p{font-size:.78rem}.water-quality-card,.water-quality-empty{padding:10px;border-radius:12px}.water-grid{grid-template-columns:56px minmax(0,1fr);gap:5px 8px}.water-grid span{font-size:.74rem}.water-grid strong{font-size:.82rem;overflow-wrap:anywhere}.youtube-section h3{font-size:.86rem}}.youtube-section{margin-top:12px}.youtube-section h3{margin:0 0 8px;color:#0f0f0f;font-size:.92rem;font-weight:900;display:flex;align-items:center;gap:7px}.youtube-embed{position:relative;width:100%;aspect-ratio:16 / 9;overflow:hidden;border:1px solid rgba(54,173,211,.22);border-radius:12px;background:#d8f6ff99}.youtube-embed+.youtube-embed{margin-top:10px}.youtube-embed.is-loaded{background:#061e29}.youtube-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}.youtube-load-card{width:100%;height:100%;border:0;padding:16px;display:flex;align-items:flex-end;text-align:left;cursor:pointer;color:#fff;background:#0f0f0f}.youtube-load-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.9;filter:saturate(1.08) contrast(.95)}.youtube-load-card:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,#0f0f0f0a,#0f0f0f29 46%,#0f0f0fc2),linear-gradient(90deg,#0f0f0f57,#0f0f0f05 58%)}.youtube-load-card:hover{background:#0f0f0f}.youtube-load-copy{min-width:0;display:flex;flex-direction:column;gap:6px;position:relative;z-index:1;width:100%}.youtube-load-copy strong{font-size:.94rem;line-height:1.35;font-weight:900;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.5);overflow-wrap:anywhere}.youtube-card-brand{width:fit-content;display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:6px;background:#0f0f0fb8;color:#fff;font-size:.7rem;font-weight:900}.youtube-logo-mark{width:24px;height:17px;border-radius:5px;background:#f03;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;box-shadow:0 5px 12px #f033}.youtube-logo-mark:before{content:"";width:0;height:0;border-top:4px solid transparent;border-bottom:4px solid transparent;border-left:7px solid #fff;margin-left:2px}.filter-buttons{display:flex;gap:8px;margin-bottom:0;flex-wrap:wrap}.filter-btn{box-sizing:border-box;padding:8px 14px;border:1px solid rgba(54,173,211,.3);background:#ffffff6b;color:#176985;border-radius:20px;cursor:pointer;font-size:.85rem;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:8px}.header-filter{min-width:0}.header-filter .filter-buttons{display:grid;grid-template-columns:repeat(4,minmax(96px,1fr));justify-content:center;flex-wrap:initial;width:100%;min-width:0}.header-filter .filter-btn{min-width:0;width:100%;justify-content:space-between}@media(max-width:720px){.header-filter,.stats-bar{width:100%;max-width:calc(100vw - 20px)}.header-filter .filter-buttons{grid-template-columns:repeat(2,minmax(0,1fr));gap:7px;width:100%;max-width:calc(100vw - 20px)}.header-filter .filter-btn{max-width:none;min-height:42px;padding:8px 10px;border-radius:14px;font-size:.78rem}}.filter-btn strong{color:#12384f;font-size:.78rem;font-variant-numeric:tabular-nums}.filter-btn:hover,.filter-btn.active{background:#31d9ff2e;border-color:#16b8db;color:#07384f}@media(max-width:420px){.container{padding:8px}.app-header,.main-content,.map-container,.sidebar,.header-filter,.stats-bar,.header-filter .filter-buttons{max-width:calc(100vw - 16px)}h1{font-size:1.22rem}.progress-label{font-size:.68rem}.progress-number{font-size:1.18rem}.progress-number span{font-size:.78rem}.header-filter .filter-btn{gap:6px;padding:7px 8px;font-size:.72rem}.filter-btn strong{font-size:.72rem}.map-container{height:54vh;min-height:340px;padding:6px}.okinawa-inset{width:128px;height:96px;top:10px;left:8px}.zoom-controls .filter-btn{width:38px;height:38px}.custom-tooltip{display:none}.data-copyright{font-size:.58rem}}@keyframes pulse{0%,to{transform:scale(1);opacity:.3}50%{transform:scale(1.5);opacity:.1}}.marker-pulse{animation:pulse 2s infinite;transform-origin:center;transform-box:fill-box}.marker-group{cursor:pointer;-webkit-tap-highlight-color:transparent;outline:none}.marker-group:focus,.marker-group:focus-visible{outline:none}.marker-group>circle:not(:first-child),.marker-group>path{filter:drop-shadow(0 1px 2px rgba(5,43,58,.4))}.marker-group:hover .marker-pulse{animation:none;opacity:.5;transform:scale(1.5)}.wave-bg{position:fixed;bottom:0;left:0;width:100%;height:200px;pointer-events:none;opacity:.16;z-index:0}.wave{position:absolute;bottom:0;left:0;width:200%;height:100%;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1200 120' preserveAspectRatio='none'%3E%3Cpath d='M0,60 C150,120 350,0 600,60 C850,120 1050,0 1200,60 L1200,120 L0,120 Z' fill='%2364b5f6'/%3E%3C/svg%3E") repeat-x;background-size:600px 100%;animation:wave 8s linear infinite}.wave:nth-child(2){bottom:10px;opacity:.5;animation:wave 6s linear infinite reverse}@keyframes wave{0%{transform:translate(0)}to{transform:translate(-600px)}}
