@import url(https://fonts.googleapis.com/css2?family=Playfair+Display:ital@1&display=swap);body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.calendar-view{display:flex;flex-direction:column;gap:1.5rem}.calendar-actions{align-items:center;display:flex;gap:.5rem}.calendar-status-info{padding:1rem;text-align:center}.calendar-status-info p{color:#64748b;margin:.5rem 0}.status-note{color:#10b981!important;font-size:.9rem;font-style:italic}.calendar-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:1.5rem}.calendar-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.calendar-header h3{color:#1e293b;font-size:1.25rem;font-weight:600;margin:0}.calendar-header .nav-btn{background:none;border:none;border-radius:4px;color:#64748b;cursor:pointer;padding:.5rem;transition:all .2s}.calendar-header .nav-btn:hover{background:#f1f5f9;color:#1e293b}.calendar-weekdays{grid-gap:1px;background:#e2e8f0;border-radius:4px;display:grid;gap:1px;grid-template-columns:repeat(7,1fr);margin-bottom:1px;overflow:hidden}.weekday{background:#f8fafc;color:#64748b;font-size:.875rem;font-weight:600;padding:.75rem;text-align:center}.calendar-days{grid-gap:1px;background:#e2e8f0;border-radius:4px;display:grid;gap:1px;grid-template-columns:repeat(7,1fr);overflow:hidden}.calendar-day{background:#fff;cursor:pointer;min-height:100px;padding:.5rem;position:relative;transition:background-color .2s}.calendar-day:hover{background:#f8fafc}.calendar-day.empty{background:#f1f5f9;cursor:default}.calendar-day.today{background:#eff6ff;border:2px solid #3b82f6}.calendar-day.has-events{background:#f0f9ff}.calendar-day.has-events:hover{background:#e0f2fe}.day-number{color:#1e293b;font-size:.875rem;font-weight:600;margin-bottom:.25rem}.calendar-day.today .day-number{color:#3b82f6}.day-events{display:flex;flex-direction:column;gap:2px}.event-dot{background:#3b82f6;border-radius:3px;color:#fff;font-size:.75rem;overflow:hidden;padding:2px 6px;text-overflow:ellipsis;white-space:nowrap}.event-dot.more{background:#64748b;font-size:.7rem}.dark-mode .calendar-container{background:#1e293b;color:#e2e8f0}.dark-mode .calendar-header h3{color:#f1f5f9}.dark-mode .weekday{background:#334155;color:#cbd5e1}.dark-mode .calendar-day{background:#2d3748;color:#e2e8f0}.dark-mode .calendar-day:hover{background:#3a4553}.dark-mode .calendar-day.empty{background:#1a202c}.dark-mode .calendar-day.today{background:#1e3a8a;border-color:#3b82f6}.dark-mode .calendar-day.has-events{background:#1e3a8a}.dark-mode .calendar-day.has-events:hover{background:#1e40af}.dark-mode .day-number{color:#e2e8f0}.dark-mode .calendar-day.today .day-number{color:#93c5fd}.dark-mode .calendar-header .nav-btn{color:#cbd5e1}.dark-mode .calendar-header .nav-btn:hover{background:#334155;color:#f1f5f9}.modal-content{border-radius:8px;box-shadow:0 10px 25px #0003;max-width:500px;width:90%}.modal-header{border-bottom:1px solid #e2e8f0;padding:1.5rem}.close-btn{align-items:center;background:none;border:none;border-radius:4px;color:#64748b;cursor:pointer;display:flex;font-size:1.5rem;height:32px;justify-content:center;padding:0;width:32px}.close-btn:hover{background:#f1f5f9}.modal-body,.modal-footer{padding:1.5rem}.modal-footer{border-top:1px solid #e2e8f0;gap:1rem}.event-detail{border:1px solid #e2e8f0;border-radius:6px;margin-bottom:1rem;padding:1rem}.event-detail h4{color:#1e293b;margin:0 0 .5rem}.event-time{color:#3b82f6;font-size:.875rem;margin-bottom:.5rem}.event-description{color:#64748b;margin:.5rem 0}.event-location{color:#64748b;font-size:.875rem;margin-top:.5rem}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1 1}.dark-mode .modal-content{background:#1e293b;color:#e2e8f0}.dark-mode .modal-header{border-bottom-color:#334155}.dark-mode .modal-header h3{color:#f1f5f9}.dark-mode .close-btn{color:#cbd5e1}.dark-mode .close-btn:hover{background:#334155}.dark-mode .modal-footer{border-top-color:#334155}.dark-mode .event-detail{background:#334155;border-color:#334155}.dark-mode .event-detail h4{color:#f1f5f9}.dark-mode .event-description,.dark-mode .event-location{color:#cbd5e1}.create-event-modal{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 25px 50px #00000040;max-height:90vh;max-width:600px;overflow:hidden;width:90%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.create-event-modal .modal-header{background:linear-gradient(135deg,#3b82f6,#1e40af);border-bottom:none;color:#fff;padding:2rem}.create-event-modal .header-content{align-items:center;display:flex;gap:1rem}.create-event-modal .header-icon{align-items:center;background:#fff3;border-radius:10px;display:flex;justify-content:center;padding:.75rem}.create-event-modal .header-text h3{color:#fff;font-size:1.5rem;font-weight:700;margin:0}.create-event-modal .header-text p{color:#fffc;font-size:.875rem;margin:.25rem 0 0}.create-event-modal .close-btn{background:#ffffff1a;border:none;border-radius:8px;color:#fff;height:40px;transition:all .2s;width:40px}.create-event-modal .close-btn:hover{background:#fff3}.create-event-modal .modal-body{max-height:60vh;overflow-y:auto;padding:2rem}.form-section{margin-bottom:2rem}.form-section:last-child{margin-bottom:0}.section-title{align-items:center;border-bottom:2px solid #e2e8f0;color:#1e293b;display:flex;font-size:1rem;font-weight:600;gap:.5rem;margin-bottom:1rem;padding-bottom:.5rem}.form-group{margin-bottom:1.5rem}.form-group:last-child{margin-bottom:0}.form-group label{color:#374151;display:block;font-weight:500;margin-bottom:.5rem}.label-text{font-size:.875rem}.required{color:#ef4444;margin-left:.25rem}.label-hint{color:#6b7280;font-size:.75rem;font-weight:400;margin-left:.5rem}.form-input,.form-textarea{background:#fff;border:2px solid #e2e8f0;border-radius:8px;color:#1e293b;font-size:.875rem;padding:.75rem 1rem;transition:all .2s;width:100%}.form-input:focus,.form-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-textarea{min-height:80px;resize:vertical}.time-inputs{align-items:end;display:flex;gap:1rem}.time-inputs .form-group{flex:1 1}.time-divider{color:#6b7280;font-size:.875rem;font-weight:500;margin-bottom:1.5rem}.time-input{font-family:monospace;font-size:1rem}.create-event-modal .modal-footer{background:#f8fafc;border-top:1px solid #e2e8f0;display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem 2rem}.btn-cancel{background:#fff;border:2px solid #e2e8f0;border-radius:8px;color:#6b7280;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.btn-cancel:hover{background:#f9fafb;border-color:#d1d5db;color:#374151}.btn-create{align-items:center;background:linear-gradient(135deg,#3b82f6,#1e40af);border:none;border-radius:8px;box-shadow:0 4px 12px #3b82f666;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s}.btn-create:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 8px 20px #3b82f680;transform:translateY(-1px)}.btn-create:active{transform:translateY(0)}.dark-mode .create-event-modal{background:#1e293b;color:#e2e8f0}.dark-mode .section-title{border-bottom-color:#334155;color:#f1f5f9}.dark-mode .form-group label{color:#e2e8f0}.dark-mode .form-input,.dark-mode .form-textarea{background:#334155;border-color:#475569;color:#e2e8f0}.dark-mode .form-input:focus,.dark-mode .form-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633}.dark-mode .time-divider{color:#cbd5e1}.dark-mode .create-event-modal .modal-footer{background:#0f172a;border-top-color:#334155}.dark-mode .btn-cancel{background:#334155;border-color:#475569;color:#cbd5e1}.dark-mode .btn-cancel:hover{background:#475569;border-color:#64748b;color:#e2e8f0}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8fafc;color:#334155;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.app{display:flex;flex-direction:column;min-height:100vh}.app-layout{display:flex;flex:1 1}.app-header{background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px 0 #0000001a;z-index:10}.header-content{align-items:center;display:flex;justify-content:space-between;padding:1rem 2rem;width:100%}.header-logo h1{align-items:baseline;color:#1e293b;display:inline-flex;font-size:1.875rem;font-weight:700;gap:.5rem;margin:0}.logo-cavalletto{font-feature-settings:"smcp";color:#8b4513;font-family:Georgia,Times New Roman,serif;font-size:2rem;font-variant:small-caps;font-weight:800;letter-spacing:.05em}.logo-law{color:#1e3a8a;font-family:Playfair Display,Georgia,serif;font-size:1.25rem;font-style:italic;font-weight:400;position:relative;top:.125rem}.search-bar{flex:1 1;margin:0 2rem;max-width:500px;position:relative}.search-bar svg{color:#9ca3af;left:1rem;position:absolute;top:50%;transform:translateY(-50%)}.search-bar input{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;font-size:.875rem;padding:.5rem 1rem .5rem 2.75rem;transition:all .2s;width:100%}.search-bar input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.search-dropdown{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;left:0;max-height:400px;overflow-y:auto;position:absolute;right:0;top:calc(100% + .5rem);z-index:1000}.search-section{padding:.5rem 0}.search-section:not(:last-child){border-bottom:1px solid #e5e7eb}.search-section-title{color:#6b7280;font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:.5rem 1rem;text-transform:uppercase}.search-result-item{align-items:center;cursor:pointer;display:flex;gap:.75rem;padding:.75rem 1rem;transition:background-color .2s}.search-result-item:hover{background-color:#f3f4f6}.search-result-icon{color:#6b7280;flex-shrink:0}.search-result-content{flex:1 1;min-width:0}.search-result-name{color:#1e293b;font-weight:500}.search-result-meta,.search-result-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-no-results,.search-result-meta{color:#6b7280;font-size:.875rem}.search-no-results{padding:1.5rem;text-align:center}.header-user{align-items:center;color:#6b7280;display:flex;font-size:.875rem;gap:1rem}.dark-mode-toggle,.logout-btn,.profile-btn{background:#f3f4f6;border:none;border-radius:.375rem;color:#6b7280;cursor:pointer;padding:.5rem;transition:all .2s}.dark-mode-toggle:hover,.logout-btn:hover,.profile-btn:hover{background:#e5e7eb;color:#374151}.app-sidebar{background:#fff;border-right:1px solid #e2e8f0;box-shadow:1px 0 3px 0 #0000000d;display:flex;flex-direction:column;width:200px}.sidebar-nav{flex:1 1;padding:1rem 0}.sidebar-tab{align-items:center;background:#0000;border:none;color:#64748b;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.75rem;padding:.75rem 1.5rem;text-align:left;transition:all .2s;width:100%}.sidebar-tab:hover{background:#f8fafc;color:#334155}.sidebar-tab.active{background:#eff6ff;border-right:3px solid #1d4ed8;color:#1d4ed8}.app-main{background:#f8fafc;flex:1 1;max-height:calc(100vh - 80px);overflow-y:auto;padding:2rem}.tab-content{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px 0 #0000001a;overflow:hidden}.tab-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:1.5rem 2rem}.tab-header h2{color:#1e293b;font-size:1.5rem;font-weight:600;margin:0}.header-buttons{display:flex;gap:.75rem}.btn-primary{align-items:center;background:#3b82f6;border:none;border-radius:.375rem;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:all .2s}.btn-primary:hover{background:#2563eb}.btn-secondary{align-items:center;background:#fff;border:1px solid #d1d5db;border-radius:.375rem;color:#374151;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:all .2s}.btn-secondary:hover{background:#f9fafb;border-color:#9ca3af}.btn-danger{align-items:center;background:#ef4444;border:none;border-radius:.375rem;color:#fff;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:all .2s}.btn-danger:hover{background:#dc2626}.data-table{border-collapse:collapse;width:100%}.data-table th{background:#f9fafb;border-bottom:1px solid #e5e7eb;color:#6b7280;font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:.875rem 1.5rem;text-align:left;text-transform:uppercase}.tab-content:has(.data-table) .data-table td:first-child,.tab-content:has(.data-table) .data-table th:first-child{padding-right:.75rem;width:18%}.tab-content:has(.data-table) .data-table td:nth-child(2),.tab-content:has(.data-table) .data-table th:nth-child(2){padding-left:.75rem;width:15%}.tab-content:has(.data-table) .data-table td:nth-child(3),.tab-content:has(.data-table) .data-table th:nth-child(3){width:12%}.tab-content:has(.data-table) .data-table td:nth-child(4),.tab-content:has(.data-table) .data-table th:nth-child(4){width:12%}.tab-content:has(.data-table) .data-table td:nth-child(5),.tab-content:has(.data-table) .data-table th:nth-child(5){width:10%}.tab-content:has(.data-table) .data-table td:nth-child(6),.tab-content:has(.data-table) .data-table th:nth-child(6){width:8%}.tab-content:has(.data-table) .data-table td:nth-child(7),.tab-content:has(.data-table) .data-table th:nth-child(7){width:10%}.tab-content:has(.data-table) .data-table td:nth-child(8),.tab-content:has(.data-table) .data-table th:nth-child(8){width:15%}.data-table td{border-bottom:1px solid #f3f4f6;color:#374151;font-size:.875rem;padding:1rem 1.5rem}.data-table tr:hover{background:#f9fafb}.contact-name-link{background:none;border:none;color:#3b82f6;cursor:pointer;font-weight:500;padding:0;text-align:left;text-decoration:none;transition:color .2s}.contact-name-link:hover{color:#1d4ed8;text-decoration:underline}.contact-type{border-radius:9999px;display:inline-block;font-size:.75rem;font-weight:500;letter-spacing:.025em;padding:.25rem .75rem;text-transform:uppercase}.type-client{background:#dbeafe;color:#1e40af}.type-co-counsel{background:#fef3c7;color:#92400e}.type-opposing-counsel{background:#fee2e2;color:#991b1b}.type-other{background:#e5e7eb;color:#374151}.table-actions{display:flex;gap:.5rem}.action-btn{align-items:center;border:none;border-radius:.25rem;cursor:pointer;display:inline-flex;font-size:.75rem;font-weight:500;gap:.25rem;padding:.375rem .625rem;transition:all .2s}.action-btn.edit{background:#eff6ff;color:#1d4ed8}.action-btn.edit:hover{background:#dbeafe}.action-btn.delete{background:#fee2e2;color:#dc2626}.action-btn.delete:hover{background:#fecaca}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:2rem;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:.5rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-height:90vh;max-width:600px;overflow-y:auto;padding:2rem;width:100%}.modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.modal-header h3{color:#1e293b;font-size:1.25rem;font-weight:600;margin:0}.modal-close{background:none;border:none;border-radius:.25rem;color:#6b7280;cursor:pointer;padding:.25rem;transition:color .2s}.modal-close:hover{color:#374151}.modal-body{margin-bottom:1.5rem}.modal-footer{border-top:1px solid #e5e7eb;display:flex;gap:.75rem;justify-content:flex-end;padding-top:1.5rem}.cases-selection{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;max-height:400px;overflow-y:auto}.case-selection-item{align-items:center;border-bottom:1px solid #e5e7eb;cursor:pointer;display:flex;gap:1rem;padding:1rem;transition:background-color .2s}.case-selection-item:hover{background-color:#f3f4f6}.case-selection-item.selected{background-color:#dbeafe;border-color:#3b82f6}.case-selection-item:last-child{border-bottom:none}.case-selection-content{flex:1 1}.case-title{margin-bottom:.5rem}.case-meta{align-items:center;flex-wrap:wrap;gap:.75rem;margin-bottom:.25rem}.case-attorney,.case-date{color:#6b7280;font-size:.875rem}.case-description{color:#6b7280;line-height:1.4;margin-top:.25rem}.case-selection-checkbox{flex-shrink:0}.case-selection-checkbox input[type=checkbox]{cursor:pointer;height:1.25rem;width:1.25rem}.mb-4{margin-bottom:1rem}.text-muted{color:#6b7280}.form-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr)}.form-row{margin-bottom:1rem}.form-label{color:#374151;display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.form-input{padding:.5rem .75rem}.form-buttons{border-top:1px solid #e5e7eb;display:flex;gap:.75rem;margin-top:1.5rem;padding-top:1.5rem}.content-card{padding:2rem}.content-card h3{font-size:1.125rem}.content-card h4{color:#374151;font-weight:500;margin-bottom:.5rem}.content-card p{color:#64748b;line-height:1.5}.placeholder-content{color:#9ca3af;font-style:italic;padding:3rem;text-align:center}.contact-info-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(2,1fr)}.info-section{background:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;padding:1.5rem}.info-section h4{color:#6b7280;font-size:.875rem;font-weight:600;letter-spacing:.05em;margin-bottom:1rem;text-transform:uppercase}.info-row{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:.5rem 0}.info-row:last-child{border-bottom:none}.info-row .label{color:#6b7280;font-size:.875rem}.info-row .value{color:#1e293b;font-size:.875rem;font-weight:500}.info-row .empty{color:#9ca3af;font-style:italic}.case-list{display:flex;flex-direction:column;gap:1rem;padding:1.5rem}.case-card{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;cursor:pointer;padding:1.5rem}.case-card:hover{border-color:#3b82f6;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.case-header{align-items:start}.case-title{color:#1e293b;font-size:1rem;font-weight:600}.case-meta{color:#6b7280;display:flex;font-size:.875rem;gap:1rem}.status-badge{border-radius:9999px;display:inline-block;font-size:.75rem;font-weight:500;letter-spacing:.025em;padding:.25rem .75rem;text-transform:uppercase}.status-active{background:#dcfce7;color:#166534}.status-completed{background:#dbeafe;color:#1e40af}.status-on-hold{background:#fef3c7;color:#92400e}.status-closed{background:#e5e7eb;color:#374151}.case-fee{color:#059669;font-weight:500}.invoice-form-grid{grid-gap:1.5rem;display:grid;gap:1.5rem}.line-items-section{margin-top:1.5rem}.line-item{grid-gap:.75rem;align-items:center;background:#f9fafb;border-radius:.375rem;display:grid;gap:.75rem;grid-template-columns:2fr 1fr auto;margin-bottom:.75rem;padding:.75rem}.remove-line-item{background:#fee2e2;border:none;border-radius:.25rem;color:#dc2626;cursor:pointer;padding:.25rem;transition:background .2s}.remove-line-item:hover{background:#fecaca}.add-line-item{align-items:center;background:#f3f4f6;border:1px solid #d1d5db;border-radius:.375rem;color:#374151;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;margin-top:.5rem;padding:.5rem 1rem;transition:all .2s}.add-line-item:hover{background:#e5e7eb;border-color:#9ca3af}.import-dropzone{border:2px dashed #d1d5db;border-radius:.5rem;cursor:pointer;padding:2rem;text-align:center;transition:all .2s}.import-dropzone:hover{background:#f0f9ff;border-color:#3b82f6}.import-dropzone.active{background:#eff6ff;border-color:#3b82f6}.import-icon{color:#9ca3af;margin-bottom:1rem}.import-preview{background:#f9fafb;border-radius:.375rem;margin-top:1.5rem;max-height:300px;overflow-y:auto;padding:1rem}.preview-table{border-collapse:collapse;font-size:.75rem;width:100%}.preview-table th{background:#fff;border-bottom:1px solid #e5e7eb;color:#6b7280;font-weight:600;padding:.5rem;text-align:left}.preview-table td{border-bottom:1px solid #f3f4f6;color:#374151;padding:.5rem}.empty-state{color:#9ca3af;padding:4rem 2rem}.empty-state h3{color:#6b7280;font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.empty-state p,.status-filters{margin-bottom:1.5rem}.status-filters{display:flex;gap:.5rem;padding:0 1.5rem}.status-filter{background:#fff;border:1px solid #d1d5db;border-radius:.375rem;color:#374151;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .2s}.status-filter:hover{background:#f9fafb;border-color:#9ca3af}.status-filter.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.notes-content{background:#f9fafb;border-radius:.375rem;color:#374151;font-size:.875rem;line-height:1.5;padding:1rem;white-space:pre-wrap}.login-container{align-items:center;background:#f8fafc;display:flex;justify-content:center;min-height:100vh;padding:2rem}.login-card{background:#fff;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;max-width:400px;padding:2.5rem;width:100%}.login-header{margin-bottom:2rem;text-align:center}.login-title{color:#1e293b;font-size:1.875rem;font-weight:700;margin-bottom:.5rem}.login-subtitle{color:#6b7280;font-size:.875rem}.auth-form{display:flex;flex-direction:column;gap:1rem}.input-group{position:relative}.input-label{color:#374151;display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.form-input{background:#fff;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;padding:.75rem 1rem;transition:all .2s;width:100%}.form-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-input:disabled{background:#f9fafb;cursor:not-allowed;opacity:.6}.form-input[type=select]{padding-left:.75rem}.password-toggle{background:none;border:none;border-radius:.25rem;color:#9ca3af;cursor:pointer;padding:.25rem;position:absolute;right:.75rem;transition:color .2s}.password-toggle:hover{color:#374151}.password-toggle:disabled{cursor:not-allowed;opacity:.6}.auth-btn{font-size:.875rem;font-weight:500;margin-top:.5rem;padding:.875rem;width:100%}.auth-switch{border-top:1px solid #e5e7eb;color:#6b7280;font-size:.875rem;margin-top:1.5rem;padding-top:1.5rem;text-align:center}.auth-switch button{background:none;border:none;color:#3b82f6;cursor:pointer;font-weight:500;transition:color .2s}.auth-switch button:hover{color:#1d4ed8;text-decoration:underline}.auth-switch button:disabled{cursor:not-allowed;opacity:.6}.auth-error{align-items:center;background:#fee2e2;border-radius:.375rem;color:#dc2626;display:flex;font-size:.875rem;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem}@media (max-width:768px){.app-layout{flex-direction:column}.app-sidebar{border-bottom:1px solid #e2e8f0;border-right:none;width:100%}.sidebar-nav{display:flex;overflow-x:auto;padding:0}.sidebar-tab{padding:1rem;white-space:nowrap}.sidebar-tab.active{border-bottom:3px solid #1d4ed8;border-right:none}.header-content{align-items:stretch;flex-direction:column;gap:1rem}.search-bar{margin:0;max-width:none}.contact-info-grid,.form-grid{grid-template-columns:1fr}.app-main{max-height:none;padding:1rem}.tab-header{align-items:stretch;flex-direction:column;gap:1rem}.header-buttons{flex-wrap:wrap}}.user-profile-content{max-width:500px}.profile-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;gap:1.5rem;margin-bottom:2rem;padding-bottom:1.5rem}.profile-avatar{align-items:center;background:#3b82f6;border-radius:50%;color:#fff;display:flex;font-size:2rem;font-weight:600;height:80px;justify-content:center;width:80px}.profile-info h3{color:#1e293b;font-size:1.25rem;font-weight:600;margin-bottom:.25rem}.profile-info p{color:#6b7280;font-size:.875rem}.profile-details{display:flex;flex-direction:column;gap:1rem}.profile-field{border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:.75rem 0}.profile-field:last-child{border-bottom:none}.field-label{color:#6b7280;font-size:.875rem;font-weight:500}.field-value{color:#1e293b;font-size:.875rem;text-align:right}.collapsible-section{margin-bottom:1rem}.section-toggle{align-items:center;background:none;border:none;color:#3b82f6;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 0;transition:color .2s}.section-toggle:hover{color:#1d4ed8}body.dark-mode{background-color:#0f172a;color:#e2e8f0}body.dark-mode .app-header{background:#1e293b;border-bottom-color:#334155}body.dark-mode .header-logo h1{color:#f1f5f9}body.dark-mode .logo-cavalletto{color:#d97706}body.dark-mode .logo-law{color:#60a5fa}body.dark-mode .search-bar input{background:#334155;border-color:#475569;color:#e2e8f0}body.dark-mode .search-bar input:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa33}body.dark-mode .search-dropdown{background:#1e293b;border-color:#475569}body.dark-mode .search-section:not(:last-child){border-bottom-color:#475569}body.dark-mode .search-section-title{color:#94a3b8}body.dark-mode .search-result-item:hover{background-color:#334155}body.dark-mode .search-result-icon{color:#94a3b8}body.dark-mode .search-result-name{color:#e2e8f0}body.dark-mode .header-user,body.dark-mode .search-no-results,body.dark-mode .search-result-meta{color:#94a3b8}body.dark-mode .dark-mode-toggle,body.dark-mode .logout-btn,body.dark-mode .profile-btn{background:#334155;color:#94a3b8}body.dark-mode .dark-mode-toggle:hover,body.dark-mode .logout-btn:hover,body.dark-mode .profile-btn:hover{background:#475569;color:#e2e8f0}body.dark-mode .app-sidebar{background:#1e293b;border-right-color:#334155}body.dark-mode .sidebar-tab{color:#94a3b8}body.dark-mode .sidebar-tab:hover{background:#334155;color:#e2e8f0}body.dark-mode .sidebar-tab.active{background:#1e3a8a;border-right-color:#60a5fa;color:#60a5fa}body.dark-mode .app-main{background:#0f172a}body.dark-mode .tab-content{background:#1e293b;box-shadow:0 1px 3px 0 #0000004d}body.dark-mode .tab-header{border-bottom-color:#334155}body.dark-mode .tab-header h2{color:#f1f5f9}body.dark-mode .btn-primary{background:#3b82f6}body.dark-mode .btn-primary:hover{background:#2563eb}body.dark-mode .btn-secondary{background:#334155;border-color:#475569;color:#e2e8f0}body.dark-mode .btn-secondary:hover{background:#475569;border-color:#64748b}body.dark-mode .data-table th{background:#334155;border-bottom-color:#475569;color:#94a3b8}body.dark-mode .data-table td{border-bottom-color:#334155;color:#e2e8f0}body.dark-mode .data-table tr:hover{background:#334155}body.dark-mode .contact-name-link{color:#60a5fa}body.dark-mode .contact-name-link:hover{color:#93c5fd}body.dark-mode .modal-overlay{background:#000000b3}body.dark-mode .modal-content{background:#1e293b;color:#e2e8f0}body.dark-mode .modal-header h3{color:#f1f5f9}body.dark-mode .modal-close{color:#94a3b8}body.dark-mode .form-label,body.dark-mode .modal-close:hover{color:#e2e8f0}body.dark-mode .form-input{background:#334155;border-color:#475569;color:#e2e8f0}body.dark-mode .form-input:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa33}body.dark-mode .content-card h3,body.dark-mode .content-card h4{color:#f1f5f9}body.dark-mode .content-card p{color:#94a3b8}body.dark-mode .info-section{background:#334155;border-color:#475569}body.dark-mode .info-section h4{color:#94a3b8}body.dark-mode .info-row{border-bottom-color:#475569}body.dark-mode .info-row .label{color:#94a3b8}body.dark-mode .info-row .value{color:#f1f5f9}body.dark-mode .info-row .empty{color:#64748b}body.dark-mode .status-badge{opacity:.9}body.dark-mode .notes-content{background:#334155;color:#e2e8f0}body.dark-mode .empty-state{color:#64748b}body.dark-mode .empty-state h3{color:#94a3b8}body.dark-mode .form-buttons{border-top-color:#334155}body.dark-mode .import-dropzone{border-color:#475569}body.dark-mode .import-dropzone.active,body.dark-mode .import-dropzone:hover{background:#1e3a8a;border-color:#60a5fa}body.dark-mode .preview-table th{background:#334155;border-bottom-color:#475569;color:#94a3b8}body.dark-mode .preview-table td{border-bottom-color:#334155;color:#e2e8f0}body.dark-mode .line-item{background:#334155}body.dark-mode .add-line-item{background:#334155;border-color:#475569;color:#e2e8f0}body.dark-mode .add-line-item:hover{background:#475569;border-color:#64748b}body.dark-mode .status-filter{background:#334155;border-color:#475569;color:#e2e8f0}body.dark-mode .status-filter:hover{background:#475569;border-color:#64748b}body.dark-mode .status-filter.active{background:#3b82f6;border-color:#3b82f6}body.dark-mode .login-card{background:#1e293b}body.dark-mode .login-title{color:#f1f5f9}body.dark-mode .login-subtitle{color:#94a3b8}body.dark-mode .input-label{color:#e2e8f0}body.dark-mode .auth-switch{border-top-color:#334155;color:#94a3b8}body.dark-mode .auth-switch button{color:#60a5fa}body.dark-mode .auth-switch button:hover{color:#93c5fd}body.dark-mode .auth-error{background:#7f1d1d;color:#fecaca}.client-dropdown{background:#fff;border:1px solid #d1d5db;border-radius:.375rem;box-shadow:0 4px 6px -1px #0000001a;left:0;margin-top:2px;max-height:200px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:1000}.client-dropdown-item{border-bottom:1px solid #f3f4f6;cursor:pointer;padding:.75rem 1rem;transition:background-color .2s}.client-dropdown-item:hover{background:#f9fafb}.client-dropdown-item:last-child{border-bottom:none}.client-dropdown-item-none{color:#6b7280;font-size:.875rem;font-style:italic;padding:.75rem 1rem;text-align:center}.client-name{color:#1e293b;font-size:.875rem;font-weight:500}.client-company{color:#6b7280;font-size:.75rem;margin-top:.25rem}body.dark-mode .client-dropdown{background:#334155;border-color:#475569}body.dark-mode .client-dropdown-item{border-bottom-color:#475569}body.dark-mode .client-dropdown-item:hover{background:#475569}body.dark-mode .client-name{color:#f1f5f9}body.dark-mode .client-company,body.dark-mode .client-dropdown-item-none{color:#94a3b8}.detail-page{background:#f8fafc;min-height:100vh;padding:1rem}.detail-header{align-items:flex-start;background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;display:flex;justify-content:space-between;margin-bottom:2rem;padding:1.5rem}.detail-header-left{display:flex;flex-direction:column;gap:1rem}.btn-back{align-items:center;background:#f1f5f9;border:none;border-radius:.375rem;color:#64748b;cursor:pointer;display:flex;font-size:.875rem;gap:.5rem;padding:.5rem 1rem;transition:all .2s;width:fit-content}.btn-back:hover{background:#e2e8f0;color:#475569}.detail-title-section{align-items:center;display:flex;gap:1rem}.detail-title-section h1{color:#1e293b;font-size:2rem;font-weight:700;margin:0}.detail-header-actions{display:flex;gap:.75rem}.detail-content{max-width:100%}.detail-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 300px}.detail-main,.detail-sidebar{display:flex;flex-direction:column;gap:1.5rem}.content-card{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.content-card h3{border-bottom:2px solid #e2e8f0;font-size:1.25rem;padding-bottom:.5rem}.content-card h3,.content-card h4{color:#1e293b;font-weight:600;margin-bottom:1rem}.content-card h4{font-size:1rem}.info-grid{grid-gap:1rem;display:grid;gap:1rem}.info-item{align-items:flex-start;border:1px solid #e2e8f0;border-radius:.375rem;display:flex;gap:.75rem;padding:.75rem;transition:all .2s}.info-item:hover{background:#f8fafc;border-color:#cbd5e1}.info-item svg{color:#64748b;flex-shrink:0;margin-top:.125rem}.info-label{color:#64748b;display:block;margin-bottom:.25rem}.info-label,.info-value{font-size:.875rem;font-weight:500}.info-value{color:#1e293b}.info-value.link{background:none;border:none;color:#3b82f6;cursor:pointer;font-size:inherit;font-weight:inherit;padding:0;text-align:left;text-decoration:none}.info-value.link:hover{text-decoration:underline}.fee-amount{color:#059669;font-size:1rem;font-weight:600}.section-header{align-items:center;display:flex;justify-content:between;margin-bottom:1rem}.section-header h3{border-bottom:none;margin-bottom:0;padding-bottom:0}.cases-list{display:flex;flex-direction:column;gap:1rem}.case-card{border:1px solid #e2e8f0;border-radius:.375rem;padding:1rem;transition:all .2s}.case-card:hover{border-color:#cbd5e1;box-shadow:0 2px 4px #0000001a}.case-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.case-title-link{background:none;border:none;color:#1e293b;cursor:pointer;font-size:1rem;font-weight:600;padding:0;text-align:left;text-decoration:none}.case-title-link:hover{color:#3b82f6}.case-details{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:.75rem}.case-detail-item{align-items:center;color:#64748b;display:flex;font-size:.875rem;gap:.375rem}.case-detail-item svg{color:#94a3b8}.case-description{color:#64748b;font-size:.875rem;line-height:1.5;margin:0}.stats-grid{grid-gap:1rem;display:grid;gap:1rem}.stat-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.375rem;padding:1rem;text-align:center}.stat-value{color:#1e293b;display:block;font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.stat-label{color:#64748b;font-size:.75rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.client-summary{display:flex;flex-direction:column;gap:.5rem}.client-link{background:none;border:none;cursor:pointer;padding:0;text-align:left;text-decoration:none;width:100%}.client-link h5{color:#1e293b;font-weight:600;margin:0}.client-link:hover h5,.text-link{color:#3b82f6}.text-link{font-size:.875rem;text-decoration:none}.text-link:hover{text-decoration:underline}.text-muted{color:#64748b;font-size:.875rem}.description-content,.notes-content{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.375rem;color:#374151;line-height:1.6;padding:1rem}.timeline{display:flex;flex-direction:column;gap:1rem}.timeline-item{align-items:flex-start;display:flex;gap:1rem}.timeline-icon{align-items:center;background:#e2e8f0;border-radius:50%;color:#64748b;display:flex;flex-shrink:0;height:2rem;justify-content:center;width:2rem}.timeline-icon.completed{background:#dcfce7;color:#059669}.timeline-content h4{color:#1e293b;font-size:.875rem;font-weight:600;margin:0 0 .25rem}.timeline-content p{color:#64748b;font-size:.875rem;margin:0}.error-state,.loading-state{min-height:400px}.empty-state,.error-state,.loading-state{align-items:center;display:flex;flex-direction:column;justify-content:center;text-align:center}.empty-state{color:#64748b;padding:2rem}.empty-state p{margin-bottom:1rem}@media (max-width:768px){.detail-grid{grid-template-columns:1fr}.detail-header{align-items:stretch;flex-direction:column;gap:1rem}.detail-header-actions{justify-content:flex-start}.detail-title-section{align-items:flex-start}.case-details,.detail-title-section{flex-direction:column;gap:.5rem}}body.dark-mode .detail-page{background:#0f172a}body.dark-mode .detail-header{background:#1e293b;border-color:#334155}body.dark-mode .detail-title-section h1{color:#f1f5f9}body.dark-mode .btn-back{background:#334155;color:#94a3b8}body.dark-mode .btn-back:hover{background:#475569;color:#e2e8f0}body.dark-mode .content-card{background:#1e293b;border-color:#334155}body.dark-mode .content-card h3{border-bottom-color:#334155;color:#f1f5f9}body.dark-mode .content-card h4{color:#f1f5f9}body.dark-mode .info-item{background:#1e293b;border-color:#334155}body.dark-mode .info-item:hover{background:#334155;border-color:#475569}body.dark-mode .info-label{color:#94a3b8}body.dark-mode .info-value{color:#e2e8f0}body.dark-mode .case-card{background:#1e293b;border-color:#334155}body.dark-mode .case-card:hover{border-color:#475569}body.dark-mode .case-title-link,body.dark-mode button.case-title-link{color:#e2e8f0!important}body.dark-mode .case-title-link:hover,body.dark-mode button.case-title-link:hover{color:#60a5fa!important}body.dark-mode .case-description,body.dark-mode .case-detail-item{color:#94a3b8}body.dark-mode .stat-item{background:#334155;border-color:#475569}body.dark-mode .stat-value{color:#f1f5f9}body.dark-mode .stat-label{color:#94a3b8}body.dark-mode .client-link h5{color:#e2e8f0}body.dark-mode .client-link:hover h5{color:#60a5fa}body.dark-mode .info-value.link,body.dark-mode button.info-value.link{color:#60a5fa!important}body.dark-mode .info-value.link:hover,body.dark-mode button.info-value.link:hover{color:#93c5fd!important}body.dark-mode .text-muted{color:#94a3b8}body.dark-mode .description-content,body.dark-mode .notes-content{background:#334155;border-color:#475569;color:#e2e8f0}body.dark-mode .timeline-icon{background:#334155;color:#94a3b8}body.dark-mode .timeline-icon.completed{background:#065f46;color:#34d399}body.dark-mode .timeline-content h4{color:#e2e8f0}body.dark-mode .timeline-content p{color:#94a3b8}.filter-bar{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;margin-bottom:1.5rem;padding:1rem}.filter-buttons{gap:.5rem}.filter-btn,.filter-buttons{align-items:center;display:flex}.filter-btn{background:#f8fafc;border:1px solid #e2e8f0;border-radius:.375rem;color:#64748b;cursor:pointer;font-size:.875rem;font-weight:500;overflow:hidden;padding:.5rem 1rem;transition:all .2s ease}.filter-btn:hover{background:#e2e8f0;border-color:#cbd5e1;box-shadow:0 2px 4px #0000001a;color:#475569;transform:translateY(-1px)}.filter-btn.active{background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-color:#1d4ed8;box-shadow:0 2px 8px #3b82f64d;color:#fff}.filter-btn.active:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af);box-shadow:0 4px 12px #3b82f666;transform:translateY(-1px)}.filter-btn:active{transform:translateY(0)}.filter-btn:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.filter-btn:hover:before{left:100%}.filter-btn.active:before{background:linear-gradient(90deg,#0000,#ffffff1a,#0000)}body.dark-mode .filter-bar{background:#1e293b;border-color:#334155}body.dark-mode .filter-btn{background:#334155;border-color:#475569;color:#94a3b8}body.dark-mode .filter-btn:hover{background:#475569;border-color:#64748b;color:#e2e8f0}body.dark-mode .filter-btn.active{background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-color:#1d4ed8;color:#fff}body.dark-mode .filter-btn.active:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af)}.filter-btn{position:relative}.filter-btn .count{background:#0000001a;border-radius:.75rem;display:inline-block;font-size:.75rem;font-weight:600;margin-left:.25rem;padding:.125rem .375rem;transition:all .2s ease}.filter-btn.active .count{background:#fff3}.filter-btn:hover .count{transform:scale(1.05)}@media (max-width:768px){.filter-buttons{align-items:stretch;flex-direction:column}.filter-btn{justify-content:center;padding:.75rem 1rem}}@media (max-width:480px){.filter-buttons{gap:.25rem}.filter-btn{font-size:.8rem;padding:.5rem .75rem}}
/*# sourceMappingURL=main.7a61719c.css.map*/