:root{--font-body: "Nunito", -apple-system, BlinkMacSystemFont, sans-serif;--font-heading: "Lora", Georgia, serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--brand-blue-deep: #2B5D8C;--brand-blue-mid: #3A7AB5;--brand-blue-light: #5A9AD4;--brand-green-forest: #3D8B37;--brand-green-leaf: #5AAD52;--brand-green-sage: #8CB88A;--brand-gold-star: #F5B731;--brand-gold-warm: #F0A818;--brand-cream: #FBF3E3;--brand-cream-dark: #F0E6CF;--brand-night: #1E3A54;--brand-night-mid: #264A68;--brand-fog: #E8E4DE;--clinical-50: #f0f9ee;--clinical-100: #ddf2da;--clinical-200: #bbe5b5;--clinical-300: #8CB88A;--clinical-400: #6BBF65;--clinical-500: #5AAD52;--clinical-600: #3D8B37;--clinical-700: #2E6B29;--clinical-800: #1F4D1C;--clinical-scheduled: var(--clinical-200);--clinical-completed: var(--clinical-600);--clinical-rtp: var(--clinical-300);--clinical-text: var(--clinical-800);--admin-50: #fef9eb;--admin-100: #fef0c7;--admin-200: #fde48a;--admin-300: #F5C84D;--admin-400: #F5B731;--admin-500: #F0A818;--admin-600: #D4920A;--admin-700: #A66F08;--admin-800: #7A5106;--admin-scheduled: var(--admin-200);--admin-completed: var(--admin-500);--admin-rtp: var(--admin-200);--admin-text: var(--admin-800);--drive-50: #EEF4FA;--drive-100: #D4E4F2;--drive-200: #B0CEE5;--drive-300: #7EB3D4;--drive-400: #5A9AD4;--drive-500: #3A7AB5;--drive-600: #2B5D8C;--drive-completed: var(--drive-400);--drive-text: #1E3A54;--holiday-50: #faf5ff;--holiday-100: #f3e8ff;--holiday-200: #e9d5ff;--holiday-300: #d8b4fe;--holiday-400: #c084fc;--holiday-500: #a855f7;--holiday-600: #9333ea;--holiday-completed: var(--holiday-400);--holiday-text: #581c87;--cancelled-100: #F1EFEB;--cancelled-200: #E8E4DE;--cancelled-300: #D5D0C8;--cancelled-400: #A39E95;--cancelled-500: #736E66;--cancelled-bg: var(--cancelled-200);--cancelled-text: var(--cancelled-500);--sub-50: #f0fdfa;--sub-100: #ccfbf1;--sub-200: #99f6e4;--sub-300: #5eead4;--sub-400: #2dd4bf;--sub-500: #14b8a6;--sub-600: #0d9488;--sub-scheduled: var(--sub-300);--sub-completed: var(--sub-500);--sub-text: #134e4a;--warning-50: #fef2f2;--warning-100: #fee2e2;--warning-200: #fecaca;--warning-300: #fca5a5;--warning-400: #f87171;--warning-500: #ef4444;--warning-600: #dc2626;--warning-bg: var(--warning-100);--warning-text: var(--warning-600);--wait-bg: var(--clinical-100);--wait-text: var(--clinical-700);--bg-primary: #FEFDFB;--bg-secondary: #ffffff;--bg-tertiary: #F5F1EB;--border-light: #E8E4DE;--border-medium: #D5D0C8;--text-primary: #1E3A54;--text-secondary: #3D5066;--text-tertiary: #8A95A3;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 50px;--shadow-sm: 0 1px 3px rgba(30, 58, 84, .04);--shadow-md: 0 2px 20px rgba(30, 58, 84, .06);--shadow-lg: 0 8px 32px rgba(30, 58, 84, .1);--transition-fast: .12s ease;--transition-normal: .2s ease;--transition-slow: .35s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:15px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);color:var(--text-primary);background:var(--bg-primary);line-height:1.5;min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}.fc{--fc-border-color: var(--border-light);--fc-today-bg-color: rgba(43, 93, 140, .04);--fc-page-bg-color: var(--bg-secondary);--fc-neutral-bg-color: var(--bg-tertiary);--fc-list-event-hover-bg-color: var(--bg-tertiary);font-family:var(--font-body)!important}.fc .fc-toolbar-title{font-family:var(--font-heading);font-size:1.25rem;font-weight:600;color:var(--text-primary)}.fc .fc-button{font-family:var(--font-body);font-weight:600;font-size:.8rem;border-radius:var(--radius-md);padding:6px 14px;border:1px solid var(--border-medium);background:var(--bg-secondary);color:var(--text-primary);transition:all var(--transition-fast)}.fc .fc-button:hover{background:var(--bg-tertiary);border-color:var(--brand-blue-mid)}.fc .fc-button-active,.fc .fc-button:active{background:var(--brand-blue-deep)!important;border-color:var(--brand-blue-deep)!important;color:#fff!important}.fc .fc-daygrid-day-number,.fc .fc-col-header-cell-cushion{font-weight:600;font-size:.8rem;color:var(--text-secondary);text-decoration:none}.fc .fc-timegrid-slot-label-cushion{font-size:.75rem;font-family:var(--font-mono);color:var(--text-tertiary)}.fc-event{border-radius:var(--radius-sm)!important;border:none!important;font-size:.78rem;font-weight:600;padding:2px 6px;cursor:pointer;transition:opacity var(--transition-fast)}.fc-event:hover{opacity:.85}.event-clinical-scheduled{background-color:var(--clinical-scheduled)!important;color:var(--clinical-text)!important}.event-clinical-completed{background-color:var(--clinical-completed)!important;color:#fff!important;text-shadow:0 1px 2px rgba(0,0,0,.15)}.event-clinical-rtp{background-color:var(--clinical-rtp)!important;color:var(--clinical-text)!important;border-left:3px solid var(--clinical-400)!important;font-style:italic}.event-admin-rtp{background-color:var(--admin-rtp)!important;color:var(--admin-text)!important;border-left:3px solid var(--admin-400)!important;font-style:italic}.event-admin-scheduled{background-color:var(--admin-scheduled)!important;color:var(--admin-text)!important}.event-admin-completed{background-color:var(--admin-completed)!important;color:#fff!important}.event-drive{background-color:var(--drive-completed)!important;color:#fff!important;border-left:3px solid var(--drive-600)!important;opacity:.88}.event-drive:hover{opacity:.78}.event-drive-estimated{background-color:var(--drive-200)!important;color:var(--drive-text)!important;border-left:3px dashed var(--drive-400)!important;opacity:.75;font-style:italic}.event-drive-estimated:hover{opacity:.65}.event-holiday{background-color:var(--holiday-completed)!important;color:#fff!important}.event-cancelled{background-color:var(--cancelled-bg)!important;color:var(--cancelled-text)!important;text-decoration:line-through}.event-substitute-scheduled{background-color:var(--sub-scheduled)!important;color:var(--sub-text)!important}.event-substitute-completed{background-color:var(--sub-completed)!important;color:#fff!important}.event-unresolved{background-color:var(--warning-bg)!important;color:var(--warning-text)!important;font-weight:700;border-left:3px solid var(--warning-500)!important}.event-rtp-review{background-color:var(--admin-100)!important;color:var(--warning-text)!important;font-weight:700;border-left:3px solid var(--warning-400)!important}.event-wait{background-color:var(--wait-bg)!important;color:var(--wait-text)!important;border-left:3px solid var(--clinical-400)!important}.mono{font-family:var(--font-mono)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.app-layout{display:flex;flex-direction:column;min-height:100vh}.top-bar{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);background:var(--bg-secondary);border-bottom:1px solid var(--border-light);position:sticky;top:0;z-index:100}.top-bar-left{display:flex;align-items:center;gap:var(--space-md)}.top-bar-logo{font-family:var(--font-heading);font-weight:700;font-size:1.1rem;letter-spacing:-.02em;color:var(--brand-blue-deep)}.top-bar-logo span{font-family:var(--font-body);font-weight:400;color:var(--text-tertiary);margin-left:2px}.top-bar-right{display:flex;align-items:center;gap:var(--space-md)}.staff-selector{position:relative}.staff-selector select{font-family:var(--font-body);font-size:.85rem;font-weight:600;padding:6px 28px 6px 12px;border:1px solid var(--border-medium);border-radius:var(--radius-md);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%233D5066' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;transition:border-color var(--transition-fast)}.staff-selector select:hover{border-color:var(--brand-blue-mid)}.staff-selector select:focus{outline:none;border-color:var(--brand-blue-deep);box-shadow:0 0 0 3px #2b5d8c1a}.pto-bar{display:flex;align-items:center;gap:var(--space-lg);padding:var(--space-sm) var(--space-lg);background:var(--bg-tertiary);border-bottom:1px solid var(--border-light);font-size:.82rem;overflow-x:auto}.pto-bar-item{display:flex;align-items:baseline;gap:6px;white-space:nowrap}.pto-bar-label{color:var(--text-secondary);font-weight:700;text-transform:uppercase;font-size:.68rem;letter-spacing:.04em}.pto-bar-value{font-family:var(--font-body);font-weight:800;color:var(--text-primary);font-size:.9rem}.pto-bar-value.warning{color:var(--warning-500)}.pto-bar-divider{width:1px;height:20px;background:var(--border-medium)}.unresolved-banner{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);background:var(--warning-50);border-bottom:2px solid var(--warning-400);font-size:.82rem;font-weight:700;color:var(--warning-text)}.unresolved-banner-icon{font-size:1rem}.main-content{flex:1;padding:var(--space-lg);max-width:1200px;margin:0 auto;width:100%}.calendar-container{background:var(--bg-secondary);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--space-lg)}.loading-overlay{display:flex;align-items:center;justify-content:center;padding:var(--space-2xl);color:var(--text-tertiary);font-size:.9rem}.loading-spinner{width:20px;height:20px;border:2px solid var(--border-light);border-top-color:var(--brand-blue-deep);border-radius:50%;animation:spin .6s linear infinite;margin-right:var(--space-sm)}@keyframes spin{to{transform:rotate(360deg)}}.error-banner{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:var(--warning-50);border:1px solid var(--warning-200);border-radius:var(--radius-md);color:var(--warning-text);font-size:.85rem;margin-bottom:var(--space-md)}.error-banner button{margin-left:auto;padding:4px 12px;border:1px solid var(--warning-400);border-radius:var(--radius-sm);background:transparent;color:var(--warning-600);font-family:var(--font-body);font-size:.8rem;font-weight:600;cursor:pointer;transition:background var(--transition-fast)}.error-banner button:hover{background:var(--warning-100)}.event-detail-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1e3a5440;z-index:200;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.event-detail-panel{position:fixed;bottom:0;left:0;right:0;max-height:70vh;background:var(--bg-secondary);border-radius:var(--radius-xl) var(--radius-xl) 0 0;box-shadow:var(--shadow-lg);z-index:201;padding:var(--space-lg);overflow-y:auto;animation:slideUp .2s cubic-bezier(.4,0,.2,1)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.event-detail-handle{width:36px;height:4px;background:var(--border-medium);border-radius:2px;margin:0 auto var(--space-md)}.event-detail-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-md)}.event-detail-title{font-family:var(--font-heading);font-size:1.05rem;font-weight:600;color:var(--text-primary)}.event-detail-badge{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:3px 8px;border-radius:var(--radius-sm)}.badge-clinical{background:var(--clinical-100);color:var(--clinical-700)}.badge-admin{background:var(--admin-100);color:var(--admin-700)}.badge-holiday{background:var(--holiday-100);color:var(--holiday-600)}.badge-wait{background:var(--clinical-100);color:var(--clinical-700)}.event-detail-row{display:flex;align-items:baseline;gap:var(--space-sm);padding:var(--space-xs) 0;font-size:.85rem}.event-detail-row-label{color:var(--text-tertiary);font-weight:700;min-width:90px;font-size:.78rem;text-transform:uppercase;letter-spacing:.03em}.event-detail-row-value{color:var(--text-primary)}.event-detail-row-value.mono{font-family:var(--font-mono);font-size:.82rem}.event-detail-actions{display:flex;gap:var(--space-sm);margin-top:var(--space-lg);padding-top:var(--space-md);border-top:1px solid var(--border-light)}.btn{font-family:var(--font-body);font-size:.82rem;font-weight:700;padding:8px 18px;border-radius:var(--radius-md);border:none;cursor:pointer;transition:all var(--transition-fast)}.btn-primary{background:var(--brand-blue-deep);color:#fff}.btn-primary:hover{background:var(--brand-night-mid);box-shadow:0 4px 16px #2b5d8c33}.btn-danger{background:transparent;color:var(--warning-600);border:1px solid var(--warning-300)}.btn-danger:hover{background:var(--warning-50)}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border-medium)}.btn-ghost:hover{background:var(--bg-tertiary)}.floating-holiday-hint{font-size:.65rem;color:var(--holiday-500);padding:1px 4px;cursor:pointer}.floating-holiday-hint:hover{text-decoration:underline}.admin-nav{display:flex;gap:var(--space-xs);margin-bottom:var(--space-lg);border-bottom:1px solid var(--border-light)}.admin-nav-item{padding:var(--space-sm) var(--space-md);font-size:.82rem;font-weight:600;color:var(--text-secondary);border-bottom:2px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.admin-nav-item:hover{color:var(--text-primary)}.admin-nav-item.active{color:var(--brand-blue-deep);border-bottom-color:var(--brand-blue-deep)}@media (max-width: 768px){.top-bar{padding:var(--space-sm) var(--space-md)}.pto-bar{padding:var(--space-sm) var(--space-md);gap:var(--space-md)}.main-content{padding:var(--space-md)}.calendar-container{padding:var(--space-md);border-radius:var(--radius-md)}.fc .fc-toolbar{flex-direction:column;gap:var(--space-sm)}.event-detail-panel{max-height:85vh;padding:var(--space-md)}}.admin-panel-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:var(--space-lg)}.admin-panel-title{font-family:var(--font-heading);font-size:1.15rem;font-weight:600;color:var(--text-primary);margin:0}.admin-panel-count{font-size:.78rem;font-weight:600;color:var(--text-tertiary);font-family:var(--font-mono)}.admin-empty-state{padding:var(--space-xl) var(--space-lg);text-align:center;color:var(--text-tertiary);font-size:.88rem;background:var(--bg-tertiary);border-radius:var(--radius-md);line-height:1.6}.staff-profile-panel{max-width:100%}.staff-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:var(--space-lg)}.staff-card{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-lg);transition:box-shadow var(--transition-normal)}.staff-card:hover{box-shadow:var(--shadow-md)}.staff-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-md);padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-light)}.staff-card-name{font-family:var(--font-heading);font-size:1rem;font-weight:600;color:var(--text-primary)}.staff-card-role{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--brand-blue-deep);background:#2b5d8c14;padding:2px 8px;border-radius:var(--radius-sm);margin-top:2px;display:inline-block}.staff-card-fields{display:flex;flex-direction:column;gap:var(--space-xs)}.staff-field-row{display:flex;align-items:baseline;gap:var(--space-sm);min-height:32px}.staff-field-label{color:var(--text-tertiary);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.03em;min-width:110px;flex-shrink:0}.staff-field-value{color:var(--text-primary);font-size:.85rem}.staff-field-value.empty{color:var(--text-tertiary);font-style:italic}.staff-field-input{font-family:var(--font-body);font-size:.85rem;padding:5px 10px;border:1px solid var(--border-medium);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-primary);flex:1;min-width:0;transition:border-color var(--transition-fast)}.staff-field-input:focus{outline:none;border-color:var(--brand-blue-deep);box-shadow:0 0 0 3px #2b5d8c1a}.staff-field-input::placeholder{color:var(--text-tertiary)}select.staff-field-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%233D5066' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px;cursor:pointer}.staff-card-actions{display:flex;gap:var(--space-sm);margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--border-light)}.staff-card-success{font-size:.8rem;font-weight:600;color:var(--clinical-600);background:var(--clinical-50);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-sm);margin-bottom:var(--space-sm)}.staff-card-error{font-size:.8rem;font-weight:600;color:var(--warning-text);background:var(--warning-50);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-sm);margin-bottom:var(--space-sm)}.client-locations-panel{max-width:100%}.add-location-form{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:var(--space-lg);margin-bottom:var(--space-lg)}.add-location-title{font-family:var(--font-heading);font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-md)}.add-location-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md);margin-bottom:var(--space-md)}.add-location-field{display:flex;flex-direction:column;gap:var(--space-xs)}.add-location-field-wide{grid-column:span 2}.locations-table-wrap{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border-light)}.locations-table{width:100%;border-collapse:collapse;font-size:.85rem}.locations-table thead{background:var(--bg-tertiary)}.locations-table th{text-align:left;padding:var(--space-sm) var(--space-md);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.03em;color:var(--text-tertiary);border-bottom:1px solid var(--border-light)}.locations-table td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border-light);color:var(--text-primary)}.locations-table tbody tr:last-child td{border-bottom:none}.locations-table tbody tr:hover{background:var(--bg-tertiary)}.location-pos-badge{font-size:.72rem;font-weight:700;text-transform:capitalize;padding:2px 8px;border-radius:var(--radius-sm);background:var(--drive-50);color:var(--drive-600)}.location-address{font-family:var(--font-mono);font-size:.8rem;color:var(--text-secondary)}.location-actions-cell{text-align:right;white-space:nowrap}.btn-sm{font-size:.75rem;padding:4px 10px}.admin-export-panel{display:flex;flex-direction:column;gap:var(--space-lg)}.export-section{background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-lg)}.export-section-title{font-family:var(--font-heading);font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-xs)}.export-section-desc{font-size:.82rem;color:var(--text-secondary);margin-bottom:var(--space-md);line-height:1.5}.export-date-range{display:flex;gap:var(--space-md);margin-bottom:var(--space-md)}.mileage-info-block{margin-top:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--drive-50);border-radius:var(--radius-md);border-left:3px solid var(--drive-400)}.mileage-info-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--drive-600);margin-bottom:var(--space-xs)}.mileage-info-rows .event-detail-row{padding:2px 0}.mileage-info-rows .event-detail-row-label{min-width:80px;font-size:.72rem}.mileage-info-rows .event-detail-row-value{font-size:.82rem}.badge-drive{background:var(--drive-100);color:var(--drive-600)}.event-other-bt{background-color:var(--brand-cream-dark)!important;color:var(--text-secondary)!important;opacity:.85}.event-other-bt:hover{opacity:.75}@media (max-width: 768px){.admin-nav{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.admin-nav::-webkit-scrollbar{display:none}.admin-nav-item{white-space:nowrap;font-size:.78rem;padding:var(--space-sm) var(--space-sm)}.staff-card-grid,.add-location-fields{grid-template-columns:1fr}.add-location-field-wide{grid-column:span 1}.export-date-range{flex-direction:column}}.address-autocomplete{position:relative;flex:1;min-width:0}.address-autocomplete-loading{position:absolute;right:8px;top:50%;transform:translateY(-50%);pointer-events:none}.address-autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;z-index:50;background:var(--bg-secondary);border:1px solid var(--border-medium);border-top:none;border-radius:0 0 var(--radius-sm) var(--radius-sm);box-shadow:var(--shadow-md);list-style:none;max-height:200px;overflow-y:auto}.address-autocomplete-item{padding:var(--space-sm) var(--space-md);font-size:.82rem;cursor:pointer;color:var(--text-primary);border-bottom:1px solid var(--border-light)}.address-autocomplete-item:last-child{border-bottom:none}.address-autocomplete-item:hover,.address-autocomplete-item.selected{background:var(--bg-tertiary)}.mileage-pending{opacity:.7;border-left-color:var(--border-medium)}.primary-nav{display:flex;gap:2px;margin-left:var(--space-md)}.primary-nav-item{display:flex;align-items:center;padding:6px 12px;font-size:.82rem;font-weight:600;color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition-fast);white-space:nowrap}.primary-nav-item:hover{color:var(--text-primary);background:var(--bg-tertiary)}.primary-nav-item.active{color:var(--brand-blue-deep);background:#2b5d8c14}.primary-nav-item svg{flex-shrink:0}.top-bar-user-name{font-size:13px;color:var(--text-secondary, #6c757d);margin-right:4px;white-space:nowrap}.top-bar-sync-btn{padding:5px 10px;font-size:12px;font-weight:500;border:1px solid var(--border-color, #dee2e6);border-radius:6px;cursor:pointer;white-space:nowrap;transition:all .2s;font-family:var(--font-body)}.top-bar-signout-btn{padding:6px 12px;font-size:12px;font-weight:500;color:var(--text-secondary, #6c757d);background:transparent;border:1px solid var(--border-color, #dee2e6);border-radius:6px;cursor:pointer;white-space:nowrap;font-family:var(--font-body)}.msg-page{flex:1;display:flex;flex-direction:column;min-height:0;height:calc(100vh - 57px)}@media (max-width: 768px){.fc .fc-timegrid-slot{height:2em}.fc-event{font-size:.72rem;padding:1px 4px}.fc .fc-toolbar{gap:var(--space-xs);padding:0}.fc .fc-toolbar-title{font-size:1rem}.fc .fc-button{padding:4px 8px;font-size:.72rem}.primary-nav{margin-left:var(--space-sm);gap:1px}.primary-nav-item{padding:5px 8px;font-size:.75rem}@media (max-width: 420px){.primary-nav-item{padding:5px 6px;font-size:0}.primary-nav-item svg{margin-right:0!important}}.top-bar-user-name{display:none}.top-bar{padding:var(--space-sm) var(--space-sm)}.top-bar-right{gap:var(--space-xs)}.msg-page{height:calc(100vh - 49px)}}.msg-page{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden;height:calc(100vh - 57px)}.msg-staff-selector{display:flex;align-items:center;gap:var(--space-sm);padding:8px var(--space-md);background:var(--bg-tertiary);border-bottom:1px solid var(--border-light);flex-shrink:0}.msg-staff-selector-label{font-size:.75rem;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.msg-staff-select{font-family:var(--font-body);font-size:.84rem;font-weight:600;padding:5px 28px 5px 10px;border:1px solid var(--border-medium);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-primary);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%233D5066' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.msg-layout{display:flex;flex:1;min-height:0;overflow:hidden}.msg-list-pane{width:100%;flex-shrink:0;display:flex;flex-direction:column;border-right:1px solid var(--border-light);overflow:hidden}.msg-conv-pane{display:none;flex:1;min-width:0;flex-direction:column;overflow:hidden}.msg-layout.conv-open .msg-list-pane{display:none}.msg-layout.conv-open .msg-conv-pane{display:flex;width:100%}@media (min-width: 768px){.msg-list-pane{width:340px;min-width:280px;max-width:400px}.msg-conv-pane,.msg-layout.conv-open .msg-list-pane{display:flex}}@media (min-width: 1024px){.msg-list-pane{width:380px}}.msg-new-message-bar{padding:8px var(--space-md);border-bottom:1px solid var(--border-light);flex-shrink:0}.msg-action-buttons{display:flex;gap:var(--space-sm)}.msg-new-message-btn{display:flex;align-items:center;justify-content:center;gap:6px;flex:1;font-family:var(--font-body);font-size:.84rem;font-weight:600;padding:9px 14px;border:1px dashed var(--border-medium);border-radius:var(--radius-md);background:transparent;color:var(--brand-blue-deep);cursor:pointer;transition:all var(--transition-fast)}.msg-new-message-btn:hover{background:#2b5d8c0a;border-color:var(--brand-blue-deep)}.msg-place-call-btn{display:flex;align-items:center;justify-content:center;gap:6px;flex:1;font-family:var(--font-body);font-size:.84rem;font-weight:600;padding:9px 14px;border:1px dashed var(--border-medium);border-radius:var(--radius-md);background:transparent;color:var(--brand-green-forest);cursor:pointer;transition:all var(--transition-fast)}.msg-place-call-btn:hover{background:#3d7b5f0a;border-color:var(--brand-green-forest)}.msg-new-message-form{display:flex;align-items:center;gap:var(--space-sm)}.msg-dialer-form{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.msg-dialer-call-btn{display:flex;align-items:center;gap:5px;font-family:var(--font-body);font-size:.82rem;font-weight:600;padding:8px 16px;border:none;border-radius:var(--radius-md);background:var(--brand-green-forest);color:#fff;cursor:pointer;white-space:nowrap}.msg-dialer-call-btn:hover:not(:disabled){filter:brightness(1.1)}.msg-dialer-call-btn:disabled{opacity:.4;cursor:not-allowed}.msg-dialer-error{flex-basis:100%;font-size:.78rem;font-weight:600;color:var(--warning-600);margin-top:2px}.msg-new-phone-input{flex:1;font-family:var(--font-body);font-size:.85rem;padding:8px 12px;border:1px solid var(--border-medium);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);outline:none}.msg-new-phone-input:focus{border-color:var(--brand-blue-deep);box-shadow:0 0 0 2px #2b5d8c1f}.msg-new-go-btn{font-family:var(--font-body);font-size:.82rem;font-weight:600;padding:8px 16px;border:none;border-radius:var(--radius-md);background:var(--brand-blue-deep);color:#fff;cursor:pointer;white-space:nowrap}.msg-new-go-btn:hover:not(:disabled){background:var(--brand-night-mid)}.msg-new-go-btn:disabled{opacity:.4;cursor:not-allowed}.msg-new-cancel-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--text-tertiary);cursor:pointer;font-size:1rem;border-radius:var(--radius-sm)}.msg-new-cancel-btn:hover{color:var(--text-primary);background:var(--bg-tertiary)}.msg-thread-list{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.msg-thread-item{display:flex;align-items:center;gap:12px;padding:14px var(--space-md);cursor:pointer;border-bottom:1px solid var(--border-light);transition:background var(--transition-fast)}.msg-thread-item:hover{background:var(--bg-tertiary)}.msg-thread-item.active{background:#2b5d8c0f;border-left:3px solid var(--brand-blue-deep);padding-left:13px}.msg-thread-item.unread .msg-thread-name{font-weight:800}.msg-thread-item.unread .msg-thread-preview{color:var(--text-primary);font-weight:600}.msg-thread-avatar{width:44px;height:44px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;font-family:var(--font-body);flex-shrink:0;letter-spacing:.02em}.msg-thread-content{flex:1;min-width:0}.msg-thread-top{display:flex;align-items:baseline;justify-content:space-between;gap:var(--space-xs);margin-bottom:3px}.msg-thread-name{font-weight:600;font-size:.88rem;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msg-thread-name.unknown{color:var(--text-secondary)}.msg-unknown-badge{display:inline-block;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;background:var(--admin-100);color:var(--admin-700);padding:1px 5px;border-radius:3px;margin-left:6px;vertical-align:middle}.msg-thread-time{font-size:.72rem;color:var(--text-tertiary);flex-shrink:0;font-family:var(--font-mono)}.msg-thread-bottom{display:flex;align-items:center;gap:var(--space-sm)}.msg-thread-preview{flex:1;font-size:.8rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.4}.msg-unread-dot{width:10px;height:10px;border-radius:50%;background:var(--brand-blue-deep);flex-shrink:0}.msg-thread-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl) var(--space-lg);gap:var(--space-md);color:var(--text-tertiary);font-size:.85rem}.msg-spinner{width:24px;height:24px;border:2.5px solid var(--border-light);border-top-color:var(--brand-blue-deep);border-radius:50%;animation:msg-spin .7s linear infinite}.msg-spinner-sm{width:16px;height:16px;border-width:2px}@keyframes msg-spin{to{transform:rotate(360deg)}}.msg-empty-threads{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl) var(--space-lg);text-align:center;color:var(--text-tertiary)}.msg-empty-title{font-size:.92rem;font-weight:600;color:var(--text-secondary);margin:0}.msg-empty-sub{font-size:.82rem;margin-top:var(--space-xs)}.msg-no-conv{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--text-tertiary);gap:var(--space-md)}.msg-no-conv p{font-size:.88rem;margin:0}.msg-conversation{display:flex;flex-direction:column;height:100%;min-height:0}.msg-conv-header{display:flex;align-items:center;gap:10px;padding:10px var(--space-md);background:var(--bg-secondary);border-bottom:1px solid var(--border-light);flex-shrink:0;min-height:56px}.msg-back-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--brand-blue-deep);cursor:pointer;border-radius:var(--radius-sm);flex-shrink:0}.msg-back-btn:hover{background:var(--bg-tertiary)}@media (min-width: 768px){.msg-back-btn{display:none}}.msg-conv-avatar{width:36px;height:36px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;flex-shrink:0}.msg-conv-header-info{flex:1;min-width:0}.msg-conv-header-name{font-weight:700;font-size:.92rem;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}.msg-conv-header-phone{font-size:.72rem;color:var(--text-tertiary);font-family:var(--font-mono);line-height:1.3}.msg-conv-header-actions{display:flex;gap:var(--space-xs);flex-shrink:0}.msg-action-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--border-light);background:var(--bg-secondary);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.msg-action-btn:hover{background:var(--bg-tertiary);color:var(--brand-blue-deep);border-color:var(--border-medium)}.msg-actions-dropdown{display:flex;flex-direction:column;background:var(--bg-secondary);border-bottom:1px solid var(--border-light);box-shadow:var(--shadow-sm)}.msg-actions-dropdown button{font-family:var(--font-body);font-size:.85rem;font-weight:600;padding:12px var(--space-md);border:none;background:transparent;color:var(--text-primary);cursor:pointer;text-align:left;transition:background var(--transition-fast)}.msg-actions-dropdown button:hover{background:var(--bg-tertiary)}.msg-actions-dropdown .msg-action-danger{color:var(--warning-600)}.msg-actions-dropdown .msg-action-danger:hover{background:var(--warning-50)}.msg-contact-form{display:flex;align-items:center;gap:var(--space-sm);padding:8px var(--space-md);background:var(--bg-tertiary);border-bottom:1px solid var(--border-light)}.msg-contact-input{flex:1;font-family:var(--font-body);font-size:.85rem;padding:7px 10px;border:1px solid var(--border-medium);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-primary);outline:none}.msg-contact-input:focus{border-color:var(--brand-blue-deep);box-shadow:0 0 0 2px #2b5d8c1f}.msg-contact-save-btn{font-family:var(--font-body);font-size:.8rem;font-weight:600;padding:6px 14px;border:none;border-radius:var(--radius-sm);background:var(--brand-blue-deep);color:#fff;cursor:pointer;white-space:nowrap}.msg-contact-save-btn:hover:not(:disabled){background:var(--brand-night-mid)}.msg-contact-save-btn:disabled{opacity:.5;cursor:not-allowed}.msg-contact-cancel-btn{font-family:var(--font-body);font-size:.8rem;font-weight:500;padding:6px 10px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;white-space:nowrap}.msg-contact-cancel-btn:hover{color:var(--text-primary)}.msg-error{display:flex;align-items:center;justify-content:space-between;padding:8px var(--space-md);background:var(--warning-50);color:var(--warning-text);font-size:.8rem;font-weight:600;flex-shrink:0}.msg-error button{border:none;background:transparent;color:var(--warning-text);cursor:pointer;font-size:.9rem;padding:2px 6px;line-height:1}.msg-messages-area{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:var(--space-md);display:flex;flex-direction:column;gap:3px}.msg-load-more{align-self:center;font-family:var(--font-body);font-size:.78rem;font-weight:600;color:var(--brand-blue-deep);background:transparent;border:1px solid var(--border-medium);border-radius:var(--radius-full);padding:5px 18px;cursor:pointer;margin-bottom:var(--space-sm)}.msg-load-more:hover{background:var(--bg-tertiary)}.msg-load-more:disabled{opacity:.5;cursor:not-allowed}.msg-date-divider{display:flex;align-items:center;gap:12px;padding:12px 0 8px}.msg-date-divider:before,.msg-date-divider:after{content:"";flex:1;height:1px;background:var(--border-light)}.msg-date-divider span{font-size:.7rem;font-weight:700;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}.msg-bubble-wrap{display:flex;max-width:82%;margin-bottom:2px}.msg-bubble-wrap.msg-outbound,.msg-bubble-wrap.msg-supervisor{align-self:flex-end;flex-direction:row-reverse}.msg-bubble-wrap.msg-inbound{align-self:flex-start}.msg-bubble-wrap.msg-system{align-self:center;max-width:90%}.msg-bubble{padding:9px 14px;border-radius:18px;line-height:1.45;word-break:break-word}.msg-inbound .msg-bubble{background:var(--bg-tertiary);color:var(--text-primary);border-bottom-left-radius:4px}.msg-outbound .msg-bubble{background:var(--brand-blue-deep);color:#fff;border-bottom-right-radius:4px}.msg-supervisor .msg-bubble{background:var(--brand-green-forest);color:#fff;border-bottom-right-radius:4px}.msg-system .msg-bubble{background:transparent;color:var(--text-tertiary);font-size:.78rem;font-style:italic;text-align:center;padding:4px 12px}.msg-bubble-text{font-size:.88rem;white-space:pre-wrap}.msg-bubble-time{font-size:.65rem;margin-top:3px;opacity:.65;font-family:var(--font-mono)}.msg-inbound .msg-bubble-time{color:var(--text-tertiary)}.msg-outbound .msg-bubble-time,.msg-supervisor .msg-bubble-time{color:#ffffffb3}.msg-failed{color:var(--warning-400);font-weight:700}.msg-compose{display:flex;align-items:flex-end;gap:8px;padding:10px var(--space-md);background:var(--bg-secondary);border-top:1px solid var(--border-light);flex-shrink:0}.msg-compose-input{flex:1;font-family:var(--font-body);font-size:.88rem;color:var(--text-primary);padding:10px 14px;border:1px solid var(--border-medium);border-radius:22px;background:var(--bg-primary);resize:none;min-height:40px;max-height:120px;line-height:1.4;overflow-y:auto;outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.msg-compose-input:focus{border-color:var(--brand-blue-deep);box-shadow:0 0 0 3px #2b5d8c1a}.msg-compose-input::placeholder{color:var(--text-tertiary)}.msg-send-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:var(--brand-blue-deep);color:#fff;border-radius:50%;cursor:pointer;flex-shrink:0;transition:all var(--transition-fast)}.msg-send-btn:hover:not(:disabled){background:var(--brand-night-mid);box-shadow:0 2px 8px #2b5d8c4d}.msg-send-btn:disabled{opacity:.35;cursor:not-allowed}@supports (padding-bottom: env(safe-area-inset-bottom)){.msg-compose{padding-bottom:calc(10px + env(safe-area-inset-bottom))}}@media (min-width: 768px){.msg-bubble-wrap{max-width:60%}.msg-bubble-text,.msg-compose-input{font-size:.85rem}}@media (max-width: 420px){.msg-thread-item{padding:12px;gap:10px}.msg-thread-avatar{width:40px;height:40px;font-size:.72rem}.msg-thread-name{font-size:.84rem}.msg-conv-header{padding:8px 12px}.msg-messages-area{padding:12px}.msg-compose{padding:8px 12px}.msg-page{height:calc(100vh - 49px)}}
