:root{--primary-dark:#0a0a0a;--primary-light:#1a1a1a;--sidebar-bg:#fff;--sidebar-hover:#b6831814;--accent-gold:#b68318;--accent-gold-light:#d4a017;--accent-gold-dark:#8e6612;--brand-primary:var(--accent-gold);--brand-primary-light:var(--accent-gold-light);--brand-primary-dark:var(--accent-gold-dark);--accent-blue:var(--accent-gold);--accent-purple:var(--accent-gold-dark);--accent-green:#22c55e;--accent-orange:#f59e0b;--accent-red:#ef4444;--bg-primary:#fff;--bg-secondary:#fafafa;--bg-tertiary:#f5f5f5;--bg-card:#fff;--card-background:#fff;--primary-color:var(--accent-gold);--secondary-color:var(--accent-gold-dark);--primary-text:#fff;--text-primary:#0a0a0a;--text-secondary:#525252;--text-muted:#737373;--text-color:#0a0a0a;--text-white:#fff;--text-inverse:#fff;--border-light:#e5e5e5;--border-medium:#d4d4d4;--border-dark:#a3a3a3;--border-color:#e5e5e5;--shadow-sm:0 1px 2px 0 #00000008;--shadow-md:0 2px 4px 0 #0000000d;--shadow-lg:0 4px 8px 0 #00000014;--shadow-xl:0 8px 16px 0 #0000001a;--font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;--font-mono:"SF Mono",Monaco,"Cascadia Code","Roboto Mono",Consolas,"Courier New",monospace;--text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--font-light:300;--font-normal:400;--font-medium:500;--font-semibold:600;--font-bold:700;--space-1:0.25rem;--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--radius-sm:0.25rem;--radius-md:0.375rem;--radius-lg:0.5rem;--radius-xl:0.75rem;--radius-2xl:1rem;--radius-3xl:1.5rem;--sidebar-width:280px;--sidebar-collapsed-width:80px;--header-height:72px;--max-content-width:1400px;--transition-fast:150ms cubic-bezier(0.4,0,0.2,1);--transition-normal:250ms cubic-bezier(0.4,0,0.2,1);--transition-slow:350ms cubic-bezier(0.4,0,0.2,1);--z-dropdown:1000;--z-sticky:1020;--z-fixed:1030;--z-modal-backdrop:1040;--z-modal:1050;--z-popover:1060;--z-tooltip:1070;--status-success:#22c55e;--status-warning:#f59e0b;--status-error:#ef4444;--status-info:var(--accent-gold);--status-success-bg:#f0fdf4;--status-warning-bg:#fffbeb;--status-error-bg:#fef2f2;--status-info-bg:#fef9f3;--calendar-today:var(--accent-gold);--calendar-event:#22c55e;--calendar-weekend:#f5f5f5;--calendar-other-month:#a3a3a3}[data-theme=dark]{--bg-primary:#0a0a0a;--bg-secondary:#121212;--bg-tertiary:#1a1a1a;--bg-card:#121212;--sidebar-bg:#0a0a0a;--sidebar-hover:#b683181a;--card-background:#121212;--primary-color:var(--accent-gold);--secondary-color:var(--accent-gold-dark);--primary-text:#fff;--text-primary:#fff;--text-secondary:#a3a3a3;--text-muted:#737373;--text-color:#fff;--border-light:#1a1a1a;--border-medium:#262626;--border-dark:#404040;--border-color:#1a1a1a;--status-success-bg:#0a1f0a;--status-warning-bg:#1f1a0a;--status-error-bg:#1f0a0a;--status-info-bg:#1a1510;--shadow-sm:0 1px 2px 0 #00000080;--shadow-md:0 2px 4px 0 #0009;--shadow-lg:0 4px 8px 0 #000000b3;--shadow-xl:0 8px 16px 0 #000c}@media (prefers-color-scheme:dark){:root:not([data-theme]){--bg-primary:#0a0a0a;--bg-secondary:#121212;--bg-tertiary:#1a1a1a;--bg-card:#121212;--sidebar-bg:#0a0a0a;--sidebar-hover:#b683181a;--card-background:#121212;--primary-color:var(--accent-gold);--secondary-color:var(--accent-gold-dark);--primary-text:#fff;--text-primary:#fff;--text-secondary:#a3a3a3;--text-muted:#737373;--text-color:#fff;--border-light:#1a1a1a;--border-medium:#262626;--border-dark:#404040;--border-color:#1a1a1a;--status-success-bg:#0a1f0a;--status-warning-bg:#1f1a0a;--status-error-bg:#1f0a0a;--status-info-bg:#1a1510;--shadow-sm:0 1px 2px 0 #00000080;--shadow-md:0 2px 4px 0 #0009;--shadow-lg:0 4px 8px 0 #000000b3;--shadow-xl:0 8px 16px 0 #000c}}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-family:var(--font-family);line-height:1.15}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg-primary);font-family:var(--font-family);font-size:var(--text-base);font-weight:var(--font-normal);line-height:1.6;overflow-x:hidden}body,h1,h2,h3,h4,h5,h6{color:var(--text-primary);margin:0}h1,h2,h3,h4,h5,h6{font-weight:var(--font-semibold);line-height:1.25}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-base)}p{color:var(--text-secondary);line-height:1.6;margin:0}a{color:var(--accent-gold);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-gold-light);opacity:1}ol,ul{list-style:none;margin:0;padding:0}img{border-style:none;height:auto;max-width:100%}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button;cursor:pointer}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}table{border-collapse:collapse;width:100%}td,th{border-bottom:1px solid var(--border-light);padding:var(--space-3);text-align:left}th{background-color:var(--bg-tertiary);color:var(--text-primary);font-weight:var(--font-semibold)}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:var(--bg-tertiary)}::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:var(--radius-lg)}::-webkit-scrollbar-thumb:hover{background:var(--border-dark)}:focus{outline:2px solid var(--accent-gold);outline-offset:2px}::selection{background-color:var(--accent-gold);color:var(--text-white)}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;padding:0;position:absolute;width:1px}.sr-only,.truncate{overflow:hidden;white-space:nowrap}.truncate{text-overflow:ellipsis}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-medium{font-weight:var(--font-medium)}.font-semibold{font-weight:var(--font-semibold)}.font-bold{font-weight:var(--font-bold)}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.container{margin:0 auto;max-width:var(--max-content-width);padding:0 var(--space-6);width:100%}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.grid{display:grid}.hidden{display:none}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.inset-0{inset:0}.p-2{padding:var(--space-2)}.p-3{padding:var(--space-3)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}.px-2{padding-left:var(--space-2);padding-right:var(--space-2)}.px-3{padding-left:var(--space-3);padding-right:var(--space-3)}.px-4{padding-left:var(--space-4);padding-right:var(--space-4)}.px-6{padding-left:var(--space-6);padding-right:var(--space-6)}.py-2{padding-bottom:var(--space-2);padding-top:var(--space-2)}.py-3{padding-bottom:var(--space-3);padding-top:var(--space-3)}.py-4{padding-bottom:var(--space-4);padding-top:var(--space-4)}.py-6{padding-bottom:var(--space-6);padding-top:var(--space-6)}.m-2{margin:var(--space-2)}.m-3{margin:var(--space-3)}.m-4{margin:var(--space-4)}.m-6{margin:var(--space-6)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.ml-2{margin-left:var(--space-2)}.ml-3{margin-left:var(--space-3)}.ml-4{margin-left:var(--space-4)}.mr-2{margin-right:var(--space-2)}.mr-3{margin-right:var(--space-3)}.mr-4{margin-right:var(--space-4)}.btn{gap:var(--space-2);line-height:1;-webkit-user-select:none;user-select:none;white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.6;pointer-events:none}.btn-primary{background-color:var(--accent-gold);box-shadow:none}.btn-primary:hover:not(:disabled){background-color:var(--accent-gold-light);box-shadow:none;transform:translateY(-1px)}.btn-secondary:hover:not(:disabled){background-color:var(--bg-tertiary);border-color:var(--border-medium)}.btn-success:hover:not(:disabled){background-color:#16a34a}.btn-warning:hover:not(:disabled){background-color:#d97706}.btn-danger:hover:not(:disabled){background-color:#dc2626}.btn-lg{font-size:var(--text-base);padding:var(--space-4) var(--space-6)}.card{background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);overflow:hidden;transition:all var(--transition-normal)}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-header{background-color:var(--bg-tertiary);border-bottom:1px solid var(--border-light)}.card-body,.card-header{padding:var(--space-6)}.card-footer{background-color:var(--bg-tertiary);border-top:1px solid var(--border-light);padding:var(--space-4) var(--space-6)}.form-control{display:block;line-height:1.5;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:100%}.form-control:focus{box-shadow:none}.form-control:disabled{background-color:var(--bg-tertiary);cursor:not-allowed;opacity:.6}.form-help{font-size:var(--text-xs);margin-top:var(--space-1)}.form-select{background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);color:var(--text-primary);cursor:pointer;display:block;font-size:var(--text-sm);line-height:1.5;padding:var(--space-3);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:100%}.form-select:focus{border-color:var(--accent-gold);box-shadow:none;outline:none}.badge{align-items:center;border-radius:var(--radius-md);display:inline-flex;font-size:var(--text-xs);font-weight:var(--font-medium);letter-spacing:.025em;line-height:1;padding:var(--space-1) var(--space-2);text-transform:uppercase}.badge-primary{background-color:var(--status-info-bg);color:var(--status-info)}.badge-success{background-color:var(--status-success-bg);color:var(--status-success)}.badge-warning{background-color:var(--status-warning-bg);color:var(--status-warning)}.badge-danger{background-color:var(--status-error-bg);color:var(--status-error)}.alert{border:1px solid #0000;margin-bottom:var(--space-4)}.alert-success{border-color:var(--status-success);color:#166534}.alert-warning{background-color:var(--status-warning-bg);border-color:var(--status-warning);color:#92400e}.alert-error{border-color:var(--status-error);color:#991b1b}.alert-info{background-color:var(--status-info-bg);border-color:var(--status-info);color:#1e40af}.modal-footer{background-color:var(--bg-tertiary);border-top:1px solid var(--border-light);display:flex;gap:var(--space-3);justify-content:flex-end;padding:var(--space-4) var(--space-6)}.loading{align-items:center;display:flex;justify-content:center;padding:var(--space-8)}.spinner{border-top-color:var(--accent-gold)}.table{background-color:var(--bg-card);border-collapse:collapse;border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);overflow:hidden;width:100%}.table th{background-color:var(--bg-tertiary);color:var(--text-primary);font-weight:var(--font-semibold);text-align:left}.table td,.table th{border-bottom:1px solid var(--border-light);padding:var(--space-4)}.table td{vertical-align:middle}.table tbody tr:hover{background-color:var(--bg-tertiary)}.table tbody tr:last-child td{border-bottom:none}.nav-link{border-radius:var(--radius-lg);color:var(--text-muted);transition:all var(--transition-fast)}.nav-link.active,.nav-link:hover{color:var(--text-white)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.rounded-sm{border-radius:var(--radius-sm)}.rounded{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-2xl{border-radius:var(--radius-2xl)}.border{border:1px solid var(--border-light)}.border-t{border-top:1px solid var(--border-light)}.border-b{border-bottom:1px solid var(--border-light)}.border-l{border-left:1px solid var(--border-light)}.border-r{border-right:1px solid var(--border-light)}:root{--primary-color:var(--accent-blue);--secondary-color:#0056b3;--background-color:var(--bg-primary);--card-background:var(--bg-card);--text-color:var(--text-primary);--text-light:var(--text-secondary);--border-color:var(--border-light);--hover-color:#0056b3;--popup-background:var(--bg-card);--button-hover-color:#0056b3;--error-color:var(--status-error);--error-hover-color:#c00}.App{background-color:var(--bg-primary);font-family:var(--font-family);min-height:100vh}.route-transition{transition:opacity var(--transition-normal)}.app-loading{align-items:center;background-color:var(--bg-primary);color:var(--text-secondary);display:flex;font-size:var(--text-lg);justify-content:center;min-height:100vh}.app-loading .spinner{animation:spin 1s linear infinite;border-top:3px solid var(--border-light);border:3px solid var(--border-light);border-radius:50%;border-top-color:var(--accent-blue);height:32px;margin-right:var(--space-4);width:32px}.app-error{align-items:center;background-color:var(--bg-primary);display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:var(--space-8);text-align:center}.app-error h1{color:var(--status-error);font-size:var(--text-3xl);margin-bottom:var(--space-4)}.app-error p{color:var(--text-secondary);font-size:var(--text-lg);margin-bottom:var(--space-6);max-width:500px}@media (prefers-reduced-motion:reduce){.route-transition,.spinner{animation:none;transition:none}}@media (prefers-contrast:high){.App{background-color:#fff;color:#000}}@media print{.App{background:#fff;color:#000}.navbar,.sidebar{display:none}}:root{--sidebar-transition:0.3s cubic-bezier(0.4,0,0.2,1)}.sidebar{border-right:1px solid var(--border-light);flex-direction:column;height:100vh;left:0;overflow:hidden;position:fixed;top:0;transition:width .3s cubic-bezier(.4,0,.2,1);transition:width var(--sidebar-transition);width:var(--sidebar-width);z-index:var(--z-fixed)}.sidebar,.sidebar-header{background-color:var(--sidebar-bg);display:flex}.sidebar-header{align-items:center;border-bottom:1px solid var(--border-light);justify-content:space-between;padding:var(--space-6) var(--space-4);position:relative}.sidebar-brand{gap:var(--space-3)}.brand-icon,.sidebar-brand{align-items:center;display:flex;overflow:hidden}.brand-icon{background-color:var(--accent-gold);border-radius:var(--radius-lg);flex-shrink:0;font-size:20px;height:40px;justify-content:center;width:40px}.brand-icon .logo-image{border-radius:var(--radius-lg);height:100%;object-fit:cover;width:100%}.brand-text{flex:1 1}.brand-title{color:var(--text-primary);font-size:var(--text-base);font-weight:var(--font-semibold);letter-spacing:.02em;line-height:1.2}.brand-subtitle{color:var(--text-secondary);font-size:var(--text-xs);font-weight:var(--font-medium);letter-spacing:.1em;margin-top:2px;text-transform:uppercase}.sidebar-toggle{align-items:center;background:#0000;border:1px solid var(--border-light);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;font-size:14px;height:32px;justify-content:center;transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--sidebar-transition);width:32px}.sidebar-toggle:hover{border-color:var(--accent-gold);color:var(--accent-gold)}.brand-text,.logout-label,.nav-label,.user-info{max-width:200px;opacity:1;overflow:hidden;transform:translateX(0);transition:opacity .3s cubic-bezier(.4,0,.2,1),max-width .3s cubic-bezier(.4,0,.2,1),margin .3s cubic-bezier(.4,0,.2,1),padding .3s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.4,0,.2,1);transition:opacity var(--sidebar-transition),max-width var(--sidebar-transition),margin var(--sidebar-transition),padding var(--sidebar-transition),transform var(--sidebar-transition);white-space:nowrap}.sidebar-nav{flex:1 1;overflow-x:hidden;overflow-y:auto;padding:var(--space-4) 0}.nav-list{display:flex;flex-direction:column;gap:var(--space-1);padding:0 var(--space-3);transition:padding .3s cubic-bezier(.4,0,.2,1);transition:padding var(--sidebar-transition)}.nav-item{list-style:none}.nav-link{align-items:center;background:#0000;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;font-size:var(--text-sm);font-weight:var(--font-medium);gap:var(--space-3);overflow:hidden;padding:var(--space-3) var(--space-4);position:relative;text-align:left;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--sidebar-transition);width:100%}.nav-link:hover{background-color:var(--sidebar-hover);color:var(--text-primary)}.nav-link.active{background-color:var(--accent-gold);box-shadow:none;color:var(--text-primary)}.nav-icon{align-items:center;display:flex;flex-shrink:0;font-size:18px;height:20px;justify-content:center;opacity:.6;transition:opacity .3s cubic-bezier(.4,0,.2,1);transition:opacity var(--sidebar-transition);width:20px}.nav-link.active .nav-icon,.nav-link:hover .nav-icon{opacity:1}.nav-icon svg{height:100%;width:100%}.sidebar-footer{background-color:var(--sidebar-bg);border-top:1px solid var(--border-light);overflow:hidden;padding:var(--space-4);transition:padding .3s cubic-bezier(.4,0,.2,1);transition:padding var(--sidebar-transition)}.user-profile{background:#0000;border:1px solid var(--border-light);border-radius:var(--radius-md);gap:var(--space-3);margin-bottom:var(--space-3);overflow:hidden;padding:var(--space-3);transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--sidebar-transition)}.user-avatar,.user-profile{align-items:center;display:flex}.user-avatar{background-color:var(--accent-gold);border-radius:50%;color:var(--text-white);flex-shrink:0;font-size:var(--text-sm);font-weight:var(--font-bold);height:36px;justify-content:center;width:36px}.user-info{flex:1 1}.user-name{color:var(--text-primary);font-size:var(--text-sm);font-weight:var(--font-semibold);white-space:nowrap}.user-role{color:var(--text-secondary);font-size:var(--text-xs);margin-top:1px}.theme-toggle-btn{align-items:center;background:#0000;border:1px solid var(--border-light);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;font-size:16px;height:40px;justify-content:center;margin-bottom:var(--space-3);transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--sidebar-transition);width:100%}.theme-toggle-btn:hover{border-color:var(--accent-gold);color:var(--accent-gold)}.logout-btn{align-items:center;background:#0000;border:1px solid var(--border-light);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;font-size:var(--text-sm);font-weight:var(--font-medium);gap:var(--space-3);padding:var(--space-3);transition:all .3s cubic-bezier(.4,0,.2,1);transition:all var(--sidebar-transition);width:100%}.logout-btn:hover{border-color:var(--status-error);color:var(--status-error)}.logout-icon{opacity:.6;transition:opacity .3s cubic-bezier(.4,0,.2,1);transition:opacity var(--sidebar-transition)}.logout-btn:hover .logout-icon{opacity:1}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar.collapsed .sidebar-header{flex-direction:column;gap:var(--space-4);padding:var(--space-4) 0}.sidebar.collapsed .brand-text,.sidebar.collapsed .logout-label,.sidebar.collapsed .nav-label,.sidebar.collapsed .user-info{margin:0;max-width:0;opacity:0;padding:0;pointer-events:none;transform:translateX(-10px)}.sidebar.collapsed .sidebar-brand{gap:0;justify-content:center}.sidebar.collapsed .nav-list{padding:0 var(--space-2)}.sidebar.collapsed .nav-link{gap:0;justify-content:center;padding:var(--space-3)}.sidebar.collapsed .user-profile{gap:0;justify-content:center;padding:var(--space-2)}.sidebar.collapsed .logout-btn,.sidebar.collapsed .theme-toggle-btn{justify-content:center;padding:var(--space-3)}.sidebar::-webkit-scrollbar{width:4px}.sidebar::-webkit-scrollbar-track{background:#0000}.sidebar::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:2px}.sidebar::-webkit-scrollbar-thumb:hover{background:var(--border-dark)}.app-layout{display:flex}.app-layout,.main-content{background-color:var(--bg-primary);min-height:100vh}.main-content{flex:1 1;margin-left:var(--sidebar-width);transition:margin-left var(--transition-normal)}.main-content.collapsed{margin-left:var(--sidebar-collapsed-width)}.content-wrapper{margin:0 auto;max-width:var(--max-content-width);min-height:calc(100vh - var(--space-16));padding:var(--space-8)}@media (max-width:1024px){.main-content{margin-left:var(--sidebar-collapsed-width)}}@media (max-width:768px){.main-content{margin-left:0}.content-wrapper{padding:var(--space-4)}}.calendar-component{background-color:var(--bg-card);border-radius:var(--radius-xl);overflow:hidden;position:relative;width:100%}.calendar-loading{align-items:center;color:var(--text-muted);display:flex;flex-direction:column;gap:var(--space-3);justify-content:center;padding:var(--space-8)}.spinner{border:2px solid var(--border-light);border-top-color:var(--accent-blue);height:24px;width:24px}.calendar-header{background:linear-gradient(135deg,var(--bg-tertiary) 0,var(--bg-secondary) 100%);border-bottom:1px solid var(--border-light);justify-content:space-between;padding:var(--space-6)}.calendar-header,.calendar-nav{align-items:center;display:flex}.calendar-nav{gap:var(--space-4)}.nav-btn{align-items:center;background-color:var(--bg-secondary);border:none;border:1px solid var(--border-light);border-radius:var(--radius-lg);color:var(--text-primary);cursor:pointer;display:flex;font-size:var(--text-lg);font-weight:var(--font-semibold);height:40px;justify-content:center;transition:all var(--transition-fast);width:40px}.nav-btn:hover{background-color:var(--accent-blue);border-color:var(--accent-blue);color:var(--text-white);transform:translateY(-1px)}.calendar-title{color:var(--text-primary);font-size:var(--text-xl);font-weight:var(--font-semibold);margin:0;min-width:200px;text-align:center}.calendar-actions{align-items:center;display:flex;gap:var(--space-3)}.calendar-grid{padding:var(--space-4)}.calendar-days-header{grid-gap:1px;display:grid;gap:1px;grid-template-columns:repeat(7,1fr);margin-bottom:var(--space-2);padding:0 1px}.day-header{color:var(--text-secondary);font-size:var(--text-sm);font-weight:var(--font-semibold);letter-spacing:.5px;padding:var(--space-3);text-align:center;text-transform:uppercase}.calendar-days-grid{grid-gap:1px;background-color:var(--border-light);border-radius:var(--radius-lg);display:grid;gap:1px;overflow:hidden;padding:1px}.calendar-days-grid.month{grid-template-columns:repeat(7,1fr)}.calendar-day{background-color:var(--bg-card);cursor:pointer;display:flex;flex-direction:column;min-height:100px;padding:var(--space-2);position:relative;transition:all var(--transition-fast)}.calendar-day:hover{background-color:var(--bg-tertiary);box-shadow:var(--shadow-md);transform:scale(1.02);z-index:10}.calendar-day.today{background:linear-gradient(135deg,var(--accent-blue) 0,#3b82f61a 100%);border:2px solid var(--accent-blue)}.calendar-day.today .day-number{color:var(--accent-blue);font-weight:var(--font-bold)}.calendar-day.other-month{background-color:var(--bg-tertiary);opacity:.5}.calendar-day.other-month .day-number{color:var(--text-muted)}.calendar-day.has-events{border-left:4px solid var(--accent-green)}.day-number{color:var(--text-primary);font-size:var(--text-sm);font-weight:var(--font-medium);line-height:1;margin-bottom:var(--space-2)}.day-events{display:flex;flex:1 1;flex-direction:column;gap:var(--space-1);overflow:hidden}.event-dot{background-color:var(--bg-secondary);border-left:3px solid;border-radius:var(--radius-md);font-size:var(--text-xs);font-weight:var(--font-medium);line-height:1.2;margin-bottom:var(--space-1);overflow:hidden;padding:var(--space-2);text-overflow:ellipsis;white-space:nowrap}.event-time{color:var(--text-primary);font-size:10px;font-weight:var(--font-bold);margin-bottom:2px;opacity:.8}.event-title{display:block;font-size:11px;line-height:1.1;width:100%}.event-dot.confirmed{background-color:var(--status-success-bg);border-left-color:var(--status-success);color:var(--status-success)}.event-dot.pending{background-color:var(--status-warning-bg);border-left-color:var(--status-warning);color:var(--status-warning)}.event-dot.cancelled{background-color:var(--status-error-bg);border-left-color:var(--status-error);color:var(--status-error)}.event-dot.completed{border-left-color:var(--text-muted)}.event-dot.completed,.more-events{background-color:var(--bg-tertiary);color:var(--text-muted)}.more-events{border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:var(--font-medium);margin-top:var(--space-1);padding:var(--space-1);text-align:center}.event-summary{background:linear-gradient(135deg,var(--bg-tertiary) 0,var(--bg-secondary) 100%);border-top:1px solid var(--border-light);padding:var(--space-6)}.event-summary h3{color:var(--text-primary);font-size:var(--text-lg);font-weight:var(--font-semibold);margin:0 0 var(--space-4) 0}.summary-stats{display:flex;gap:var(--space-6)}.stat{align-items:center;display:flex;flex-direction:column;gap:var(--space-1)}.stat-number{color:var(--accent-blue);font-size:var(--text-2xl);font-weight:var(--font-bold);line-height:1}.stat-label{font-size:var(--text-xs);font-weight:var(--font-medium);letter-spacing:.5px;text-transform:uppercase}@media (max-width:1024px){.calendar-header{align-items:stretch;flex-direction:column;gap:var(--space-4)}.calendar-nav{justify-content:center}.calendar-actions{justify-content:space-between}.calendar-day{min-height:80px}.summary-stats{justify-content:space-around}}@media (max-width:768px){.calendar-container{border-radius:0}.calendar-header{padding:var(--space-4)}.calendar-actions{align-items:stretch;flex-direction:column;gap:var(--space-2)}.view-toggle{margin-bottom:var(--space-2);margin-right:0}.calendar-grid{padding:var(--space-2)}.calendar-day{min-height:60px;padding:var(--space-1)}.day-number{font-size:var(--text-xs)}.event-dot{font-size:10px;padding:1px var(--space-1)}}@media (max-width:480px){.calendar-title{font-size:var(--text-lg);min-width:auto}.nav-btn{height:36px;width:36px}.calendar-day{min-height:50px}.day-header{font-size:var(--text-xs);padding:var(--space-2)}.event-dot{display:none}.calendar-day.has-events:after{color:var(--status-success);content:"•";font-size:var(--text-sm);font-weight:var(--font-bold);position:absolute;right:var(--space-1);top:var(--space-1)}}.upcoming-events-card-content{animation:fadeIn .5s ease-in-out;background-color:var(--card-background);border-radius:10px;box-shadow:0 4px 8px #0000001a;max-width:500px;min-height:200px;padding:1.5rem;transition:transform .3s ease,box-shadow .3s ease;width:100%}.upcoming-events-card-content:hover{box-shadow:0 6px 12px #00000026;transform:translateY(-5px)}.upcoming-events-loading{text-align:center}.upcoming-events-card,.upcoming-events-loading{background-color:var(--card-background);border:1px solid var(--border-color);border-radius:10px;box-shadow:0 4px 8px #0000001a;max-width:500px;padding:2rem;width:100%}.upcoming-events-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.upcoming-events-title{color:var(--text-color);font-size:1.25rem;font-weight:700;margin:0}.upcoming-events-button{background-color:var(--primary-color);border:none;border-radius:5px;color:var(--primary-text);cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem .75rem;text-decoration:none;transition:all .3s ease}.upcoming-events-button:hover{background-color:var(--secondary-color);box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.upcoming-events-content{width:100%}.upcoming-events-list{list-style:none;margin:0;padding:0}.upcoming-events-item{border-bottom:1px solid var(--border-color);padding:1rem 0}.upcoming-events-item:last-child{border-bottom:none}.upcoming-events-date{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.upcoming-events-date-text{color:var(--text-color);font-size:1rem;font-weight:600}.upcoming-events-location{margin-top:.5rem}.upcoming-events-location-name{color:var(--text-color);font-size:.875rem;font-weight:500;margin:0 0 .25rem}.upcoming-events-event-names{color:var(--text-secondary);font-size:.875rem;list-style:none;margin:0;padding:0}.upcoming-events-event-names li{margin-bottom:.125rem}@media (max-width:640px){.upcoming-events-card,.upcoming-events-card-content,.upcoming-events-loading{max-width:100%;padding:1rem}.upcoming-events-header{align-items:flex-start;flex-direction:column;gap:.75rem}.upcoming-events-button{align-self:flex-end}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.dashboard{background-color:var(--bg-primary);max-width:none;padding:0}.dashboard-header{align-items:flex-start;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;margin-bottom:var(--space-8);padding:var(--space-6) 0}.header-content h1.dashboard-title{color:var(--text-primary);font-size:var(--text-3xl);font-weight:var(--font-bold);margin-bottom:var(--space-2)}.dashboard-subtitle{color:var(--text-secondary);font-size:var(--text-base);margin:0}.stats-grid{grid-gap:var(--space-6);display:grid;gap:var(--space-6);grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:var(--space-8)}.stat-card{align-items:center;background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);display:flex;gap:var(--space-4);padding:var(--space-6);transition:all var(--transition-normal)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-icon{align-items:center;background:linear-gradient(135deg,var(--accent-blue) 0,var(--accent-purple) 100%);border-radius:var(--radius-xl);display:flex;flex-shrink:0;font-size:20px;height:48px;justify-content:center;width:48px}.stat-content{flex:1 1}.stat-value{color:var(--text-primary);font-size:var(--text-2xl);font-weight:var(--font-bold);line-height:1.2}.stat-label{color:var(--text-secondary);font-size:var(--text-sm)}.stat-change,.stat-label{margin-top:var(--space-1)}.stat-change{font-size:var(--text-xs);font-weight:var(--font-medium)}.stat-change.positive{color:var(--status-success)}.stat-change.negative{color:var(--status-error)}.dashboard-grid{display:flex;flex-direction:column;gap:var(--space-8)}.calendar-section{order:1}.upcoming-events-section{order:2}.section-title{margin:0}.calendar-container,.upcoming-events-container{background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);height:-webkit-fit-content;height:fit-content;padding:var(--space-6)}@media (max-width:1200px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width:768px){.dashboard-header{align-items:flex-start;flex-direction:column;gap:var(--space-4)}.header-actions{align-self:stretch}.header-actions .btn{flex:1 1;justify-content:center}.stats-grid{gap:var(--space-4);grid-template-columns:1fr}.dashboard-grid{gap:var(--space-6)}.calendar-container,.upcoming-events-container{padding:var(--space-4)}}@media (max-width:480px){.quick-action-card{flex-direction:column;gap:var(--space-3);text-align:center}.action-arrow{display:none}.stats-grid{gap:var(--space-3)}.stat-card{padding:var(--space-4)}.stat-icon{font-size:18px;height:40px;width:40px}}.contract-form-page{margin:0 auto;max-width:900px;padding:0}.contract-form{display:flex;flex-direction:column;gap:var(--space-8)}.form-section{background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:var(--space-8)}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--space-6)}.section-title{border-bottom:1px solid var(--border-light);color:var(--text-primary);font-size:var(--text-xl);font-weight:var(--font-semibold);margin:0 0 var(--space-6) 0;padding-bottom:var(--space-3);position:relative}.section-title:after{background:var(--accent-gold);bottom:-1px;content:"";height:2px;left:0;position:absolute;width:60px}.form-grid{grid-gap:var(--space-6);display:grid;gap:var(--space-6);grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.form-group-full{grid-column:1/-1}.form-control{background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--text-sm);padding:var(--space-3);transition:all var(--transition-fast)}.form-control:focus{background-color:var(--bg-card);border-color:var(--accent-gold);box-shadow:0 0 0 3px #b683181a;outline:none}.form-control.error{border-color:var(--status-error);box-shadow:0 0 0 3px #ef44441a}.form-control[readonly]{background-color:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed}.form-error{color:var(--status-error);font-size:var(--text-xs);font-weight:var(--font-medium);margin-top:var(--space-1)}textarea.form-control{min-height:100px;resize:vertical}.singer-tag{background:var(--accent-gold);border-radius:var(--radius-lg);font-size:var(--text-sm);font-weight:var(--font-medium);gap:var(--space-2);padding:var(--space-2) var(--space-3)}.remove-singer,.singer-tag{align-items:center;color:var(--text-white);display:flex}.remove-singer{background:none;border:none;border-radius:50%;cursor:pointer;font-size:var(--text-xs);height:16px;justify-content:center;padding:0;transition:background-color var(--transition-fast);width:16px}.remove-singer:hover{background-color:#fff3}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);inset:0}.modal{border-radius:var(--radius-2xl);max-height:80vh;overflow:hidden;z-index:var(--z-modal)}.modal-header{background:var(--bg-secondary);padding:var(--space-6)}.modal-title{color:var(--text-primary);font-size:var(--text-lg);font-weight:var(--font-semibold);margin:0}.modal-body{padding:var(--space-6)}.search-box{margin-bottom:var(--space-4)}.singers-list{border:1px solid var(--border-light);border-radius:var(--radius-lg);max-height:300px;overflow-y:auto}.singer-item{border-bottom:1px solid var(--border-light);cursor:pointer;padding:var(--space-4);transition:background-color var(--transition-fast)}.singer-item:last-child{border-bottom:none}.singer-item:hover{background-color:var(--bg-tertiary)}.singer-info{display:flex;flex-direction:column;gap:var(--space-1)}.singer-name{color:var(--text-primary);font-weight:var(--font-medium)}.singer-phone{color:var(--text-secondary);font-size:var(--text-sm)}.form-actions{flex-direction:column;gap:var(--space-4);padding-top:var(--space-6)}.action-buttons{gap:var(--space-4);justify-content:flex-end}.alert{border-radius:var(--radius-lg);font-weight:var(--font-medium);padding:var(--space-4);text-align:center}.alert-success{background-color:var(--status-success-bg);border:1px solid var(--status-success);color:var(--status-success)}.alert-error{background-color:var(--status-error-bg);border:1px solid var(--status-error);color:var(--status-error)}.spinner{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:currentcolor;height:16px;margin-right:var(--space-2);width:16px}@media (max-width:768px){.contract-form-page{padding:0}.page-header{align-items:flex-start;flex-direction:column;gap:var(--space-3)}.page-header h1{font-size:var(--text-2xl)}.form-section{border-left:none;border-radius:0;border-right:none;margin:0 -var(--space-4);padding:var(--space-6)}.form-grid{gap:var(--space-4);grid-template-columns:1fr}.section-header{gap:var(--space-3)}.section-header,.selected-singers{align-items:flex-start;flex-direction:column}.action-buttons{flex-direction:column-reverse}.action-buttons .btn{justify-content:center;width:100%}.modal{margin:var(--space-4);width:95%}.modal-body{padding:var(--space-4)}}@media (max-width:480px){.form-section,.modal-header{padding:var(--space-4)}.singer-item{padding:var(--space-3)}}input[name=endTime],input[name=startTime]{display:inline-block;font-family:Courier New,monospace;font-size:16px;letter-spacing:.5px;text-align:center;width:100px}input[name=endTime]:focus,input[name=startTime]:focus{border-color:var(--accent-blue);box-shadow:0 0 0 2px #3b82f61a;outline:none}.form-help{color:var(--text-muted);font-size:12px;font-style:italic;margin-top:4px}.event-count-info{border-radius:6px;margin-top:8px;padding:8px 12px}.event-count-text,.event-limit-warning{font-size:14px;font-weight:500}.event-limit-warning{border-radius:6px;gap:8px;margin-top:8px;padding:10px 12px}.events-container{background-color:var(--bg-primary);max-width:none;padding:0}.events-page-header{align-items:flex-start;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;margin-bottom:var(--space-8);padding:var(--space-6) 0}.events-page-header h1{color:var(--text-primary);font-size:var(--text-3xl);font-weight:var(--font-bold);margin:0 0 var(--space-2) 0}.events-subtitle{color:var(--text-secondary);font-size:var(--text-base);margin:0}.filters input,.filters select{background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--text-sm);min-width:200px;padding:var(--space-3);transition:all var(--transition-fast)}.filters input:focus,.filters select:focus{border-color:var(--accent-gold);box-shadow:0 0 0 3px #b683181a;outline:none}.events-list{grid-gap:var(--space-6);display:grid;gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));padding:0}.event-card{background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-6);position:relative;transition:all var(--transition-normal)}.event-card:hover{border-color:var(--accent-gold);box-shadow:var(--shadow-md);transform:translateY(-2px)}.event-card h3{color:var(--text-primary);font-size:var(--text-lg);font-weight:var(--font-semibold);margin:0 0 var(--space-3) 0}.event-card p{color:var(--text-secondary);font-size:var(--text-sm);line-height:1.6;margin:0}.event-card p strong{color:var(--text-primary);font-weight:var(--font-medium)}.event-card-actions{border-top:1px solid var(--border-light);display:flex;gap:var(--space-2);margin-top:var(--space-4);padding-top:var(--space-4)}.delete-button,.download-button,.edit-button{background:none;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;padding:var(--space-2);transition:all var(--transition-fast)}.download-button:hover{background-color:#b683181a;color:var(--accent-gold)}.cancel-button{border:none;border-radius:var(--radius-lg);color:var(--text-white);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);margin-top:var(--space-2);padding:var(--space-3);transition:all var(--transition-fast);width:100%}.cancel-button.reactivate{background-color:var(--accent-gold)}.cancel-button.reactivate:hover{background-color:var(--accent-gold-dark);transform:translateY(-1px)}.cancel-button.cancel{background-color:var(--status-error)}.cancel-button.cancel:hover{background-color:#dc2626;transform:translateY(-1px)}.events-list p{color:var(--text-secondary);font-size:var(--text-base);grid-column:1/-1;padding:var(--space-8);text-align:center}@media (max-width:768px){.events-page-header{flex-direction:column;gap:var(--space-4)}.header-actions{align-self:stretch}.add-button,.header-actions .btn{flex:1 1;justify-content:center}.filters{flex-direction:column}.filters input,.filters select{min-width:0;width:100%}.events-list{gap:var(--space-4);grid-template-columns:1fr}.event-card{padding:var(--space-4)}}@media (max-width:480px){.events-page-header h1{font-size:var(--text-2xl)}.event-card h3{font-size:var(--text-base)}}.event-form-page{margin:0 auto;max-width:900px;padding:0}.page-header{align-items:flex-start;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;margin-bottom:var(--space-8);padding-bottom:var(--space-4)}.page-header h1{color:var(--text-primary);font-size:var(--text-3xl);font-weight:var(--font-bold);margin:0 0 var(--space-2) 0}.page-subtitle{color:var(--text-secondary);font-size:var(--text-base);margin:0}.event-form{gap:var(--space-6)}.event-form,.form-group{display:flex;flex-direction:column}.form-group{gap:var(--space-2)}.form-input,.form-textarea{background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--text-sm);padding:var(--space-3);transition:all var(--transition-fast)}.form-input:focus,.form-textarea:focus{border-color:var(--accent-gold);box-shadow:0 0 0 3px #b683181a;outline:none}.form-textarea{min-height:100px;resize:vertical}.add-singer-button{align-items:center;background-color:var(--accent-gold);border:none;border-radius:var(--radius-lg);color:var(--text-white);cursor:pointer;display:inline-flex;font-size:var(--text-sm);font-weight:var(--font-medium);gap:var(--space-2);padding:var(--space-3) var(--space-4);transition:all var(--transition-fast)}.add-singer-button:hover{background-color:var(--accent-gold-dark);transform:translateY(-1px)}.singer-list{background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);margin-top:var(--space-4);max-height:200px;overflow-y:auto;padding:var(--space-4)}.singer-item{margin-bottom:var(--space-2)}.singer-item:last-child{margin-bottom:0}.select-singer-button{background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:var(--text-sm);padding:var(--space-3);text-align:left;transition:all var(--transition-fast);width:100%}.select-singer-button:hover{background-color:var(--accent-gold);border-color:var(--accent-gold);color:var(--text-white)}.selected-singers{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-4)}.selected-singer-item{align-items:center;background-color:var(--accent-gold);border-radius:var(--radius-lg);color:var(--text-white);display:flex;font-size:var(--text-sm);gap:var(--space-2);padding:var(--space-2) var(--space-3)}.remove-singer-button{background:none;border:none;color:var(--text-white);cursor:pointer;font-size:16px;padding:0;transition:transform var(--transition-fast)}.remove-singer-button:hover{transform:scale(1.2)}.form-button{background-color:var(--accent-gold);border:none;border-radius:var(--radius-lg);color:var(--text-white);cursor:pointer;font-size:var(--text-base);font-weight:var(--font-semibold);margin-top:var(--space-4);padding:var(--space-4) var(--space-6);transition:all var(--transition-fast)}.form-button:hover{background-color:var(--accent-gold-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.event-count-info{background-color:var(--bg-secondary);border-left:3px solid var(--accent-gold);border-radius:var(--radius-md);margin-top:var(--space-2);padding:var(--space-3)}.event-count-text{color:var(--text-primary);margin:0}.event-count-text,.event-limit-warning{font-size:var(--text-sm);font-weight:var(--font-medium)}.event-limit-warning{align-items:center;background-color:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-md);color:#dc2626;display:flex;gap:var(--space-2);margin-top:var(--space-2);padding:var(--space-3)}.warning-icon{color:#dc2626;flex-shrink:0;font-size:16px}@media (max-width:768px){.event-form-page{padding:0 var(--space-4)}.page-header{flex-direction:column;gap:var(--space-4)}.page-header h1{font-size:var(--text-2xl)}.form-button{width:100%}}.singers-container{background-color:var(--bg-primary);max-width:none;padding:0}.singers-page-header{align-items:flex-start;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;margin-bottom:var(--space-8);padding:var(--space-6) 0}.header-content{flex:1 1}.singers-page-header h1{color:var(--text-primary);font-size:var(--text-3xl);font-weight:var(--font-bold);margin:0 0 var(--space-2) 0}.singers-subtitle{color:var(--text-secondary);font-size:var(--text-base);margin:0}.header-actions{align-items:center}.filters,.header-actions{display:flex;gap:var(--space-3)}.filters{flex-wrap:wrap;margin-bottom:var(--space-6)}.filters input{background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);color:var(--text-primary);flex:1 1;font-size:var(--text-sm);min-width:300px;padding:var(--space-3);transition:all var(--transition-fast)}.filters input:focus{border-color:var(--accent-gold);box-shadow:0 0 0 3px #b683181a;outline:none}.add-button{background-color:var(--accent-gold);border:none;border-radius:var(--radius-lg);color:var(--text-white);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);padding:var(--space-3) var(--space-6);transition:all var(--transition-fast);white-space:nowrap}.add-button:hover{background-color:var(--accent-gold-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.singers-list{grid-gap:var(--space-6);display:grid;gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(350px,1fr));padding:0}.singer-item{background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:var(--space-6);transition:all var(--transition-normal)}.singer-item:hover{border-color:var(--accent-gold);box-shadow:var(--shadow-md);transform:translateY(-2px)}.singer-item h3{color:var(--text-primary);font-size:var(--text-lg);font-weight:var(--font-semibold);margin:0 0 var(--space-3) 0}.singer-item p{color:var(--text-secondary);font-size:var(--text-sm);line-height:1.6;margin:0 0 var(--space-4) 0}.singer-item p strong{color:var(--text-primary);font-weight:var(--font-medium)}.singer-actions{border-top:1px solid var(--border-light);display:flex;gap:var(--space-2);margin-top:var(--space-4);padding-top:var(--space-4)}.delete-button,.edit-button,.events-toggle-button{background:none;border:1px solid var(--border-light);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);padding:var(--space-2) var(--space-3);transition:all var(--transition-fast)}.events-toggle-button{flex:1 1}.edit-button:hover,.events-toggle-button:hover{background-color:#b683181a;border-color:var(--accent-gold);color:var(--accent-gold)}.delete-button:hover{background-color:#ef44441a;border-color:var(--status-error);color:var(--status-error)}.trash-icon{font-size:14px}.events-dropdown{background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);margin-top:var(--space-4);padding:var(--space-4)}.events-dropdown h4{color:var(--text-primary);font-size:var(--text-base);font-weight:var(--font-semibold);margin:0 0 var(--space-3) 0}.events-dropdown ul{list-style:none;margin:0;padding:0}.events-dropdown li{background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-md);font-size:var(--text-sm);line-height:1.6;margin-bottom:var(--space-2);padding:var(--space-3)}.events-dropdown li:last-child{margin-bottom:0}.see-all-button{background-color:var(--accent-gold);border:none;border-radius:var(--radius-md);color:var(--text-white);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);margin-top:var(--space-3);padding:var(--space-2) var(--space-4);transition:all var(--transition-fast);width:100%}.see-all-button:hover{background-color:var(--accent-gold-dark);transform:translateY(-1px)}.back-button{align-items:center;background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);color:var(--text-primary);cursor:pointer;display:inline-flex;font-size:var(--text-sm);font-weight:var(--font-medium);gap:var(--space-2);margin-bottom:var(--space-6);padding:var(--space-3) var(--space-4);transition:all var(--transition-fast)}.back-button:hover{background-color:var(--bg-tertiary);border-color:var(--accent-gold);transform:translateX(-2px)}.back-icon{font-size:16px}.popup-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#00000080;display:flex;inset:0;justify-content:center;position:fixed;z-index:var(--z-modal-backdrop)}.popup-content{background-color:var(--bg-card);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);max-height:80vh;max-width:500px;overflow-y:auto;padding:var(--space-6);width:90%;z-index:var(--z-modal)}.popup-content h2{border-bottom:1px solid var(--border-light);color:var(--text-primary);font-size:var(--text-xl);font-weight:var(--font-semibold);margin:0 0 var(--space-6) 0;padding-bottom:var(--space-3)}.popup-content form{display:flex;flex-direction:column;gap:var(--space-4)}.popup-content label{display:flex;flex-direction:column;font-weight:var(--font-medium);gap:var(--space-2)}.popup-content input,.popup-content label{color:var(--text-primary);font-size:var(--text-sm)}.popup-content input{background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-3);transition:all var(--transition-fast)}.popup-content input:focus{background-color:var(--bg-card);border-color:var(--accent-gold);box-shadow:0 0 0 3px #b683181a;outline:none}.phone-number-row{display:flex;gap:var(--space-2);margin-bottom:var(--space-2)}.phone-input{flex:1 1}.remove-phone-button{background-color:var(--status-error);border:none;border-radius:var(--radius-md);color:var(--text-white);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);padding:var(--space-2) var(--space-3);transition:all var(--transition-fast)}.remove-phone-button:hover{background-color:#dc2626}.add-phone-button{background-color:var(--accent-gold);border:none;border-radius:var(--radius-md);color:var(--text-white);cursor:pointer;font-size:var(--text-sm);font-weight:var(--font-medium);margin-top:var(--space-2);padding:var(--space-2) var(--space-4);transition:all var(--transition-fast)}.add-phone-button:hover{background-color:var(--accent-gold-dark);transform:translateY(-1px)}.modal-actions{margin-top:var(--space-6)}.btn-cancel,.btn-submit{border:none;border-radius:var(--radius-lg);cursor:pointer;flex:1 1;font-size:var(--text-base);font-weight:var(--font-semibold);padding:var(--space-3) var(--space-6);transition:all var(--transition-fast)}.btn-submit{background-color:var(--accent-gold);color:var(--text-white)}.btn-submit:hover{background-color:var(--accent-gold-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-cancel{background-color:var(--bg-tertiary);border:1px solid var(--border-light);color:var(--text-primary)}.btn-cancel:hover{background-color:var(--bg-secondary)}.singers-list p{color:var(--text-secondary);font-size:var(--text-base);grid-column:1/-1;padding:var(--space-8);text-align:center}@media (max-width:768px){.singers-page-header{flex-direction:column;gap:var(--space-4)}.header-actions{align-self:stretch}.add-button,.header-actions .btn{flex:1 1;justify-content:center}.filters{flex-direction:column}.filters input{min-width:0;width:100%}.singers-list{gap:var(--space-4);grid-template-columns:1fr}.popup-content,.singer-item{padding:var(--space-4)}.popup-content{width:95%}}@media (max-width:480px){.singers-page-header h1{font-size:var(--text-2xl)}.singer-item h3{font-size:var(--text-base)}.singer-actions{flex-wrap:wrap}.events-toggle-button{flex:1 1 100%}}.user-management{background-color:var(--bg-primary);color:var(--text-primary);margin:0 auto;max-width:var(--max-content-width);padding:var(--space-5)}.user-management-header{align-items:center;background:linear-gradient(135deg,var(--accent-blue) 0,var(--accent-purple) 100%);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);color:var(--text-white);display:flex;justify-content:space-between;margin-bottom:var(--space-5);padding:var(--space-5)}.user-management-header h2{font-size:var(--text-2xl);font-weight:var(--font-semibold);margin:0}.loading{color:var(--text-muted);font-size:var(--text-lg);padding:var(--space-10);text-align:center}.error-message,.success-message{margin-bottom:var(--space-5);padding:var(--space-3) var(--space-4)}.success-message{background-color:var(--status-success-bg);border:1px solid var(--status-success);border-radius:var(--radius-lg);color:var(--status-success);font-weight:var(--font-medium)}.users-table-container{background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);margin-bottom:var(--space-5);overflow:hidden}.users-table{border-collapse:collapse;font-size:var(--text-sm);width:100%}.users-table thead{background:linear-gradient(135deg,var(--bg-tertiary) 0,var(--bg-secondary) 100%)}.users-table th{border-bottom:2px solid var(--border-light);color:var(--text-primary);font-size:var(--text-xs);font-weight:var(--font-semibold);letter-spacing:.5px;padding:var(--space-4) var(--space-3);text-align:left;text-transform:uppercase}.users-table td{border-bottom:1px solid var(--border-light);color:var(--text-primary);padding:var(--space-3);vertical-align:middle}.users-table tbody tr:hover{background-color:var(--bg-tertiary);transition:background-color var(--transition-fast)}.inactive-user{background-color:var(--bg-tertiary);opacity:.6}.role-badge{border-radius:var(--radius-lg);font-size:var(--text-xs);font-weight:var(--font-semibold);letter-spacing:.5px;padding:var(--space-1) var(--space-2);text-transform:uppercase}.role-badge.admin{background-color:var(--status-warning-bg);color:var(--status-warning)}.role-badge.contract_user{background-color:var(--status-info-bg);color:var(--status-info)}.status-badge{border-radius:var(--radius-lg);font-size:var(--text-xs);font-weight:var(--font-semibold);letter-spacing:.5px;padding:var(--space-1) var(--space-2);text-transform:uppercase}.status-badge.active{background-color:var(--status-success-bg);color:var(--status-success)}.status-badge.inactive{background-color:var(--status-error-bg);color:var(--status-error)}.current-user-badge{background-color:var(--accent-blue);border-radius:var(--radius-lg);color:var(--text-white);font-size:var(--text-xs);font-weight:var(--font-semibold);padding:var(--space-1) var(--space-2)}.action-buttons{align-items:center;display:flex;gap:var(--space-2)}.action-buttons .btn{align-items:center;border:none;border-radius:var(--radius-md);cursor:pointer;display:flex;font-size:var(--text-sm);height:36px;justify-content:center;min-width:36px;padding:var(--space-2);transition:all var(--transition-fast)}.action-buttons .btn:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary{background-color:var(--bg-secondary);border:1px solid var(--border-light);color:var(--text-primary)}.btn-warning{background-color:var(--status-warning);color:var(--text-white)}.btn-success{background-color:var(--status-success)}.btn-info,.btn-success{color:var(--text-white)}.btn-info{background-color:var(--status-info)}.btn-danger{background-color:var(--status-error);color:var(--text-white)}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:var(--z-modal-backdrop)}.modal{background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-height:90vh;max-width:500px;overflow-y:auto;padding:var(--space-6);width:90%}.modal-small{max-width:400px}.modal-header{align-items:center;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;margin-bottom:var(--space-5);padding-bottom:var(--space-4)}.modal-header h3{color:var(--text-primary);font-size:var(--text-xl);font-weight:var(--font-semibold);margin:0}.modal-close{background:none;border:none;border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;font-size:var(--text-xl);padding:var(--space-1);transition:all var(--transition-fast)}.modal-close:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.modal-body{padding:24px}.modal-actions{border-top:1px solid var(--border-light);display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-5);padding-top:var(--space-4)}.form-group{margin-bottom:var(--space-4)}.form-group label{color:var(--text-primary);display:block;font-weight:var(--font-medium);margin-bottom:var(--space-2)}.form-group input,.form-group select{background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--text-sm);padding:var(--space-3);transition:border-color var(--transition-fast);width:100%}.form-group input:focus,.form-group select:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-actions{border-top:1px solid var(--border-light);display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-5);padding-top:var(--space-4)}.warning{color:#dc3545;font-size:.9rem;font-weight:500;margin-top:8px}.delete-modal{text-align:center}.delete-modal h3{color:var(--status-error);margin-bottom:var(--space-3)}.delete-modal p{color:var(--text-secondary);margin-bottom:var(--space-5)}.delete-modal .modal-actions{display:flex;gap:var(--space-3);justify-content:center}.btn{align-items:center;border:none;border-radius:var(--radius-lg);cursor:pointer;display:inline-flex;font-family:inherit;font-size:var(--text-sm);font-weight:var(--font-medium);justify-content:center;padding:var(--space-3) var(--space-4);text-decoration:none;transition:all var(--transition-fast)}.btn:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn-sm{font-size:var(--text-xs);height:32px;min-width:32px;padding:var(--space-2) var(--space-3)}.btn-primary{background:linear-gradient(135deg,var(--accent-blue) 0,var(--accent-purple) 100%);color:var(--text-white);font-size:var(--text-sm);padding:var(--space-3) var(--space-5)}@media (max-width:1200px){.users-table{font-size:.8rem}.users-table td,.users-table th{padding:10px 8px}}@media (max-width:768px){.user-management{padding:var(--space-3)}.user-management-header{flex-direction:column;gap:var(--space-3);text-align:center}.user-management-header h2{font-size:1.5rem}.users-table-container{overflow-x:auto}.users-table{min-width:800px}.action-buttons{flex-wrap:wrap;gap:var(--space-1)}.action-buttons .btn{font-size:var(--text-xs);height:32px;min-width:32px}.modal{margin:var(--space-3);padding:var(--space-4)}}@media (max-width:480px){.users-table td,.users-table th{font-size:.75rem;padding:8px 6px}.btn-sm{font-size:.7rem;height:28px;min-width:28px;padding:4px 6px}.role-badge,.status-badge{font-size:.7rem;padding:2px 6px}}.login-page{align-items:center;background-color:var(--bg-primary);display:flex;font-family:var(--font-family);justify-content:center;min-height:100vh;overflow:hidden;padding:var(--space-4);position:relative}.login-container{background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);max-width:400px;padding:var(--space-12);position:relative;width:100%;z-index:1}.login-header{margin-bottom:var(--space-8);text-align:center}.login-logo{align-items:center;background-color:var(--accent-gold);border-radius:var(--radius-xl);display:flex;font-size:2rem;height:80px;justify-content:center;margin:0 auto var(--space-4);overflow:hidden;width:80px}.login-logo .logo-image{border-radius:var(--radius-xl);height:100%;object-fit:cover;width:100%}.login-title{color:var(--text-primary);font-size:var(--text-2xl);font-weight:var(--font-semibold);letter-spacing:.02em;margin:0 0 var(--space-2) 0}.login-subtitle{color:var(--text-secondary);font-size:var(--text-base);font-weight:var(--font-normal);margin:0}.login-form{display:flex;flex-direction:column;gap:var(--space-6)}.form-group{position:relative}.form-label{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);margin-bottom:var(--space-2)}.form-input,.form-label{color:var(--text-primary)}.form-input{background-color:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);font-size:var(--text-base);outline:none;padding:var(--space-4);transition:all var(--transition-normal);width:100%}.form-input:focus{background-color:var(--bg-card);border-color:var(--accent-gold)}.form-input::placeholder{color:var(--text-muted)}.login-button{background-color:var(--accent-gold);border:none;border-radius:var(--radius-lg);color:var(--text-white);cursor:pointer;font-size:var(--text-base);font-weight:var(--font-semibold);overflow:hidden;padding:var(--space-4);position:relative;transition:all var(--transition-normal);width:100%}.login-button:hover{background-color:var(--accent-gold-light);transform:translateY(-1px)}.login-button:disabled{cursor:not-allowed;opacity:.5;transform:none}.login-button:disabled:hover{background-color:var(--accent-gold);transform:none}.error-message{background-color:var(--status-error-bg);border:1px solid var(--status-error);border-radius:var(--radius-lg);color:var(--status-error);font-size:var(--text-sm);font-weight:var(--font-medium);margin-top:var(--space-4);padding:var(--space-4);text-align:center}.login-footer{border-top:1px solid var(--border-light);margin-top:var(--space-8);padding-top:var(--space-6);text-align:center}.login-footer p{color:var(--text-secondary);font-size:var(--text-sm);margin:0}.loading-spinner{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:20px;margin-right:var(--space-2);width:20px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){.login-page{padding:var(--space-4)}.login-container{max-width:360px;padding:var(--space-8)}.login-logo{font-size:1.5rem;height:60px;width:60px}.login-title{font-size:var(--text-xl)}.login-subtitle{font-size:var(--text-sm)}}@media (max-width:480px){.login-container{border-radius:var(--radius-lg);padding:var(--space-6)}.login-title{font-size:var(--text-lg)}.form-input,.login-button{padding:var(--space-3)}}.login-container{animation:slideUp .4s cubic-bezier(.4,0,.2,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.form-input:focus,.login-button:focus{outline:2px solid var(--accent-gold);outline-offset:2px}
/*# sourceMappingURL=main.c1d8b378.css.map*/