*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--navy:#062a47;--navy-light:#0d3d66;--green:#0a8944;--green-light:#85c441;--sage:#cbe3aa;--sage-pale:#eef7e5;--white:#fff;--gray-50:#f8fafb;--gray-100:#edf0f2;--gray-200:#d1d9df;--gray-600:#5a6a75;--gray-800:#2c3e4a;--text:#1a2b36;--state-default:#c8dde9;--state-hover:#85c441;--state-active:#0a8944;--state-no-law:#e2ebf0;--state-stroke:#fff}body,html{background:var(--gray-50);color:var(--text);font-family:Inter,Segoe UI,Arial,sans-serif;font-size:15px;height:100%;line-height:1.55}.page-wrap{margin:0 auto;max-width:1340px;padding:36px 24px 64px}.page-title{color:var(--navy);font-size:26px;font-weight:700;margin-bottom:5px}.page-subtitle{color:var(--gray-600);font-size:14px;margin-bottom:24px}.page-subtitle strong{color:var(--navy)}.filter-bar{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:22px}.search-input{background:var(--white);border:1.5px solid var(--gray-200);border-radius:7px;color:var(--text);flex:1;font-family:inherit;font-size:13.5px;height:38px;min-width:180px;outline:none;padding:0 14px;transition:border-color .15s}.search-input:focus{border-color:var(--green)}.search-input::placeholder{color:var(--gray-600)}.filter-btn{background:var(--white);border:1.5px solid var(--gray-200);border-radius:7px;color:var(--gray-800);cursor:pointer;font-family:inherit;font-size:13px;font-weight:500;height:38px;padding:0 16px;transition:background .15s,border-color .15s;white-space:nowrap}.filter-btn:hover{background:var(--sage-pale);border-color:var(--green-light)}.filter-btn.active{background:var(--navy);border-color:var(--navy);color:var(--white)}.map-layout{align-items:start;display:grid;gap:24px;grid-template-columns:1fr 390px}@media (max-width:980px){.map-layout{grid-template-columns:1fr}}.map-container{background:var(--white);border-radius:12px;box-shadow:0 1px 4px rgba(6,42,71,.07),0 4px 16px rgba(6,42,71,.04);padding:20px}#us-map{display:block;height:auto;width:100%}.state{cursor:pointer;fill:var(--state-default);stroke:#fff;stroke-width:.8;transition:fill .15s ease}.state:hover{fill:var(--state-hover)}.state.active{fill:var(--state-active)}.state.no-law{fill:var(--state-no-law)}.state.no-law:hover{fill:var(--state-hover)}.state.no-law.active{fill:#7a9bad}.state.dimmed{opacity:.15;pointer-events:none}.state-borders{fill:none;pointer-events:none;stroke:#fff;stroke-width:.8}.state-label{dominant-baseline:middle;fill:var(--navy);font-family:Inter,Segoe UI,Arial,sans-serif;font-size:7.5px;font-weight:700;pointer-events:none;text-anchor:middle;user-select:none}.state-label.active{fill:#fff}.dc-dot{pointer-events:none}.ne-label{font-size:6.5px}.map-legend{border-top:1px solid var(--gray-100);display:flex;flex-wrap:wrap;gap:20px;margin-top:14px;padding-top:14px}.legend-item{align-items:center;color:var(--gray-600);display:flex;font-size:12px;gap:7px}.legend-swatch{border-radius:3px;flex-shrink:0;height:14px;width:14px}.detail-panel{background:var(--white);border-radius:12px;box-shadow:0 1px 4px rgba(6,42,71,.07),0 4px 16px rgba(6,42,71,.04);overflow:hidden;position:sticky;top:24px}.detail-panel__header{background:var(--navy);padding:18px 22px}.detail-panel__state-name{color:var(--white);font-size:20px;font-weight:700;line-height:1.2}.detail-panel__prompt{color:var(--sage);font-size:13px;margin-top:3px}.detail-panel__body{padding:20px 22px}.detail-empty{flex-direction:column;gap:12px;padding:40px 20px;text-align:center}.detail-empty,.detail-empty__icon{align-items:center;display:flex;justify-content:center}.detail-empty__icon{background:var(--sage-pale);border-radius:50%;height:52px;width:52px}.detail-empty__icon svg{height:24px;stroke:var(--green);width:24px}.detail-empty__title{color:var(--navy);font-size:15px;font-weight:600}.detail-empty__text{color:var(--gray-600);font-size:13px;line-height:1.5}.rule-card{border-radius:8px;margin-bottom:10px;padding:12px 14px}.rule-card--quit{background:var(--sage-pale);border-left:3px solid var(--green-light)}.rule-card--fired{background:#ebf2f9;border-left:3px solid var(--navy-light)}.rule-card__scenario{font-size:10px;font-weight:700;letter-spacing:.7px;margin-bottom:4px;text-transform:uppercase}.rule-card--quit .rule-card__scenario{color:var(--green)}.rule-card--fired .rule-card__scenario{color:var(--navy-light)}.rule-card__deadline{color:var(--text);font-size:14px;font-weight:600;line-height:1.4}.penalty-block{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:8px;margin:12px 0;padding:11px 14px}.penalty-block__label{color:var(--gray-600);font-size:10px;font-weight:700;letter-spacing:.7px;margin-bottom:4px;text-transform:uppercase}.penalty-block__text{color:var(--text);font-size:13px;line-height:1.5}.notes-block{background:#fff9ec;border-left:3px solid #e6b84a;border-radius:0 6px 6px 0;color:#5a4a1a;font-size:12.5px;line-height:1.5;margin-top:12px;padding:10px 13px}.source-line{border-top:1px solid var(--gray-100);color:var(--gray-600);font-size:11.5px;line-height:1.5;margin-top:14px;padding-top:13px}.source-line a{color:var(--green);font-weight:500;text-decoration:none}.source-line a:hover{text-decoration:underline}.disclaimer{background:#fff9ec;border:1px solid #edce82;border-radius:8px;color:#5a4a1a;font-size:12px;line-height:1.6;margin-top:26px;padding:14px 18px}.disclaimer strong{color:#3a2e0a}#map-tooltip{background:var(--navy);border-radius:6px;box-shadow:0 2px 8px rgba(0,0,0,.2);color:#fff;font-family:Inter,Segoe UI,Arial,sans-serif;font-size:12px;opacity:0;padding:6px 11px;pointer-events:none;position:fixed;transition:opacity .1s;white-space:nowrap;z-index:200}#map-tooltip.visible{opacity:1}#map-loading{align-items:center;color:var(--gray-600);display:flex;font-size:14px;gap:10px;height:400px;justify-content:center}.spinner{animation:spin .7s linear infinite;border:2px solid var(--gray-200);border-radius:50%;border-top-color:var(--green);height:20px;width:20px}@keyframes spin{to{transform:rotate(1turn)}}