*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;color:#333;line-height:1.6}.app{max-width:100%;margin:0 auto;padding:20px;overflow-x:hidden}.app-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 30px;box-shadow:0 2px 4px #0000001a;margin-bottom:30px}.app-header.app-header-compact{padding:10px 24px;margin-bottom:12px}.app-header-compact .header-content{align-items:center}.save-status-inline{font-size:.8rem;white-space:nowrap}.app-header.spouse-theme{background:linear-gradient(135deg,#11998e,#38ef7d)}.app-header .user-badge{background:#fff3;padding:6px 12px;border-radius:6px;font-weight:600;font-size:.9rem;border:1px solid rgba(255,255,255,.3)}.app-header.spouse-theme .switch-user-link:hover{background:#ffffff40;border-color:#ffffff80}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:100%;margin:0 auto}.app-header h1{margin:0 0 5px;font-size:1.8rem}.app-header p{margin:0;opacity:.9;font-size:.95rem}.user-indicator{display:flex;align-items:center;gap:15px;margin-top:10px}.user-badge{background:#fff3;padding:6px 12px;border-radius:6px;font-weight:600;font-size:.9rem;border:1px solid rgba(255,255,255,.3)}.switch-user-link{color:#fff;text-decoration:none;padding:6px 12px;border-radius:6px;background:#ffffff26;border:1px solid rgba(255,255,255,.3);font-size:.85rem;transition:all .3s}.switch-user-link:hover{background:#ffffff40;border-color:#ffffff80;transform:translateY(-1px)}.save-status{margin-top:10px;text-align:right;font-size:.9rem}.save-status .saving{color:gold;animation:pulse 1s infinite}.save-status .saved{color:#90ee90}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.auth-container{display:flex;align-items:center;gap:15px}.user-info{display:flex;align-items:center;gap:12px}.user-avatar{width:48px;height:48px;border-radius:50%;border:2px solid white}.user-details{display:flex;flex-direction:column;align-items:flex-start}.user-name{font-weight:600;font-size:1rem}.user-email{font-size:.85rem;opacity:.9}.btn-logout{padding:10px 20px;background:#fff3;color:#fff;border:2px solid white;border-radius:4px;cursor:pointer;font-weight:600;transition:all .3s}.btn-logout:hover{background:#fff;color:#667eea}.login-prompt{text-align:right}.login-prompt p{margin:0;font-size:.9rem}.auth-error{color:#fcc;font-size:.85rem;margin-top:5px}.btn-google-login{display:flex;align-items:center;gap:10px;padding:12px 24px;background:#fff;color:#333;border:none;border-radius:4px;cursor:pointer;font-weight:600;font-size:1rem;transition:all .3s;box-shadow:0 2px 4px #0003}.btn-google-login:hover{box-shadow:0 4px 8px #0000004d;transform:translateY(-2px)}.google-icon{width:20px;height:20px}.grant-manager-section{background:#fff;padding:25px;border-radius:8px;margin-bottom:30px;box-shadow:0 2px 4px #0000001a}.grant-manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.grant-manager-header h2{margin:0;color:#333}.grants-list{display:flex;flex-direction:column;gap:12px}.grant-item{display:flex;justify-content:space-between;align-items:center;padding:15px;background:#f9f9f9;border-radius:8px;border-left:4px solid #667eea}.grant-info h4{margin:0 0 5px;color:#667eea;font-size:1.1rem}.grant-info p{margin:0;color:#666;font-size:.9rem}.grant-actions{display:flex;gap:10px}.btn-edit{padding:8px 16px;background:#667eea;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600;transition:background .3s}.btn-edit:hover:not(:disabled){background:#5568d3}.btn-edit:disabled{background:#ccc;cursor:not-allowed}.grant-form-container{margin-bottom:20px;padding:20px}.grant-form{background:#f8f9fa;padding:20px;border-radius:8px;max-width:350px}.grant-form-inline{max-width:none!important;width:100%!important}.grant-form h3{margin-top:0;margin-bottom:20px;color:#667eea}.form-group{margin-bottom:15px}.form-group label{display:flex;flex-direction:column;gap:5px;font-weight:600;color:#333}.form-group input,.form-group select{padding:10px;border:2px solid #e0e0e0;border-radius:4px;font-size:1rem;transition:border-color .3s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea}.form-group small{color:#666;font-size:.85rem;font-weight:400;font-style:italic}.form-actions{display:flex;gap:10px;margin-top:20px}.btn-save{padding:12px 24px;background:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600;transition:background .3s}.btn-save:hover{background:#45a049}.btn-cancel{padding:12px 24px;background:#999;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600;transition:background .3s}.btn-cancel:hover{background:#777}.controls-section{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;align-items:flex-start}.control-group{background:#fff;padding:12px;border-radius:6px;box-shadow:0 1px 3px #0000001a;flex:0 0 auto}.control-group label{display:flex;flex-direction:column;gap:4px;font-weight:600;font-size:.85rem}.control-group input{padding:6px 8px;border:1px solid #e0e0e0;border-radius:4px;font-size:.9rem;width:90px;transition:border-color .3s}.control-group input:focus{outline:none;border-color:#667eea}.control-help{color:#667eea;font-weight:600;font-size:.85rem}.separation-dates-section{background:#fff;padding:15px 20px;border-radius:8px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.separation-dates-section h2{margin-bottom:10px;color:#333;font-size:1.3rem}.separation-dates-controls{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;margin-bottom:12px}.separation-date-item{display:flex;gap:8px;align-items:center}.separation-date-item input[type=date]{flex:1;padding:8px;border:2px solid #e0e0e0;border-radius:4px;font-size:.9rem}.btn-select{padding:8px 16px;background:#e0e0e0;border:none;border-radius:4px;cursor:pointer;font-weight:600;transition:all .3s;min-width:85px;font-size:.85rem}.btn-select.active{background:#667eea;color:#fff}.btn-select:hover{background:#764ba2;color:#fff}.btn-remove{padding:8px 12px;background:#f44336;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600;font-size:1.1rem;transition:background .3s}.btn-remove:hover:not(:disabled){background:#d32f2f}.btn-remove:disabled{background:#ccc;cursor:not-allowed}.btn-add{padding:8px 16px;background:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600;transition:background .3s;align-self:flex-start;font-size:.9rem}.btn-add:hover{background:#45a049}.help-text{margin-top:15px;color:#666;font-size:.9rem;font-style:italic}.chart-container,.chart-section{background:#fff;padding:25px;border-radius:8px;margin-bottom:30px;box-shadow:0 2px 4px #0000001a}.chart-header{margin-bottom:20px}.chart-header h2{margin-bottom:15px;color:#333}.calculation-method-toggle{background:#f9f9f9;padding:15px;border-radius:8px;border:2px solid #e0e0e0}.toggle-label{font-weight:600;color:#333;margin-bottom:10px;display:block}.display-options-group{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}.display-option-label{display:flex;align-items:center;gap:8px;padding:10px;background:#fff;border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;transition:all .3s}.display-option-label:hover{border-color:#667eea;background:#f8f9ff}.display-option-label input[type=checkbox]{margin:0;width:16px;height:16px;cursor:pointer;accent-color:#667eea;flex-shrink:0}.display-option-label input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.display-option-label span{font-weight:600;color:#333;font-size:.9rem}.display-option-label.differences-option{border-color:#4caf50}.display-option-label.differences-option:hover{border-color:#45a049;background:#f1f8f4}.display-option-label.differences-option input[type=checkbox]{accent-color:#4caf50}.grant-visibility-toggle{background:#f0f8ff;padding:15px;border-radius:8px;border:2px solid #667eea;margin-top:15px}.grant-visibility-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.btn-toggle-all{padding:8px 16px;background:#667eea;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600;font-size:.9rem;transition:all .3s}.btn-toggle-all:hover{background:#5568d3}.grant-checkbox-group{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}.grant-checkbox-label{display:flex;align-items:center;gap:8px;padding:10px;background:#fff;border:2px solid #e0e0e0;border-radius:6px;cursor:pointer;transition:all .3s}.grant-checkbox-label:hover{border-color:#667eea;background:#f8f9ff}.grant-checkbox-label input[type=checkbox]{margin:0;width:16px;height:16px;cursor:pointer;accent-color:#667eea;flex-shrink:0}.grant-checkbox-content{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.grant-name{font-weight:600;color:#333;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.grant-checkbox-label small{color:#666;font-size:.8rem}.control-group.export-import{flex:0 0 auto}.control-group.export-import label{font-size:.85rem}.export-import-buttons{display:flex;gap:8px;margin-top:4px}.btn-export,.btn-import{padding:8px 12px;background:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600;font-size:.8rem;transition:all .3s;text-align:center}.btn-export:hover{background:#45a049}.btn-import{background:#2196f3;display:block}.btn-import:hover{background:#0b7dda}.collapsible-section{background:#fff;border-radius:8px;margin-bottom:30px;box-shadow:0 2px 4px #0000001a;overflow:hidden;transition:all .3s ease}.section-header{display:flex;justify-content:space-between;align-items:center;padding:20px 25px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .3s}.section-header:hover{background:linear-gradient(135deg,#5568d3,#653b8f)}.spouse-theme .section-header{background:linear-gradient(135deg,#11998e,#38ef7d)}.spouse-theme .section-header:hover{background:linear-gradient(135deg,#0e8a80,#2fd970)}.section-header h2{margin:0;color:#fff;font-size:1.5rem}.collapse-btn{padding:8px 16px;background:#fff3;color:#fff;border:2px solid white;border-radius:4px;cursor:pointer;font-weight:600;font-size:.9rem;transition:all .3s;pointer-events:none}.section-header:hover .collapse-btn{background:#fff;color:#667eea}.collapsible-section.collapsed{box-shadow:0 1px 2px #0000001a}.collapsible-section.collapsed .section-header{padding:15px 25px}.collapsible-section .chart-section,.collapsible-section .dos-comparison-section,.collapsible-section .summary-section,.collapsible-section .table-section,.collapsible-section .grant-manager-section{box-shadow:none;margin-bottom:0}.dos-comparison-section{background:#fff;padding:25px;border-radius:8px;margin-bottom:30px;box-shadow:0 2px 4px #0000001a;max-width:100%;overflow:hidden}.dos-comparison-section h2{color:#333;margin-bottom:10px}.section-description{color:#666;font-size:.95rem;margin-bottom:20px;font-style:italic}.comparison-table-wrapper{overflow-x:auto;margin-bottom:30px}.comparison-table{width:100%;border-collapse:collapse;font-size:.9rem}.comparison-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.comparison-table th{padding:10px 6px;text-align:center;font-weight:600;border:1px solid #5568d3;font-size:.75rem;white-space:nowrap}.comparison-table td{padding:8px 6px;text-align:center;border:1px solid #e0e0e0;font-size:.8rem}.comparison-table tbody tr{background:#fff}.comparison-table tbody tr:hover{background:#f8f9ff}.comparison-table tbody tr.first-method-row{border-top:3px solid #667eea}.dos-cell{background:#f0f4ff!important;font-weight:600;color:#667eea;vertical-align:middle}.method-cell{font-weight:600;text-align:left!important;padding-left:15px!important}.method-cell.method-tranche{color:#667eea}.method-cell.method-grant{color:#ff6b6b}.method-cell.method-vested{color:#4caf50}.number-cell{font-family:Courier New,monospace;color:#333}.value-cell{font-family:Courier New,monospace;color:#666}.number-cell.highlight,.value-cell.highlight{background:#fff9e6;font-weight:700;color:#000}.number-cell.vested-cell,.value-cell.vested-cell{background:#e8f5e9;color:#2e7d32;font-weight:600}.number-cell.net-cell,.value-cell.net-cell{background:#e3f2fd;color:#1565c0;font-weight:700}.value-cell.support-cell{background:#fff3e0;color:#e65100;font-weight:600}.number-cell.final-net-cell,.value-cell.final-net-cell{background:#c8e6c9;color:#1b5e20;font-weight:700;font-size:1.05em}.method-differences{margin-bottom:30px}.method-differences h3{color:#333;margin-bottom:20px}.dos-comparison-group{margin-bottom:25px}.dos-comparison-group h4{color:#667eea;margin-bottom:15px}.comparison-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:15px}.comparison-card{background:#f9f9f9;border:2px solid #e0e0e0;border-radius:8px;padding:15px;transition:all .3s}.comparison-card:hover{border-color:#667eea;box-shadow:0 4px 8px #667eea1a}.comparison-header{display:flex;align-items:center;gap:10px;margin-bottom:15px;padding-bottom:10px;border-bottom:2px solid #e0e0e0}.method-badge{background:#667eea;color:#fff;padding:6px 12px;border-radius:4px;font-size:.85rem;font-weight:600}.vs{font-weight:700;color:#999;font-size:.9rem}.comparison-details{display:flex;flex-direction:column;gap:10px}.comparison-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.comparison-row span:first-child{color:#666;font-size:.9rem}.comparison-row span:last-child{font-weight:700;font-size:1rem}.comparison-row .positive{color:#4caf50}.comparison-row .negative{color:#f44336}.dos-date-comparison{margin-top:30px}.dos-date-comparison h3{color:#333;margin-bottom:10px}.method-dos-comparison{margin-bottom:25px}.method-dos-comparison h4{color:#667eea;margin-bottom:10px;font-size:1.1rem}.method-dos-comparison h5{color:#333;margin-top:20px;margin-bottom:10px;font-size:1rem}.overall-comparison{margin-top:15px}.range-card{max-width:600px;background:linear-gradient(135deg,#f5f7ff,#fff9e6);border:2px solid #667eea}.range-card .method-badge{font-size:.8rem;padding:5px 10px}.range-card .method-badge.earliest{background:#ff6b6b}.range-card .method-badge.latest{background:#4caf50}.highlight-row{margin-top:10px;padding-top:10px;border-top:2px solid #667eea}.dos-diff-table{width:100%;border-collapse:collapse;font-size:.9rem}.dos-diff-table thead{background:#f9f9f9}.dos-diff-table th{padding:10px 8px;text-align:center;font-weight:600;border:1px solid #e0e0e0}.dos-diff-table td{padding:10px 8px;text-align:center;border:1px solid #e0e0e0}.dos-diff-table tbody tr:hover{background:#f5f5f5}.dos-diff-table .baseline-method-row{background:#f0f4ff;font-weight:600;border-left:4px solid #667eea}.dos-diff-table .baseline-method-row:hover{background:#e3f2fd}.dos-diff-table .baseline-badge{color:#667eea;font-weight:700;font-size:.95rem}.dos-diff-table .baseline-cell{color:#667eea;background:#f0f4ff;font-weight:600}.dos-diff-table .positive{color:#4caf50;font-weight:600}.dos-diff-table .negative{color:#f44336;font-weight:600}.dos-diff-table .overall-range-row{border-top:3px solid #667eea;background:#f0f4ff}.dos-diff-table .overall-range-row td{padding:12px 8px}.dos-diff-table .baseline{color:#999;font-style:italic}.dos-diff-table .range-label{text-align:left!important;padding-left:15px!important;color:#667eea}.chart-container{background:transparent;padding:0;box-shadow:none}.chart-container h2{margin-bottom:20px;color:#333}.separation-values{margin-top:30px;padding:20px;background:#f9f9f9;border-radius:8px}.separation-values h3{margin-bottom:15px;color:#333}.separation-date-section{margin-bottom:20px}.separation-date-section h4{color:#667eea;margin-bottom:10px}.separation-date-section ul{list-style:none;padding-left:20px}.separation-date-section li{padding:5px 0}.method-section{margin-bottom:15px;padding:10px;background:#fff;border-radius:4px;border-left:3px solid #667eea}.method-section strong{display:block;margin-bottom:5px;color:#667eea}.method-section ul{margin-top:5px}.difference-section{margin-top:15px;padding:15px;background:#e8f5e9;border-radius:4px;border-left:4px solid #4caf50}.difference-section strong{color:#2e7d32;font-size:1.05rem}.summary-section{background:#fff;padding:25px;border-radius:8px;margin-bottom:30px;box-shadow:0 2px 4px #0000001a}.summary-section h2{margin-bottom:20px;color:#333}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.summary-card{background:#f9f9f9;padding:20px;border-radius:8px;border:2px solid #e0e0e0}.summary-card h3{margin-bottom:15px;color:#667eea;padding-bottom:10px;border-bottom:2px solid #667eea}.summary-item{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid #e0e0e0}.summary-item:last-child{border-bottom:none}.summary-item span:first-child{font-weight:600}.summary-item span:last-child{color:#667eea;font-weight:700}.table-section{background:#fff;padding:25px;border-radius:8px;box-shadow:0 2px 4px #0000001a;max-width:100%;overflow:hidden}.table-section h2{margin-bottom:20px;color:#333}.table-container{width:100%}.table-wrapper{overflow-x:auto;margin-bottom:20px}.data-table{width:100%;border-collapse:collapse;font-size:.9rem}.data-table thead{background:#667eea;color:#fff;position:sticky;top:0;z-index:10}.data-table th{padding:10px 6px;text-align:center;font-weight:600;border:1px solid #5568d3;white-space:nowrap;font-size:.8rem}.data-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.data-table th.sortable:hover{background:#5568d3}.data-table td{padding:8px 6px;text-align:center;border:1px solid #e0e0e0;white-space:nowrap;font-size:.8rem}.data-table tbody tr{background:#fff;transition:background-color .2s}.data-table tbody tr:hover{background:#f5f5f5}.data-table tbody tr.estimated-row{background:#fff9e6}.data-table tbody tr.estimated-row:hover{background:#fff3cc}.data-table tbody tr.pre-dos-row{background:#f0f0f0}.data-table tbody tr.pre-dos-row:hover{background:#e5e5e5}.data-table tbody tr.unpaid-row{background:#e3f2fd}.data-table tbody tr.unpaid-row:hover{background:#bbdefb}.data-table tbody tr.overdue-row{background:#ffebee}.data-table tbody tr.overdue-row:hover{background:#ffcdd2}.data-table tbody tr.new-grant-row{border-top:3px solid #667eea}.filter-summary{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding:15px;background:#f9f9f9;border-radius:8px;flex-wrap:wrap;gap:10px;position:relative}.active-filters{display:flex;align-items:center;gap:10px;flex-wrap:wrap;flex:1}.filter-label{font-weight:600;color:#667eea}.filter-badge{display:inline-flex;align-items:center;gap:5px;background:#667eea;color:#fff;padding:6px 10px;border-radius:4px;font-size:.85rem;font-weight:500}.filter-clear{background:#ffffff4d;color:#fff;border:none;border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.2rem;font-weight:700;line-height:1;padding:0;transition:all .2s}.filter-clear:hover{background:#ffffff80}.btn-clear-all-filters{padding:6px 12px;background:#f44336;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600;font-size:.85rem;transition:all .3s}.btn-clear-all-filters:hover{background:#d32f2f}.row-count{color:#666;font-weight:600;white-space:nowrap;display:flex;align-items:center;gap:8px}.btn-column-settings{background:none;border:1px solid #e0e0e0;border-radius:4px;cursor:pointer;font-size:1.1rem;padding:4px 8px;transition:all .2s;line-height:1}.btn-column-settings:hover{background:#f0f4ff;border-color:#667eea}.column-settings-panel{position:absolute;right:15px;top:100%;z-index:100;background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 8px 24px #00000026;width:300px;max-height:480px;display:flex;flex-direction:column}.column-settings-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid #e0e0e0;font-weight:700;font-size:.95rem;color:#333}.column-settings-close{background:none;border:none;font-size:1.3rem;cursor:pointer;color:#999;padding:0 4px;line-height:1}.column-settings-close:hover{color:#333}.column-settings-list{overflow-y:auto;flex:1;padding:8px 0}.column-settings-item{display:flex;justify-content:space-between;align-items:center;padding:6px 16px;transition:background .15s}.column-settings-item:hover{background:#f5f7ff}.column-settings-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.85rem;color:#333;flex:1;min-width:0}.column-settings-label input[type=checkbox]{accent-color:#667eea;width:15px;height:15px;cursor:pointer;flex-shrink:0}.column-settings-label span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.column-settings-arrows{display:flex;gap:2px;flex-shrink:0}.btn-reorder{background:none;border:1px solid #e0e0e0;border-radius:3px;cursor:pointer;font-size:.6rem;padding:2px 6px;color:#666;transition:all .15s;line-height:1}.btn-reorder:hover:not(:disabled){background:#667eea;color:#fff;border-color:#667eea}.btn-reorder:disabled{opacity:.3;cursor:not-allowed}.column-settings-footer{padding:10px 16px;border-top:1px solid #e0e0e0}.btn-reset-columns{width:100%;padding:8px;background:#f44336;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:600;font-size:.85rem;transition:background .2s}.btn-reset-columns:hover{background:#d32f2f}.column-resizer{position:absolute;right:0;top:0;height:100%;width:4px;cursor:col-resize;-webkit-user-select:none;user-select:none;touch-action:none;background:transparent;transition:background .15s}.column-resizer:hover,.column-resizer.isResizing{background:#667eea80}.filter-row{background:#f0f4ff!important}.filter-row th{padding:8px 4px!important;background:#f0f4ff}.column-filter{width:100%;padding:6px 8px;border:2px solid #e0e0e0;border-radius:4px;font-size:.85rem;transition:border-color .3s;box-sizing:border-box}.column-filter:focus{outline:none;border-color:#667eea}.date-range-filter{display:flex;flex-direction:column;gap:4px}.date-filter{font-size:.75rem;padding:4px 6px}.table-legend{display:flex;gap:20px;margin-top:15px;padding:15px;background:#f9f9f9;border-radius:8px}.legend-item{display:flex;align-items:center;gap:8px}.legend-color{width:24px;height:24px;border-radius:4px;border:1px solid #ccc}.legend-color.earned{background:#fff}.legend-color.estimated{background:#fff9e6}.legend-color.unpaid{background:#e3f2fd}.legend-color.overdue{background:#ffebee}.legend-color.pre-dos{background:#f0f0f0}.yearly-tax-rates{flex:1 1 auto!important;min-width:200px}.yearly-rate-grid{display:flex;flex-wrap:wrap;gap:6px;margin-top:4px}.yearly-rate-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px;border:2px solid transparent;border-radius:6px;transition:border-color .3s}.yearly-rate-item.settled{border-color:#4caf50;background:#f1f8f4}.yearly-rate-label{font-size:.7rem;color:#888;font-weight:600}.yearly-rate-inputs{display:flex;flex-direction:column;gap:2px}.yearly-rate-row{display:flex;align-items:center;gap:3px}.yearly-rate-type-label{font-size:.6rem;font-weight:700;color:#999;width:20px;text-align:right}.yearly-rate-type-label.act{color:#4caf50}.yearly-rate-input{width:52px!important;padding:3px 5px!important;border:1px solid #e0e0e0;border-radius:4px;font-size:.78rem!important;text-align:center;transition:border-color .3s}.yearly-rate-input:focus{outline:none;border-color:#667eea}.yearly-rate-input::placeholder{color:#ccc;font-style:italic}.trueup-summary{flex:1 1 auto!important;min-width:300px}.trueup-table{width:100%;border-collapse:collapse;font-size:.8rem;margin-top:4px}.trueup-table thead{background:#667eea;color:#fff}.trueup-table th{padding:5px 8px;text-align:center;font-weight:600;font-size:.72rem;white-space:nowrap;border:1px solid #5568d3}.trueup-table td{padding:4px 8px;text-align:center;border:1px solid #e0e0e0;font-size:.78rem;white-space:nowrap}.trueup-table tbody tr:hover{background:#f5f7ff}.trueup-year{font-weight:600;color:#667eea}.trueup-over{color:#4caf50;font-weight:700}.trueup-under{color:#f44336;font-weight:700}.trueup-even{color:#999;font-weight:600}.btn-paid-unit-toggle{width:32px;height:30px;padding:0;border:1px solid #ddd;border-radius:4px;background:#f5f5f5;cursor:pointer;font-weight:700;font-size:.8rem;color:#555;transition:all .2s;flex-shrink:0;display:flex;align-items:center;justify-content:center}.btn-paid-unit-toggle:hover{background:#667eea;color:#fff;border-color:#667eea}.case-details-step{display:flex;flex-direction:column;gap:20px}.step-intro{margin-bottom:4px}.grants-step{display:flex;flex-direction:column;gap:20px}.step-intro h2{margin:0 0 8px;font-size:1.5rem;color:#333}.step-intro p{margin:0;color:#666;font-size:.95rem;line-height:1.6;max-width:720px}.detail-card{background:#fff;border-radius:10px;box-shadow:0 2px 6px #00000012;overflow:hidden}.detail-card-header{display:flex;gap:14px;padding:16px 20px 12px;border-bottom:1px solid #f0f0f0;align-items:flex-start}.detail-card-icon{font-size:1.5rem;flex-shrink:0;margin-top:1px}.detail-card-header h3{margin:0 0 4px;font-size:1rem;color:#333}.detail-card-desc{margin:0;color:#888;font-size:.85rem;line-height:1.55}.detail-card-body{padding:16px 20px 20px}.grants-step-context-bar{display:flex;align-items:center;gap:16px;padding-bottom:12px;margin-bottom:12px;border-bottom:1px solid #f0f0f0;font-size:.9rem;color:#555}.role-select{padding:8px 12px;border:2px solid #e0e0e0;border-radius:6px;font-size:.95rem;font-weight:600;color:#333;background:#fafafa;cursor:pointer;transition:border-color .2s;min-width:240px}.role-select:focus{outline:none;border-color:#667eea;background:#fff}.dos-entries{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}.dos-entry{display:flex;gap:8px;align-items:center}.dos-entry input[type=date]{flex:0 0 180px;padding:8px 10px;border:2px solid #e0e0e0;border-radius:6px;font-size:.9rem;transition:border-color .2s}.dos-entry input[type=date]:focus{outline:none;border-color:#667eea}.btn-add-dos{padding:7px 14px;background:none;color:#667eea;border:1px dashed #667eea;border-radius:6px;cursor:pointer;font-weight:600;font-size:.85rem;transition:all .2s;align-self:flex-start}.btn-add-dos:hover{background:#f0f4ff}.ticker-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.ticker-card{padding:14px;border-radius:8px;border:1px solid #eee;background:#fafafa}.ticker-card h4{margin:0 0 10px;font-size:.9rem}.ticker-employee h4{color:#667eea}.ticker-spouse h4{color:#11998e}@media (max-width: 768px){.ticker-grid{grid-template-columns:1fr}.detail-card-header{flex-direction:column;gap:8px}.dos-entry input[type=date]{flex:1;min-width:0}.role-select{width:100%;min-width:0}}.wizard-shell{display:flex;flex-direction:row;min-height:calc(100vh - 60px);gap:0}.wizard-sidebar{display:flex;flex-direction:column;width:190px;flex-shrink:0;margin-right:12px;align-self:flex-start;position:sticky;top:0;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.sidebar-header{padding:14px 16px 12px;border-bottom:1px solid #f0f0f0}.sidebar-brand{font-size:.8rem;font-weight:700;color:#667eea;margin-bottom:10px;letter-spacing:-.01em}.sidebar-save-status{margin-top:6px;font-size:.75rem}.sidebar-save-status .saving{color:#e6a700}.sidebar-save-status .saved{color:#4caf50}.auth-compact{width:100%}.auth-compact-user{display:flex;align-items:center;gap:8px}.auth-compact-avatar{width:28px;height:28px;border-radius:50%;flex-shrink:0}.auth-compact-details{display:flex;flex-direction:column;gap:1px;min-width:0}.auth-compact-name{font-size:.8rem;font-weight:600;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.auth-compact-logout{background:none;border:none;color:#999;font-size:.7rem;cursor:pointer;padding:0;text-align:left;transition:color .2s}.auth-compact-logout:hover{color:#f44336}.auth-compact-login{display:flex;align-items:center;gap:6px;width:100%;padding:7px 10px;background:#f8f9ff;color:#667eea;border:1px dashed #ccc;border-radius:6px;cursor:pointer;font-weight:600;font-size:.75rem;transition:all .2s}.auth-compact-login:hover{background:#eef1ff;border-color:#667eea}.auth-compact-error{color:#f44336;font-size:.7rem;margin:4px 0 0}.wizard-main{flex:1;display:flex;flex-direction:column;min-width:0}.wizard-content{flex:1;padding:20px 0}.category-bar{display:flex;flex-direction:column;padding:4px 0 8px;gap:2px}.category-item{display:flex;align-items:center;gap:10px;padding:14px 16px;border:none;background:none;cursor:pointer;font-size:.9rem;font-weight:600;color:#999;transition:all .2s;text-align:left;border-left:3px solid transparent;position:relative}.category-item:hover:not(.cat-active):not(.cat-disabled){background:#f5f7ff;color:#667eea;border-left-color:#e0e0e0}.category-item.cat-active{color:#667eea;background:#f0f4ff;border-left-color:#667eea}.category-item.cat-completed{color:#4caf50}.category-item.cat-completed:hover{background:#f1f8f4;border-left-color:#4caf50}.category-item.cat-disabled{cursor:not-allowed;opacity:.35}.category-icon{font-size:1.2rem;flex-shrink:0}.category-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.category-check{margin-left:auto;font-size:.8rem;color:#4caf50}.wizard-step-bar{display:flex;align-items:center;justify-content:center;padding:14px 20px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:4px;overflow-x:auto;gap:0}.step-indicator{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;transition:all .2s;flex-shrink:0}.step-indicator.step-disabled{cursor:not-allowed;opacity:.35}.step-indicator.step-active{cursor:default}.step-circle{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;transition:all .3s;border:2px solid #e0e0e0;background:#f5f5f5;color:#999}.step-active .step-circle{border-color:#667eea;background:#667eea;color:#fff;box-shadow:0 2px 8px #667eea66;transform:scale(1.1)}.step-completed .step-circle{border-color:#4caf50;background:#4caf50;color:#fff}.step-indicator:not(.step-disabled):not(.step-active):hover .step-circle{border-color:#667eea;background:#e8eaf6;color:#667eea}.step-label{font-size:10px;font-weight:600;color:#999;white-space:nowrap;max-width:80px;text-align:center;overflow:hidden;text-overflow:ellipsis}.step-active .step-label{color:#667eea}.step-completed .step-label{color:#4caf50}.step-disabled .step-label{color:#ccc}.step-connector{width:24px;height:2px;background:#e0e0e0;flex-shrink:0;margin:0 2px 18px}.connector-completed{background:#4caf50}.connector-disabled{background:#f0f0f0}.wizard-nav-buttons{display:flex;justify-content:space-between;align-items:center;padding:16px 0;margin-top:8px;border-top:1px solid #e0e0e0}.wizard-btn{padding:12px 28px;border:none;border-radius:8px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all .2s}.wizard-btn-next{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 2px 8px #667eea4d}.wizard-btn-next:hover{box-shadow:0 4px 12px #667eea80;transform:translateY(-1px)}.wizard-btn-back{background:#f5f5f5;color:#666;border:1px solid #e0e0e0}.wizard-btn-back:hover{background:#e0e0e0;color:#333}.wizard-step-enter{opacity:0;transform:translate(20px)}.wizard-step-active{opacity:1;transform:translate(0);transition:opacity .3s ease,transform .3s ease}.animation-overlay{background:#f8f9ff;border:1px solid #e0e0e0;border-radius:8px;padding:16px 20px;margin-top:12px;display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:90px}.animation-text{font-size:.95rem;color:#555;line-height:1.5;flex:1;transition:opacity .5s ease;min-height:4.5em}.animation-controls{display:flex;align-items:center;gap:8px;flex-shrink:0}.animation-phase-indicator{font-size:.8rem;color:#999;font-weight:600;min-width:36px;text-align:center}@keyframes nelsonReveal{0%{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0 0 0 0)}}.nelson-line-reveal path{animation:nelsonReveal 3s linear forwards}.animation-btn{padding:8px 16px;min-width:120px;border:1px solid #e0e0e0;border-radius:6px;background:#fff;color:#666;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;text-align:center}.animation-btn:hover{background:#667eea;color:#fff;border-color:#667eea}.animation-btn-skip{background:#fff3e0;border-color:#ffb74d;color:#e65100}.animation-btn-skip:hover{background:#ffb74d;color:#fff}.editable-cell{cursor:pointer;padding:4px 6px;border-radius:3px;transition:background .15s;min-height:24px}.editable-cell:hover{background:#e8eaf6}.editable-cell-editing{padding:0}.editable-cell-editing input,.editable-cell-editing select{width:100%;padding:4px 6px;border:2px solid #667eea;border-radius:3px;font-size:inherit;outline:none}.total-impact-table{width:100%;border-collapse:collapse;font-size:.9rem}.total-impact-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.total-impact-table th{padding:10px 12px;text-align:center;font-weight:600;border:1px solid #5568d3}.total-impact-table td{padding:10px 12px;text-align:center;border:1px solid #e0e0e0}.total-impact-table tbody tr:hover{background:#f5f7ff}.total-impact-positive{color:#4caf50;font-weight:700}.total-impact-negative{color:#f44336;font-weight:700}.total-impact-net-row{background:#f0f4ff;font-weight:700;border-top:3px solid #667eea}.y-zoom-track{display:flex;flex-direction:column;align-items:center;width:24px;flex-shrink:0;padding:5px 0 25px;gap:2px}.y-zoom-slider{writing-mode:vertical-lr;direction:rtl;flex:1;width:20px;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;background:transparent;margin:0}.y-zoom-slider::-webkit-slider-runnable-track{width:6px;background:#e0e0e0;border-radius:3px;border:1px solid #ccc}.y-zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:3px;background:#667eea;border:1px solid #5568d3;cursor:grab;margin-left:-4px}.y-zoom-slider::-webkit-slider-thumb:hover{background:#5568d3}.y-zoom-slider::-webkit-slider-thumb:active{cursor:grabbing;background:#4454b8}.y-zoom-slider::-moz-range-track{width:6px;background:#e0e0e0;border-radius:3px;border:1px solid #ccc}.y-zoom-slider::-moz-range-thumb{width:14px;height:14px;border-radius:3px;background:#667eea;border:1px solid #5568d3;cursor:grab}.y-zoom-slider::-moz-range-thumb:hover{background:#5568d3}@media (max-width: 768px){.app{padding:10px}.app-header h1{font-size:2rem}.controls-section{flex-direction:column}.summary-grid{grid-template-columns:1fr}.data-table{font-size:.8rem}.data-table th,.data-table td{padding:8px 4px}.wizard-shell{flex-direction:column}.wizard-sidebar{flex-direction:row;width:100%;margin-right:0;margin-bottom:8px;position:static;border-radius:12px}.sidebar-header{display:none}.category-bar{flex-direction:row;border-radius:12px;padding:4px 0;overflow-x:auto}.category-item{flex-direction:column;padding:10px 12px;gap:4px;min-width:0;flex:1;text-align:center;border-left:none;border-bottom:3px solid transparent}.category-item.cat-active{border-left-color:transparent;border-bottom-color:#667eea}.category-item.cat-completed:hover{border-left-color:transparent;border-bottom-color:#4caf50}.category-item:hover:not(.cat-active):not(.cat-disabled){border-left-color:transparent;border-bottom-color:#e0e0e0}.category-label{font-size:.7rem}.category-check{position:absolute;top:4px;right:4px;margin-left:0;font-size:.65rem}.wizard-step-bar{padding:12px 10px;gap:0;justify-content:flex-start}.step-circle{width:26px;height:26px;font-size:11px}.step-label{font-size:8px;max-width:55px}.step-connector{width:14px}.wizard-nav-buttons{padding:12px 0}.wizard-btn{padding:10px 16px;font-size:.85rem}.animation-overlay{flex-direction:column;gap:10px}}
