.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.auth-card{background:#fff;padding:40px;border-radius:10px;box-shadow:0 10px 25px #0000001a;width:100%;max-width:400px}.auth-card h1{margin:0 0 10px;font-size:24px;color:#333;text-align:center}.auth-card h2{margin:0 0 30px;font-size:20px;color:#666;text-align:center;font-weight:400}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group input{padding:12px;border:1px solid #ddd;border-radius:5px;font-size:14px;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#667eea}.btn{padding:12px 20px;border:none;border-radius:5px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s}.auth-link{text-align:center;margin-top:20px;color:#666;font-size:14px}.auth-link a{color:#667eea;text-decoration:none;font-weight:600}.auth-link a:hover{text-decoration:underline}.dashboard-container{min-height:100vh;background-color:#f5f7fa}.dashboard-header{background:#fff;padding:20px 40px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center}.header-left h1{margin:0;font-size:24px;color:#333}.user-email{margin:5px 0 0;color:#666;font-size:14px}.header-right{display:flex;align-items:center;gap:15px}.dashboard-content{max-width:1200px;margin:0 auto;padding:40px 20px}.tabs{display:flex;gap:10px;margin-bottom:30px;border-bottom:2px solid #e0e0e0}.tab{padding:12px 24px;background:none;border:none;border-bottom:3px solid transparent;font-size:16px;font-weight:500;color:#666;cursor:pointer;transition:all .3s;margin-bottom:-2px}.tab:hover{color:#667eea}.tab.active{color:#667eea;border-bottom-color:#667eea}.tab-content{background:#fff;padding:30px;border-radius:10px;box-shadow:0 2px 8px #0000001a}.rates-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;flex-wrap:wrap;gap:20px}.rates-header h2{margin:0;font-size:24px;color:#333}.last-updated{margin:5px 0 0;color:#666;font-size:14px}.rates-display{display:flex;flex-direction:column;gap:40px}.loan-type-section h3{margin:0 0 20px;font-size:20px;color:#333;padding-bottom:10px;border-bottom:2px solid #667eea}.rates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px}.rate-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:24px;border-radius:10px;box-shadow:0 4px 6px #0000001a;transition:transform .3s,box-shadow .3s}.rate-card:hover{transform:translateY(-5px);box-shadow:0 8px 15px #0003}.rate-header{margin-bottom:12px;display:flex;justify-content:flex-end}.mortgage-type-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;background-color:#fff3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.mortgage-type-badge.purchase{background-color:#2ed5734d}.mortgage-type-badge.refinance{background-color:#3498db4d}.rate-main{display:flex;flex-direction:column;align-items:center;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.3)}.rate-value{font-size:36px;font-weight:700}.rate-label{font-size:14px;opacity:.9;margin-top:5px}.rate-details{display:flex;flex-direction:column;gap:10px}.rate-detail{display:flex;justify-content:space-between;align-items:center;font-size:14px}.detail-label{opacity:.9}.detail-value{font-weight:600}.no-data{text-align:center;padding:60px 20px;color:#666}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:5px;border:1px solid #fcc;margin-bottom:20px}.btn-small{padding:6px 12px;font-size:12px}.my-rates-container{display:flex;flex-direction:column;gap:20px}.my-rates-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.subtitle{margin:5px 0 0;color:#666;font-size:14px}.rate-group{border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.rate-group-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;cursor:pointer;transition:opacity .2s}.rate-group-header:hover{opacity:.95}.rate-group-title h3{margin:0;font-size:18px;font-weight:600}.rate-group-subtitle{display:block;font-size:13px;opacity:.9;margin-top:4px}.rate-group-summary{display:flex;align-items:center;gap:15px}.offer-count{background:#fff3;padding:4px 12px;border-radius:12px;font-size:13px}.expand-icon{font-size:12px}.rate-group-content{padding:20px;background:#fafafa}.rate-group-details{display:flex;gap:20px;flex-wrap:wrap;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid #e0e0e0;font-size:14px;color:#666}.rates-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.rates-table th,.rates-table td{padding:12px 16px;text-align:left;border-bottom:1px solid #eee}.rates-table th{background:#f5f7fa;font-weight:600;color:#333;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.rates-table tr:last-child td{border-bottom:none}.rates-table tr:hover{background:#f9f9f9}.lender-cell{display:flex;flex-direction:column}.lender-name{font-weight:500;color:#333}.lender-nmls{font-size:11px;color:#999;margin-top:2px}.apr-cell{font-weight:600;color:#667eea}.empty-state{text-align:center;padding:60px 20px;color:#666}.empty-state h3{margin:0 0 15px;color:#333}.empty-state p{max-width:400px;margin:10px auto}.rate-group-thresholds{background:#e8eef9;border:1px solid #667eea;border-radius:6px;padding:12px 16px;margin-bottom:20px;font-size:14px;color:#333}.threshold-indicator{color:#ffc107;font-size:16px;font-weight:700}.indicator-cell{width:30px;text-align:center;padding:12px 8px!important}.rates-table tr.meets-threshold{background-color:#f0f7ff}.rates-table tr.meets-threshold:hover{background-color:#e8f0ff}.rates-table tr.meets-threshold td{font-weight:500}.rules-list-container{width:100%}.rules-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;flex-wrap:wrap;gap:20px}.rules-header h2{margin:0;font-size:24px;color:#333}.rules-description{margin:5px 0 0;color:#666;font-size:14px}.rules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.rule-card{background:#fff;border:2px solid #e0e0e0;border-radius:10px;padding:20px;transition:all .3s}.rule-card.active{border-color:#667eea}.rule-card.inactive{opacity:.7}.rule-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.rule-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:15px;gap:10px}.rule-header h3{margin:0;font-size:18px;color:#333;word-break:break-word;flex:1}.status-badge{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap}.status-badge.active{background-color:#e8f5e9;color:#2e7d32}.status-badge.inactive{background-color:#f5f5f5;color:#757575}.rule-body{margin-bottom:15px}.rule-info{display:flex;flex-direction:column;gap:8px}.info-row{display:flex;justify-content:space-between;align-items:center;font-size:14px}.info-label{color:#666;font-weight:500}.info-value{color:#333;font-weight:600}.rule-actions{display:flex;gap:10px;margin-top:15px;padding-top:15px;border-top:1px solid #e0e0e0}.btn-small{padding:8px 16px;font-size:13px;flex:1}.btn-danger{background-color:#f44336;color:#fff}.btn-danger:hover:not(:disabled){background-color:#d32f2f}.no-rules{text-align:center;padding:60px 20px;color:#666}.no-rules p{margin:10px 0}.rule-form-container{margin-bottom:30px}.rule-form{background:#f9f9f9;border:2px solid #667eea;border-radius:10px;padding:30px}.rule-form h3{margin:0 0 25px;font-size:20px;color:#333}.rule-form form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;color:#333;font-size:14px}.form-group input,.form-group select{padding:12px;border:1px solid #ddd;border-radius:5px;font-size:14px;transition:border-color .3s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea}.form-group small{color:#666;font-size:12px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}@media (max-width: 768px){.form-row{grid-template-columns:1fr}}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-weight:600;color:#333}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.form-actions{display:flex;gap:15px;justify-content:flex-end;margin-top:10px}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:5px;border:1px solid #fcc;margin-bottom:15px;font-size:14px}.loading{text-align:center;padding:60px 20px;color:#666;font-size:18px}.notification-bell-container{position:relative}.notification-bell{position:relative;background:none;border:none;color:#333;cursor:pointer;padding:8px;border-radius:50%;transition:background-color .3s;display:flex;align-items:center;justify-content:center}.notification-bell:hover{background-color:#f0f0f0}.notification-badge{position:absolute;top:4px;right:4px;background:#f44336;color:#fff;border-radius:10px;padding:2px 6px;font-size:11px;font-weight:700;min-width:18px;text-align:center}.notification-dropdown{position:absolute;top:calc(100% + 10px);right:0;width:400px;max-width:90vw;background:#fff;border-radius:10px;box-shadow:0 10px 40px #0003;z-index:1000;max-height:80vh;display:flex;flex-direction:column}.notification-list{display:flex;flex-direction:column;max-height:600px}.notification-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-bottom:1px solid #e0e0e0}.notification-header h3{margin:0;font-size:18px;color:#333}.mark-all-read-btn{background:none;border:none;color:#667eea;font-size:13px;font-weight:600;cursor:pointer;padding:5px 10px;border-radius:5px;transition:background-color .3s}.mark-all-read-btn:hover{background-color:#f0f0f0}.notification-items{overflow-y:auto;max-height:500px}.notification-item{display:flex;gap:10px;padding:15px 20px;border-bottom:1px solid #f0f0f0;transition:background-color .3s;position:relative}.notification-item:hover{background-color:#f9f9f9}.notification-item.unread{background-color:#f0f4ff}.notification-item.unread:hover{background-color:#e8f0ff}.unread-indicator{position:absolute;left:8px;top:50%;transform:translateY(-50%);width:8px;height:8px;background-color:#667eea;border-radius:50%}.notification-content{flex:1;display:flex;flex-direction:column;gap:6px;padding-left:10px}.notification-rule{font-weight:600;color:#333;font-size:14px}.notification-message{color:#666;font-size:13px;line-height:1.4}.notification-rate-details{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px}.rate-detail{background:#fff;padding:4px 10px;border-radius:12px;font-size:12px;color:#667eea;font-weight:600;border:1px solid #667eea}.notification-time{color:#999;font-size:12px;margin-top:4px}.notification-actions{display:flex;gap:5px;align-items:flex-start}.notification-action-btn{background:none;border:none;color:#999;font-size:18px;cursor:pointer;padding:5px;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s}.notification-action-btn:hover{background-color:#f0f0f0;color:#333}.notification-action-btn.delete:hover{background-color:#fee;color:#f44336}.no-notifications{text-align:center;padding:40px 20px;color:#666}.no-notifications p{margin:10px 0}.no-notifications .small{font-size:13px;color:#999}.notification-loading,.notification-error{text-align:center;padding:40px 20px;color:#666}.notification-error{color:#f44336}@media (max-width: 768px){.notification-dropdown{width:350px}}.profile-page{min-height:100vh;background-color:#f5f5f5}.profile-header{background:#fff;padding:1.5rem 2rem;box-shadow:0 2px 4px #0000001a;display:flex;align-items:center;gap:2rem;margin-bottom:2rem}.profile-header h1{margin:0;color:#2c3e50;font-size:1.5rem}.profile-container{max-width:800px;margin:0 auto;padding:0 2rem 2rem}.profile-container h2{margin-bottom:2rem;color:#2c3e50}.profile-section{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem}.profile-section h3{margin-top:0;margin-bottom:1.5rem;color:#34495e;font-size:1.2rem;border-bottom:2px solid #ecf0f1;padding-bottom:.5rem}.profile-info{display:flex;flex-direction:column;gap:1rem}.profile-info .info-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background-color:#f8f9fa;border-radius:4px}.profile-info .info-label{font-weight:600;color:#5a6c7d}.profile-info .info-value{color:#2c3e50}.password-form-container{margin-top:1rem}.password-form{max-width:500px}.password-form .form-group{margin-bottom:1.5rem}.password-form label{display:block;margin-bottom:.5rem;font-weight:600;color:#34495e}.password-form input[type=password]{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;box-sizing:border-box}.password-form input[type=password]:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.password-form small{display:block;margin-top:.25rem;color:#7f8c8d;font-size:.875rem}.form-actions{display:flex;gap:1rem;margin-top:1.5rem}.error-message{background-color:#fee;color:#c33;padding:.75rem;border-radius:4px;margin-bottom:1rem;border-left:4px solid #c33}.success-message{background-color:#efe;color:#2a7;padding:.75rem;border-radius:4px;margin-bottom:1rem;border-left:4px solid #2a7}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:600}.status-badge.active{background-color:#d4edda;color:#155724}.status-badge.inactive{background-color:#f8d7da;color:#721c24}@media (max-width: 768px){.profile-container{padding:1rem}.profile-section{padding:1.5rem}.profile-info .info-row{flex-direction:column;align-items:flex-start;gap:.5rem}.form-actions{flex-direction:column}.form-actions button{width:100%}}*{box-sizing:border-box;margin:0;padding:0}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:#f5f7fa}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px}.spinner{width:50px;height:50px;border:5px solid #f3f3f3;border-top:5px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-screen p{color:#666;font-size:16px}.btn{padding:10px 20px;border:none;border-radius:5px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.btn-secondary{background:#f0f0f0;color:#333}.btn-secondary:hover:not(:disabled){background:#e0e0e0}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:5px;border:1px solid #fcc;margin-bottom:20px;font-size:14px}.success-message{background-color:#e8f5e9;color:#2e7d32;padding:12px;border-radius:5px;border:1px solid #c8e6c9;margin-bottom:20px;font-size:14px}
