:root{--bg-deep: #0a0e1a;--bg: #111827;--bg-card: #1a2235;--bg-hover: #1f2a40;--bg-input: #0f1729;--border: #2a3555;--border-focus: #06b6d4;--text: #f1f5f9;--text-soft: #94a3b8;--text-muted: #64748b;--primary: #06b6d4;--primary-hover: #22d3ee;--primary-glow: rgba(6, 182, 212, .15);--secondary: #8b5cf6;--secondary-glow: rgba(139, 92, 246, .15);--success: #10b981;--success-bg: rgba(16, 185, 129, .12);--warn: #f59e0b;--warn-bg: rgba(245, 158, 11, .12);--danger: #ef4444;--danger-bg: rgba(239, 68, 68, .12);--info: #3b82f6;--info-bg: rgba(59, 130, 246, .12);--radius: 12px;--radius-sm: 8px;--radius-xs: 6px;--gradient-primary: linear-gradient(135deg, #06b6d4, #8b5cf6);--gradient-card: linear-gradient(135deg, rgba(6, 182, 212, .05), rgba(139, 92, 246, .05));--gradient-header: linear-gradient(135deg, #0f172a, #1e1b4b);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .35);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .45);--shadow-glow: 0 0 20px rgba(6, 182, 212, .15);--transition: .2s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-deep);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}#root{min-height:100vh;display:flex}.app-layout{display:flex;width:100%;min-height:100vh}.sidebar{width:260px;background:var(--gradient-header);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;height:100vh;z-index:100;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.sidebar__brand{padding:24px 20px;border-bottom:1px solid var(--border)}.sidebar__brand h1{font-size:18px;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.3px}.sidebar__brand p{font-size:11px;color:var(--text-muted);margin-top:4px;letter-spacing:.5px;text-transform:uppercase}.sidebar__nav{flex:1;padding:12px 10px;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-soft);font-size:14px;font-weight:500;transition:all var(--transition);border:1px solid transparent;position:relative;overflow:hidden}.nav-item:hover{background:var(--bg-hover);color:var(--text)}.nav-item--active{background:var(--primary-glow);color:var(--primary);border-color:#06b6d433}.nav-item--active:before{content:"";position:absolute;left:0;top:12px;bottom:12px;width:3px;background:var(--primary);border-radius:0 3px 3px 0}.nav-item__icon{font-size:18px;width:24px;text-align:center;flex-shrink:0}.nav-item__badge{margin-left:auto;background:var(--danger);color:#fff;font-size:11px;font-weight:600;padding:1px 7px;border-radius:10px;min-width:20px;text-align:center}.main-content{flex:1;margin-left:260px;padding:28px 32px;max-width:1400px}.page-header{margin-bottom:28px}.page-header__title{font-size:26px;font-weight:700;color:var(--text);letter-spacing:-.3px}.page-header__sub{font-size:14px;color:var(--text-muted);margin-top:4px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:all var(--transition);overflow:hidden}.card:hover{box-shadow:var(--shadow-md)}.card__header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border);background:var(--gradient-card)}.card__title{font-size:15px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:8px}.card__body{padding:20px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:28px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;gap:8px;transition:all var(--transition);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient-primary);opacity:0;transition:opacity var(--transition)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow);border-color:#06b6d44d}.stat-card:hover:before{opacity:1}.stat-card__icon{font-size:26px;margin-bottom:4px}.stat-card__value{font-size:28px;font-weight:800;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}.stat-card__label{font-size:13px;color:var(--text-muted);font-weight:500}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.3px;white-space:nowrap}.badge--planned{background:var(--info-bg);color:var(--info)}.badge--active{background:var(--success-bg);color:var(--success)}.badge--completed{background:var(--secondary-glow);color:var(--secondary)}.badge--cancelled{background:var(--danger-bg);color:var(--danger)}.badge--pending{background:var(--warn-bg);color:var(--warn)}.badge--covered{background:var(--success-bg);color:var(--success)}.badge--uncovered{background:var(--danger-bg);color:var(--danger)}.badge--lead{background:var(--primary-glow);color:var(--primary)}.badge--co_trainer{background:var(--info-bg);color:var(--info)}.badge--assistant{background:#94a3b81f;color:var(--text-soft)}.badge--guest{background:var(--secondary-glow);color:var(--secondary)}.badge--scheduled{background:var(--info-bg);color:var(--info)}.badge--holiday{background:var(--warn-bg);color:var(--warn)}.badge--other_event{background:var(--secondary-glow);color:var(--secondary)}.badge--spec{background:linear-gradient(135deg,#06b6d41f,#8b5cf61f);color:var(--primary-hover);border:1px solid rgba(6,182,212,.15)}.badge--count{background:var(--bg-hover);color:var(--text-soft);font-weight:700}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 18px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:all var(--transition);white-space:nowrap;font-family:inherit}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:var(--gradient-primary);color:#fff;border:none;box-shadow:0 2px 8px #06b6d440}.btn--primary:hover:not(:disabled){box-shadow:0 4px 16px #06b6d466;transform:translateY(-1px)}.btn--ghost{background:transparent;color:var(--text-soft);border:1px solid var(--border)}.btn--ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text);border-color:var(--primary)}.btn--danger{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(239,68,68,.2)}.btn--danger:hover:not(:disabled){background:var(--danger);color:#fff}.btn--success{background:var(--success-bg);color:var(--success);border:1px solid rgba(16,185,129,.2)}.btn--success:hover:not(:disabled){background:var(--success);color:#fff}.btn--sm{padding:5px 12px;font-size:12px}.btn--xs{padding:3px 8px;font-size:11px}.form{display:flex;flex-direction:column;gap:16px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.form-field{display:flex;flex-direction:column;gap:6px}.form-field label{font-size:12px;font-weight:600;color:var(--text-soft);text-transform:uppercase;letter-spacing:.5px}.form-field input,.form-field select,.form-field textarea{padding:10px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-input);color:var(--text);font-size:14px;font-family:inherit;transition:all var(--transition);outline:none}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-glow)}.form-field textarea{min-height:80px;resize:vertical}.form-field input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary)}.form-actions{display:flex;gap:10px;padding-top:4px}.list-item{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);transition:all var(--transition);cursor:pointer}.list-item:hover{border-color:#06b6d44d;background:var(--bg-hover);transform:translate(2px)}.list-item--active{border-color:var(--primary);background:var(--primary-glow)}.list-item__main{flex:1;min-width:0}.list-item__name{font-size:14px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:8px}.list-item__sub{font-size:12px;color:var(--text-muted);margin-top:3px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.list-item__actions{display:flex;gap:6px;align-items:center}.table-wrap{overflow-x:auto;border-radius:var(--radius-sm);border:1px solid var(--border)}table{width:100%;border-collapse:collapse;font-size:13px}thead{background:var(--bg-hover)}th{padding:10px 14px;text-align:left;font-weight:600;color:var(--text-soft);text-transform:uppercase;font-size:11px;letter-spacing:.5px;white-space:nowrap;border-bottom:1px solid var(--border)}td{padding:10px 14px;color:var(--text);border-bottom:1px solid rgba(42,53,85,.5)}tr:hover td{background:var(--bg-hover)}.divider{height:1px;background:var(--border);margin:16px 0}.toast{position:fixed;bottom:24px;right:24px;padding:14px 22px;border-radius:var(--radius);font-size:13px;font-weight:600;z-index:9999;animation:slideUp .4s cubic-bezier(.16,1,.3,1);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-lg)}.toast--success{background:#10b981e6;color:#fff;border:1px solid rgba(16,185,129,.6)}.toast--error{background:#ef4444e6;color:#fff;border:1px solid rgba(239,68,68,.6)}.toast--info{background:#3b82f6e6;color:#fff;border:1px solid rgba(59,130,246,.6)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}.empty-state__icon{font-size:48px;margin-bottom:16px;opacity:.4}.empty-state__text{font-size:14px;line-height:1.7}.progress-bar{height:6px;background:var(--bg-hover);border-radius:3px;overflow:hidden;width:100%}.progress-bar__fill{height:100%;border-radius:3px;background:var(--gradient-primary);transition:width .5s cubic-bezier(.16,1,.3,1)}.cost-display{font-variant-numeric:tabular-nums;font-weight:700;color:var(--primary-hover)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:500;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:90%;max-width:560px;max-height:85vh;overflow-y:auto;animation:scaleIn .25s cubic-bezier(.16,1,.3,1)}.modal__header{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-bottom:1px solid var(--border)}.modal__title{font-size:16px;font-weight:600}.modal__body{padding:22px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.flex{display:flex}.flex-col{flex-direction:column}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.items-center{align-items:center}.justify-between{justify-content:space-between}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.text-muted{color:var(--text-muted)}.text-soft{color:var(--text-soft)}.text-sm{font-size:13px}.text-xs{font-size:11px}.text-right{text-align:right}.font-bold{font-weight:700}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.spinner{display:flex;align-items:center;justify-content:center;padding:40px}.spinner:after{content:"";width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.cal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.cal-header__title{font-size:20px;font-weight:700;color:var(--text);letter-spacing:-.3px}.cal-header__nav{display:flex;gap:6px;align-items:center}.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;margin-bottom:1px}.cal-weekdays__day{text-align:center;padding:10px 0;font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;background:var(--bg-hover);border-radius:var(--radius-xs) var(--radius-xs) 0 0}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--border);border-radius:0 0 var(--radius) var(--radius);overflow:hidden}.cal-day{background:var(--bg-card);min-height:110px;padding:6px;display:flex;flex-direction:column;transition:background var(--transition);position:relative;cursor:default}.cal-day:hover{background:var(--bg-hover)}.cal-day--other{opacity:.35}.cal-day--today{background:#06b6d40f;box-shadow:inset 0 0 0 1px #06b6d440}.cal-day--today:hover{background:#06b6d41a}.cal-day__number{font-size:12px;font-weight:600;color:var(--text-soft);margin-bottom:4px;padding:2px 6px;display:inline-block;border-radius:4px}.cal-day--today .cal-day__number{background:var(--primary);color:#fff;font-weight:700}.cal-day__events{flex:1;display:flex;flex-direction:column;gap:3px;overflow-y:auto}.cal-event{padding:3px 6px;border-radius:4px;font-size:10px;font-weight:600;line-height:1.4;cursor:pointer;transition:all var(--transition);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-left:3px solid transparent}.cal-event:hover{filter:brightness(1.2);transform:translate(1px)}.cal-event--scheduled{background:var(--info-bg);color:var(--info);border-left-color:var(--info)}.cal-event--completed{background:var(--success-bg);color:var(--success);border-left-color:var(--success)}.cal-event--cancelled{background:var(--danger-bg);color:var(--danger);border-left-color:var(--danger);text-decoration:line-through;opacity:.7}.cal-event--holiday{background:var(--warn-bg);color:var(--warn);border-left-color:var(--warn)}.cal-event--other_event{background:var(--secondary-glow);color:var(--secondary);border-left-color:var(--secondary)}.cal-day__more{font-size:10px;color:var(--text-muted);font-weight:600;padding:2px 4px;cursor:pointer}.cal-day__more:hover{color:var(--primary)}.cal-detail{position:fixed;z-index:200;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:300px;max-width:420px;max-height:400px;overflow-y:auto;animation:scaleIn .2s cubic-bezier(.16,1,.3,1)}.cal-detail__header{padding:14px 16px;border-bottom:1px solid var(--border);font-weight:700;font-size:14px;display:flex;justify-content:space-between;align-items:center}.cal-detail__body{padding:12px;display:flex;flex-direction:column;gap:8px}.cal-detail-item{padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg)}.cal-detail-item__title{font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px;margin-bottom:4px}.cal-detail-item__sub{font-size:11px;color:var(--text-muted);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.cal-detail-item__actions{display:flex;gap:4px;margin-top:6px}.cal-legend{display:flex;gap:16px;align-items:center}.cal-legend__item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-muted)}.cal-legend__dot{width:8px;height:8px;border-radius:2px}@media(max-width:900px){.sidebar{width:60px}.sidebar__brand p,.nav-item span:not(.nav-item__icon):not(.nav-item__badge){display:none}.main-content{margin-left:60px;padding:20px 16px}.stats-grid{grid-template-columns:repeat(2,1fr)}.form-row,.form-row-3{grid-template-columns:1fr}.cal-day{min-height:80px}.cal-event{font-size:9px;padding:2px 4px}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:radial-gradient(ellipse at 50% 30%,rgba(6,182,212,.06) 0%,var(--bg-deep) 70%);padding:24px}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 20px 60px #0009;padding:44px 48px;width:100%;max-width:420px;animation:scaleIn .3s cubic-bezier(.16,1,.3,1)}.login-header{text-align:center;margin-bottom:32px}.login-icon{font-size:42px;margin-bottom:16px}.login-header h1{font-size:22px;font-weight:700;color:var(--text);display:flex;align-items:center;justify-content:center;gap:10px}.login-badge{font-size:10px;font-weight:700;letter-spacing:1px;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;border:1px solid rgba(6,182,212,.3);border-radius:4px;padding:1px 6px}.login-subtitle{font-size:13px;color:var(--text-muted);margin-top:6px}.login-error{background:var(--danger-bg);border:1px solid rgba(239,68,68,.3);color:var(--danger);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;font-weight:500;margin-bottom:20px;display:flex;align-items:center;gap:8px}.login-form{display:flex;flex-direction:column;gap:18px}.login-field{display:flex;flex-direction:column;gap:6px}.login-field label{font-size:12px;font-weight:600;color:var(--text-soft);text-transform:uppercase;letter-spacing:.5px}.login-field input{width:100%;padding:11px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-input);color:var(--text);font-size:14px;font-family:inherit;transition:all var(--transition);outline:none}.login-field input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--primary-glow)}.login-password-wrap{position:relative}.login-password-wrap input{padding-right:44px}.login-eye{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:16px;line-height:1;color:var(--text-muted);transition:color var(--transition)}.login-eye:hover{color:var(--text)}.login-btn{width:100%;padding:12px;background:var(--gradient-primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition);box-shadow:0 4px 16px #06b6d44d;font-family:inherit;margin-top:4px}.login-btn:hover:not(:disabled){box-shadow:0 6px 24px #06b6d473;transform:translateY(-1px)}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-footer{text-align:center;font-size:12px;color:var(--text-muted);margin-top:20px}.sidebar__user{padding:14px 16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px}.sidebar__user-info{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.sidebar__username{font-size:13px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar__logout{width:100%;justify-content:center}.role-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;white-space:nowrap}.role-admin{background:#8b5cf626;color:#c4b5fd;border:1px solid rgba(139,92,246,.3)}.role-manager{background:#06b6d41f;color:var(--primary);border:1px solid rgba(6,182,212,.25)}.role-viewer{background:var(--bg-hover);color:var(--text-soft);border:1px solid var(--border)}.panel-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px}.panel-card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.panel-card__title{font-size:17px;font-weight:700;color:var(--text)}.staff-form{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:20px;margin-bottom:20px;display:flex;flex-direction:column;gap:14px}.staff-list{display:flex;flex-direction:column;gap:10px}.staff-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);transition:border-color var(--transition)}.staff-item:hover{border-color:#06b6d440}.staff-item__info{flex:1;display:flex;align-items:center;gap:10px}.staff-item__name{font-size:14px;font-weight:600;color:var(--text)}.staff-item__meta{font-size:12px;color:var(--text-muted);min-width:140px}.text-muted{color:var(--text-muted);font-size:14px}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
