.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:var(--space-md);max-width:1400px;margin:0 auto;width:100%}.header{background:var(--black);border-bottom:2px solid var(--nadc-red);padding:var(--space-sm) var(--space-md);position:sticky;top:0;z-index:100}.header-container{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.header-logo{display:flex;align-items:center;gap:var(--space-sm);color:var(--white)}.logo-image{height:45px;width:auto}.logo-text-wrapper{display:flex;flex-direction:column}.logo-text{font-family:var(--font-heading);font-size:1.1rem;font-weight:700;color:var(--nadc-red)}.logo-subtitle{font-size:.75rem;color:var(--silver);text-transform:uppercase;letter-spacing:1px}.header-nav{display:flex;gap:var(--space-md)}.nav-link{color:var(--white);font-weight:500;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);transition:background .2s}.nav-link:hover{background:var(--steel);color:var(--white)}.header-user{display:flex;align-items:center;gap:var(--space-sm)}.user-name{font-weight:500}.user-role{font-size:.75rem;background:var(--steel);padding:2px 8px;border-radius:var(--radius-sm);text-transform:uppercase}.logout-btn{background:transparent;border:1px solid var(--nadc-red);color:var(--nadc-red);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.875rem;transition:all .2s}.logout-btn:hover{background:var(--nadc-red);color:var(--white)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--black) 0%,var(--charcoal) 100%);padding:var(--space-md)}.login-container{background:var(--black);border:1px solid var(--steel);border-radius:var(--radius-lg);padding:var(--space-xl);width:100%;max-width:400px;box-shadow:var(--shadow-lg)}.login-header{text-align:center;margin-bottom:var(--space-lg)}.login-logo{height:80px;width:auto;margin-bottom:var(--space-sm)}.login-title{font-size:1.75rem;color:var(--nadc-red);margin-bottom:var(--space-xs);line-height:1.2}.login-subtitle{font-size:1.25rem;color:var(--silver);font-weight:400}.login-form{display:flex;flex-direction:column;gap:var(--space-md)}.login-instructions{color:var(--silver);text-align:center;font-size:.875rem}.login-error{background:#ef44441a;border:1px solid var(--danger);color:var(--danger);padding:var(--space-sm);border-radius:var(--radius-sm);text-align:center}.form-group{display:flex;flex-direction:column;gap:var(--space-xs)}.form-group label{font-size:.875rem;font-weight:500;color:var(--silver)}.form-group input,.form-group select,.form-group textarea{background:var(--charcoal);border:1px solid var(--steel);color:var(--white);padding:var(--space-sm);border-radius:var(--radius-sm);transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--nadc-yellow)}.form-group input::placeholder{color:var(--silver)}.checkbox-label{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;color:var(--white);font-weight:500}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--nadc-yellow)}.date-input-wrapper{position:relative}.form-group input[type=date],.form-group input[type=time]{width:100%;cursor:pointer}.form-group input[type=date]::-webkit-calendar-picker-indicator,.form-group input[type=time]::-webkit-calendar-picker-indicator{filter:invert(1);cursor:pointer;padding:4px;margin-right:-4px}.form-group input[type=date]::-webkit-calendar-picker-indicator:hover,.form-group input[type=time]::-webkit-calendar-picker-indicator:hover{background:var(--steel);border-radius:var(--radius-sm)}.login-btn{background:var(--nadc-red);color:var(--white);border:none;padding:var(--space-sm) var(--space-md);font-size:1rem;font-weight:600;border-radius:var(--radius-sm);transition:background .2s}.login-btn:hover:not(:disabled){background:var(--nadc-red-dark)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-footer{text-align:center;color:var(--steel);font-size:.75rem;margin-top:var(--space-lg)}.calendar-page{display:flex;flex-direction:column;gap:var(--space-md)}.calendar-toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--space-sm);background:var(--black);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md)}.toolbar-filters{display:flex;gap:var(--space-sm);flex-wrap:wrap;align-items:center}.filter-select{background:var(--charcoal);border:1px solid var(--steel);color:var(--white);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);min-width:150px}.filter-checkbox{display:flex;align-items:center;gap:var(--space-xs);color:var(--silver);font-size:.875rem;cursor:pointer}.filter-checkbox input{accent-color:var(--nadc-yellow)}.add-event-btn{background:var(--nadc-yellow);color:var(--black);border:none;padding:var(--space-xs) var(--space-md);font-weight:600;border-radius:var(--radius-sm);transition:background .2s}.add-event-btn:hover{background:var(--nadc-yellow-dark)}.calendar-container{background:var(--black);border-radius:var(--radius-md);padding:var(--space-md);overflow:hidden}.fc{--fc-border-color: var(--steel);--fc-button-bg-color: var(--steel);--fc-button-border-color: var(--steel);--fc-button-hover-bg-color: var(--silver);--fc-button-hover-border-color: var(--silver);--fc-button-active-bg-color: var(--nadc-red);--fc-button-active-border-color: var(--nadc-red);--fc-today-bg-color: rgba(247, 197, 30, .1);--fc-page-bg-color: var(--black);--fc-neutral-bg-color: var(--charcoal);--fc-list-event-hover-bg-color: var(--charcoal)}.fc .fc-toolbar-title{font-family:var(--font-heading);color:var(--white)}.fc .fc-button{font-family:var(--font-body);text-transform:capitalize}.fc .fc-col-header-cell-cushion,.fc .fc-daygrid-day-number,.fc .fc-list-day-cushion{color:var(--white)}.fc .fc-daygrid-day.fc-day-today{background:var(--fc-today-bg-color)}.fc .fc-event{border-radius:var(--radius-sm);font-size:.875rem;padding:2px 4px}.fc .fc-event.event-cancelled{opacity:.6;text-decoration:line-through}.fc .fc-list-event:hover td{background:var(--charcoal)}.calendar-legend{display:flex;gap:var(--space-md);justify-content:center;padding:var(--space-sm);background:var(--black);border-radius:var(--radius-md)}.legend-item{display:flex;align-items:center;gap:var(--space-xs);font-size:.875rem;color:var(--silver)}.legend-color{width:16px;height:16px;border-radius:var(--radius-sm)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;padding:var(--space-md);z-index:1000}.modal{background:var(--black);border:1px solid var(--steel);border-radius:var(--radius-lg);width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);border-bottom:1px solid var(--steel)}.modal-header h2{font-size:1.25rem}.modal-close{background:none;border:none;color:var(--silver);font-size:1.5rem;line-height:1;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.modal-close:hover{background:var(--steel);color:var(--white)}.modal-form{padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-md)}.form-error{background:#ef44441a;border:1px solid var(--danger);color:var(--danger);padding:var(--space-sm);border-radius:var(--radius-sm)}.view-only-notice{background:#3b82f61a;border:1px solid var(--info);color:var(--info);padding:var(--space-sm);border-radius:var(--radius-sm);font-size:.875rem}.event-meta{display:flex;flex-wrap:wrap;gap:var(--space-sm);align-items:center;font-size:.875rem;color:var(--silver)}.meta-badge{font-size:.75rem;padding:2px 8px;border-radius:var(--radius-sm);text-transform:uppercase;font-weight:600}.meta-badge.bamboohr{background:var(--success);color:var(--white)}.meta-badge.locked{background:var(--steel);color:var(--white)}.meta-badge.status-cancelled{background:var(--danger);color:var(--white)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.modal-actions{display:flex;gap:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--steel)}.btn-primary{background:var(--nadc-yellow);color:var(--black);border:none;padding:var(--space-sm) var(--space-md);font-weight:600;border-radius:var(--radius-sm);transition:background .2s}.btn-primary:hover:not(:disabled){background:var(--nadc-yellow-dark)}.btn-secondary{background:var(--steel);color:var(--white);border:none;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);transition:background .2s}.btn-secondary:hover{background:var(--silver)}.btn-danger{background:var(--danger);color:var(--white);border:none;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);transition:background .2s}.btn-danger:hover{background:#dc2626}button:disabled{opacity:.6;cursor:not-allowed}.admin-panel{max-width:1200px;margin:0 auto}.admin-panel h1{font-size:2rem;margin-bottom:var(--space-md)}.admin-message{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);margin-bottom:var(--space-md)}.admin-message.info{background:var(--info);color:var(--white)}.admin-message.success{background:var(--success);color:var(--white)}.admin-message.error{background:var(--danger);color:var(--white)}.admin-message .close-btn{background:none;border:none;color:inherit;font-size:1.25rem;cursor:pointer;padding:0;line-height:1}.modal-content{background:var(--black);border:1px solid var(--steel);border-radius:var(--radius-lg);padding:var(--space-lg);width:100%;max-width:400px}.modal-content h3{margin-bottom:var(--space-sm);color:var(--nadc-yellow)}.modal-content p{color:var(--silver);margin-bottom:var(--space-md);font-size:.875rem}.modal-content form{display:flex;flex-direction:column;gap:var(--space-md)}.modal-content .modal-actions{display:flex;justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-sm)}.modal-content.modal-wide{max-width:800px}.ad-user-toolbar{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md)}.ad-user-actions{display:flex;align-items:center;gap:var(--space-sm)}.selected-count{color:var(--nadc-yellow);font-weight:600;font-size:.875rem}.ad-user-list{max-height:400px;overflow-y:auto;margin-bottom:var(--space-md);border:1px solid var(--steel);border-radius:var(--radius-sm)}.ad-user-list .data-table{margin:0}.ad-user-list .data-table tr.selected{background:#f7c51e1a}.ad-user-list .data-table tr:hover{background:var(--charcoal)}.ad-user-list .data-table input[type=checkbox]{accent-color:var(--nadc-yellow);width:18px;height:18px}.status-badge{font-size:.75rem;padding:2px 8px;border-radius:var(--radius-sm);font-weight:600}.status-badge.new{background:var(--info);color:var(--white)}.status-badge.active{background:var(--success);color:var(--white)}.status-badge.inactive{background:var(--steel);color:var(--white)}.admin-tabs{display:flex;gap:var(--space-xs);border-bottom:1px solid var(--steel);margin-bottom:var(--space-md)}.tab{background:none;border:none;color:var(--silver);padding:var(--space-sm) var(--space-md);font-weight:500;border-bottom:2px solid transparent;transition:all .2s}.tab:hover{color:var(--white)}.tab.active{color:var(--nadc-yellow);border-bottom-color:var(--nadc-yellow)}.admin-content{background:var(--black);border-radius:var(--radius-md);padding:var(--space-md);min-height:400px}.loading{text-align:center;padding:var(--space-xl);color:var(--silver)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md);margin-bottom:var(--space-lg)}.stat-card{background:var(--charcoal);border-radius:var(--radius-md);padding:var(--space-md);text-align:center}.stat-card h3{font-size:.875rem;color:var(--silver);margin-bottom:var(--space-xs)}.stat-value{font-size:2.5rem;font-weight:700;color:var(--nadc-yellow)}.stat-label{font-size:.75rem;color:var(--silver)}.dashboard-section{margin-top:var(--space-lg)}.dashboard-section h3{margin-bottom:var(--space-sm)}.action-buttons{display:flex;gap:var(--space-sm)}.action-buttons button{background:var(--steel);color:var(--white);border:none;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);transition:background .2s}.action-buttons button:hover:not(:disabled){background:var(--silver)}.settings-section h3{font-size:1.125rem;margin:var(--space-md) 0 var(--space-sm);padding-bottom:var(--space-xs);border-bottom:1px solid var(--steel)}.settings-form{display:flex;flex-direction:column;gap:var(--space-sm)}.setting-row{display:flex;align-items:center;gap:var(--space-md)}.setting-row>label:first-child{width:200px;color:var(--silver)}.setting-row input[type=text],.setting-row input[type=password],.setting-row select{flex:1;max-width:400px;background:var(--charcoal);border:1px solid var(--steel);color:var(--white);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm)}.setting-row label:has(input[type=checkbox]){display:flex;align-items:center;gap:var(--space-xs);cursor:pointer;color:var(--white)}.users-toolbar{display:flex;justify-content:space-between;margin-bottom:var(--space-md)}.search-input{background:var(--charcoal);border:1px solid var(--steel);color:var(--white);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);width:250px}.users-toolbar button{background:var(--nadc-yellow);color:var(--black);border:none;padding:var(--space-xs) var(--space-md);font-weight:600;border-radius:var(--radius-sm)}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:var(--space-sm);text-align:left;border-bottom:1px solid var(--steel)}.data-table th{background:var(--charcoal);font-weight:600;color:var(--silver);font-size:.875rem;text-transform:uppercase}.data-table tr:hover{background:var(--charcoal)}.data-table tr.inactive{opacity:.5}.data-table select{background:var(--charcoal);border:1px solid var(--steel);color:var(--white);padding:4px 8px;border-radius:var(--radius-sm)}.btn-small{background:var(--steel);color:var(--white);border:none;padding:4px 12px;font-size:.75rem;border-radius:var(--radius-sm)}.btn-small:hover{background:var(--silver)}.color-preview{display:inline-block;width:16px;height:16px;border-radius:var(--radius-sm);margin-right:var(--space-xs);vertical-align:middle}.status-completed{color:var(--success)}.status-failed{color:var(--danger)}.status-completed_with_errors{color:var(--warning)}.reports-section h4{margin:var(--space-lg) 0 var(--space-sm);padding-bottom:var(--space-xs);border-bottom:1px solid var(--steel)}.report-filters{display:flex;gap:var(--space-md);align-items:flex-end;flex-wrap:wrap;margin-bottom:var(--space-lg);padding:var(--space-md);background:var(--charcoal);border-radius:var(--radius-md)}.filter-group{display:flex;flex-direction:column;gap:var(--space-xs)}.filter-group label{font-size:.875rem;color:var(--silver)}.filter-group input,.filter-group select{background:var(--black);border:1px solid var(--steel);color:var(--white);padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);min-width:150px}.report-summary{margin-bottom:var(--space-lg)}.summary-cards{display:flex;gap:var(--space-md);flex-wrap:wrap}.summary-card{background:var(--charcoal);border-radius:var(--radius-md);padding:var(--space-md);min-width:150px;text-align:center}.summary-type{font-size:.875rem;color:var(--silver);margin-bottom:var(--space-xs)}.summary-hours{font-size:1.75rem;font-weight:700;color:var(--nadc-yellow)}.summary-count{font-size:.75rem;color:var(--silver)}@media(max-width:768px){.header-container{flex-wrap:wrap}.header-nav{order:3;width:100%;justify-content:center;margin-top:var(--space-sm)}.calendar-toolbar,.toolbar-filters{flex-direction:column;align-items:stretch}.filter-select{width:100%}.form-row{grid-template-columns:1fr}.setting-row{flex-direction:column;align-items:flex-start}.setting-row>label:first-child{width:auto}.data-table{font-size:.875rem}.data-table th,.data-table td{padding:var(--space-xs)}}.input-with-button{display:flex;gap:var(--space-sm)}.input-with-button input{flex:1}.help-text{color:var(--silver);font-size:.8rem;margin-top:var(--space-xs);display:block}.ical-status-card{background:var(--graphite);border:1px solid var(--steel);border-radius:var(--radius-md);padding:var(--space-md);margin-top:var(--space-md)}.ical-status-card .status-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.status-indicator{font-weight:600;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm)}.status-indicator.configured{background:#22c55e33;color:#22c55e}.status-indicator.not-configured{background:#ef444433;color:#ef4444}.ical-stats{display:flex;gap:var(--space-lg);padding:var(--space-sm) 0;border-bottom:1px solid var(--steel);margin-bottom:var(--space-sm)}.ical-stats span{color:var(--silver)}.ical-stats strong{color:var(--white)}.last-sync-info{font-size:.9rem;color:var(--silver)}.last-sync-info .sync-status{margin-left:var(--space-sm);padding:2px 8px;border-radius:var(--radius-sm);font-size:.75rem;text-transform:uppercase}.last-sync-info .sync-status.completed{background:#22c55e33;color:#22c55e}.last-sync-info .sync-status.completed_with_errors{background:#eab30833;color:#eab308}.last-sync-info .sync-status.failed{background:#ef444433;color:#ef4444}.last-sync-info .sync-message{margin-top:var(--space-xs);font-size:.85rem;color:var(--silver)}.settings-form.collapsible{opacity:.7;padding:var(--space-sm);background:var(--graphite);border-radius:var(--radius-sm);margin-top:var(--space-sm)}:root{--nadc-red: #C41E3A;--nadc-red-dark: #9B1830;--nadc-yellow: #f7c51e;--nadc-yellow-dark: #d4a80d;--black: #0A0A0A;--charcoal: #1A1A1A;--steel: #3A3A3A;--silver: #B0B0B0;--white: #FFFFFF;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--info: #3788d8;--font-heading: "Oswald", sans-serif;--font-body: "Open Sans", sans-serif;--space-xs: .5rem;--space-sm: 1rem;--space-md: 1.5rem;--space-lg: 2rem;--space-xl: 3rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .1);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1)}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px}body{font-family:var(--font-body);background-color:var(--charcoal);color:var(--white);line-height:1.6;min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600;line-height:1.2}a{color:var(--nadc-yellow);text-decoration:none}a:hover{color:var(--nadc-yellow-dark)}button{font-family:var(--font-body);cursor:pointer}input,select,textarea{font-family:var(--font-body);font-size:1rem}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:var(--space-sm)}.loading-spinner{width:40px;height:40px;border:3px solid var(--steel);border-top-color:var(--nadc-yellow);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--charcoal)}::-webkit-scrollbar-thumb{background:var(--steel);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--silver)}
