*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;background-color:#fdfcf7;color:#1a1a1a;font-family:Inter,Noto Sans Devanagari,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.header{position:fixed;top:0;left:0;right:0;z-index:100;height:70px;background-color:#fdfcf7;border-bottom:1px solid #d4d0c4;display:flex;align-items:center;justify-content:space-between;padding:0 24px}.header-left{display:flex;flex-direction:column;gap:2px}.header-title{font-family:Libre Baskerville,Georgia,serif;font-size:18px;font-weight:400;color:#1a1a1a;line-height:1.2}.header-subtitle{font-family:Libre Baskerville,Georgia,serif;font-size:12px;font-style:italic;color:#6b6560;line-height:1.3}.header-right{display:flex;align-items:center;gap:16px}.header-link{font-size:13px;color:#6b6560;text-decoration:none;white-space:nowrap}.header-link:hover{color:#2c4a2c}.graph-container{position:fixed;inset:70px 0 40px;background-color:#fdfcf7}.graph-container .sigma-container{background-color:#fdfcf7}.legend{position:fixed;bottom:40px;left:0;right:0;height:36px;background-color:#fdfcf7;border-top:1px solid #d4d0c4;border-bottom:1px solid #d4d0c4;display:flex;align-items:center;justify-content:center;gap:32px;z-index:100}.legend-item{display:flex;align-items:center;gap:8px;font-size:12px;color:#6b6560}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.legend-dot--demand{background-color:#9c3a2e}.legend-dot--officer{background-color:#3d5a73;border-radius:0;transform:rotate(45deg);width:8px;height:8px}.legend-dot--budget-head{background-color:#2c4a2c;border-radius:0;width:9px;height:9px}.footer{position:fixed;bottom:0;left:0;right:0;height:40px;background-color:#fdfcf7;display:flex;align-items:center;justify-content:center;gap:8px;font-size:11px;color:#9b9588;z-index:100}.footer a{color:#9b9588;text-decoration:none}.footer a:hover{color:#2c4a2c}.footer-sep{color:#d4d0c4}.btn-reset{background:none;border:1px solid #d4d0c4;color:#6b6560;font-size:12px;padding:4px 10px;cursor:pointer;border-radius:3px;font-family:inherit}.btn-reset:hover{border-color:#2c4a2c;color:#2c4a2c}@media(max-width:768px){.header{height:56px;padding:0 12px}.header-title{font-size:14px}.header-subtitle{display:none}.graph-container{top:56px;bottom:36px}.legend{bottom:36px;height:32px;gap:16px}.legend-item{font-size:11px}.footer{height:36px;font-size:10px}}
