:root{--color-primary: #4CAF50;--color-primary-dark: #388E3C;--color-primary-light: #81C784;--color-secondary: #2196F3;--color-secondary-dark: #1976D2;--color-secondary-light: #64B5F6;--color-white: #FFFFFF;--color-gray-50: #FAFAFA;--color-gray-100: #F5F5F5;--color-gray-200: #EEEEEE;--color-gray-300: #E0E0E0;--color-gray-400: #BDBDBD;--color-gray-500: #9E9E9E;--color-gray-600: #757575;--color-gray-700: #616161;--color-gray-800: #424242;--color-gray-900: #212121;--color-black: #000000;--color-success: #4CAF50;--color-error: #F44336;--color-warning: #FF9800;--color-info: #2196F3;--font-family-base: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-family-mono: "Courier New", monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--transition-fast: .15s ease-in-out;--transition-base: .25s ease-in-out;--transition-slow: .35s ease-in-out;--container-max-width: 1200px;--content-max-width: 800px;--sidebar-width: 250px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family-base);font-size:var(--font-size-base);line-height:1.6;color:var(--color-gray-900);background-color:var(--color-gray-50);min-height:100vh}h1,h2,h3,h4,h5,h6{line-height:1.2;font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-md);color:var(--color-gray-900)}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}p{margin-bottom:var(--spacing-md)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-dark)}.container{max-width:var(--container-max-width);margin:0 auto;padding:0 var(--spacing-md)}.content-wrapper{max-width:var(--content-max-width);margin:0 auto;padding:var(--spacing-xl) var(--spacing-md)}.btn{display:inline-block;padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);text-align:center;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--color-primary);color:var(--color-white)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-dark)}.btn-secondary{background-color:var(--color-secondary);color:var(--color-white)}.btn-secondary:hover:not(:disabled){background-color:var(--color-secondary-dark)}.btn-danger{background-color:var(--color-error);color:var(--color-white)}.btn-danger:hover:not(:disabled){background-color:#d32f2f}.card{background-color:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-xl);margin-bottom:var(--spacing-lg)}.card-title{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-md)}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;margin-bottom:var(--spacing-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-700)}.form-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-base);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);transition:border-color var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #4caf501a}.form-input::placeholder{color:var(--color-gray-400)}.alert{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);border:1px solid transparent}.alert-success{background-color:#e8f5e9;color:#2e7d32;border-color:#4caf50}.alert-error{background-color:#ffebee;color:#c62828;border-color:#f44336}.alert-warning{background-color:#fff3e0;color:#e65100;border-color:#ff9800}.alert-info{background-color:#e3f2fd;color:#1565c0;border-color:#2196f3}.loading{display:flex;justify-content:center;align-items:center;min-height:200px}.spinner{border:4px solid var(--color-gray-200);border-top:4px solid var(--color-primary);border-radius:var(--radius-full);width:40px;height:40px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-muted{color:var(--color-gray-600)}.text-bold{font-weight:var(--font-weight-bold)}.mt-sm{margin-top:var(--spacing-sm)}.mt-md{margin-top:var(--spacing-md)}.mt-lg{margin-top:var(--spacing-lg)}.mt-xl{margin-top:var(--spacing-xl)}.mb-sm{margin-bottom:var(--spacing-sm)}.mb-md{margin-bottom:var(--spacing-md)}.mb-lg{margin-bottom:var(--spacing-lg)}.mb-xl{margin-bottom:var(--spacing-xl)}.d-flex{display:flex}.justify-center{justify-content:center}.align-center{align-items:center}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.navbar{background-color:var(--color-gray-900);box-shadow:var(--shadow-md);position:sticky;top:0;z-index:1000}.navbar-container{max-width:var(--container-max-width);margin:0 auto;padding:var(--spacing-md) var(--spacing-lg);display:flex;justify-content:space-between;align-items:center}.navbar-logo{color:var(--color-white);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);text-decoration:none;transition:color var(--transition-fast)}.navbar-logo:hover{color:var(--color-primary-light)}.navbar-links{display:flex;gap:var(--spacing-xl);align-items:center}.navbar-link{color:var(--color-white);text-decoration:none;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);transition:color var(--transition-fast);position:relative}.navbar-link:hover{color:var(--color-primary-light)}.navbar-link.active{color:var(--color-white);background-color:var(--color-primary)}.navbar-logout-btn{background-color:var(--color-error);color:var(--color-white);border:none;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);line-height:1.6;cursor:pointer;transition:background-color var(--transition-fast)}.navbar-logout-btn:hover{background-color:#d32f2f}@media(max-width:768px){.navbar-container{flex-direction:column;gap:var(--spacing-md)}.navbar-links{flex-wrap:wrap;justify-content:center;gap:var(--spacing-md)}}.home-container{max-width:var(--content-max-width);margin:0 auto;padding:var(--spacing-2xl) var(--spacing-md)}.home-title{text-align:center;color:var(--color-gray-900);margin-bottom:var(--spacing-lg)}.home-subtitle{font-size:var(--font-size-lg);text-align:center;color:var(--color-gray-600);margin-bottom:var(--spacing-2xl)}.home-card{background-color:var(--color-gray-100);padding:var(--spacing-2xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.home-list{margin-top:var(--spacing-md);line-height:1.8;padding-left:var(--spacing-lg)}.home-list li{margin-bottom:var(--spacing-sm)}.auth-page{min-height:calc(100vh - 80px);display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl) var(--spacing-md)}.auth-card{background-color:var(--color-white);padding:var(--spacing-2xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:450px}.auth-title{text-align:center;color:var(--color-gray-900);margin-bottom:var(--spacing-xl);font-size:var(--font-size-3xl)}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.auth-submit-btn{width:100%;padding:var(--spacing-md);font-size:var(--font-size-lg);margin-top:var(--spacing-md)}.auth-footer{text-align:center;margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--color-gray-200);color:var(--color-gray-600);font-size:var(--font-size-sm)}.auth-footer-link{color:var(--color-primary);font-weight:var(--font-weight-semibold);text-decoration:none;transition:color var(--transition-fast)}.auth-footer-link:hover{color:var(--color-primary-dark);text-decoration:underline}.signup-page .form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4caf501a}.signup-page .auth-footer-link{color:var(--color-primary)}.signup-page .auth-footer-link:hover{color:var(--color-primary-dark)}.login-page .form-input:focus{border-color:var(--color-secondary);box-shadow:0 0 0 3px #2196f31a}.login-page .auth-footer-link{color:var(--color-secondary)}.login-page .auth-footer-link:hover{color:var(--color-secondary-dark)}.dashboard-container{max-width:var(--content-max-width);margin:0 auto;padding:var(--spacing-2xl) var(--spacing-md)}.dashboard-title{text-align:center;color:var(--color-gray-900);margin-bottom:var(--spacing-xl)}.dashboard-card-success{background-color:#e8f5e9;padding:var(--spacing-xl);border-radius:var(--radius-lg);border:2px solid var(--color-success);margin-bottom:var(--spacing-xl);text-align:center}.dashboard-card-user{background-color:var(--color-white);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin-bottom:var(--spacing-xl)}.dashboard-user-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.dashboard-user-avatar{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:var(--font-weight-bold);font-size:var(--font-size-lg);flex-shrink:0;box-shadow:var(--shadow-md)}.dashboard-user-header h3{margin:0;color:var(--color-gray-900);font-size:var(--font-size-2xl)}.dashboard-user-info{margin-top:var(--spacing-md);line-height:1.8;background-color:var(--color-gray-50);padding:var(--spacing-md);border-radius:var(--radius-md)}.dashboard-user-info p{margin-bottom:var(--spacing-sm)}.dashboard-card-features{background-color:#e3f2fd;padding:var(--spacing-xl);border-radius:var(--radius-lg);border:1px solid var(--color-info);margin-bottom:var(--spacing-xl)}.dashboard-card-tips{background-color:#fff3e0;padding:var(--spacing-xl);border-radius:var(--radius-lg);border:1px solid var(--color-warning)}.dashboard-list{margin-top:var(--spacing-md);line-height:2;padding-left:var(--spacing-lg)}.dashboard-list li{margin-bottom:var(--spacing-sm)}.schedule-page{max-width:1400px;margin:0 auto;padding:var(--spacing-xl) var(--spacing-md)}.schedule-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2xl);padding-bottom:var(--spacing-lg);border-bottom:2px solid var(--color-gray-200)}.schedule-header h1{margin:0;color:var(--color-gray-900);font-size:var(--font-size-3xl)}.schedule-content{margin-top:var(--spacing-xl)}.schedule-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:var(--spacing-md);margin-top:var(--spacing-xl)}.day-column{background-color:var(--color-white);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden;min-height:400px}.day-header{background-color:var(--color-gray-100);padding:var(--spacing-md);text-align:center;border-bottom:2px solid var(--color-gray-200)}.day-header h3{margin:0;font-size:var(--font-size-lg);color:var(--color-gray-800);font-weight:var(--font-weight-semibold)}.shifts-container{padding:var(--spacing-sm)}.no-shifts{padding:var(--spacing-xl) var(--spacing-md);text-align:center;color:var(--color-gray-400);font-style:italic;font-size:var(--font-size-sm)}.shift-card{background-color:var(--color-white);border:2px solid var(--color-gray-200);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-sm);transition:all var(--transition-normal);cursor:pointer;position:relative}.shift-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.shift-card-time{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);font-weight:var(--font-weight-semibold);color:var(--color-gray-800);margin-bottom:var(--spacing-sm);font-size:var(--font-size-sm)}.time-separator{color:var(--color-gray-400)}.shift-card-worker{margin-top:var(--spacing-sm)}.worker-info{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs);background-color:var(--color-gray-50);border-radius:var(--radius-sm)}.worker-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:var(--font-weight-bold);font-size:var(--font-size-xs);flex-shrink:0;box-shadow:var(--shadow-sm)}.worker-name{font-size:var(--font-size-sm);color:var(--color-gray-700);font-weight:var(--font-weight-medium);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shift-open-badge{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--color-gray-100);border:1px dashed var(--color-gray-300);border-radius:var(--radius-sm);color:var(--color-gray-600);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.open-icon{font-size:var(--font-size-md);color:var(--color-gray-400)}.shift-card-details{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-gray-200);font-size:var(--font-size-sm)}.detail-row{margin-bottom:var(--spacing-xs);color:var(--color-gray-700)}.detail-row strong{color:var(--color-gray-900);margin-right:var(--spacing-xs)}.admin-actions{display:flex;gap:var(--spacing-xs);margin-top:var(--spacing-sm)}.btn-small{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs);border:none;border-radius:var(--radius-sm);cursor:pointer;font-weight:var(--font-weight-medium);transition:all var(--transition-fast)}.btn-small.btn-secondary{background-color:var(--color-secondary);color:#fff}.btn-small.btn-secondary:hover{background-color:var(--color-secondary-dark)}.btn-small.btn-danger{background-color:#f44336;color:#fff}.btn-small.btn-danger:hover{background-color:#d32f2f}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.modal-content{background-color:var(--color-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-lg);border-bottom:1px solid var(--color-gray-200)}.modal-header h2{margin:0;font-size:var(--font-size-2xl);color:var(--color-gray-900)}.modal-close{background:none;border:none;font-size:var(--font-size-2xl);color:var(--color-gray-400);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.modal-close:hover{background-color:var(--color-gray-100);color:var(--color-gray-600)}.modal-body{padding:var(--spacing-lg)}.modal-header-content{flex-grow:1}.modal-header-content h2{margin:0 0 var(--spacing-xs) 0}.modal-shift-info{margin:0;font-size:var(--font-size-xl);color:var(--color-gray-900);font-weight:var(--font-weight-bold)}.modal-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end;padding:var(--spacing-lg);border-top:1px solid var(--color-gray-200);background-color:var(--color-gray-50)}.shift-info-box{background-color:var(--color-gray-50);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);text-align:center}.shift-info-box h3{margin:0 0 var(--spacing-xs) 0;color:var(--color-gray-900);font-size:var(--font-size-xl)}.shift-info-box p{margin:0;color:var(--color-gray-600);font-size:var(--font-size-md)}.current-assignment{margin-bottom:var(--spacing-lg)}.current-assignment strong{display:block;margin-bottom:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-gray-700)}.current-assignment-inline{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.current-assignment-inline strong{font-size:var(--font-size-sm);color:var(--color-gray-700);white-space:nowrap}.worker-badge-with-actions{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-white);border-radius:var(--radius-md);border:1px solid var(--color-gray-200);flex-grow:1}.worker-info-compact{display:flex;align-items:center;gap:var(--spacing-sm);flex-grow:1}.worker-actions{display:flex;gap:var(--spacing-xs);margin-left:auto}.btn-icon{background:none;border:none;cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm);font-size:var(--font-size-lg);display:flex;align-items:center;justify-content:center;width:28px;height:28px;transition:all var(--transition-fast)}.btn-icon-danger{color:var(--color-white);background-color:var(--color-error)}.btn-icon-danger:hover:not(:disabled){background-color:#d32f2f}.btn-icon-primary{color:var(--color-primary)}.btn-icon-primary:hover:not(:disabled){background-color:#4caf501a}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.worker-badge{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-white);border-radius:var(--radius-md);border:1px solid var(--color-gray-200)}.worker-avatar-small{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:var(--font-weight-bold);font-size:10px;flex-shrink:0}.unassign-section{text-align:center}.helper-text{color:var(--color-gray-600);font-size:var(--font-size-sm);margin-bottom:var(--spacing-lg)}.btn-full{width:100%}.btn-danger{background-color:#f44336;color:#fff;border:none;padding:var(--spacing-md);border-radius:var(--radius-md);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast)}.btn-danger:hover{background-color:#d32f2f}.btn-danger:disabled{background-color:var(--color-gray-300);cursor:not-allowed}.assign-form .form-group{margin-bottom:var(--spacing-lg)}.loading-small{padding:var(--spacing-md);text-align:center;color:var(--color-gray-500);font-size:var(--font-size-sm)}.delete-shift-section{padding-top:var(--spacing-md)}.delete-shift-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-error);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-md)}.shift-form{padding:var(--spacing-lg)}.shift-form .form-group{margin-bottom:var(--spacing-lg)}.shift-form .form-label{display:block;margin-bottom:var(--spacing-sm);font-weight:var(--font-weight-semibold);color:var(--color-gray-700)}.shift-form .form-input,.shift-form select{width:100%;padding:var(--spacing-md);border:1px solid var(--color-gray-300);border-radius:var(--radius-md);font-size:var(--font-size-md);transition:all var(--transition-fast)}.shift-form .form-input:focus,.shift-form select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #4caf501a}.shift-form select{cursor:pointer;background-color:var(--color-white)}.shift-form .alert{margin-top:var(--spacing-md)}@media(max-width:1200px){.schedule-grid{grid-template-columns:repeat(4,1fr)}}@media(max-width:768px){.schedule-grid{grid-template-columns:repeat(2,1fr)}.day-column{min-height:300px}}@media(max-width:480px){.schedule-grid{grid-template-columns:1fr}.schedule-header{flex-direction:column;gap:var(--spacing-md)}.schedule-header h1{font-size:var(--font-size-2xl)}}
