:root{color:#18201d;background:#f5f3ed;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Hiragino Sans,Yu Gothic,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input{font:inherit}button{cursor:pointer}.app-shell{width:min(1480px,100%);margin:0 auto;padding:20px}.topbar,.notice-bar,.map-panel,.detail-panel,.leaderboard-section{border:1px solid #d9d4c5;background:#fffef9eb;box-shadow:0 18px 50px #2b2c2612}.topbar{display:flex;align-items:center;justify-content:space-between;gap:20px;min-height:86px;padding:16px 18px;border-radius:8px}.brand-block,.top-metrics,.panel-heading,.notice-bar,.list-title,.detail-header,.vote-head,.stats-heading{display:flex;align-items:center}.brand-block{gap:12px;min-width:0}.brand-mark{display:grid;place-items:center;width:44px;height:44px;border-radius:8px;color:#fffef9;background:#b43b2f;flex:0 0 auto}.eyebrow{margin:0 0 4px;color:#69726c;font-size:.73rem;font-weight:800;letter-spacing:0;text-transform:uppercase}h1,h2,h3,p{margin-top:0}h1{margin-bottom:0;font-size:clamp(1.4rem,2.2vw,2rem);letter-spacing:0}h2{margin-bottom:0;font-size:1.25rem;letter-spacing:0}h3{margin-bottom:0;font-size:1rem;letter-spacing:0}.top-metrics{gap:10px;flex-wrap:wrap;justify-content:flex-end}.top-metrics>div{min-width:132px;padding:10px 12px;border-radius:8px;border:1px solid #ded7c7;background:#f8f6ef}.top-metrics span,.label,.stat-cell span,.hint,.member-row small,.rank-row small{color:#6f776f;font-size:.78rem}.top-metrics strong{display:block;margin-top:3px;font-size:.98rem}.notice-bar{margin:14px 0;padding:10px 14px;border-radius:8px;gap:9px;color:#31463f;background:#edf5ed;box-shadow:none}.workspace{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(390px,.85fr);gap:16px;align-items:start}.map-panel,.detail-panel,.leaderboard-section{border-radius:8px;padding:16px}.panel-heading{justify-content:space-between;gap:12px;margin-bottom:14px}.pill,.role-badge{display:inline-flex;align-items:center;justify-content:center;gap:6px;border-radius:999px;min-height:28px;padding:5px 10px;font-size:.78rem;font-weight:800;color:#214137;background:#dff0e5;white-space:nowrap}.pill.muted{color:#6b6254;background:#eee5d4}.search-box{display:flex;align-items:center;gap:10px;width:100%;min-height:46px;margin-bottom:14px;padding:0 13px;border:1px solid #d7d1c2;border-radius:8px;background:#fffefa}.search-box input{width:100%;min-width:0;border:0;outline:0;background:transparent;color:#18201d}.member-tabs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;margin-bottom:12px}.tab-button{min-height:40px;border:1px solid #d7d1c2;border-radius:8px;color:#4b5852;background:#f8f5ec;font-weight:900}.tab-button.active{border-color:#2f675b;color:#fffefa;background:#2f675b}.map-and-list{display:grid;grid-template-columns:minmax(320px,.9fr) minmax(260px,.7fr);gap:14px;align-items:start}.japan-map{display:grid;grid-template-columns:repeat(8,minmax(34px,1fr));grid-template-rows:repeat(22,28px);gap:5px;min-height:706px;padding:12px;border-radius:8px;border:1px solid #d7d1c2;background:linear-gradient(180deg,#eef6f2eb,#f8f4e8eb),#f6f2e6}.proportional-panel{display:grid;align-content:start;gap:12px;min-height:706px;padding:16px;border-radius:8px;border:1px solid #d7d1c2;background:linear-gradient(180deg,#eef6f2eb,#f8f4e8eb),#f6f2e6}.block-map{display:grid;grid-template-columns:repeat(8,minmax(34px,1fr));grid-template-rows:repeat(18,31px);gap:5px;min-height:638px}.kana-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.kana-button{min-height:50px;border:1px solid #c9d2c9;border-radius:8px;color:#20332e;background:#f8fbf7;font-weight:900}.kana-button:hover,.kana-button.active{border-color:#b43b2f;background:#ffe8df}.pref-tile,.block-tile{min-width:0;min-height:28px;padding:0 4px;border:1px solid #c9d2c9;border-radius:7px;color:#20332e;background:#f8fbf7;font-size:clamp(.62rem,1.2vw,.78rem);font-weight:800;line-height:1;transition:transform .16s ease,border-color .16s ease,background .16s ease}.pref-tile:hover,.pref-tile.active,.block-tile:hover,.block-tile.active{border-color:#b43b2f;background:#ffe8df;transform:translateY(-1px)}.member-list{max-height:706px;border-radius:8px;border:1px solid #d7d1c2;overflow-y:auto;background:#fffefa}.member-list-backdrop,.detail-backdrop,.member-list-close{display:none}.list-title{position:sticky;top:0;z-index:1;gap:8px;min-height:44px;padding:0 12px;border-bottom:1px solid #e5dfd1;background:#f7f4ea}.member-row{display:flex;align-items:center;justify-content:space-between;width:100%;min-height:66px;gap:10px;padding:10px 12px;border:0;border-bottom:1px solid #ece6d8;color:#1d2521;background:#fffefa;text-align:left}.member-row:last-child{border-bottom:0}.member-row.selected{background:#f0f7f2}.member-row span,.rank-row div{min-width:0}.member-row strong,.member-row small,.rank-row strong,.rank-row small{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-row em{flex:0 1 auto;color:#9b3a31;font-size:.72rem;font-style:normal;font-weight:800;text-align:right}.empty-list{display:grid;place-items:center;min-height:160px;padding:18px;color:#6f776f;background:#fffefa;font-size:.88rem;font-weight:800;text-align:center}.detail-panel{position:sticky;top:16px}.empty-detail{display:grid;place-items:center;min-height:240px;text-align:center}.empty-detail p:not(.eyebrow){max-width:280px;margin:8px auto 0;color:#6f776f}.detail-header{justify-content:space-between;gap:16px;margin-bottom:14px}.detail-header p:not(.eyebrow){margin-bottom:0;color:#6d736e;font-size:.86rem}.icon-button{display:grid;place-items:center;width:36px;height:36px;border:1px solid #d7d1c2;border-radius:8px;color:#53605a;background:#fffefa}.salary-card,.vote-card,.stats-card{border:1px solid #ded7c7;border-radius:8px;background:#fffefa}.salary-card{display:flex;justify-content:space-between;gap:12px;padding:14px;margin-bottom:12px}.salary-card strong{display:block;margin:4px 0;font-size:clamp(1.7rem,4vw,2.5rem);line-height:1;color:#9c332a}.salary-card p{margin-bottom:0;color:#6f776f;font-size:.82rem}.role-badge{align-self:start}.vote-card,.stats-card{padding:14px;margin-bottom:12px}.vote-head,.stats-heading{justify-content:space-between;gap:12px;margin-bottom:14px}.vote-head>strong{display:grid;place-items:center;min-width:76px;min-height:38px;border-radius:8px;color:#fffefa;background:#2f675b}.range-readout{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:10px}.range-readout span{color:#69726c;font-size:.82rem;font-weight:800}.range-readout strong{color:#18201d;font-size:clamp(1.45rem,4vw,2.1rem)}.salary-slider{width:100%;accent-color:#b43b2f}.quick-actions{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:7px;margin:12px 0}.quick-actions button{min-height:34px;padding:0 4px;border:1px solid #d7d1c2;border-radius:8px;color:#2f3c37;background:#f8f5ec;font-size:.8rem;font-weight:800}.turnstile-box{display:grid;gap:6px;margin:10px 0 12px}.turnstile-widget{min-height:65px}.turnstile-box-silent{min-height:0;margin:0 0 10px}.turnstile-box-silent .turnstile-widget{min-height:0}.turnstile-box span{display:grid;place-items:center;min-height:44px;border:1px dashed #d7d1c2;border-radius:8px;color:#6f776f;background:#f8f5ec;font-size:.82rem}.turnstile-box small{color:#6f776f;font-size:.75rem}.primary-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;min-height:46px;border:0;border-radius:8px;color:#fffefa;background:#b43b2f;font-weight:900}.share-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;min-height:42px;margin-top:8px;border:1px solid #d7d1c2;border-radius:8px;color:#24342f;background:#fffefa;font-weight:900}.primary-button:disabled{cursor:progress;opacity:.72}.stat-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.stat-cell{min-height:74px;padding:10px;border-radius:8px;background:#f8f5ec}.stat-cell strong{display:block;margin-top:7px;overflow-wrap:anywhere;font-size:.98rem}.hint{margin:10px 0 0}.empty-state,.empty-rank{display:grid;place-items:center;min-height:96px;padding:16px;border-radius:8px;color:#6f776f;background:#f8f5ec;text-align:center}.empty-state strong{color:#26332e}.empty-state p{margin:6px 0 0;font-size:.84rem}.empty-rank{min-height:80px;font-size:.84rem;font-weight:800}.leaderboard-section{margin-top:16px}.site-footer{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap;margin:16px 0 4px;color:#6f776f;font-size:.82rem}.footer-link{min-height:34px;padding:0 10px;border:1px solid #d7d1c2;border-radius:8px;color:#24342f;background:#fffefa;font-weight:900}.privacy-backdrop{position:fixed;inset:0;z-index:90;border:0;padding:0;background:#18201d6b}.privacy-dialog{position:fixed;inset:50% auto auto 50%;z-index:100;width:min(760px,calc(100vw - 32px));max-height:min(760px,calc(100dvh - 32px));padding:18px;border:1px solid #d9d4c5;border-radius:8px;background:#fffefa;box-shadow:0 24px 70px #18201d47;transform:translate(-50%,-50%);overflow-y:auto}.privacy-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:14px}.privacy-content{color:#38433e;font-size:.92rem;line-height:1.72}.privacy-content h3{margin-top:18px;margin-bottom:8px}.privacy-content p,.privacy-content ul{margin-bottom:10px}.privacy-content ul{padding-left:1.2rem}.privacy-content a{color:#2f675b;font-weight:900}.leaderboard-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.leaderboard-card{min-width:0;padding:12px;border:1px solid #ded7c7;border-radius:8px;background:#fffefa}.leaderboard-card h3{display:flex;align-items:center;gap:8px;margin-bottom:10px}.rank-row{display:grid;grid-template-columns:28px minmax(0,1fr) auto;align-items:center;gap:9px;min-height:52px;border-top:1px solid #ece6d8}.rank-row>span{display:grid;place-items:center;width:25px;height:25px;border-radius:50%;color:#fffefa;background:#2f675b;font-size:.8rem;font-weight:900}.rank-row em{color:#9b3a31;font-style:normal;font-weight:900;white-space:nowrap}@media(max-width:1180px){.workspace,.map-and-list,.leaderboard-grid{grid-template-columns:1fr}.detail-panel{position:static}.japan-map{grid-template-rows:repeat(22,26px);min-height:658px}.proportional-panel{min-height:260px}.block-map{grid-template-rows:repeat(18,28px);min-height:589px}.member-list{max-height:520px}}@media(max-width:720px){.app-shell{padding:10px}.topbar{align-items:flex-start;flex-direction:column;min-height:64px;padding:12px}.top-metrics,.notice-bar{display:none}.top-metrics{width:100%;justify-content:stretch}.top-metrics>div{flex:1 1 140px}.map-panel,.detail-panel,.leaderboard-section{padding:12px}.japan-map{grid-template-columns:repeat(8,minmax(27px,1fr));grid-template-rows:repeat(22,24px);gap:4px;min-height:606px;padding:8px}.proportional-panel{min-height:180px;padding:10px}.block-map{grid-template-columns:repeat(8,minmax(27px,1fr));grid-template-rows:repeat(18,24px);gap:4px;min-height:500px}.pref-tile,.block-tile{border-radius:6px;font-size:.58rem}.kana-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.member-list{max-height:380px}.member-list-backdrop{display:block;position:fixed;inset:0;z-index:40;padding:0;border:0;background:#18201d33}.detail-backdrop{display:block;position:fixed;inset:0;z-index:60;padding:0;border:0;background:#18201d3d}.member-list{position:fixed;top:0;right:0;bottom:0;z-index:50;width:min(88vw,370px);height:100dvh;max-height:none;border-radius:8px 0 0 8px;background:#fffefa;box-shadow:-18px 0 48px #2b2c263d;transform:translate(105%);transition:transform .22s ease}.member-list.mobile-open{transform:translate(0)}.detail-panel{position:fixed;top:0;right:0;bottom:0;z-index:70;width:min(92vw,410px);height:100dvh;padding:12px;overflow-y:auto;border-radius:8px 0 0 8px;background:#fffefa;box-shadow:-18px 0 48px #2b2c2642;transform:translate(105%);transition:transform .22s ease}.detail-panel.detail-drawer-open{transform:translate(0)}.empty-detail{display:none}.list-title{min-height:54px}.list-title strong{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.member-list-close{display:grid;place-items:center;flex:0 0 auto;width:34px;height:34px;margin-left:auto;border:1px solid #d7d1c2;border-radius:8px;color:#53605a;background:#fffefa}.salary-card{flex-direction:column}.stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.quick-actions{grid-template-columns:repeat(5,minmax(48px,1fr));overflow-x:auto;padding-bottom:2px}.quick-actions button{min-width:48px}.site-footer{align-items:stretch;flex-direction:column;margin-top:12px;text-align:center}.privacy-dialog{inset:auto 0 0;width:100%;max-height:88dvh;border-radius:8px 8px 0 0;transform:none}}
