body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}body{font-family:Arial,sans-serif;height:100vh;margin:0;overflow-x:hidden;padding:0}.menu-container{box-sizing:border-box;flex-direction:column;min-height:100vh;overflow-x:hidden;padding:20px 0;position:relative}.menu-container,.menu-header{align-items:center;display:flex;justify-content:center}.menu-header{margin-bottom:20px;transition:all .3s ease;width:100%}.menu-logo{height:60px}@media screen and (max-width:768px){.menu-logo{height:100px}}.flipbook-wrapper{display:block!important;margin:0 auto;position:relative;width:350px}.menu-book{background:#0000!important;border-radius:12px;box-shadow:0 8px 24px #0003;margin:0 auto!important;max-width:100%}.stf__parent{left:0!important;right:0!important;transform:none!important}.stf__parent,.stf__wrapper{margin:0 auto!important;position:relative!important}.menu-page{align-items:center;background-color:#fffaf6;display:flex;flex-direction:column;justify-content:center;padding:20px;text-align:center}.menu-image-page{background-position:50%;background-size:cover;border-radius:8px;height:100%;width:100%}.menu-single-column{color:#3e2723;font-family:Barlow,sans-serif;font-size:9px;left:80px;line-height:1.2;position:absolute;right:40px;top:80px}.menu-single-column h2{margin-left:-8px;margin-top:36px;padding-left:0;text-align:left}.menu-single-column ul{list-style:none;margin:0;padding:0}.menu-single-column li{display:flex;font-weight:1000;margin-bottom:0}.menu-overlay{background-position:50%;background-repeat:no-repeat;background-size:cover;height:100%;position:relative;width:100%}.menu-text{color:#3e2723;font-family:Barlow,sans-serif;font-size:20px;left:50px;line-height:1.5;position:absolute;text-align:left;top:100px}.cover-logo{height:60px;margin:10px 0}.nav-arrow{background:#fffc;border:none;border-radius:50%;box-shadow:0 2px 6px #0000001a;color:#5c452b;cursor:pointer;font-size:2rem;height:40px;position:fixed;top:50%;transform:translateY(-50%);transition:background .2s ease;width:40px;z-index:1000}.nav-arrow:hover{background:#f3e8dc}.nav-arrow.left{left:10px}.nav-arrow.right{right:10px}@media screen and (max-width:768px){.nav-arrow.left{left:10px}.nav-arrow.right{right:10px}.nav-arrow{font-size:1.5rem;height:35px;width:35px}}.login-page{align-items:center;background:#f3f4f6;display:flex;justify-content:center;min-height:100vh;padding:1rem}.login-card{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 10px 15px #0000000d;max-width:400px;padding:2rem 2.5rem;width:100%}.login-title{color:#1d4ed8;font-size:1.875rem;font-weight:800;margin-bottom:1.5rem;text-align:center}.login-error{color:#dc2626;font-size:.875rem;text-align:center}.login-error,.login-group{margin-bottom:1rem}.login-group label{color:#374151;display:block;font-size:.875rem;margin-bottom:.25rem}.login-group input{border:1px solid #d1d5db;border-radius:.375rem;font-size:1rem;padding:.5rem .75rem;width:100%}.login-group input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f64d;outline:none}.login-button{background:linear-gradient(90deg,#3b82f6,#1e40af);border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem;transition:background .2s ease-in-out,box-shadow .2s ease-in-out;width:100%}.login-button:hover{background:linear-gradient(90deg,#2563eb,#1e3a8a);box-shadow:0 4px 6px #0000001a}:root{--bg-primary:#fafbfc;--bg-card:#fff;--bg-sidebar:#fff;--text-primary:#1a202c;--text-secondary:#4a5568;--text-muted:#718096;--accent-primary:#2563eb;--accent-secondary:#3b82f6;--accent-green:#059669;--accent-red:#dc2626;--accent-orange:#d97706;--accent-yellow:#ca8a04;--border-color:#e5e7eb;--border-light:#f3f4f6;--shadow-sm:0 1px 2px 0 #00000008;--shadow-md:0 4px 6px -1px #0000000f,0 2px 4px -2px #0000000a;--shadow-lg:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000f;--shadow-xl:0 20px 25px -5px #00000014,0 10px 10px -5px #0000000a;--radius-sm:0.375rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--font-sans:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif}.dark-mode{--bg-primary:#0f1419;--bg-card:#1a202c;--bg-sidebar:#1a202c;--text-primary:#f7fafc;--text-secondary:#cbd5e0;--text-muted:#718096;--border-color:#2d3748;--border-light:#2d3748}*{margin:0;padding:0}body{background-color:#fafbfc;background-color:var(--bg-primary);color:#1a202c;color:var(--text-primary);font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-family:var(--font-sans);line-height:1.6;transition:background-color .3s cubic-bezier(.4,0,.2,1),color .3s cubic-bezier(.4,0,.2,1)}.app{display:flex;min-height:100vh}.main-content{flex:1 1;margin-left:280px;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}@media (max-width:768px){.main-content{margin-left:0}}.sidebar{background-color:#fff;background-color:var(--bg-sidebar);border-right:1px solid #e5e7eb;border-right:1px solid var(--border-color);box-shadow:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000f;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;height:100vh;left:0;position:fixed;top:0;transition:transform .3s cubic-bezier(.4,0,.2,1);width:280px;z-index:100}.sidebar.closed{transform:translateX(-100%)}.sidebar-header{border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light);padding:2rem 1.5rem 1.5rem}.logo{align-items:center;display:flex;gap:.75rem;margin-bottom:1.5rem}.logo h1{color:#2563eb;color:var(--accent-primary);font-size:1.5rem;font-weight:700;letter-spacing:-.025em}.user-info{display:flex;flex-direction:column;gap:.375rem}.username{color:#1a202c;color:var(--text-primary);font-size:.95rem;font-weight:600}.status{align-items:center;color:#4a5568;color:var(--text-secondary);display:flex;font-size:.8rem;font-weight:500;gap:.5rem}.status-dot{background-color:#059669;background-color:var(--accent-green);border-radius:50%;box-shadow:0 0 0 2px #05966933;height:.5rem;width:.5rem}.sidebar-menu{flex:1 1;overflow-y:auto;padding:1rem 0;scroll-behavior:smooth}.sidebar-menu ul{list-style:none;padding:0 1rem}.sidebar-menu li{align-items:center;border-radius:.75rem;border-radius:var(--radius-lg);color:#4a5568;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.9rem;font-weight:500;margin:.125rem 0;padding:.875rem 1rem;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1)}.sidebar-menu li:hover{background-color:#2563eb14;color:#2563eb;color:var(--accent-primary);transform:translateX(2px)}.sidebar-menu li.active{background-color:#2563eb;background-color:var(--accent-primary);box-shadow:0 4px 6px -1px #0000000f,0 2px 4px -2px #0000000a;box-shadow:var(--shadow-md);color:#fff;font-weight:600;transform:translateX(0)}.sidebar-menu li.active:before{background-color:#3b82f6;background-color:var(--accent-secondary);border-radius:0 2px 2px 0;content:"";height:20px;left:-1rem;position:absolute;top:50%;transform:translateY(-50%);width:4px}.menu-icon{align-items:center;display:flex;height:20px;justify-content:center;margin-right:.75rem;width:20px}.sidebar-footer{border-top:1px solid #f3f4f6;border-top:1px solid var(--border-light);padding:1rem 1.5rem 1.5rem}.logout-button{align-items:center;background-color:initial;border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:.75rem;border-radius:var(--radius-lg);color:#4a5568;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.9rem;font-weight:500;justify-content:center;padding:.875rem 1rem;transition:all .2s cubic-bezier(.4,0,.2,1);width:100%}.logout-button:hover{background-color:#dc2626;background-color:var(--accent-red);border-color:#dc2626;border-color:var(--accent-red);box-shadow:0 4px 6px -1px #0000000f,0 2px 4px -2px #0000000a;box-shadow:var(--shadow-md);color:#fff;transform:translateY(-1px)}.logout-button svg{margin-right:.5rem}.sidebar-toggle{align-items:center;background-color:#2563eb;background-color:var(--accent-primary);border:none;border-radius:1rem;border-radius:var(--radius-xl);box-shadow:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000f;box-shadow:var(--shadow-lg);color:#fff;cursor:pointer;display:flex;height:2.75rem;justify-content:center;left:1rem;position:fixed;top:1rem;transition:all .2s cubic-bezier(.4,0,.2,1);width:2.75rem;z-index:150}.sidebar-toggle:hover{box-shadow:0 20px 25px -5px #00000014,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);transform:scale(1.05)}.sidebar-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0006;height:100%;left:0;position:fixed;top:0;width:100%;z-index:90}.dashboard-header{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background-color:#fff;background-color:var(--bg-card);border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light);box-shadow:0 1px 2px 0 #00000008;box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;padding:1.25rem 2rem}.search-bar{position:relative;width:350px}.search-bar input{background-color:#fafbfc;background-color:var(--bg-primary);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:1rem;border-radius:var(--radius-xl);color:#1a202c;color:var(--text-primary);font-size:.9rem;padding:.75rem 1rem .75rem 2.75rem;transition:all .2s cubic-bezier(.4,0,.2,1);width:100%}.search-bar input:focus{border-color:#2563eb;border-color:var(--accent-primary);box-shadow:0 0 0 3px #2563eb1a;outline:none}.search-bar svg{color:#718096;color:var(--text-muted);height:18px;left:1rem;position:absolute;top:50%;transform:translateY(-50%);width:18px}.header-actions{align-items:center;display:flex;gap:.75rem}.message-btn,.notification-btn,.settings-btn,.theme-toggle{align-items:center;background:none;border:none;border-radius:.75rem;border-radius:var(--radius-lg);color:#4a5568;color:var(--text-secondary);cursor:pointer;display:flex;height:2.5rem;justify-content:center;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1);width:2.5rem}.message-btn:hover,.notification-btn:hover,.settings-btn:hover,.theme-toggle:hover{background-color:#2563eb14;color:#2563eb;color:var(--accent-primary);transform:scale(1.05)}.badge{align-items:center;background-color:#dc2626;background-color:var(--accent-red);border:2px solid #fff;border:2px solid var(--bg-card);border-radius:50%;color:#fff;display:flex;font-size:.7rem;font-weight:600;height:1.25rem;justify-content:center;position:absolute;right:-.25rem;top:-.25rem;width:1.25rem}.user-profile{margin-left:.5rem;position:relative}.avatar{border:2px solid #2563eb;border:2px solid var(--accent-primary);border-radius:50%;height:2.5rem;object-fit:cover;transition:transform .2s cubic-bezier(.4,0,.2,1);width:2.5rem}.avatar:hover{transform:scale(1.05)}.online-indicator{background-color:#059669;background-color:var(--accent-green);border:2px solid #fff;border:2px solid var(--bg-card);border-radius:50%;bottom:0;box-shadow:0 0 0 1px #05966933;height:.75rem;position:absolute;right:0;width:.75rem}.dashboard-container{margin:0 auto;max-width:1400px;padding:2rem}.loading-screen{align-items:center;background-color:#fafbfc;background-color:var(--bg-primary);color:#1a202c;color:var(--text-primary);display:flex;flex-direction:column;height:100vh;justify-content:center}.loading-spinner{animation:spin 1s ease-in-out infinite;border-top:3px solid var(--accent-primary)}.stats-row{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));margin-bottom:2rem}.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-md);display:flex}.stat-card:hover{box-shadow:var(--shadow-lg)}.stat-card.blue .stat-icon{background-color:#2563eb1a;color:#2563eb;color:var(--accent-primary)}.stat-card.green .stat-icon{background-color:#0596691a;color:#059669;color:var(--accent-green)}.stat-card.red .stat-icon{background-color:#dc26261a;color:#dc2626;color:var(--accent-red)}.stat-card.orange .stat-icon{background-color:#d977061a;color:#d97706;color:var(--accent-orange)}.stat-card.yellow .stat-icon{background-color:#ca8a041a;color:#ca8a04;color:var(--accent-yellow)}.stat-icon{align-items:center;border-radius:.75rem;border-radius:var(--radius-lg);display:flex;height:3.5rem;justify-content:center;margin-right:1.25rem;width:3.5rem}.stat-info h3{color:#4a5568;color:var(--text-secondary);font-size:.85rem;font-weight:600;letter-spacing:.025em;margin-bottom:.5rem;text-transform:uppercase}.stat-info h2{color:#1a202c;color:var(--text-primary);font-size:1.75rem;font-weight:700;margin-bottom:.375rem}.stat-change{align-items:center;display:flex;font-size:.8rem;font-weight:500;gap:.375rem}.positive{color:#059669;color:var(--accent-green)}.negative{color:#dc2626;color:var(--accent-red)}.period{color:#718096;color:var(--text-muted)}.dashboard-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(12,1fr)}.dashboard-card{background-color:#fff;background-color:var(--bg-card);border:1px solid #f3f4f6;border:1px solid var(--border-light);border-radius:1rem;border-radius:var(--radius-xl);box-shadow:0 4px 6px -1px #0000000f,0 2px 4px -2px #0000000a;box-shadow:var(--shadow-md);overflow:hidden;transition:all .2s cubic-bezier(.4,0,.2,1)}.dashboard-card:hover{box-shadow:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000f;box-shadow:var(--shadow-lg)}.chart-section{grid-column:span 8}.performance-section{grid-column:span 4}.sales-chart,.subjects-section{grid-column:span 6}.task-list{grid-column:span 12}.card-header{align-items:center;background-color:#2563eb05;border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:1.5rem 1.75rem}.card-header h3{color:#1a202c;color:var(--text-primary);font-size:1.125rem;font-weight:600}.card-actions button{align-items:center;background:none;border:none;border-radius:.5rem;border-radius:var(--radius-md);color:#718096;color:var(--text-muted);cursor:pointer;display:flex;height:2rem;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);width:2rem}.card-actions button:hover{background-color:#2563eb1a;color:#2563eb;color:var(--accent-primary)}.card-content{padding:1.75rem}.progress-container{margin-bottom:1.5rem;width:100%}.progress-header{display:flex;font-size:.8rem;justify-content:space-between;margin-bottom:.75rem}.progress-title{color:#4a5568;color:var(--text-secondary);font-weight:500}.progress-value{color:#1a202c;color:var(--text-primary);font-weight:600}.progress-bar{background-color:#f3f4f6;background-color:var(--border-light);height:.625rem;overflow:hidden;width:100%}.progress-bar,.progress-fill{border-radius:.75rem;border-radius:var(--radius-lg)}.progress-fill{height:100%;transition:width .3s cubic-bezier(.4,0,.2,1)}.progress-fill.blue{background:linear-gradient(90deg,#2563eb,#3b82f6);background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary))}.progress-fill.green{background:linear-gradient(90deg,#059669,#10b981);background:linear-gradient(90deg,var(--accent-green),#10b981)}.progress-fill.orange{background:linear-gradient(90deg,#d97706,#f59e0b);background:linear-gradient(90deg,var(--accent-orange),#f59e0b)}.progress-fill.yellow{background:linear-gradient(90deg,#ca8a04,#eab308);background:linear-gradient(90deg,var(--accent-yellow),#eab308)}.task-headers{background-color:#2563eb05;border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light);color:#4a5568;color:var(--text-secondary);display:grid;font-size:.8rem;font-weight:600;grid-template-columns:50px 1fr 1fr 120px;letter-spacing:.025em;padding:1rem 1.75rem;text-transform:uppercase}.tasks-container{padding:.5rem 0}.task-item{align-items:center;border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light);display:grid;grid-template-columns:50px 1fr 1fr 120px;padding:1rem 1.75rem;transition:background-color .2s cubic-bezier(.4,0,.2,1)}.task-item:hover{background-color:#2563eb05}.task-item:last-child{border-bottom:none}.task-content h4{color:#1a202c;color:var(--text-primary);font-size:.9rem;font-weight:600;margin-bottom:.25rem}.task-content p{color:#4a5568;color:var(--text-secondary);font-size:.8rem}.task-actions{display:flex;gap:.5rem;justify-content:flex-end}.complete-btn,.edit-btn{align-items:center;border:none;border-radius:.5rem;border-radius:var(--radius-md);cursor:pointer;display:flex;font-size:.8rem;height:2rem;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);width:2rem}.edit-btn{background-color:#2563eb1a;color:#2563eb;color:var(--accent-primary)}.edit-btn:hover{background-color:#2563eb;background-color:var(--accent-primary);color:#fff;transform:scale(1.05)}.complete-btn{background-color:#0596691a;color:#059669;color:var(--accent-green)}.complete-btn:hover{transform:scale(1.05)}.complete-btn.completed,.complete-btn:hover{background-color:#059669;background-color:var(--accent-green);color:#fff}@media (max-width:1200px){.chart-section,.performance-section,.sales-chart,.subjects-section{grid-column:span 12}}@media (max-width:768px){.stats-row{gap:1rem;grid-template-columns:1fr}.dashboard-header{flex-direction:column;gap:1rem;padding:1rem}.search-bar{width:100%}.dashboard-container{padding:1rem}.task-headers,.task-item{grid-template-columns:40px 1fr 80px}.task-content p,.task-header-subject{display:none}.stat-card{padding:1.5rem}.card-content,.card-header{padding:1.25rem}}:root{--surface-bg:#fff;--surface-bg-alt:#f8f9fa;--border-color:#eaeaea;--text-default:#2c3e50;--text-muted:#7f8c8d;--primary:#3498db;--primary-hover:#2980b9;--success:#27ae60;--success-hover:#219653;--shadow-light:0 2px 10px #0000001a;--radius:8px;--spacing:1rem;--font-primary:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen,Ubuntu,Cantarell,"Open Sans","Helvetica Neue",sans-serif;--font-weight-normal:400;--font-weight-medium:500;--font-weight-bold:600}.menu-management{background:#fff;background:var(--surface-bg);border-radius:8px;border-radius:var(--radius);box-shadow:0 2px 10px #0000001a;box-shadow:var(--shadow-light);max-width:100%;overflow-x:hidden;padding:1rem;padding:var(--spacing);transition:transform .2s,box-shadow .2s}.menu-management:hover{box-shadow:0 4px 20px #00000014;transform:translateY(-2px)}.management-header{align-items:center;border-bottom:1px solid #eaeaea;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:1.25rem;margin-bottom:calc(var(--spacing)*1.25);padding-bottom:.75rem}.management-header h2{color:#2c3e50;color:var(--text-default);font-size:1.5rem;font-weight:600;margin:0}.add-button{background:#3498db;background:var(--primary);border-radius:8px;border-radius:var(--radius);display:inline-flex;max-width:fit-content;padding:.5rem 1rem;transition:background .3s,transform .2s;white-space:nowrap;width:auto}.add-button:hover{background:#2980b9;background:var(--primary-hover)}.error-message{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;border-radius:var(--radius);color:#721c24;margin-bottom:1rem;margin-bottom:var(--spacing);padding:12px}.empty-state,.loading{color:#7f8c8d;color:var(--text-muted);padding:40px}.empty-state{background-color:#f8f9fa;background-color:var(--surface-bg-alt);border:1px dashed #eaeaea;border:1px dashed var(--border-color);border-radius:6px;border-radius:calc(var(--radius) - 2px)}.menu-form{grid-gap:1rem;grid-gap:var(--spacing);background:#f8f9fa;background:var(--surface-bg-alt);border:1px solid #eaeaea;border:1px solid var(--border-color);border-radius:6px;border-radius:calc(var(--radius) - 2px);display:grid;gap:1rem;gap:var(--spacing);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:1rem;margin-bottom:var(--spacing);padding:1rem;padding:var(--spacing)}.menu-form h3{color:#2c3e50;color:var(--text-default);font-size:1.1rem;font-weight:500;grid-column:1/-1;margin:0 0 1rem;margin:0 0 var(--spacing) 0}.form-group{gap:.25rem}.form-group label{color:#2c3e50;color:var(--text-default)}.file-input,.form-group input[type=number],.form-group input[type=text]{border:1px solid #eaeaea;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);font-size:.9rem;padding:.5rem;transition:border-color .2s,box-shadow .2s;width:100%}.file-input:focus,.form-group input:focus{border-color:#3498db;border-color:var(--primary);box-shadow:0 0 0 2px #3498db33;outline:none}.checkbox-label{align-items:center;cursor:pointer;display:flex}.checkbox-label input{margin-right:8px}.form-actions{flex-wrap:wrap;gap:var(--spacing);margin-top:1rem;margin-top:var(--spacing)}button{border:none;border-radius:8px;border-radius:var(--radius);cursor:pointer;font-weight:500;transition:background .3s,transform .2s}.submit-button{background:#27ae60;background:var(--success);padding:.5rem 1rem}.submit-button:hover{background:#219653;background:var(--success-hover);transform:translateY(-1px)}.cancel-button{background:#95a5a6;color:#fff;padding:.5rem 1rem}.cancel-button:hover{background:#7f8c8d;transform:translateY(-1px)}.menu-pages-list{margin-top:1rem;margin-top:var(--spacing);overflow-x:auto;width:100%}.menu-pages-list table{border-collapse:collapse;min-width:650px;table-layout:fixed;width:100%}.menu-pages-list td,.menu-pages-list th{border-bottom:1px solid #eaeaea;border-bottom:1px solid var(--border-color);box-sizing:border-box;overflow:hidden;padding:.75rem 1rem;text-align:left;text-overflow:ellipsis;vertical-align:middle;white-space:nowrap}.menu-pages-list thead th{background:#f8f9fa;background:var(--surface-bg-alt);color:#2c3e50;color:var(--text-default);font-weight:600;position:sticky;top:0;z-index:1}.menu-pages-list tbody tr:nth-child(2n){background:#fbfcfd}.menu-pages-list tbody tr:hover{background:#3498db0d}.thumbnail{border:1px solid #eaeaea;border:1px solid var(--border-color);border-radius:4px;height:60px;object-fit:cover;width:80px}.status-badge{border-radius:12px;white-space:nowrap}.status-badge.active{background-color:#e3f7ee;color:#27ae60;color:var(--success)}.status-badge.inactive{background-color:#f8f0ed;color:#e67e22}.table-actions{flex-wrap:wrap}.action-button{align-items:center;background:none;border:none;border-radius:4px;color:#7f8c8d;color:var(--text-muted);cursor:pointer;display:flex;height:30px;justify-content:center;transition:background .2s,color .2s;width:30px}.action-button:hover{background-color:#f8f9fa;background-color:var(--surface-bg-alt);color:#2c3e50;color:var(--text-default)}.action-button:disabled{cursor:not-allowed;opacity:.5}.inactive-row{background-color:#f8f9fa;background-color:var(--surface-bg-alt);opacity:.7}.menu-pages-list::-webkit-scrollbar{height:6px}.menu-pages-list::-webkit-scrollbar-thumb{background:#0000001a;border-radius:3px}@media (max-width:768px){.menu-management{border-radius:0;padding:15px 10px}.management-header{align-items:flex-start;flex-direction:column}.management-header h2{font-size:1.3rem}.menu-form{padding:15px}.form-actions{flex-direction:column}.cancel-button,.submit-button{width:100%}.menu-pages-list table{min-width:100%;width:650px}.menu-pages-list td,.menu-pages-list th{font-size:13px;padding:.5rem .75rem}.thumbnail{height:45px;width:60px}.table-actions{flex-wrap:nowrap}.action-button{height:28px;width:28px}}@media (max-width:480px){.management-header h2{font-size:1.2rem}.add-button{font-size:13px;padding:6px 12px}}.current-image{background-color:#f8f9fa;background-color:var(--surface-bg-alt);border:1px solid #eaeaea;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);margin-top:10px;padding:10px}.current-image p{color:#7f8c8d;color:var(--text-muted);font-size:.9rem;margin:0 0 8px}.current-image img{border-radius:4px;display:block;max-width:100%}.shift-management{max-width:100%;padding:20px}.shift-management .section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.shift-management .section-header h2{color:#333;font-size:1.8rem;margin:0}.shift-management .view-toggle{display:flex;flex-wrap:wrap;gap:10px}.shift-management .view-toggle button{align-items:center;background-color:#f5f5f5;border:1px solid #ddd;border-radius:4px;color:#555;cursor:pointer;display:flex;font-weight:500;justify-content:center;min-width:140px;padding:8px 15px;transition:all .2s ease}.shift-management .view-toggle button.active{background-color:#4caf50;border-color:#4caf50;color:#fff}.shift-management .calendar-controls{align-items:center;background-color:#f5f5f5;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;margin-bottom:20px;padding:10px 15px}.shift-management .week-navigation{align-items:center;display:flex;gap:10px}.shift-management .week-navigation button{align-items:center;background-color:#fff;border:1px solid #ddd;border-radius:18px;color:#333;cursor:pointer;display:flex;height:36px;justify-content:center;padding:0 12px;white-space:nowrap}.shift-management .nav-button{min-width:36px}.shift-management .week-navigation button:hover{background-color:#f0f0f0}.shift-management .current-week-button{background-color:#17a2b8!important;border:none!important;color:#fff!important;font-weight:500;padding:0 15px!important}.shift-management .current-week-button:hover{background-color:#138496!important}.shift-management .icon{display:inline-block;font-size:1.2rem;line-height:1}.shift-management .nav-text{margin:0 5px}.shift-management .week-display h3{color:#333;font-size:1.1rem;margin:0}.shift-management .weekly-calendar{background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.shift-management .calendar-header{background-color:#f5f5f5;border-bottom:1px solid #ddd;display:grid;grid-template-columns:repeat(7,1fr)}.shift-management .day-header{border-right:1px solid #ddd;padding:10px;text-align:center}.shift-management .day-header:last-child{border-right:none}.shift-management .day-name{color:#333;font-weight:600}.shift-management .day-date{color:#555;font-size:.9rem;margin-top:4px}.shift-management .calendar-body{display:grid;grid-template-columns:repeat(7,1fr);min-height:600px}.shift-management .day-column{border-right:1px solid #ddd;display:flex;flex-direction:column;gap:10px;max-height:700px;overflow-y:auto;padding:10px}.shift-management .day-column:last-child{border-right:none}.shift-management .add-shift-button{align-items:center;background-color:#f0f0f0;border:1px dashed #ccc;border-radius:4px;color:#555;cursor:pointer;display:flex;font-size:.9rem;gap:5px;justify-content:center;padding:8px;transition:all .2s ease}.shift-management .add-shift-button:hover{background-color:#e0e0e0;border-color:#aaa}.shift-management .add-shift-button .icon{font-size:1.2rem;line-height:1}.shift-management .button-text{font-size:.9rem;margin-left:4px}.shift-management .day-shifts{display:flex;flex-direction:column;flex-grow:1;gap:8px}.shift-management .shift-card{background-color:#fff;border-left-style:solid;border-left-width:4px;border-radius:4px;box-shadow:0 2px 4px #0000001a;cursor:pointer;display:flex;flex-direction:column;gap:5px;padding:10px;transition:all .2s ease}.shift-management .shift-card:hover{box-shadow:0 4px 8px #00000026}.shift-management .shift-header{align-items:center;display:flex;justify-content:space-between}.shift-management .shift-type{font-size:.9rem;font-weight:600}.shift-management .delete-shift-button{align-items:center;background:none;border:none;border-radius:4px;color:#dc3545;cursor:pointer;display:flex;justify-content:center;padding:2px 5px}.shift-management .delete-shift-button:hover{background-color:#f8d7da}.shift-management .delete-shift-button .icon{font-size:1.2rem;line-height:1}.shift-management .delete-shift-button .button-text{font-size:.8rem;margin-right:3px}.shift-management .shift-employee{font-weight:500}.shift-management .shift-time{color:#555;font-size:.85rem}.shift-management .shift-notes{background-color:#f9f9f9;border-radius:3px;color:#666;font-size:.8rem;margin-top:4px;padding:4px 6px}.shift-management .no-shifts{align-items:center;color:#888;display:flex;font-style:italic;height:100%;justify-content:center;padding:30px;text-align:center}.shift-management .actions-cell{white-space:nowrap}.shift-management .delete-button,.shift-management .edit-button,.shift-management .view-button{align-items:center;border:none;border-radius:4px;color:#fff;cursor:pointer;display:inline-flex;height:32px;justify-content:center;margin-right:5px;min-width:32px;padding:0 8px}.shift-management .view-button{background-color:#17a2b8}.shift-management .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:1000}.shift-management .modal{background-color:#fff;border-radius:8px;box-shadow:0 4px 20px #0003;max-height:90vh;max-width:700px;overflow-y:auto;width:90%}.shift-management .modal-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:15px 20px}.shift-management .modal-header h3{color:#333;margin:0}.shift-management .close-button{background:none;border:none;color:#777;cursor:pointer;font-size:1.5rem}.shift-management .close-button:hover{color:#333}.shift-management .modal form{padding:20px}.shift-management .form-row{display:flex;gap:20px;margin-bottom:15px}.shift-management .form-group{display:flex;flex:1 1;flex-direction:column}.shift-management .form-group label{color:#555;font-weight:500;margin-bottom:5px}.shift-management .form-group input,.shift-management .form-group select,.shift-management .form-group textarea{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:10px}.shift-management .form-group input[disabled]{background-color:#f5f5f5;cursor:not-allowed}.shift-management .form-group textarea{min-height:80px;resize:vertical}.shift-management .checkbox-group{align-items:center;flex-direction:row;margin-top:22px}.shift-management .checkbox-group label{align-items:center;cursor:pointer;display:flex;margin-bottom:0}.shift-management .checkbox-group input[type=checkbox]{height:18px;margin-right:8px;width:18px}.shift-management .form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.shift-management .cancel-button,.shift-management .save-button{border-radius:4px;cursor:pointer;font-weight:500;padding:10px 20px}.shift-management .cancel-button{background-color:#f0f0f0;border:1px solid #ddd;color:#333}.shift-management .save-button{background-color:#4caf50;border:none;color:#fff}.shift-management .cancel-button:hover{background-color:#e0e0e0}.shift-management .save-button:hover{background-color:#45a049}.shift-management .loading{color:#666;font-size:1.2rem;padding:50px;text-align:center}.shift-management .error-message{background-color:#f8d7da;border-radius:4px;color:#721c24;margin-bottom:20px;padding:15px}@media (max-width:992px){.shift-management .calendar-body{min-height:500px}}@media (max-width:768px){.shift-management .section-header{align-items:flex-start;flex-direction:column;gap:10px}.shift-management .view-toggle{width:100%}.shift-management .view-toggle button{flex:1 1;text-align:center}.shift-management .calendar-controls{flex-direction:column;gap:10px}.shift-management .weekly-calendar{overflow-x:auto}.shift-management .calendar-body,.shift-management .calendar-header{min-width:700px}.shift-management .form-row{flex-direction:column;gap:10px}.shift-management .checkbox-group{margin-top:0}.shift-management .button-text,.shift-management .nav-text{display:none}.shift-management .nav-button{padding:0!important;width:36px}}@media (max-width:576px){.shift-management .add-shift-button .button-text{display:none}}.employee-management{max-width:100%;padding:2rem}.employee-management .section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.employee-management .section-header h2{color:#1a202c;color:var(--text-primary,#1a202c);font-size:1.75rem;font-weight:700;letter-spacing:-.025em;margin:0}.employee-management .add-button{align-items:center;background-color:#059669;background-color:var(--accent-green,#059669);border:none;border-radius:.75rem;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:.5rem;padding:.75rem 1.25rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.employee-management .add-button:hover{background-color:#047857;box-shadow:0 4px 6px -1px #05966933;transform:translateY(-1px)}.employee-management .filters-container{background-color:#fff;background-color:var(--bg-card,#fff);border:1px solid #f3f4f6;border:1px solid var(--border-light,#f3f4f6);border-radius:1rem;box-shadow:0 1px 2px 0 #00000008;margin-bottom:1.5rem;padding:1.5rem}.employee-management .filter-controls{align-items:flex-end;display:flex;flex-wrap:wrap;gap:1rem}.employee-management .filter-group{display:flex;flex-direction:column;flex-grow:1;min-width:200px}.employee-management .filter-group label{color:#1a202c;color:var(--text-primary,#1a202c);font-size:.875rem;font-weight:600;margin-bottom:.5rem}.employee-management .filter-group input,.employee-management .filter-group select{background-color:#fff;background-color:var(--bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:.75rem;box-sizing:border-box;color:#1a202c;color:var(--text-primary,#1a202c);font-size:.9rem;padding:.75rem 1rem;transition:all .2s cubic-bezier(.4,0,.2,1);width:100%}.employee-management .filter-group input:focus,.employee-management .filter-group select:focus{border-color:#2563eb;border-color:var(--accent-primary,#2563eb);box-shadow:0 0 0 3px #2563eb1a;outline:none}.employee-management .reset-button{background-color:#fafbfc;background-color:var(--bg-primary,#fafbfc);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:.75rem;color:#4a5568;color:var(--text-secondary,#4a5568);cursor:pointer;font-size:.9rem;font-weight:500;padding:.75rem 1.25rem;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap}.employee-management .reset-button:hover{background-color:#f3f4f6;background-color:var(--border-light,#f3f4f6);border-color:#e5e7eb;border-color:var(--border-color,#e5e7eb)}.employee-management .employees-container{background-color:#fff;background-color:var(--bg-card,#fff);border:1px solid #f3f4f6;border:1px solid var(--border-light,#f3f4f6);border-radius:1rem;box-shadow:0 1px 2px 0 #00000008;overflow-x:auto}.employee-management .employees-table{border-collapse:collapse;width:100%}.employee-management .employees-table td,.employee-management .employees-table th{border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light,#f3f4f6);padding:1rem .75rem;text-align:left;vertical-align:middle}.employee-management .employees-table th{background-color:#2563eb08;color:#1a202c;color:var(--text-primary,#1a202c);font-size:.875rem;font-weight:600;white-space:nowrap}.employee-management .employees-table td{color:#4a5568;color:var(--text-secondary,#4a5568);font-size:.9rem}.employee-management .employees-table tr:hover{background-color:#2563eb05}.employee-management .inactive-row{background-color:#f3f4f6;background-color:var(--border-light,#f3f4f6);opacity:.7}.employee-management .inactive-row:hover{background-color:#2563eb05}.employee-management .status-badge{border-radius:.5rem;display:inline-block;font-size:.8rem;font-weight:600;padding:.375rem .75rem;white-space:nowrap}.employee-management .status-badge.active{background-color:#0596691a;color:#059669;color:var(--accent-green,#059669)}.employee-management .status-badge.inactive{background-color:#6b72801a;color:#718096;color:var(--text-muted,#718096)}.employee-management .credential-status{border-radius:.375rem;display:inline-block;font-size:.75rem;font-weight:500;padding:.25rem .5rem}.employee-management .credential-status.has-credentials{background-color:#2563eb1a;color:#2563eb;color:var(--accent-primary,#2563eb)}.employee-management .credential-status.no-credentials{background-color:#f3f4f6;background-color:var(--border-light,#f3f4f6);color:#718096;color:var(--text-muted,#718096)}.employee-management .actions-cell{padding:.75rem .5rem!important;text-align:center!important;vertical-align:middle!important;white-space:nowrap;width:auto}.employee-management .action-buttons{align-items:center;display:inline-flex;gap:.375rem;justify-content:center}.employee-management .credential-button,.employee-management .delete-button,.employee-management .edit-button,.employee-management .view-button{align-items:center;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:inline-flex;font-size:.8rem;height:2rem;justify-content:center;margin:0;padding:0;transition:all .2s cubic-bezier(.4,0,.2,1);width:2rem}.employee-management .view-button{background-color:#2563eb;background-color:var(--accent-primary,#2563eb)}.employee-management .edit-button{background-color:#d97706;background-color:var(--accent-orange,#d97706)}.employee-management .credential-button{background-color:#3b82f6;background-color:var(--accent-secondary,#3b82f6)}.employee-management .delete-button{background-color:#718096;background-color:var(--text-muted,#718096)}.employee-management .view-button:hover{background-color:#3b82f6;background-color:var(--accent-secondary,#3b82f6);transform:scale(1.05)}.employee-management .edit-button:hover{background-color:#b45309;transform:scale(1.05)}.employee-management .credential-button:hover{background-color:#2563eb;background-color:var(--accent-primary,#2563eb);transform:scale(1.05)}.employee-management .delete-button:hover{background-color:#4a5568;background-color:var(--text-secondary,#4a5568);transform:scale(1.05)}.employee-management .icon{display:inline-block;font-size:.875rem;line-height:1}.employee-management .button-text{display:none;font-size:.8rem;font-weight:500;margin-left:.375rem}@media (min-width:1200px){.employee-management .button-text{display:inline}.employee-management .credential-button,.employee-management .delete-button,.employee-management .edit-button,.employee-management .view-button{min-width:2rem;padding:0 .75rem;width:auto}.employee-management .add-button .icon{margin-right:.375rem}}.employee-management .modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#0006;bottom:0;box-sizing:border-box;display:flex;justify-content:center;left:0;padding:1.25rem;position:fixed;right:0;top:0;z-index:1001}.employee-management .modal{background-color:#fff;background-color:var(--bg-card,#fff);border:1px solid #f3f4f6;border:1px solid var(--border-light,#f3f4f6);border-radius:1rem;box-shadow:0 20px 25px -5px #0000001f,0 10px 10px -5px #00000014;display:flex;flex-direction:column;max-height:90vh;max-width:700px;overflow:hidden;width:100%}.employee-management .modal-header{align-items:center;background-color:#2563eb05;border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light,#f3f4f6);display:flex;flex-shrink:0;justify-content:space-between;padding:1.5rem 2rem}.employee-management .modal-header h3{color:#1a202c;color:var(--text-primary,#1a202c);font-size:1.375rem;font-weight:600;margin:0}.employee-management .close-button{align-items:center;background:none;border:none;border-radius:.5rem;color:#718096;color:var(--text-muted,#718096);cursor:pointer;display:flex;font-size:1.5rem;height:2.5rem;justify-content:center;line-height:1;padding:.375rem;transition:all .2s cubic-bezier(.4,0,.2,1);width:2.5rem}.employee-management .close-button:hover{background-color:#f3f4f6;background-color:var(--border-light,#f3f4f6);color:#4a5568;color:var(--text-secondary,#4a5568)}.employee-management .modal form{flex-grow:1;overflow-y:auto;padding:2rem}.employee-management .form-row{display:flex;gap:1.5rem;margin-bottom:1.25rem}.employee-management .form-group{display:flex;flex:1 1;flex-direction:column;min-width:0}.employee-management .form-group label{color:#1a202c;color:var(--text-primary,#1a202c);font-size:.875rem;font-weight:600;margin-bottom:.5rem}.employee-management .form-group input,.employee-management .form-group select,.employee-management .form-group textarea{background-color:#fff;background-color:var(--bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:.75rem;box-sizing:border-box;color:#1a202c;color:var(--text-primary,#1a202c);font-size:.9rem;padding:.75rem 1rem;transition:all .2s cubic-bezier(.4,0,.2,1);width:100%}.employee-management .form-group input:focus,.employee-management .form-group select:focus,.employee-management .form-group textarea:focus{border-color:#2563eb;border-color:var(--accent-primary,#2563eb);box-shadow:0 0 0 3px #2563eb1a;outline:none}.employee-management .form-group textarea{min-height:80px;resize:vertical}.employee-management .checkbox-group{align-items:center;flex-direction:row;margin-top:1.75rem}.employee-management .checkbox-group label{align-items:center;cursor:pointer;display:flex;font-weight:500;margin-bottom:0}.employee-management .checkbox-group input[type=checkbox]{accent-color:#2563eb;accent-color:var(--accent-primary,#2563eb);flex-shrink:0;height:1.125rem;margin-right:.5rem;width:1.125rem}.employee-management .form-actions{background-color:#2563eb05;border-top:1px solid #f3f4f6;border-top:1px solid var(--border-light,#f3f4f6);display:flex;flex-shrink:0;gap:.75rem;justify-content:flex-end;margin-top:1.5rem;padding:1.5rem 2rem}.employee-management .cancel-button,.employee-management .save-button{border-radius:.75rem;cursor:pointer;font-size:.9rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.employee-management .cancel-button{background-color:#fafbfc;background-color:var(--bg-primary,#fafbfc);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);color:#4a5568;color:var(--text-secondary,#4a5568)}.employee-management .save-button{background-color:#059669;background-color:var(--accent-green,#059669);border:none;color:#fff}.employee-management .cancel-button:hover{background-color:#f3f4f6;background-color:var(--border-light,#f3f4f6);border-color:#e5e7eb;border-color:var(--border-color,#e5e7eb)}.employee-management .save-button:hover{background-color:#047857;box-shadow:0 4px 6px -1px #05966933;transform:translateY(-1px)}.employee-management .loading{color:#4a5568;color:var(--text-secondary,#4a5568);font-size:1.125rem;font-weight:500;padding:3rem;text-align:center}.employee-management .error-message{background-color:#6b72800d;border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:.75rem;color:#4a5568;color:var(--text-secondary,#4a5568);font-weight:500;margin-bottom:1.5rem;padding:1rem 1.25rem}.employee-management .no-data{color:#4a5568;color:var(--text-secondary,#4a5568);font-style:italic;font-weight:500;padding:3rem;text-align:center}@media (max-width:768px){.employee-management{padding:1.5rem}.employee-management .section-header{align-items:flex-start;flex-direction:column;gap:1rem}.employee-management .add-button{justify-content:center;width:100%}.employee-management .filter-controls{align-items:stretch;flex-direction:column;gap:1rem}.employee-management .filter-group{min-width:0;min-width:auto;width:100%}.employee-management .reset-button{margin-left:0;width:100%}.employee-management .form-row{flex-direction:column;gap:1rem;margin-bottom:1rem}.employee-management .form-group.checkbox-group{margin-top:.75rem}.employee-management .modal{max-height:85vh}.employee-management .modal-header h3{font-size:1.25rem}.employee-management .form-actions{padding:1.25rem 1.5rem}.employee-management .modal form{padding:1.5rem}}@media (max-width:480px){.employee-management{padding:1rem}.employee-management .form-actions,.employee-management .modal form,.employee-management .modal-header{padding:1.25rem}.employee-management .action-buttons{gap:.25rem}.employee-management .credential-button,.employee-management .delete-button,.employee-management .edit-button,.employee-management .view-button{height:1.875rem;width:1.875rem}.employee-management .icon{font-size:.75rem}.employee-management .employees-table td,.employee-management .employees-table th{font-size:.8rem;padding:.75rem .5rem}}.shift-type-management{max-width:100%;padding:20px}.shift-type-management .section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.shift-type-management .section-header h2{color:#333;font-size:1.8rem;margin:0}.shift-type-management .add-button{align-items:center;background-color:#4caf50;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-weight:500;padding:10px 15px}.shift-type-management .add-button:hover{background-color:#45a049}.shift-type-management .shift-types-container{background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow-x:auto}.shift-type-management .shift-types-table{border-collapse:collapse;width:100%}.shift-type-management .shift-types-table td,.shift-type-management .shift-types-table th{border-bottom:1px solid #ddd;padding:12px 15px;text-align:left}.shift-type-management .shift-types-table th{background-color:#f5f5f5;color:#333;font-weight:600}.shift-type-management .shift-types-table tr:hover{background-color:#f9f9f9}.shift-type-management .color-box{border:1px solid #0000001a;border-radius:4px;height:24px;width:24px}.shift-type-management .status-badge{border-radius:20px;display:inline-block;font-size:.8rem;font-weight:500;padding:4px 8px}.shift-type-management .status-badge.active{background-color:#d4edda;color:#155724}.shift-type-management .status-badge.inactive{background-color:#f8d7da;color:#721c24}.shift-type-management .actions-cell{text-align:center;vertical-align:middle;white-space:nowrap}.shift-type-management .action-buttons{align-items:center;display:inline-flex;gap:5px;justify-content:center}.shift-type-management .delete-button,.shift-type-management .edit-button{align-items:center;border:none;border-radius:4px;color:#fff;cursor:pointer;display:inline-flex;height:32px;justify-content:center;margin-right:5px;min-width:32px;padding:0 8px}.shift-type-management .edit-button{background-color:#ffc107;color:#212529}.shift-type-management .delete-button{background-color:#dc3545}.shift-type-management .edit-button:hover{background-color:#e0a800}.shift-type-management .delete-button:hover{background-color:#c82333}.shift-type-management .icon{display:inline-block;font-size:1.2rem;line-height:1}.shift-type-management .button-text{display:none;font-size:.9rem;margin-left:4px}@media (min-width:1200px){.shift-type-management .button-text{display:inline}.shift-type-management .delete-button,.shift-type-management .edit-button{min-width:auto;padding:0 10px;width:auto}}.shift-type-management .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:1000}.shift-type-management .modal{background-color:#fff;border-radius:8px;box-shadow:0 4px 20px #0003;max-height:90vh;max-width:600px;overflow-y:auto;width:90%}.shift-type-management .modal-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:15px 20px}.shift-type-management .modal-header h3{color:#333;margin:0}.shift-type-management .close-button{background:none;border:none;color:#777;cursor:pointer;font-size:1.5rem}.shift-type-management .close-button:hover{color:#333}.shift-type-management .modal form{padding:20px}.shift-type-management .form-row{display:flex;gap:20px;margin-bottom:15px}.shift-type-management .form-group{display:flex;flex:1 1;flex-direction:column}.shift-type-management .form-group label{color:#555;font-weight:500;margin-bottom:5px}.shift-type-management .form-group input,.shift-type-management .form-group select,.shift-type-management .form-group textarea{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:10px}.shift-type-management .form-group input[type=color]{height:40px;padding:5px;width:60px}.shift-type-management .color-picker-wrapper{align-items:center;display:flex;gap:10px}.shift-type-management .color-value{font-family:monospace;font-size:.9rem}.shift-type-management .form-group input[disabled]{background-color:#f5f5f5;cursor:not-allowed}.shift-type-management .form-group textarea{min-height:80px;resize:vertical}.shift-type-management .checkbox-group{align-items:flex-start;flex-direction:row;margin-top:10px}.shift-type-management .checkbox-group label{align-items:center;cursor:pointer;display:flex;margin-bottom:0}.shift-type-management .checkbox-group input[type=checkbox]{height:18px;margin-right:8px;margin-top:2px;width:18px}.shift-type-management .helper-text{color:#666;font-size:.8rem;font-style:italic;margin-left:26px;margin-top:5px}.shift-type-management .form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.shift-type-management .cancel-button,.shift-type-management .save-button{border-radius:4px;cursor:pointer;font-weight:500;padding:10px 20px}.shift-type-management .cancel-button{background-color:#f0f0f0;border:1px solid #ddd;color:#333}.shift-type-management .save-button{background-color:#4caf50;border:none;color:#fff}.shift-type-management .cancel-button:hover{background-color:#e0e0e0}.shift-type-management .save-button:hover{background-color:#45a049}.shift-type-management .loading{color:#666;font-size:1.2rem;padding:30px;text-align:center}.shift-type-management .error-message{background-color:#f8d7da;border-radius:4px;color:#721c24;margin-bottom:20px;padding:15px}.shift-type-management .no-data{color:#666;font-style:italic;padding:30px;text-align:center}@media (max-width:768px){.shift-type-management .form-row{flex-direction:column;gap:10px}.shift-type-management .section-header{align-items:flex-start;flex-direction:column;gap:10px}.shift-type-management .add-button{justify-content:center;width:100%}.shift-type-management .button-text{display:none}}.am-loading-indicator{align-items:center;color:#666;display:flex;flex-direction:column;justify-content:center;padding:40px}@keyframes am-fadeIn{0%{opacity:0}to{opacity:1}}@keyframes am-fadeOut{0%{opacity:1}to{opacity:0}}@media (max-width:1200px){.am-calendar-grid{min-width:800px}}@media (max-width:768px){.am-week-navigation{flex-direction:column;gap:10px}.am-current-week-button,.am-nav-button{justify-content:center;width:100%}}.am-calendar-container{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:0 auto;max-width:100%;overflow:hidden}.am-calendar-header{background-color:#f9f9f9;border-bottom:1px solid #eaeaea;padding:20px}.am-calendar-header h2{color:#333;font-size:24px;margin:0 0 15px}.am-week-navigation{align-items:center;display:flex;gap:15px;justify-content:center;margin-bottom:15px}.am-nav-button{align-items:center;background-color:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;display:flex;font-size:14px;padding:8px 16px;transition:all .2s}.am-nav-button:hover{background-color:#f5f5f5;border-color:#ccc}.am-current-week-button{background-color:#4a6fdc;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:600;padding:8px 16px;transition:all .2s}.am-current-week-button:hover{background-color:#3f5fcb}.am-week-display{margin-top:10px;text-align:center}.am-week-display h3{color:#555;font-size:18px;font-weight:500;margin:0}.am-notification{animation:am-fadeIn .3s,am-fadeOut .3s 2.7s;border-radius:4px;margin:10px 20px;padding:12px 20px;text-align:center}.am-notification.am-success{background-color:#e7f7e7;border-left:4px solid #2e7d32;color:#2e7d32}.am-error-message,.am-notification.am-error{background-color:#fdecea;border-left:4px solid #d32f2f;color:#d32f2f}.am-error-message{border-radius:4px;margin:10px 20px;padding:12px 20px;text-align:center}.am-availability-calendar{overflow-x:auto;padding:20px}.am-calendar-grid{display:flex;min-width:1000px}.am-day-column,.am-time-column{border-right:1px solid #eaeaea;flex:1 1}.am-time-column{background-color:#f9f9f9;flex:0 0 180px}.am-column-header{background-color:#f2f2f2;border-bottom:1px solid #ddd;display:flex;flex-direction:column;font-weight:600;height:60px;justify-content:center;padding:10px;text-align:center}.am-day-name{color:#333;font-size:15px}.am-day-date{color:#666;font-size:13px;margin-top:4px}.am-shift-type{background-color:#f9f9f9;border-bottom:1px solid #eaeaea;display:flex;flex-direction:column;justify-content:center;min-height:100px;padding:15px 10px}.am-shift-name{color:#333;font-weight:600;margin-bottom:5px}.am-shift-time{color:#666;font-size:13px}.am-day-cell{background-color:#fff;border-bottom:1px solid #eaeaea;min-height:100px;padding:10px}.am-employee-availabilities{display:flex;flex-direction:column;gap:8px}.am-employee-availability{align-items:center;border-radius:4px;display:flex;justify-content:space-between;padding:8px 10px;transition:all .2s}.am-employee-availability.am-status-pending{background-color:#fff8e1;border:1px solid #ffd54f}.am-employee-availability.am-status-approved{background-color:#e8f5e9;border:1px solid #a5d6a7}.am-employee-availability.am-status-rejected{background-color:#f5f5f5;border:1px solid #e0e0e0;color:#9e9e9e}.am-employee-availability.am-assigned{border:2px solid #2e7d32}.am-employee-info{align-items:center;display:flex;gap:8px}.am-employee-name{font-size:14px;font-weight:500}.am-assigned-label{background-color:#2e7d32;border-radius:4px;color:#fff;font-size:11px;font-weight:600;padding:2px 6px}.am-availability-actions{display:flex;gap:5px}.am-approve-button,.am-reject-button{align-items:center;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:14px;height:30px;justify-content:center;transition:all .2s;width:30px}.am-approve-button{background-color:#4caf50;color:#fff}.am-approve-button:hover{background-color:#388e3c}.am-reject-button{background-color:#f44336;color:#fff}.am-reject-button:hover{background-color:#d32f2f}.am-no-availability{align-items:center;background-color:#fafafa;border-radius:4px;color:#9e9e9e;display:flex;font-size:13px;font-style:italic;height:100%;justify-content:center;min-height:80px}.am-employee-availability.am-has-other-shift{background-color:#fff3e0;border:1px solid #ffb74d}.am-conflict-label{align-items:center;background-color:#ff9800;border-radius:4px;color:#fff;display:flex;font-size:11px;font-weight:600;padding:2px 6px}.am-conflict-info{color:#e65100;font-size:12px;font-style:italic;margin-left:8px}.am-unapprove-button{align-items:center;background-color:#ff9800;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:16px;height:30px;justify-content:center;transition:all .2s;width:30px}.am-unapprove-button:hover{background-color:#f57c00}.availability-calendar-container{background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:0 auto;max-width:100%;overflow:hidden}.calendar-header{background-color:#f9f9f9;border-bottom:1px solid #eaeaea;padding:20px}.calendar-header h2{color:#333;font-size:24px;margin:0 0 15px}.week-navigation{align-items:center;display:flex;gap:15px;justify-content:center;margin-bottom:15px}.nav-button{background-color:#fff;border:1px solid #ddd;border-radius:4px;font-size:14px;padding:8px 16px;transition:all .2s}.nav-button:hover{background-color:#f5f5f5;border-color:#ccc}.current-week-button{background-color:#4a6fdc;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:600;padding:8px 16px;transition:all .2s}.current-week-button:hover{background-color:#3f5fcb}.week-display{margin-top:10px;text-align:center}.week-display h3{color:#555;font-size:18px;font-weight:500;margin:0}.notification{animation:fadeIn .3s,fadeOut .3s 2.7s;border-radius:4px;margin:10px 20px;padding:12px 20px;text-align:center}.notification.success{background-color:#e7f7e7;border-left:4px solid #2e7d32;color:#2e7d32}.notification.error{color:#d32f2f}.error-message,.notification.error{background-color:#fdecea;border-left:4px solid #d32f2f}.error-message{margin:10px 20px;padding:12px 20px}.availability-calendar{overflow-x:auto;padding:20px}.calendar-grid{display:flex;min-width:1000px}.day-column,.time-column{border-right:1px solid #eaeaea;flex:1 1}.time-column{background-color:#f9f9f9;flex:0 0 180px}.column-header{background-color:#f2f2f2;border-bottom:1px solid #ddd;display:flex;flex-direction:column;font-weight:600;height:60px;justify-content:center;padding:10px;text-align:center}.day-name{color:#333;font-size:15px}.day-date{color:#666;font-size:13px;margin-top:4px}.shift-type{background-color:#f9f9f9;border-bottom:1px solid #eaeaea;display:flex;flex-direction:column;justify-content:center;min-height:100px;padding:15px 10px}.shift-name{color:#333;font-weight:600;margin-bottom:5px}.shift-time{color:#666;font-size:13px}.day-cell{background-color:#fff;border-bottom:1px solid #eaeaea;min-height:100px;padding:10px}.employee-availabilities{display:flex;flex-direction:column;gap:8px}.employee-availability{align-items:center;border-radius:4px;justify-content:space-between;padding:8px 10px;transition:all .2s}.employee-availability.pending{background-color:#fff8e1;border:1px solid #ffd54f}.employee-availability.approved{background-color:#e8f5e9;border:1px solid #a5d6a7}.employee-availability.rejected{background-color:#f5f5f5;border:1px solid #e0e0e0;color:#9e9e9e}.employee-availability.assigned{border:2px solid #2e7d32}.employee-info{align-items:center;gap:8px}.employee-name{font-size:14px}.assigned-label{background-color:#2e7d32;border-radius:4px;color:#fff;font-size:11px;font-weight:600;padding:2px 6px}.availability-actions{display:flex;gap:5px}.approve-button,.reject-button{align-items:center;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:14px;height:30px;justify-content:center;transition:all .2s;width:30px}.approve-button{background-color:#4caf50;color:#fff}.approve-button:hover{background-color:#388e3c}.reject-button{background-color:#f44336;color:#fff}.reject-button:hover{background-color:#d32f2f}.no-availability{align-items:center;background-color:#fafafa;border-radius:4px;color:#9e9e9e;display:flex;font-size:13px;font-style:italic;height:100%;justify-content:center;min-height:80px}.loading-indicator{color:#666;padding:40px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@media (max-width:1200px){.calendar-grid{min-width:800px}}@media (max-width:768px){.week-navigation{flex-direction:column;gap:10px}.current-week-button,.nav-button{justify-content:center;width:100%}}.loading-indicator{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:30px}.spinner{animation:spin 1s linear infinite;border:4px solid #007bff1a;border-left-color:#007bff;border-radius:50%;height:40px;margin-bottom:15px;width:40px}.loading-message{color:#6c757d;font-size:16px;margin:0}.employee-payment-management{background-color:#fafbfc;background-color:var(--bg-primary,#fafbfc);margin:0 auto;max-width:1600px;min-height:100vh;padding:2rem}.section-header{background:#fff;background:var(--bg-card,#fff);border:1px solid #f3f4f6;border:1px solid var(--border-light,#f3f4f6);border-radius:1rem;box-shadow:0 1px 2px 0 #00000008;padding:2rem}.section-header h3{color:#1a202c;color:var(--text-primary,#1a202c);font-size:1.75rem;font-weight:700;letter-spacing:-.025em;margin:0}.payment-controls{align-items:center;display:flex;gap:1.5rem}.month-selector{align-items:center;display:flex;gap:.75rem}.month-selector label{font-size:.875rem;font-weight:600}.month-selector input,.month-selector label{color:#1a202c;color:var(--text-primary,#1a202c)}.month-selector input{background:#fff;background:var(--bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:.75rem;font-size:.9rem;padding:.75rem 1rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.month-selector input:focus{border-color:#2563eb;border-color:var(--accent-primary,#2563eb);box-shadow:0 0 0 3px #2563eb1a;outline:none}.payment-summary{background:#fff;background:var(--bg-card,#fff);border:1px solid #f3f4f6;border:1px solid var(--border-light,#f3f4f6);border-radius:1rem;box-shadow:0 1px 2px 0 #00000008;margin-bottom:2rem;padding:2rem}.payment-summary h4{color:#1a202c;color:var(--text-primary,#1a202c);font-size:1.25rem;font-weight:600;margin:0 0 1.5rem}.summary-cards{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.summary-card{background:#fff;background:var(--bg-card,#fff);border:1px solid #f3f4f6;border:1px solid var(--border-light,#f3f4f6);border-radius:1rem;box-shadow:0 4px 6px -1px #0000000f,0 2px 4px -2px #0000000a;color:#1a202c;color:var(--text-primary,#1a202c);overflow:hidden;padding:2rem 1.5rem;position:relative;text-align:center;transition:all .2s cubic-bezier(.4,0,.2,1)}.summary-card:before{background-color:#2563eb;background-color:var(--accent-primary,#2563eb);border-radius:1rem 1rem 0 0;content:"";height:4px;left:0;position:absolute;right:0;top:0}.summary-card:nth-child(2):before{background-color:#d97706;background-color:var(--accent-orange,#d97706)}.summary-card:nth-child(3):before{background-color:#059669;background-color:var(--accent-green,#059669)}.summary-card:nth-child(4):before{background-color:#3b82f6;background-color:var(--accent-secondary,#3b82f6)}.summary-card:hover{box-shadow:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000f;transform:translateY(-2px)}.summary-title{color:#4a5568;color:var(--text-secondary,#4a5568);font-size:.875rem;font-weight:600;letter-spacing:.025em;margin-bottom:.75rem;text-transform:uppercase}.summary-value{color:#1a202c;color:var(--text-primary,#1a202c);font-size:1.875rem;font-weight:700;margin:0}.payment-table-container{background:#fff;background:var(--bg-card,#fff);border:1px solid #f3f4f6;border:1px solid var(--border-light,#f3f4f6);border-radius:1rem;box-shadow:0 1px 2px 0 #00000008;overflow:hidden}.payment-table{width:100%}.table-header{background:#2563eb08;color:#1a202c;color:var(--text-primary,#1a202c);font-size:.875rem;font-weight:600;padding:1.25rem 1.5rem}.table-header,.table-row{grid-gap:1rem;border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light,#f3f4f6);display:grid;gap:1rem;grid-template-columns:2fr 1fr 1.2fr 1.2fr 1.2fr 1.2fr 1.5fr}.table-row{align-items:center;padding:1.5rem;transition:background-color .2s cubic-bezier(.4,0,.2,1)}.table-row:hover{background-color:#2563eb05}.table-row:last-child{border-bottom:none}.employee-info{display:flex;flex-direction:column;gap:.5rem}.employee-name{font-size:1rem}.employee-position{background:#f3f4f6;background:var(--border-light,#f3f4f6);border-radius:1rem;color:#4a5568;color:var(--text-secondary,#4a5568);display:inline-block;font-size:.8rem;font-weight:500;padding:.25rem .75rem;width:fit-content}.work-info{align-items:center;display:flex;flex-direction:column;gap:.25rem}.days-worked{color:#1a202c;color:var(--text-primary,#1a202c);font-size:1rem;font-weight:600}.daily-rate{gap:.75rem}.daily-rate,.rate-display{align-items:center;display:flex;flex-direction:column}.rate-display{gap:.5rem}.rate-amount{color:#059669;color:var(--accent-green,#059669);font-size:.9rem;font-weight:600}.rate-actions{display:flex;gap:.375rem}.rate-edit-btn{background:#2563eb;background:var(--accent-primary,#2563eb);border:none;border-radius:.375rem;color:#fff;cursor:pointer;font-size:.75rem;font-weight:500;padding:.25rem .5rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.rate-edit-btn:hover{background:#3b82f6;background:var(--accent-secondary,#3b82f6);transform:scale(1.05)}.set-rate-btn{background:#d97706;background:var(--accent-orange,#d97706);border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:.8rem;font-weight:600;padding:.75rem 1rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.set-rate-btn:hover{background:#b45309;box-shadow:0 4px 6px -1px #d9770633;transform:translateY(-1px)}.calculated-amount{color:#059669;color:var(--accent-green,#059669);font-size:1.125rem;font-weight:700;text-align:center}.paid-amount{align-items:center;display:flex;flex-direction:column;gap:.25rem}.amount-display{color:#059669;color:var(--accent-green,#059669);font-size:.9rem;font-weight:600}.payment-count{background:#f3f4f6;background:var(--border-light,#f3f4f6);border-radius:.75rem;color:#718096;color:var(--text-muted,#718096);font-size:.75rem;font-weight:500;padding:.125rem .5rem}.remaining-debt{align-items:center;display:flex;flex-direction:column;gap:.25rem}.remaining-debt.has-debt .debt-amount{color:#d97706;color:var(--accent-orange,#d97706);font-size:1rem;font-weight:700}.remaining-debt.no-debt .debt-amount{color:#718096;color:var(--text-muted,#718096);font-size:.875rem;font-weight:600}.status-complete{background:#0596691a;border-radius:.75rem;color:#059669;color:var(--accent-green,#059669);font-size:.75rem;font-weight:600;padding:.125rem .5rem}.payment-actions{display:flex;flex-wrap:wrap;gap:.375rem;justify-content:center}.action-buttons button{border:none;border-radius:.5rem;cursor:pointer;font-size:.75rem;font-weight:600;min-width:60px;padding:.5rem .75rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.add-payment-button{background-color:#059669;background-color:var(--accent-green,#059669);color:#fff;font-size:.8rem;padding:.625rem .875rem}.add-payment-button:hover{background-color:#047857;box-shadow:0 2px 4px -1px #05966933;transform:translateY(-1px)}.view-history-button{background-color:#3b82f6;background-color:var(--accent-secondary,#3b82f6);color:#fff;font-size:.75rem;padding:.5rem .75rem}.view-history-button:hover{background-color:#2563eb;background-color:var(--accent-primary,#2563eb);box-shadow:0 2px 4px -1px #3b82f633;transform:translateY(-1px)}.edit-button:hover{transform:scale(1.05)}.delete-button{background-color:#718096;background-color:var(--text-muted,#718096)}.delete-button:hover{background-color:#4a5568;background-color:var(--text-secondary,#4a5568);transform:scale(1.05)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0006;padding:1.25rem}.modal{animation:modalSlideIn .3s ease-out;background:#fff;background:var(--bg-card,#fff);border:1px solid #f3f4f6;border:1px solid var(--border-light,#f3f4f6);border-radius:1rem;box-shadow:0 20px 25px -5px #0000001f,0 10px 10px -5px #00000014;max-width:600px}.modal.large-modal{max-width:900px}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{background:#2563eb05;border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light,#f3f4f6);border-radius:1rem 1rem 0 0;padding:2rem}.modal-header h3{color:#1a202c;color:var(--text-primary,#1a202c);font-size:1.375rem}.close-button{color:#718096;color:var(--text-muted,#718096);font-size:1.5rem;height:2.5rem;padding:0;transition:all .2s cubic-bezier(.4,0,.2,1);width:2.5rem}.close-button:hover{background-color:#f3f4f6;background-color:var(--border-light,#f3f4f6);color:#4a5568;color:var(--text-secondary,#4a5568)}.modal-content{padding:2rem}.payment-summary-info{background:#2563eb08;border:1px solid #f3f4f6;border:1px solid var(--border-light,#f3f4f6);border-radius:.75rem;margin:1.25rem 0;padding:1.25rem}.summary-row{align-items:center;border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light,#f3f4f6);display:flex;justify-content:space-between;padding:.5rem 0}.summary-row:last-child{border-bottom:none}.summary-row.total{border-top:2px solid #f3f4f6;border-top:2px solid var(--border-light,#f3f4f6);color:#d97706;color:var(--accent-orange,#d97706);font-size:1rem;font-weight:700;padding-top:.75rem}.summary-row .amount{font-weight:600}.form-row{grid-gap:1.5rem;gap:1.5rem;margin-bottom:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem}.form-group input,.form-group label,.form-group textarea{color:#1a202c;color:var(--text-primary,#1a202c)}.form-group input,.form-group textarea{background:#fff;background:var(--bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:.75rem;font-size:.9rem;padding:.75rem 1rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.form-group input:focus,.form-group textarea:focus{border-color:#2563eb;border-color:var(--accent-primary,#2563eb);box-shadow:0 0 0 3px #2563eb1a;outline:none}.readonly-input{background-color:#f3f4f6!important;background-color:var(--border-light,#f3f4f6)!important;color:#4a5568!important;color:var(--text-secondary,#4a5568)!important;cursor:not-allowed}.form-group textarea{font-family:inherit;min-height:80px}.form-group small{color:#718096;color:var(--text-muted,#718096);font-size:.8rem;font-weight:500;margin-top:.25rem}.rate-info{background:#2563eb0d;border-left:4px solid #2563eb;border-left:4px solid var(--accent-primary,#2563eb);border-radius:.75rem;margin-top:1.5rem;padding:1.5rem}.rate-info p{color:#2563eb;color:var(--accent-primary,#2563eb);font-size:.875rem;font-weight:500;line-height:1.6;margin:0}.form-actions{background:#2563eb05;border-radius:0 0 1rem 1rem;border-top:1px solid #f3f4f6;border-top:1px solid var(--border-light,#f3f4f6);gap:.75rem;padding:2rem}.cancel-button{background:#fff;background:var(--bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:.75rem;color:#4a5568;color:var(--text-secondary,#4a5568);font-size:.9rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.cancel-button:hover{background-color:#f3f4f6;background-color:var(--border-light,#f3f4f6);border-color:#e5e7eb;border-color:var(--border-color,#e5e7eb);color:#1a202c;color:var(--text-primary,#1a202c)}.save-button{background:#059669;background:var(--accent-green,#059669);border-radius:.75rem;font-size:.9rem;font-weight:600;padding:.75rem 1.5rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.save-button:hover{background:#047857;box-shadow:0 4px 6px -1px #05966933}.payment-history-table{width:100%}.payment-history-table .table-header{background:#2563eb08;color:#1a202c;color:var(--text-primary,#1a202c);font-size:.8rem;font-weight:600}.payment-history-table .table-header,.payment-history-table .table-row{grid-gap:1rem;border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light,#f3f4f6);display:grid;gap:1rem;grid-template-columns:1.5fr 1fr 2fr .8fr;padding:1rem 1.25rem}.payment-history-table .table-row{align-items:center}.payment-history-table .payment-amount{color:#059669;color:var(--accent-green,#059669);font-weight:600}.payment-history-table .payment-date{color:#1a202c;color:var(--text-primary,#1a202c);font-size:.8rem}.payment-history-table .payment-notes{color:#4a5568;color:var(--text-secondary,#4a5568);font-size:.8rem}.history-summary{background:#2563eb08;border-top:2px solid #f3f4f6;border-top:2px solid var(--border-light,#f3f4f6);margin-top:.75rem;padding:1rem 1.25rem}.history-summary .summary-row{border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light,#f3f4f6);padding:.375rem 0}.history-summary .summary-row.total{color:#059669;color:var(--accent-green,#059669);font-size:1rem}.loading{font-size:1.125rem;padding:4rem}.error-message{justify-content:space-between;position:relative}.error-close{align-items:center;background:none;border:none;border-radius:50%;color:#4a5568;color:var(--text-secondary,#4a5568);cursor:pointer;display:flex;font-size:1.25rem;height:1.5rem;justify-content:center;padding:0;transition:background-color .2s cubic-bezier(.4,0,.2,1);width:1.5rem}.error-close:hover{background-color:#f3f4f6;background-color:var(--border-light,#f3f4f6)}.no-data{padding:3rem}@media (max-width:1400px){.employee-payment-management{padding:1.5rem}.table-header,.table-row{gap:.75rem;grid-template-columns:1.8fr .8fr 1fr 1fr 1fr 1fr 1.3fr;padding:1.25rem 1rem}}@media (max-width:1200px){.summary-cards{grid-template-columns:repeat(2,1fr)}.table-header,.table-row{grid-template-columns:1.5fr .8fr 1fr 1fr 1fr 1fr 1.2fr}.employee-name{font-size:.875rem}.calculated-amount{font-size:1rem}}@media (max-width:900px){.section-header{flex-direction:column;gap:1rem;text-align:center}.summary-cards{grid-template-columns:1fr}.payment-table-container{overflow-x:auto}.table-header,.table-row{min-width:900px}.form-row{grid-template-columns:1fr}.modal{margin:.75rem;width:95%}}@media (max-width:600px){.employee-payment-management{padding:1rem}.section-header{padding:1.5rem}.section-header h3{font-size:1.5rem}.form-actions,.modal-content,.payment-summary{padding:1.5rem}.action-buttons button{font-size:.7rem;min-width:50px;padding:.5rem .625rem}.form-actions,.modal-header{padding:1.5rem}}.checkin-management{margin:0 auto;max-width:1400px;padding:2rem}.section-header{flex-wrap:wrap;gap:1.5rem;margin-bottom:2rem}.section-header h2{color:#1a202c;color:var(--text-primary,#1a202c);font-size:1.75rem;letter-spacing:-.025em}.controls{flex-wrap:wrap;gap:1.5rem}.controls,.month-navigation{align-items:center;display:flex}.month-navigation{gap:.75rem}.nav-button{align-items:center;background:#fff;background:var(--bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:.75rem;color:#4a5568;color:var(--text-secondary,#4a5568);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.nav-button:hover{background:#f3f4f6;background:var(--border-light,#f3f4f6);border-color:#e5e7eb;border-color:var(--border-color,#e5e7eb);color:#1a202c;color:var(--text-primary,#1a202c);transform:translateY(-1px)}.nav-button .icon{font-size:1rem;font-weight:700}.current-month-button{background:#2563eb;background:var(--accent-primary,#2563eb);border:none;border-radius:.75rem;color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;padding:.75rem 1rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.current-month-button:hover{background:#3b82f6;background:var(--accent-secondary,#3b82f6);box-shadow:0 4px 6px -1px #2563eb33;transform:translateY(-1px)}.month-display h3{color:#1a202c;color:var(--text-primary,#1a202c);font-size:1.25rem;font-weight:600;margin:0;text-transform:capitalize}.filter-controls{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.group-toggle{background:#f3f4f6;background:var(--border-light,#f3f4f6);border-radius:.75rem;display:flex;gap:.125rem;padding:.25rem}.group-toggle button{align-items:center;background:#0000;border:none;border-radius:.5rem;color:#4a5568;color:var(--text-secondary,#4a5568);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.75rem 1rem;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap}.group-toggle button:hover{background:#2563eb0d;color:#2563eb;color:var(--accent-primary,#2563eb)}.group-toggle button.active{background:#2563eb;background:var(--accent-primary,#2563eb);box-shadow:0 2px 4px #2563eb33;color:#fff}.group-toggle button .icon{font-size:1rem}.employee-filter{background:#fff;background:var(--bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:.75rem;color:#1a202c;color:var(--text-primary,#1a202c);font-size:.875rem;min-width:200px;padding:.75rem 1rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.employee-filter:focus{border-color:#2563eb;border-color:var(--accent-primary,#2563eb);box-shadow:0 0 0 3px #2563eb1a;outline:none}.loading{font-size:1rem;font-weight:500;padding:3rem}.error-message,.loading{color:#4a5568;color:var(--text-secondary,#4a5568);text-align:center}.error-message{background:#6b72800d;border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb)}.no-data{background:#fff;background:var(--bg-card,#fff);border:1px solid #f3f4f6;border:1px solid var(--border-light,#f3f4f6);border-radius:1rem;color:#4a5568;color:var(--text-secondary,#4a5568);font-size:1rem;font-weight:500;padding:4rem 1.5rem}.checkin-data{display:flex;flex-direction:column;gap:1.5rem}.employee-section{background:#fff;background:var(--bg-card,#fff);border:1px solid #f3f4f6;border:1px solid var(--border-light,#f3f4f6);border-radius:1rem;box-shadow:0 1px 2px 0 #00000008;overflow:hidden}.employee-header{align-items:center;background:#2563eb05;border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light,#f3f4f6);display:flex;justify-content:space-between;padding:1.5rem 2rem}.employee-header h3{color:#1a202c;color:var(--text-primary,#1a202c);font-size:1.125rem;font-weight:600;margin:0}.record-count{background:#2563eb;background:var(--accent-primary,#2563eb);border-radius:1rem;color:#fff;font-size:.8rem;font-weight:600;padding:.375rem .875rem}.records-table{overflow-x:auto}.records-table table{border-collapse:collapse;width:100%}.records-table th{background:#2563eb08;color:#1a202c;color:var(--text-primary,#1a202c);font-weight:600;text-align:left}.records-table td,.records-table th{border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light,#f3f4f6);font-size:.875rem;padding:1rem 1.25rem}.records-table td{color:#4a5568;color:var(--text-secondary,#4a5568);vertical-align:middle}.records-table tr:hover{background:#2563eb05}.shift-type-badge{border-radius:1rem;color:#fff;display:inline-block;font-size:.8rem;font-weight:600;padding:.375rem .75rem;text-shadow:0 1px 2px #0000001a}.no-checkin{color:#718096;color:var(--text-muted,#718096);font-style:italic;font-weight:500}.status-badge{border-radius:.75rem;font-size:.8rem;letter-spacing:.025em;padding:.375rem .75rem;text-transform:uppercase}.status-badge.on-time{background:#0596691a;color:#059669;color:var(--accent-green,#059669)}.status-badge.slightly-late{background:#d977061a;color:#d97706;color:var(--accent-orange,#d97706)}.status-badge.late{background:#ef44441a;color:#dc2626}.status-badge.absent{background:#6b72801a;color:#718096;color:var(--text-muted,#718096)}.verification-badge{border-radius:.5rem;display:inline-block;font-size:.75rem;font-weight:600;margin-right:.5rem;padding:.25rem .625rem}.verification-badge.verified{background:#0596691a;border:1px solid #05966933;color:#059669;color:var(--accent-green,#059669)}.verification-badge.rejected{background:#ef44441a;border:1px solid #ef444433;color:#dc2626}.distance-info{color:#718096;color:var(--text-muted,#718096);font-size:.75rem;font-style:italic;font-weight:500}.employee-name{color:#1a202c;color:var(--text-primary,#1a202c);font-weight:600}@media (max-width:768px){.checkin-management{padding:1.5rem}.section-header{align-items:stretch;flex-direction:column;gap:1rem}.section-header h2{text-align:center}.controls,.filter-controls{align-items:stretch;flex-direction:column;gap:1rem}.group-toggle{order:-1}.group-toggle,.month-navigation{justify-content:center}.month-display{text-align:center}.employee-filter{min-width:auto;width:100%}.employee-header{align-items:flex-start;flex-direction:column;gap:.75rem;padding:1.25rem 1.5rem}.records-table{font-size:.8rem}.records-table td,.records-table th{padding:.75rem .5rem}.nav-button .nav-text{display:none}.group-toggle button{font-size:.8rem;padding:.625rem .875rem}}@media (max-width:480px){.checkin-management{padding:1rem}.section-header h2{font-size:1.5rem}.records-table td,.records-table th{font-size:.75rem;padding:.625rem .375rem}.shift-type-badge,.status-badge,.verification-badge{font-size:.7rem;padding:.25rem .5rem}.employee-header{padding:1rem}.employee-header h3{font-size:1rem}.record-count{font-size:.75rem;padding:.25rem .625rem}.current-month-button,.employee-filter,.nav-button{font-size:.8rem;padding:.625rem .875rem}}.admin-image-gallery-component{background-color:#fafbfc;background-color:var(--bg-primary,#fafbfc);font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-family:var(--font-sans,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif);margin:0 auto;max-width:1400px;min-height:100vh;padding:2rem;width:100%}.admin-section-header{background:#fff;background:var(--bg-card,#fff);border:1px solid #f3f4f6;border:1px solid var(--border-light,#f3f4f6);border-radius:1rem;box-shadow:0 1px 2px 0 #00000008;color:#1a202c;color:var(--text-primary,#1a202c);margin-bottom:2rem;padding:2rem;text-align:center}.admin-section-header h2{font-size:1.75rem;font-weight:700;letter-spacing:-.025em;margin:0}.admin-content-layout{grid-gap:2rem;align-items:start;display:grid;gap:2rem;grid-template-columns:350px 1fr}.admin-calendar-container{background:#fff;background:var(--bg-card,#fff);border:1px solid #f3f4f6;border:1px solid var(--border-light,#f3f4f6);border-radius:1rem;box-shadow:0 1px 2px 0 #00000008;padding:2rem;position:sticky;top:1.25rem}.admin-calendar-header{border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light,#f3f4f6);margin-bottom:2rem;padding-bottom:1.25rem;text-align:center}.admin-calendar-header h3{color:#1a202c;color:var(--text-primary,#1a202c);font-size:1.25rem;font-weight:600;margin:0 0 1rem}.admin-date-display{background:#2563eb;background:var(--accent-primary,#2563eb);border-radius:.75rem;box-shadow:0 2px 4px #2563eb33;color:#fff;font-weight:600;padding:.875rem 1.25rem}.admin-selected-date{font-size:1rem}.admin-months-selector{margin-bottom:2rem}.admin-selector-heading{color:#1a202c;color:var(--text-primary,#1a202c);font-size:1rem;font-weight:600;margin-bottom:.875rem;text-align:center}.admin-month-buttons{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(4,1fr)}.admin-month-button{background:#fff;background:var(--bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:.75rem;color:#4a5568;color:var(--text-secondary,#4a5568);cursor:pointer;font-size:.8rem;font-weight:500;padding:.75rem .5rem;text-align:center;transition:all .2s cubic-bezier(.4,0,.2,1)}.admin-month-button:hover{background-color:#2563eb0d;color:#2563eb;color:var(--accent-primary,#2563eb)}.admin-month-button.active,.admin-month-button:hover{border-color:#2563eb;border-color:var(--accent-primary,#2563eb)}.admin-month-button.active{background:#2563eb;background:var(--accent-primary,#2563eb);box-shadow:0 2px 4px #2563eb33;color:#fff}.admin-days-selector{margin-bottom:1rem}.admin-days-grid{grid-gap:.375rem;display:grid;gap:.375rem;grid-template-columns:repeat(7,1fr);max-height:240px;overflow-y:auto;padding:.375rem}.admin-day-button{align-items:center;background:#fff;background:var(--bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:.75rem;color:#4a5568;color:var(--text-secondary,#4a5568);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;justify-content:center;min-height:45px;padding:.875rem .5rem;position:relative;text-align:center;transition:all .2s cubic-bezier(.4,0,.2,1)}.admin-day-button:hover{background-color:#2563eb0d;color:#2563eb;color:var(--accent-primary,#2563eb)}.admin-day-button.active,.admin-day-button:hover{border-color:#2563eb;border-color:var(--accent-primary,#2563eb)}.admin-day-button.active{background:#2563eb;background:var(--accent-primary,#2563eb);box-shadow:0 2px 4px #2563eb33;color:#fff}.admin-day-count{align-items:center;background:#d97706;background:var(--accent-orange,#d97706);border-radius:50%;box-shadow:0 1px 2px #0000001a;color:#fff;display:flex;font-size:.625rem;font-weight:700;height:1.125rem;justify-content:center;position:absolute;right:-.25rem;top:-.25rem;width:1.125rem}.admin-gallery-container{background:#fff;background:var(--bg-card,#fff);box-shadow:0 1px 2px 0 #00000008}.admin-gallery-container,.admin-upload-form-container{border:1px solid #f3f4f6;border:1px solid var(--border-light,#f3f4f6);border-radius:1rem;padding:2rem}.admin-upload-form-container{background:#2563eb05;margin-bottom:2rem}.admin-upload-form-container h3{color:#1a202c;color:var(--text-primary,#1a202c);font-size:1.25rem;font-weight:600;margin:0 0 1.5rem;text-align:center}.admin-upload-form{grid-gap:1.5rem;display:grid;gap:1.5rem}.admin-form-group{display:flex;flex-direction:column}.admin-form-group label{font-weight:600;margin-bottom:.5rem}.admin-form-control,.admin-form-group label{color:#1a202c;color:var(--text-primary,#1a202c);font-size:.875rem}.admin-form-control{background:#fff;background:var(--bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:.75rem;padding:.875rem 1rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.admin-form-control:focus{border-color:#2563eb;border-color:var(--accent-primary,#2563eb);box-shadow:0 0 0 3px #2563eb1a;outline:none}.admin-file-group{position:relative}.admin-file-input-container{align-items:center;display:flex;gap:1rem}.admin-file-input{display:none}.admin-file-button{background:#059669;background:var(--accent-green,#059669);border:none;border-radius:.75rem;box-shadow:0 2px 4px #05966933;color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;padding:.875rem 1.25rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.admin-file-button:hover{background:#047857;box-shadow:0 4px 6px #0596694d;transform:translateY(-1px)}.admin-file-name{background:#f3f4f6;background:var(--border-light,#f3f4f6);border-radius:.5rem;color:#4a5568;color:var(--text-secondary,#4a5568);font-size:.875rem;font-weight:500;max-width:200px;overflow:hidden;padding:.625rem .875rem;text-overflow:ellipsis;white-space:nowrap}.admin-upload-button{background:#2563eb;background:var(--accent-primary,#2563eb);border:none;border-radius:.75rem;box-shadow:0 2px 4px #2563eb33;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;justify-self:start;padding:1rem 2rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.admin-upload-button:hover:not(:disabled){background:#3b82f6;background:var(--accent-secondary,#3b82f6);box-shadow:0 4px 6px #2563eb4d;transform:translateY(-1px)}.admin-upload-button:disabled{background:#718096;background:var(--text-muted,#718096);box-shadow:none;cursor:not-allowed;transform:none}.admin-error-message{background:#6b72800d;border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:.75rem;color:#4a5568;color:var(--text-secondary,#4a5568)}.admin-error-message,.admin-success-message{font-weight:500;margin-top:1rem;padding:1rem 1.25rem}.admin-success-message{background:#0596691a;border:1px solid #05966933;border-radius:.75rem;color:#059669;color:var(--accent-green,#059669)}.admin-image-display h3{border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light,#f3f4f6);color:#1a202c;color:var(--text-primary,#1a202c);font-size:1.25rem;font-weight:600;margin:0 0 2rem;padding-bottom:1rem;text-align:center}.admin-loading-indicator{color:#2563eb;color:var(--accent-primary,#2563eb);font-weight:400}.admin-image-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.admin-image-item{background:#fff;background:var(--bg-card,#fff);border:1px solid #f3f4f6;border:1px solid var(--border-light,#f3f4f6);border-radius:1rem;box-shadow:0 4px 6px -1px #0000000f,0 2px 4px -2px #0000000a;overflow:hidden;transition:all .2s cubic-bezier(.4,0,.2,1)}.admin-image-item:hover{box-shadow:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000f;transform:translateY(-2px)}.admin-image-item img{display:block;height:200px;object-fit:cover;width:100%}.admin-image-details{padding:1.25rem;position:relative}.admin-image-category{background:#2563eb;background:var(--accent-primary,#2563eb);border-radius:1rem;color:#fff;display:inline-block;font-size:.8rem;font-weight:600;margin-bottom:.625rem;padding:.375rem .875rem}.admin-image-uploader{color:#1a202c;color:var(--text-primary,#1a202c);display:block;font-size:.875rem;font-weight:500;margin-bottom:.375rem}.admin-image-date{color:#718096;color:var(--text-muted,#718096);display:block;font-size:.8rem;font-weight:500;margin-bottom:.875rem}.admin-delete-button{background:#718096;background:var(--text-muted,#718096);border:none;border-radius:.5rem;box-shadow:0 2px 4px #71809633;color:#fff;cursor:pointer;font-size:.8rem;font-weight:600;padding:.5rem .875rem;position:absolute;right:1.25rem;top:1.25rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.admin-delete-button:hover:not(:disabled){background:#4a5568;background:var(--text-secondary,#4a5568);box-shadow:0 4px 6px #7180964d;transform:translateY(-1px)}.admin-delete-button:disabled{background:#718096;background:var(--text-muted,#718096);box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}.admin-loading-message,.admin-no-images{background:#2563eb05;border:1px dashed #e5e7eb;border:1px dashed var(--border-color,#e5e7eb);border-radius:1rem;color:#4a5568;color:var(--text-secondary,#4a5568);font-size:1rem;font-style:italic;font-weight:500;grid-column:1/-1;padding:3rem 1.5rem;text-align:center}@media screen and (max-width:1200px){.admin-content-layout{gap:1.5rem;grid-template-columns:320px 1fr}}@media screen and (max-width:992px){.admin-content-layout{gap:1.5rem;grid-template-columns:1fr}.admin-calendar-container{position:static}.admin-days-grid{max-height:none}}@media screen and (max-width:768px){.admin-image-gallery-component,.admin-section-header{padding:1.5rem}.admin-section-header h2{font-size:1.5rem}.admin-calendar-container,.admin-gallery-container,.admin-upload-form-container{padding:1.5rem}.admin-image-grid{gap:1rem;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.admin-month-buttons{grid-template-columns:repeat(3,1fr)}.admin-days-grid{grid-template-columns:repeat(6,1fr)}}@media screen and (max-width:576px){.admin-image-gallery-component,.admin-section-header{padding:1rem}.admin-section-header h2{font-size:1.375rem}.admin-calendar-container,.admin-gallery-container,.admin-upload-form-container{padding:1.25rem}.admin-image-grid{gap:1rem;grid-template-columns:1fr}.admin-month-buttons{gap:.375rem;grid-template-columns:repeat(2,1fr)}.admin-days-grid{gap:.25rem;grid-template-columns:repeat(5,1fr)}.admin-day-button{font-size:.8rem;min-height:40px;padding:.625rem .375rem}.admin-file-input-container{align-items:stretch;flex-direction:column;gap:.75rem}.admin-file-name{max-width:none}}.admin-days-grid::-webkit-scrollbar{width:6px}.admin-days-grid::-webkit-scrollbar-track{background:#f3f4f6;background:var(--border-light,#f3f4f6);border-radius:3px}.admin-days-grid::-webkit-scrollbar-thumb{background:#e5e7eb;background:var(--border-color,#e5e7eb);border-radius:3px}.admin-days-grid::-webkit-scrollbar-thumb:hover{background:#718096;background:var(--text-muted,#718096)}:root{--todo-primary:#6c5ce7;--todo-secondary:#74b9ff;--todo-success:#00b894;--todo-warning:#fdcb6e;--todo-danger:#e17055;--todo-light:#ddd6fe;--todo-dark:#2d3748;--todo-gray:#718096;--todo-light-gray:#e2e8f0;--todo-white:#fff;--todo-black:#1a202c;--todo-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--todo-shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--todo-radius:0.75rem;--todo-radius-sm:0.5rem;--todo-transition:all 0.3s cubic-bezier(0.4,0,0.2,1)}.dark-mode{--todo-white:#1a202c;--todo-black:#fff;--todo-light-gray:#4a5568;--todo-gray:#a0aec0}.modern-todo-list{background:linear-gradient(135deg,#667eea,#764ba2);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;margin:0 auto;max-width:1200px;min-height:100vh;padding:2rem}.modern-breadcrumbs{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;background:var(--todo-white);border-radius:.75rem;border-radius:var(--todo-radius);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--todo-shadow);margin-bottom:2rem;padding:1rem 1.5rem}.breadcrumb-item,.modern-breadcrumbs{align-items:center;display:flex;gap:.5rem}.breadcrumb-item{background:none;border:none;border-radius:.5rem;border-radius:var(--todo-radius-sm);color:#6c5ce7;color:var(--todo-primary);cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--todo-transition)}.breadcrumb-item:hover{background:#ddd6fe;background:var(--todo-light);transform:translateY(-1px)}.breadcrumb-current{background:#6c5ce7;background:var(--todo-primary);border-radius:.5rem;border-radius:var(--todo-radius-sm);color:#fff;color:var(--todo-white);font-weight:600;padding:.5rem 1rem}.modern-container{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border:1px solid #fff3;border-radius:.75rem;border-radius:var(--todo-radius);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--todo-shadow-lg);overflow:hidden}.section-header{padding:2rem 2rem 1rem;text-align:center}.section-header h2{font-size:2rem;font-weight:700}.section-header h2,.section-header h3{color:#2d3748;color:var(--todo-dark);margin-bottom:.5rem}.section-header h3{align-items:center;display:flex;font-size:1.5rem;font-weight:600;justify-content:space-between}.section-header p{color:#718096;color:var(--todo-gray);font-size:1rem;margin:0 auto;max-width:600px}.modern-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;padding:2rem}.years-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.months-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.days-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.modern-card{background:#fff;background:var(--todo-white);border:1px solid #e2e8f0;border:1px solid var(--todo-light-gray);border-radius:.75rem;border-radius:var(--todo-radius);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--todo-shadow);overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--todo-transition)}.modern-card.clickable{cursor:pointer}.modern-card.clickable:hover{border-color:#6c5ce7;border-color:var(--todo-primary);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--todo-shadow-lg);transform:translateY(-4px)}.year-card{align-items:center;display:flex;flex-direction:column;gap:1rem;padding:2rem;text-align:center}.year-card span{color:#2d3748;color:var(--todo-dark);font-size:1.5rem;font-weight:700}.year-card svg{color:#6c5ce7;color:var(--todo-primary);height:2rem;width:2rem}.month-card{align-items:center;display:flex;justify-content:center;min-height:120px;padding:1.5rem;text-align:center}.month-card .card-content h3{color:#2d3748;color:var(--todo-dark);font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.day-card{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:80px;padding:1rem;position:relative;text-align:center}.day-number{color:#2d3748;color:var(--todo-dark);font-size:1.25rem;font-weight:600}.count-badge{background:linear-gradient(135deg,#6c5ce7,#74b9ff);background:linear-gradient(135deg,var(--todo-primary),var(--todo-secondary));border-radius:1rem;color:#fff;color:var(--todo-white);font-size:.875rem;font-weight:600;margin-top:.5rem;padding:.25rem .75rem}.count-badge.small{align-items:center;border-radius:50%;display:flex;font-size:.75rem;height:1.5rem;justify-content:center;min-width:1.5rem;padding:.25rem .5rem;position:absolute;right:.5rem;top:.5rem}.day-view{background:#0000;box-shadow:none;padding:0}.day-header{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border-radius:.75rem;border-radius:var(--todo-radius);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--todo-shadow);margin-bottom:1.5rem;padding:2rem}.day-title{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between}.day-title h2{color:#2d3748;color:var(--todo-dark);font-size:2rem;font-weight:700;margin:0}.stats-badge{align-items:center;border-radius:.5rem;border-radius:var(--todo-radius-sm);display:flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.5rem 1rem}.stats-badge.pending{background:#fdcb6e;background:var(--todo-warning);color:#2d3748;color:var(--todo-dark)}.stats-badge.completed{background:#00b894;background:var(--todo-success);color:#fff;color:var(--todo-white)}.forms-section{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.modern-form-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border-radius:.75rem;border-radius:var(--todo-radius);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--todo-shadow);overflow:hidden}.form-header{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--todo-light-gray);padding:1.5rem 2rem 1rem}.form-header h3{color:#2d3748;color:var(--todo-dark);font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.form-header p{color:#718096;color:var(--todo-gray);font-size:.875rem}.modern-form{padding:2rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:1rem}.form-group{margin-bottom:1.5rem}.form-group label{color:#2d3748;color:var(--todo-dark);font-size:.875rem;font-weight:600;margin-bottom:.5rem}.modern-input,.modern-select,.modern-textarea{background:#fff;background:var(--todo-white);border:2px solid #e2e8f0;border:2px solid var(--todo-light-gray);border-radius:.5rem;border-radius:var(--todo-radius-sm);color:#2d3748;color:var(--todo-dark);font-size:1rem;padding:.75rem 1rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--todo-transition);width:100%}.modern-input:focus,.modern-select:focus,.modern-textarea:focus{border-color:#6c5ce7;border-color:var(--todo-primary);box-shadow:0 0 0 3px #6c5ce71a;outline:none}.modern-textarea{min-height:100px;resize:vertical}.modern-textarea.small{min-height:60px}.modern-button{align-items:center;border:none;border-radius:.5rem;border-radius:var(--todo-radius-sm);cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--todo-transition);white-space:nowrap}.modern-button.primary{background:linear-gradient(135deg,#6c5ce7,#74b9ff);background:linear-gradient(135deg,var(--todo-primary),var(--todo-secondary));color:#fff;color:var(--todo-white)}.modern-button.primary:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--todo-shadow-lg);transform:translateY(-2px)}.modern-button.secondary{background:#e2e8f0;background:var(--todo-light-gray);color:#2d3748;color:var(--todo-dark)}.modern-button.secondary:hover{background:#718096;background:var(--todo-gray);color:#fff;color:var(--todo-white)}.modern-button.danger{background:#e17055;background:var(--todo-danger);color:#fff;color:var(--todo-white)}.modern-button.danger:hover{background:#d63031;transform:translateY(-1px)}.modern-button.small{font-size:.75rem;padding:.5rem 1rem}.modern-button:disabled{cursor:not-allowed;opacity:.6;transform:none!important}.add-task-section{display:flex;justify-content:center;margin-bottom:1.5rem}.add-task-btn{font-size:1rem;padding:1rem 2rem}.form-actions{gap:1rem;margin-top:1.5rem}.entries-section,.tasks-section{margin-bottom:2rem}.entries-section .section-header,.tasks-section .section-header{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border-radius:.75rem .75rem 0 0;border-radius:var(--todo-radius) var(--todo-radius) 0 0;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--todo-shadow);margin-bottom:0;padding:1.5rem 2rem}.task-counter{background:#ddd6fe;background:var(--todo-light);border-radius:1rem;color:#6c5ce7;color:var(--todo-primary);font-size:.875rem;font-weight:600;padding:.25rem .75rem}.entries-list,.tasks-list{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border-radius:0 0 .75rem .75rem;border-radius:0 0 var(--todo-radius) var(--todo-radius);display:flex;flex-direction:column;gap:1rem;padding:1.5rem 2rem 2rem}.entries-list,.modern-entry-card,.modern-task-card,.tasks-list{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--todo-shadow)}.modern-entry-card,.modern-task-card{background:#fff;background:var(--todo-white);border:1px solid #e2e8f0;border:1px solid var(--todo-light-gray);border-radius:.75rem;border-radius:var(--todo-radius);overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--todo-transition)}.modern-entry-card:hover,.modern-task-card:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--todo-shadow-lg);transform:translateY(-2px)}.modern-task-card.completed{background:#00b8940d;opacity:.7}.entry-header,.task-header{align-items:flex-start;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--todo-light-gray);display:flex;gap:1rem;justify-content:space-between;padding:1.5rem}.task-checkbox-section{align-items:flex-start;display:flex;flex:1 1;gap:1rem}.entry-title-section,.task-title-section{flex:1 1}.task-title-section h4{font-size:1.125rem;margin-bottom:.25rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--todo-transition)}.entry-title-section h3,.task-title-section h4{color:#2d3748;color:var(--todo-dark);font-weight:600}.entry-title-section h3{font-size:1.25rem;margin-bottom:.5rem}.completed-text{opacity:.6;text-decoration:line-through}.item-description,.task-description{color:#718096;color:var(--todo-gray);font-size:.875rem;margin-top:.25rem}.entry-meta{display:flex;font-size:.75rem;gap:1rem;margin-bottom:.5rem}.entry-meta,.entry-notes{color:#718096;color:var(--todo-gray)}.entry-notes{font-size:.875rem}.modern-checkbox{cursor:pointer;display:inline-block;position:relative;-webkit-user-select:none;user-select:none}.modern-checkbox input{cursor:pointer;height:0;opacity:0;position:absolute;width:0}.checkmark{background-color:#fff;background-color:var(--todo-white);border:2px solid #e2e8f0;border:2px solid var(--todo-light-gray);border-radius:.5rem;border-radius:var(--todo-radius-sm);display:inline-block;height:1.5rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--todo-transition);width:1.5rem}.modern-checkbox input:checked~.checkmark,.modern-checkbox:hover .checkmark{border-color:#6c5ce7;border-color:var(--todo-primary)}.modern-checkbox input:checked~.checkmark{background-color:#6c5ce7;background-color:var(--todo-primary)}.checkmark:after{border:solid #fff;border-width:0 2px 2px 0;content:"";display:none;height:.7rem;left:.35rem;position:absolute;top:.1rem;transform:rotate(45deg);width:.4rem}.modern-checkbox input:checked~.checkmark:after{display:block}.entry-actions,.task-actions{align-items:flex-start;display:flex;gap:.5rem}.delete-button{align-items:center;background:none;border:none;border-radius:.5rem;border-radius:var(--todo-radius-sm);color:#718096;color:var(--todo-gray);cursor:pointer;display:flex;padding:.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--todo-transition)}.delete-button:hover{background:#e170551a;color:#e17055;color:var(--todo-danger)}.item-notes-section,.task-notes-section{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--todo-light-gray);padding:1rem 1.5rem}.item-image-section,.task-image-section{padding:1.5rem}.image-display{position:relative}.image-display img{border:1px solid #e2e8f0;border:1px solid var(--todo-light-gray);border-radius:.5rem;border-radius:var(--todo-radius-sm);max-height:300px;object-fit:cover;width:100%}.remove-image-btn{margin-top:1rem}.image-upload-section{border:2px dashed #e2e8f0;border:2px dashed var(--todo-light-gray);border-radius:.5rem;border-radius:var(--todo-radius-sm);padding:2rem;text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--todo-transition)}.image-upload-section:hover{background:#6c5ce70d;border-color:#6c5ce7;border-color:var(--todo-primary)}.image-upload-section.required{background:#fdcb6e1a;border-color:#fdcb6e;border-color:var(--todo-warning)}.required-indicator{margin-bottom:1rem}.required-indicator span{background:#fdcb6e;background:var(--todo-warning);border-radius:.5rem;border-radius:var(--todo-radius-sm);color:#2d3748;color:var(--todo-dark);font-size:.75rem;font-weight:600;padding:.25rem .75rem}.upload-area{align-items:center;background:#fff;background:var(--todo-white);border:2px solid #e2e8f0;border:2px solid var(--todo-light-gray);border-radius:.5rem;border-radius:var(--todo-radius-sm);color:#718096;color:var(--todo-gray);cursor:pointer;display:inline-flex;flex-direction:column;font-weight:500;gap:.5rem;padding:1rem 2rem;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--todo-transition)}.upload-area:hover{background:#ddd6fe;background:var(--todo-light);border-color:#6c5ce7;border-color:var(--todo-primary);color:#6c5ce7;color:var(--todo-primary)}.file-input{display:none}.uploading-status{align-items:center;color:#6c5ce7;color:var(--todo-primary);display:flex;font-size:.875rem;gap:.5rem;margin-top:1rem}.entry-items{display:flex;flex-direction:column;gap:.5rem;padding:1rem 1.5rem 1.5rem}.modern-item-card{background:#ffffff80;border:1px solid #e2e8f0;border:1px solid var(--todo-light-gray);border-radius:.5rem;border-radius:var(--todo-radius-sm);overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);transition:var(--todo-transition)}.modern-item-card.completed{background:#00b8941a;opacity:.8}.item-header{align-items:flex-start;display:flex;gap:1rem;padding:1rem}.item-content{flex:1 1}.item-content h4{color:#2d3748;color:var(--todo-dark);font-size:1rem;font-weight:500;margin-bottom:.25rem}.completion-info{align-items:center;background:#00b8941a;border-top:1px solid #00b89433;color:#00b894;color:var(--todo-success);display:flex;font-size:.75rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem}.delete-confirmation-modal{background:#fff;background:var(--todo-white);border:1px solid #e2e8f0;border:1px solid var(--todo-light-gray);border-radius:.5rem;border-radius:var(--todo-radius-sm);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;box-shadow:var(--todo-shadow-lg);min-width:200px;padding:1rem;position:absolute;right:0;top:100%;z-index:10}.delete-confirmation-modal p{color:#2d3748;color:var(--todo-dark);font-size:.875rem;margin-bottom:1rem}.confirmation-actions{display:flex;gap:.5rem;justify-content:flex-end}.modern-alert{align-items:flex-start;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:.75rem;border-radius:var(--todo-radius);display:flex;gap:1rem;margin-bottom:1.5rem;padding:1rem 1.5rem}.modern-alert span:first-child{flex-shrink:0;font-size:1.25rem}.modern-alert.error{background:#e170551a;border:1px solid #e170554d;color:#e17055;color:var(--todo-danger)}.modern-alert.success{background:#00b8941a;border:1px solid #00b8944d;color:#00b894;color:var(--todo-success)}.modern-alert strong{display:block;font-weight:600;margin-bottom:.25rem}.modern-alert p{font-size:.875rem;margin:0}.loading-section{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border-radius:.75rem;border-radius:var(--todo-radius);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--todo-shadow);display:flex;flex-direction:column;justify-content:center;margin-bottom:2rem;padding:3rem}.loading-spinner{display:inline-block;height:2rem;margin-bottom:1rem;width:2rem}.spinner{animation:rotate 2s linear infinite}.path{stroke-linecap:round;stroke-dasharray:90,150;stroke-dashoffset:0;stroke:#6c5ce7;stroke:var(--todo-primary);animation:dash 1.5s ease-in-out infinite}@keyframes rotate{to{transform:rotate(1turn)}}@keyframes dash{0%{stroke-dasharray:1,150;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35}to{stroke-dasharray:90,150;stroke-dashoffset:-124}}.loading-section p{color:#718096;color:var(--todo-gray);font-size:1rem}.empty-state{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border-radius:.75rem;border-radius:var(--todo-radius);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--todo-shadow);padding:4rem 2rem;text-align:center}.empty-icon{color:#718096;color:var(--todo-gray);height:4rem;margin:0 auto 1.5rem;opacity:.5;width:4rem}.empty-state h3{color:#2d3748;color:var(--todo-dark);font-size:1.5rem;font-weight:600;margin-bottom:1rem}.empty-state p{color:#718096;color:var(--todo-gray);font-size:1rem;line-height:1.5;margin:0 auto .5rem;max-width:500px}.error-state{align-items:center;background:#e170551a;border:1px solid #e170554d;border-radius:.5rem;border-radius:var(--todo-radius-sm);color:#e17055;color:var(--todo-danger);display:flex;gap:1rem;padding:2rem}.error-state span{font-size:1.5rem}.error-state p{font-weight:500;margin:0}@media (max-width:1024px){.modern-todo-list{padding:1rem}.form-row{grid-template-columns:1fr}.day-title{align-items:flex-start;flex-direction:column}}@media (max-width:768px){.modern-todo-list{padding:.5rem}.modern-breadcrumbs{margin-bottom:1rem;padding:1rem}.section-header{padding:1.5rem 1rem 1rem}.section-header h2{font-size:1.5rem}.modern-grid{gap:1rem;padding:1rem}.years-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.months-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.days-grid{grid-template-columns:repeat(auto-fill,minmax(60px,1fr))}.day-header{padding:1.5rem}.day-title h2{font-size:1.5rem}.modern-form{padding:1.5rem}.entry-header,.task-header{align-items:flex-start;flex-direction:column;padding:1rem}.task-checkbox-section{width:100%}.entry-actions,.task-actions{justify-content:flex-end;width:100%}.entries-list,.tasks-list{padding:1rem}.delete-confirmation-modal{left:50%;max-width:300px;position:fixed;top:50%;transform:translate(-50%,-50%);width:90%}}@media (max-width:480px){.breadcrumb-item{font-size:.875rem;padding:.25rem .5rem}.modern-button{font-size:.875rem;padding:.5rem 1rem}.form-actions{flex-direction:column}.days-grid{grid-template-columns:repeat(auto-fill,minmax(50px,1fr))}.day-card{min-height:60px}.day-number{font-size:1rem}}.todo-templates{margin:0 auto;max-width:1200px;padding:20px;width:100%}.todo-templates h1{color:#333;margin-bottom:20px}.error-message{background-color:#ffebee;color:#d32f2f}.error-message,.success-message{border-radius:4px;margin:10px 0;padding:10px}.success-message{background-color:#e8f5e9;color:#2e7d32}.template-form-container{background-color:#f5f5f5;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:30px;padding:20px}.template-form-container h2{color:#333;font-size:18px;margin-bottom:20px}.form-group label{color:#555;font-weight:700;margin-bottom:5px}.form-control{border:1px solid #ddd;border-radius:4px;font-size:14px;padding:10px;width:100%}textarea.form-control{min-height:80px;resize:vertical}.checkbox-group label{font-weight:400}.checkbox-group input[type=checkbox]{margin-right:8px}.template-item{background-color:#fff;border:1px solid #e0e0e0;border-radius:4px;margin-bottom:15px;padding:15px}.add-item-button{background-color:#e3f2fd;border:1px dashed #2196f3;border-radius:4px;color:#2196f3;cursor:pointer;font-size:14px;margin-bottom:20px;padding:10px;text-align:center;width:100%}.add-item-button:hover{background-color:#bbdefb}.remove-item-button{background-color:#ffebee;border:none;border-radius:4px;color:#f44336;cursor:pointer;font-size:12px;padding:5px 10px}.remove-item-button:hover{background-color:#ffcdd2}.form-actions{gap:10px;margin-top:20px}.submit-button{background-color:#2196f3;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:10px 20px}.submit-button:hover{background-color:#1976d2}.submit-button:disabled{background-color:#90caf9;cursor:not-allowed}.cancel-button{background-color:#e0e0e0;border:none;color:#333;padding:10px 20px}.cancel-button:hover{background-color:#bdbdbd}.templates-list{margin-top:30px}.templates-list h2{color:#333;font-size:18px;margin-bottom:20px}.template-card{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;padding:20px;position:relative}.template-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.template-header h3{color:#333;font-size:18px;margin:0}.status-badge.active{background-color:#e8f5e9;color:#2e7d32}.status-badge.inactive{background-color:#f5f5f5;color:#757575}.template-description{color:#666;font-size:14px;margin-bottom:15px}.template-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:15px;position:relative}.delete-button,.edit-button,.status-button{background-color:#e3f2fd;border:none;border-radius:4px;color:#2196f3;cursor:pointer;flex:0 0 auto;font-size:14px;padding:5px 10px}.edit-button:hover{background-color:#bbdefb}.delete-button{background-color:#ffebee;color:#f44336}.delete-button:hover{background-color:#ffcdd2}.loading,.no-templates{background-color:#fff;border-radius:8px;color:#757575;padding:30px;text-align:center}.status-button{border:none;border-radius:4px;cursor:pointer;font-size:14px;padding:5px 10px}.status-button.activate{background-color:#e8f5e9;color:#2e7d32}.status-button.deactivate{background-color:#ffebee;color:#f44336}.status-button:hover.activate{background-color:#c8e6c9}.status-button:hover.deactivate{background-color:#ffcdd2}.status-button:disabled{cursor:not-allowed;opacity:.5}.activation-confirmation,.delete-confirmation{background-color:#f9f9f9;border:1px solid #e0e0e0;border-radius:4px;box-shadow:0 2px 8px #0000001a;left:0;margin:15px 0 0;padding:15px;position:absolute;width:calc(100% - 40px);z-index:10}.confirmation-warning{color:#f44336;font-size:13px;font-weight:700;margin-bottom:10px}.cancel-activation,.cancel-delete,.confirm-activation,.confirm-delete{border:none;border-radius:4px;cursor:pointer;font-size:14px;margin-right:8px;padding:5px 10px}.confirm-activation{background-color:#e8f5e9;color:#2e7d32}.confirm-activation:hover{background-color:#c8e6c9}.cancel-activation{background-color:#ffebee;color:#f44336}.cancel-activation:hover{background-color:#ffcdd2}.confirm-delete{background-color:#ffebee;color:#f44336;font-weight:700}.confirm-delete:hover{background-color:#ffcdd2}.cancel-delete{background-color:#e0e0e0;color:#333}.cancel-delete:hover{background-color:#bdbdbd}@media (max-width:768px){.template-header{align-items:flex-start;flex-direction:column}.status-badge{margin-top:5px}.template-actions{align-items:stretch;flex-direction:column;gap:5px}.delete-button,.edit-button,.status-button{margin:0;text-align:center;width:100%}.activation-confirmation,.delete-confirmation{left:0;margin-top:10px;position:relative;width:100%}.cancel-activation,.cancel-delete,.confirm-activation,.confirm-delete{display:block;margin:5px 0;text-align:center;width:100%}}.suppliers{background-color:#f9fafc;box-sizing:border-box;min-height:calc(100vh - 60px);padding:24px;width:100%}.section-header{align-items:center;border-bottom:1px solid #e0e6ed;display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.section-header h2{color:#1e293b;font-size:1.8rem;font-weight:600;margin:0}.test-button{background-color:#f1f5f9;border:1px solid #cbd5e1;border-radius:6px;color:#475569;cursor:pointer;font-weight:500;padding:8px 12px;transition:all .2s ease}.test-button:hover{background-color:#e2e8f0;box-shadow:0 1px 2px #0000000d}.tabs{border-bottom:1px solid #e0e6ed;display:flex;margin-bottom:24px;overflow-x:auto;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab-button{background:none;border:none;border-bottom:3px solid #0000;color:#64748b;cursor:pointer;font-weight:600;outline:none;padding:12px 20px;transition:all .3s;white-space:nowrap}.tab-button:hover{color:#1e40af}.tab-button.active{border-bottom-color:#2563eb;color:#2563eb}.tab-content{border-radius:8px;box-shadow:0 1px 3px #00000014,0 1px 2px #0000000a;margin-bottom:24px;padding:24px}.content-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.content-header h3{color:#1e293b;font-size:1.4rem;font-weight:600;margin:0}.add-button{background-color:#2563eb;border-radius:6px;box-shadow:0 1px 2px #0000000d;padding:10px 18px;transition:all .2s ease}.add-button:hover{background-color:#1d4ed8;box-shadow:0 2px 4px #0000001a}.add-button:active{transform:translateY(0)}.icon{font-size:16px;margin-right:8px}.filters{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px;padding:16px}.search-box{flex:1 1;min-width:200px}.search-box input{background-color:#fff;border:1px solid #cbd5e1;border-radius:6px;box-shadow:0 1px 2px #0000000d;padding:10px 14px;transition:all .2s ease;width:100%}.search-box input:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33;outline:none}.filter-box{align-items:center;display:flex;min-width:180px}.filter-box label{color:#475569;font-weight:500;margin-right:10px;white-space:nowrap}.filter-box input[type=date],.filter-box select{background-color:#fff;border:1px solid #cbd5e1;border-radius:6px;box-shadow:0 1px 2px #0000000d;color:#1e293b;flex:1 1;min-width:120px;padding:10px 14px;transition:all .2s ease}.filter-box input[type=date]:focus,.filter-box select:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33;outline:none}.data-table{border-collapse:initial;border-radius:8px;border-spacing:0;box-shadow:0 1px 3px #00000014;margin-top:12px;overflow:hidden}.data-table th{background-color:#f1f5f9;border-bottom:2px solid #e2e8f0;color:#475569;font-weight:600;padding:16px;text-align:left}.data-table td{border-bottom:1px solid #e2e8f0;color:#1e293b;padding:14px 16px}.data-table tbody tr:hover{background-color:#f8fafc}.active-row{background-color:#f0fdf4}.inactive-row{background-color:#fef2f2;color:#6b7280}.status-badge{border-radius:16px;font-weight:600;letter-spacing:.5px;padding:6px 10px;text-transform:capitalize}.status-badge.active{background-color:#dcfce7;color:#16a34a}.status-badge.inactive{background-color:#fee2e2;color:#dc2626}.status-badge.stock-ok{background-color:#dcfce7;color:#16a34a}.status-badge.stock-low{background-color:#ffedd5;color:#ea580c}.status-badge.stock-out{background-color:#fee2e2;color:#dc2626}.no-data{background-color:#f8fafc;border-radius:8px;color:#64748b;font-style:italic;padding:48px 0;text-align:center}.action-buttons{gap:8px;justify-content:center}.delete-button,.edit-button,.payment-button,.stock-button,.view-button{align-items:center;background:none;border:none;border-radius:6px;cursor:pointer;display:flex;height:30px;justify-content:center;padding:6px;transition:all .2s ease;width:30px}.edit-button{color:#2563eb}.delete-button{color:#dc2626}.view-button{color:#7c3aed}.payment-button{color:#16a34a}.stock-button{color:#ea580c}.edit-button:hover{background-color:#2563eb1a}.delete-button:hover{background-color:#dc26261a}.view-button:hover{background-color:#7c3aed1a}.payment-button:hover{background-color:#16a34a1a}.stock-button:hover{background-color:#ea580c1a}.payment-button:disabled,.stock-button:disabled{color:#cbd5e1;cursor:not-allowed}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal{animation:modal-appear .3s ease-out;background-color:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;max-height:90vh;max-width:800px;overflow-y:auto;width:90%}@keyframes modal-appear{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.wide-modal{max-width:1000px}.modal-header{align-items:center;background-color:#f8fafc;border-bottom:1px solid #e2e8f0;border-radius:12px 12px 0 0;display:flex;justify-content:space-between;padding:20px 24px}.modal-header h3{color:#1e293b;font-size:1.5rem;font-weight:600;margin:0}.close-button{align-items:center;border-radius:50%;color:#64748b;display:flex;height:32px;justify-content:center;transition:color .2s;width:32px}.close-button:hover{background-color:#f1f5f9;color:#1e293b}.form{padding:24px}.form-section{border-bottom:1px solid #e2e8f0;margin-bottom:28px;padding-bottom:24px}.form-section:last-child{border-bottom:none;margin-bottom:0}.form-section h4{color:#475569;font-size:1.2rem;font-weight:600;margin-bottom:20px;margin-top:0}.form-row{flex-wrap:wrap;gap:20px;margin-bottom:16px}.form-group{flex:1 1;margin-bottom:16px;min-width:200px}.form-group label{color:#475569}.form-group input[type=date],.form-group input[type=email],.form-group input[type=number],.form-group input[type=text],.form-group select,.form-group textarea{background-color:#fff;border:1px solid #cbd5e1;border-radius:6px;box-shadow:0 1px 2px #0000000d;box-sizing:border-box;color:#1e293b;font-size:14px;padding:10px 14px;transition:all .2s ease;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33;outline:none}.form-group textarea{min-height:100px}.checkbox-group input[type=checkbox]{accent-color:#2563eb;height:16px;margin-right:10px;width:16px}.categories-selection{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}.category-checkbox{align-items:center;background-color:#f1f5f9;border-radius:6px;cursor:pointer;display:flex;padding:8px 14px;transition:all .2s ease}.category-checkbox:hover{background-color:#e2e8f0}.category-checkbox input{accent-color:#2563eb;margin-right:10px}.form-actions{border-top:1px solid #e2e8f0;display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:24px}.cancel-button{background-color:#f1f5f9;border:1px solid #cbd5e1;border-radius:6px;color:#475569;font-weight:500;padding:10px 18px;transition:all .2s ease}.cancel-button:hover{background-color:#e2e8f0}.save-button{background-color:#2563eb;border-radius:6px;box-shadow:0 1px 2px #0000000d;font-weight:500;padding:10px 18px;transition:all .2s ease}.save-button:hover{background-color:#1d4ed8;box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.save-button:active{transform:translateY(0)}.loading{align-items:center;color:#64748b;display:flex;font-size:16px;justify-content:center;padding:48px}.loading:after{animation:spin 1s linear infinite;border:3px solid #cbd5e1;border-radius:50%;border-top-color:#2563eb;content:"";display:inline-block;height:24px;margin-left:12px;width:24px}.error-message{background-color:#fee2e2;border-left:4px solid #dc2626;border-radius:6px;color:#b91c1c;padding:16px}.add-category{align-items:center;display:flex;gap:12px;margin-top:16px}.add-category input{background-color:#fff;border:1px solid #cbd5e1;border-radius:6px;flex:1 1;padding:10px 14px}.add-category button{background-color:#2563eb;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:10px 16px;white-space:nowrap}.add-category button:hover{background-color:#1d4ed8}.text-right{text-align:right}.secondary-button{align-items:center;background-color:#f1f5f9;border:1px solid #cbd5e1;border-radius:6px;color:#475569;cursor:pointer;display:inline-flex;font-weight:500;gap:8px;padding:10px 16px;transition:all .2s ease}.secondary-button:hover{background-color:#e2e8f0}.invoice-modal{max-width:900px;width:90%}.invoice-viewer{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:20px;padding:24px;text-align:center}.order-items-table{border:1px solid #e2e8f0;border-radius:8px;margin-bottom:24px;overflow:hidden}.add-item-button{margin-top:16px;text-align:right}.upload-progress{background-color:#f1f5f9;border-radius:6px;height:8px;margin-top:12px;overflow:hidden;position:relative}.progress-bar{background-color:#2563eb;border-radius:6px;height:100%;transition:width .3s}.status-badge.status-pending{background-color:#ffedd5;color:#c2410c}.status-badge.status-delivered{background-color:#dcfce7;color:#15803d}.status-badge.status-cancelled{background-color:#fee2e2;color:#b91c1c}.status-badge.payment-paid{background-color:#dcfce7;color:#15803d}.status-badge.payment-unpaid{background-color:#fee2e2;color:#b91c1c}.status-badge.payment-partial{background-color:#ffedd5;color:#c2410c}@media (max-width:992px){.modal{max-width:none;width:95%}.form-row{flex-direction:column;gap:10px}.form-group{min-width:100%}}@media (max-width:768px){.suppliers{padding:16px}.content-header,.section-header{align-items:flex-start;flex-direction:column;gap:12px}.content-header h3,.section-header h2{margin-bottom:8px}.filters{flex-direction:column;padding:12px}.data-table{display:block;overflow-x:auto}.button-text{display:none}.add-button{padding:10px}.icon{margin-right:0}.form,.modal-header{padding:16px}.form-section{margin-bottom:16px;padding-bottom:16px}}@media (max-width:480px){.action-buttons{flex-wrap:wrap}.tabs{gap:0}.tab-button{font-size:14px;padding:10px 14px}}.ord-container{box-sizing:border-box;padding:20px;width:100%}.ord-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.ord-title{color:#333;font-size:1.8rem;margin:0}.ord-test-button{background-color:#f5f5f5;border:1px solid #ddd;border-radius:4px;cursor:pointer;padding:5px 10px;transition:background-color .2s}.ord-test-button:hover{background-color:#e5e5e5}.ord-filters{background-color:#f9f9f9;border-radius:8px;box-shadow:0 1px 3px #00000014;display:flex;flex-wrap:wrap;gap:15px;margin-bottom:25px;padding:15px}.ord-search-box{flex:1 1;min-width:200px}.ord-search-box input{border:1px solid #ddd;border-radius:4px;padding:10px 12px;transition:border-color .2s;width:100%}.ord-search-box input:focus{border-color:#4a90e2;outline:none}.ord-filter-box{align-items:center;display:flex;min-width:180px}.ord-filter-label{color:#555;font-weight:500;margin-right:8px;white-space:nowrap}.ord-filter-select{background-color:#fff;border:1px solid #ddd;border-radius:4px;flex:1 1;padding:10px 12px;transition:border-color .2s}.ord-filter-select:focus{border-color:#4a90e2;outline:none}.ord-filter-date{border:1px solid #ddd;border-radius:4px;padding:8px 12px}.ord-filter-date:focus{border-color:#4a90e2;outline:none}.ord-table-container{border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.ord-table{background-color:#fff;border-collapse:collapse;width:100%}.ord-table th{background-color:#f5f7fa;border-bottom:2px solid #e0e0e0;color:#333;font-weight:600;padding:14px;position:sticky;text-align:left;top:0}.ord-table td{border-bottom:1px solid #f0f0f0;padding:14px;vertical-align:middle}.ord-table tr:hover{background-color:#f9fafc}.ord-active-row{background-color:#f8fffa}.ord-inactive-row{background-color:#fff9f9;color:#777}.ord-status-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:500;padding:5px 10px;text-transform:uppercase}.ord-status-pending{background-color:#fff3e0;color:#e65100}.ord-status-confirmed{background-color:#e3f2fd;color:#0d47a1}.ord-status-shipped{background-color:#e8f5e9;color:#1b5e20}.ord-status-delivered{background-color:#e0f7e0;color:#2e7d32}.ord-status-cancelled{background-color:#ffebee;color:#c62828}.ord-payment-paid{background-color:#e0f7e0;color:#2e7d32}.ord-payment-unpaid{background-color:#ffebee;color:#c62828}.ord-payment-partial{background-color:#fff3e0;color:#e65100}.ord-no-data{background-color:#fafafa;color:#777;font-style:italic;padding:50px 0;text-align:center}.ord-add-button{align-items:center;background-color:#4a90e2;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-weight:500;padding:10px 18px;transition:background-color .2s}.ord-add-button:hover{background-color:#3a7bcb}.ord-icon{font-size:16px;margin-right:8px}.ord-action-buttons{display:flex;gap:10px;justify-content:center}.ord-delete-button,.ord-doc-button,.ord-edit-button,.ord-payment-button,.ord-view-button{background:none;border:none;border-radius:4px;cursor:pointer;padding:6px;transition:background-color .2s}.ord-view-button{color:#673ab7}.ord-edit-button{color:#2196f3}.ord-delete-button{color:#f44336}.ord-payment-button{color:#4caf50}.ord-doc-button{color:#ff9800}.ord-view-button:hover{background-color:#673ab71a}.ord-edit-button:hover{background-color:#2196f31a}.ord-delete-button:hover{background-color:#f443361a}.ord-payment-button:hover{background-color:#4caf501a}.ord-doc-button:hover{background-color:#ff98001a}.ord-payment-button:disabled{color:#bdbdbd;cursor:not-allowed}.ord-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.ord-modal{background-color:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;max-height:90vh;max-width:800px;overflow-y:auto;width:90%}.ord-modal-wide{max-width:1000px}.ord-modal-header{align-items:center;background-color:#f9fafc;border-bottom:1px solid #eee;border-radius:8px 8px 0 0;display:flex;justify-content:space-between;padding:18px 24px}.ord-modal-title{color:#333;font-size:1.5rem;margin:0}.ord-close-button{background:none;border:none;color:#777;cursor:pointer;font-size:24px;transition:color .2s}.ord-close-button:hover{color:#333}.ord-form{padding:20px 24px}.ord-form-section{border-bottom:1px solid #f0f0f0;margin-bottom:25px;padding-bottom:20px}.ord-form-section:last-child{border-bottom:none}.ord-form-section-title{color:#444;font-size:1.3rem;font-weight:500;margin-bottom:20px;margin-top:0}.ord-form-row{display:flex;flex-wrap:wrap;gap:20px;margin-bottom:20px}.ord-form-group{flex:1 1;margin-bottom:15px;min-width:200px}.ord-form-label{color:#444;display:block;font-weight:500;margin-bottom:8px}.ord-form-control{background-color:#fff;border:1px solid #ddd;border-radius:4px;box-sizing:border-box;padding:10px 12px;transition:border-color .2s;width:100%}.ord-form-control:focus{border-color:#4a90e2;outline:none}.ord-form-textarea{min-height:100px;resize:vertical}.ord-checkbox-group{align-items:center;display:flex;gap:8px}.ord-checkbox{height:16px;margin-right:8px;width:16px}.ord-items-table{border:1px solid #eee;border-radius:4px;margin-bottom:20px;overflow:hidden}.ord-text-right{text-align:right}.ord-add-item-button{margin-top:15px;text-align:right}.ord-secondary-button{align-items:center;background-color:#f5f5f5;border:1px solid #ddd;border-radius:4px;color:#333;cursor:pointer;display:inline-flex;padding:10px 16px;transition:background-color .2s}.ord-secondary-button:hover{background-color:#e0e0e0}.ord-file-upload{margin-top:10px}.ord-file-input{margin-top:8px}.ord-upload-progress{background-color:#f1f1f1;border-radius:4px;height:20px;margin-top:12px;overflow:hidden;position:relative}.ord-progress-bar{background-color:#4caf50;border-radius:4px 0 0 4px;height:100%;transition:width .3s}.ord-progress-text{color:#333;color:#fff;font-size:12px;left:0;line-height:20px;mix-blend-mode:difference;position:absolute;right:0;text-align:center;top:0}.ord-invoice-modal{max-width:900px;width:90%}.ord-invoice-viewer{background-color:#f7f9fc;border:1px solid #eee;border-radius:4px;margin-bottom:20px;padding:24px;text-align:center}.ord-invoice-image{box-shadow:0 2px 8px #0000001a;max-height:600px;max-width:100%}.ord-invoice-frame{border:none;height:600px;width:100%}.ord-form-actions{border-top:1px solid #eee;display:flex;gap:15px;justify-content:flex-end;margin-top:25px;padding-top:20px}.ord-cancel-button{background-color:#f5f5f5;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-weight:500;padding:10px 20px;transition:background-color .2s}.ord-cancel-button:hover{background-color:#e0e0e0}.ord-save-button{background-color:#4a90e2;border:none;border-radius:4px;color:#fff;cursor:pointer;font-weight:500;padding:10px 20px;transition:background-color .2s}.ord-save-button:hover{background-color:#3a7bcb}.ord-loading{align-items:center;color:#777;display:flex;font-style:italic;justify-content:center;padding:50px}.ord-loading:after{animation:ord-spin 1s linear infinite;border:2px solid #ddd;border-radius:50%;border-top-color:#4a90e2;content:"";display:inline-block;height:20px;margin-left:10px;width:20px}@keyframes ord-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.ord-error-message{background-color:#ffebee;border-left:4px solid #c62828;border-radius:4px;color:#c62828;margin-bottom:20px;padding:15px}@media (max-width:992px){.ord-modal{max-width:none;width:95%}.ord-form-row{flex-direction:column;gap:10px}.ord-form-group{min-width:100%}}@media (max-width:768px){.ord-header{align-items:flex-start;gap:10px}.ord-filters,.ord-header{flex-direction:column}.ord-table{display:block;overflow-x:auto}.ord-button-text{display:none}.ord-add-button{padding:10px}.ord-icon{margin-right:0}.ord-form,.ord-modal-header{padding:15px}}@media (max-width:480px){.ord-action-buttons{flex-wrap:wrap}}.recipe-dashboard{margin:0;padding:0;width:100%}.dashboard-title{color:#1a202c;color:var(--text-primary,#1a202c);font-size:1.75rem;font-weight:700;letter-spacing:-.025em;margin-bottom:2rem}.stats-container{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:2rem}.stat-card{background-color:#fff;background-color:var(--bg-card,#fff);border:1px solid #f3f4f6;border:1px solid var(--border-light,#f3f4f6);border-radius:1rem;box-shadow:0 4px 6px -1px #0000000f,0 2px 4px -2px #0000000a;overflow:hidden;padding:2rem 1.5rem;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1)}.stat-card:before{background:linear-gradient(90deg,#2563eb,#3b82f6);background:linear-gradient(90deg,var(--accent-primary,#2563eb),var(--accent-secondary,#3b82f6));border-radius:1rem 1rem 0 0;content:"";height:4px;left:0;position:absolute;right:0;top:0}.stat-card:hover{box-shadow:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000f;transform:translateY(-2px)}.stat-value{color:#1a202c;color:var(--text-primary,#1a202c);font-size:2rem;margin-bottom:.75rem}.stat-card:first-child .stat-value{color:#2563eb;color:var(--accent-primary,#2563eb)}.stat-card:nth-child(2) .stat-value{color:#d97706;color:var(--accent-orange,#d97706)}.stat-card:nth-child(3) .stat-value{color:#059669;color:var(--accent-green,#059669)}.stat-card:nth-child(4) .stat-value{color:#3b82f6;color:var(--accent-secondary,#3b82f6)}.stat-label{color:#4a5568;color:var(--text-secondary,#4a5568);font-size:.875rem;font-weight:600;letter-spacing:.025em;text-transform:uppercase}.tab-navigation{background-color:#fff;background-color:var(--bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:1rem;box-shadow:0 1px 2px 0 #00000008;display:flex;margin-bottom:1.5rem;overflow-x:auto;padding:.5rem;scrollbar-color:#e5e7eb #0000;scrollbar-color:var(--border-color,#e5e7eb) #0000;scrollbar-width:thin}.tab-navigation::-webkit-scrollbar{height:4px}.tab-navigation::-webkit-scrollbar-track{background:#0000}.tab-navigation::-webkit-scrollbar-thumb{background:#e5e7eb;background:var(--border-color,#e5e7eb);border-radius:2px}.tab-item{align-items:center;border-radius:.75rem;color:#4a5568;color:var(--text-secondary,#4a5568);cursor:pointer;display:flex;font-size:.9rem;font-weight:500;padding:.875rem 1.25rem;position:relative;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap}.tab-item:hover{background-color:#2563eb0d;color:#2563eb;color:var(--accent-primary,#2563eb)}.tab-item.active{background-color:#2563eb;background-color:var(--accent-primary,#2563eb);box-shadow:0 4px 6px -1px #2563eb33;color:#fff;font-weight:600}.tab-icon{align-items:center;display:flex;height:18px;justify-content:center;margin-right:.75rem;width:18px}.tab-label{font-weight:inherit}.tab-content{background-color:#fff;background-color:var(--bg-card,#fff);border:1px solid #f3f4f6;border:1px solid var(--border-light,#f3f4f6);border-radius:1rem;box-shadow:0 1px 2px 0 #00000008;min-height:400px;padding:2rem}@media (max-width:768px){.stats-container{gap:1rem;grid-template-columns:repeat(2,1fr)}.stat-card{padding:1.5rem 1rem}.stat-value{font-size:1.5rem}.tab-item{padding:.75rem 1rem}.tab-label{font-size:.875rem}.tab-content{min-height:300px;padding:1.5rem}.dashboard-title{font-size:1.5rem;margin-bottom:1.5rem}}@media (max-width:480px){.stats-container{grid-template-columns:1fr}.tab-navigation{padding:.375rem}.tab-item{font-size:.8rem;padding:.625rem .875rem}.tab-icon{height:16px;margin-right:.5rem;width:16px}.tab-content{padding:1.25rem}}.menu-item-selector{width:100%}.action-buttons{gap:10px}.category-button{align-items:center;background-color:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-weight:500;height:42px;padding:0 15px}.category-button:hover{background-color:#5a6268}.category-button.active{background-color:#0d6efd}.category-list-container{background-color:#f8f9fa;border:1px solid #ddd;border-radius:5px;margin-bottom:20px;padding:15px}.category-list-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.category-list-header h3{font-size:18px;margin:0}.add-category-button{align-items:center;background-color:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;padding:6px 12px}.add-category-button:hover{background-color:#218838}.category-list{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.category-item{background-color:#fff;border:1px solid #ddd;border-radius:4px;display:flex;flex-direction:column;padding:15px}.category-item-content{flex-grow:1;margin-bottom:10px}.category-name{font-size:16px;margin-bottom:10px;margin-top:0}.category-description{color:#666;font-size:14px;margin-bottom:10px}.category-meta{color:#666;display:flex;font-size:13px;gap:15px;margin-bottom:5px}.category-status{border-radius:3px;font-weight:500;padding:2px 6px}.category-status.active{background-color:#d4edda;color:#155724}.category-status.inactive{background-color:#f8d7da;color:#721c24}.category-item-actions{display:flex;gap:8px}.close-button{font-size:18px}.inline-button{background:none;border:none;color:#0d6efd;cursor:pointer;font-size:inherit;margin-left:5px;padding:0;text-decoration:underline}.menu-item-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.menu-item-card{background-color:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 2px 4px #0000000d;display:flex;flex-direction:column;height:100%;overflow:hidden}.menu-item-image-container{height:150px;overflow:hidden}.menu-item-image{height:100%;object-fit:cover;width:100%}.menu-item-content{flex-grow:1;padding:15px}.menu-item-title{font-size:18px;margin-bottom:10px}.menu-item-badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:10px}.category-badge{background-color:#e6f7ff;color:#06c}.category-badge,.price-badge{border-radius:4px;font-size:12px;font-weight:500;padding:4px 8px}.price-badge{background-color:#f6ffed;color:#52c41a}.inactive-badge{background-color:#fff2e8;border-radius:4px;color:#fa541c;font-size:12px;font-weight:500;padding:4px 8px}.menu-item-description{color:#666;font-size:14px;margin-top:10px}.menu-item-footer{border-top:1px solid #eee;display:flex;flex-direction:column;gap:10px;padding:15px}.menu-item-actions{display:flex;gap:8px}.delete-button,.edit-button{border-radius:4px;flex:1 1;font-size:14px;justify-content:center;padding:8px 0}.recipe-button{align-items:center;border:none;border-radius:4px;cursor:pointer;display:flex;font-weight:500;justify-content:center;padding:8px 0;width:100%}.recipe-button.primary{background-color:#1890ff;color:#fff}.recipe-button.warning{background-color:#faad14;color:#fff}.recipe-button:hover{opacity:.9}@media (max-width:768px){.actions-bar,.filter-container{flex-direction:column}.actions-bar{align-items:stretch}.action-buttons{margin-top:10px}.form-row{flex-direction:column;gap:10px}.category-list,.menu-item-grid{grid-template-columns:1fr}}.cost-analysis{margin:0;padding:0;width:100%}.filter-container{background-color:#f8f9fa;border:1px solid #ddd;border-radius:5px;margin-bottom:20px;padding:15px}.filter-select{font-size:inherit}.loading-container{padding:40px 0}.error-message{color:#f5222d}.info-message{padding:40px 15px}.summary-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px}.stat-card{background-color:#f9f9f9;border:1px solid #ddd;border-radius:5px;padding:20px;text-align:center}.stat-title{color:#666;font-size:16px;margin:0 0 10px}.stat-value{font-size:24px;font-weight:700;margin-bottom:5px}.stat-label{color:#666;font-size:14px;margin-bottom:5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stat-percent{color:#666;font-size:16px}.positive{color:#52c41a}.negative{color:#f5222d}.chart-container{background-color:#fff;border:1px solid #ddd;border-radius:5px;box-shadow:0 2px 8px #0000000d;margin-bottom:30px;padding:20px}.custom-tooltip{background-color:#ffffffe6;border:1px solid #ddd;border-radius:4px;padding:10px}.tooltip-label{font-weight:700;margin:0 0 10px}.tooltip-entry{font-size:14px;margin:0}.data-table-container{margin-bottom:30px}.table-title{font-size:18px;margin:0 0 15px}.table-wrapper{border:1px solid #ddd;border-radius:4px;overflow-x:auto}.data-table{border-collapse:collapse;width:100%}.data-table td,.data-table th{border-bottom:1px solid #ddd;padding:12px 15px;text-align:left}.data-table th{background-color:#f8f9fa;font-weight:700;position:sticky;top:0;z-index:1}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover{background-color:#f5f5f5}.data-table td.positive{color:#52c41a}.data-table td.negative{color:#f5222d}.data-table tfoot{border-top:2px solid #ddd}.data-table tfoot th{font-weight:700}@media (max-width:768px){.filter-container{flex-direction:column}.reset-button{align-self:flex-start}.data-table td:nth-child(2),.data-table th:nth-child(2){display:none}}.rcp-modal-overlay{align-items:center;animation:rcpFadeIn .2s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background-color:#0006;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.rcp-modal{animation:rcpSlideUp .3s ease-out;background-color:#fff;border:1px solid #f3f4f6;border-radius:1rem;box-shadow:0 20px 25px -5px #0000001f,0 10px 10px -5px #00000014;display:flex;flex-direction:column;max-height:90vh;max-width:900px;width:90%}.rcp-modal-header{align-items:center;background-color:#fafbfc;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;padding:1.5rem 2rem}.rcp-modal-header h2{color:#1a202c;font-size:1.375rem;font-weight:600;margin:0}.rcp-modal-close-button{align-items:center;background:none;border:none;border-radius:.5rem;color:#718096;cursor:pointer;display:flex;font-size:1.5rem;height:2.5rem;justify-content:center;transition:all .2s cubic-bezier(.4,0,.2,1);width:2.5rem}.rcp-modal-close-button:hover{background-color:#f3f4f6;color:#4a5568}.rcp-modal-close-button:disabled{cursor:not-allowed;opacity:.5}.rcp-modal-tabs{background-color:#fafbfc;border-bottom:1px solid #f3f4f6;display:flex;overflow-x:auto;scrollbar-width:thin}.rcp-tab{border-bottom:3px solid #0000;color:#4a5568;cursor:pointer;font-size:.9rem;font-weight:500;padding:1rem 1.5rem;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap}.rcp-tab:hover{background-color:#2563eb0d;color:#2563eb}.rcp-tab.active{background-color:#fff;border-bottom-color:#2563eb;color:#2563eb;font-weight:600}.rcp-modal-body{flex-grow:1;max-height:calc(90vh - 200px);overflow-y:auto;padding:2rem}.rcp-form{display:flex;flex-direction:column;height:100%}.rcp-tab-content{animation:rcpFadeIn .3s ease-out}.rcp-form-group{margin-bottom:1.25rem}.rcp-form-group label{color:#1a202c;display:block;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.rcp-form-group input,.rcp-form-group select,.rcp-form-group textarea{background-color:#fff;border:1px solid #e5e7eb;border-radius:.75rem;color:#1a202c;font-family:inherit;font-size:.9rem;padding:.75rem 1rem;transition:all .2s cubic-bezier(.4,0,.2,1);width:100%}.rcp-form-group input:focus,.rcp-form-group select:focus,.rcp-form-group textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.rcp-form-group textarea{min-height:100px;resize:vertical}.rcp-form-group .rcp-has-error{border-color:#4a5568!important}.rcp-error-text{color:#4a5568!important;font-size:.8rem;font-weight:500;margin-top:.375rem}.rcp-form-row{display:flex;flex-wrap:wrap;gap:1rem}.rcp-form-group.half{flex:1 1;min-width:200px}.rcp-form-group.quarter{flex-basis:calc(25% - 1rem);flex-grow:0;flex-shrink:0;min-width:120px}.rcp-ingredient-form{background-color:#fafbfc;border:1px solid #f3f4f6;border-radius:1rem;margin-bottom:1.5rem;padding:1.5rem}.rcp-ingredient-form h3{color:#1a202c;font-size:1.125rem;font-weight:600;margin-bottom:1rem;margin-top:0}.rcp-add-ingredient-button{align-items:center;background-color:#2563eb;border:none;border-radius:.75rem;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:.5rem;padding:.75rem 1.25rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.rcp-add-ingredient-button:hover{background-color:#3b82f6;box-shadow:0 4px 6px -1px #2563eb33;transform:translateY(-1px)}.rcp-add-ingredient-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.rcp-button-icon{font-size:.875rem}.rcp-divider{border:0;border-top:1px solid #f3f4f6;margin:1.5rem 0}.rcp-ingredients-list h3{color:#1a202c;font-size:1.125rem;font-weight:600;margin-bottom:1rem;margin-top:0}.rcp-ingredients-table-container{border:1px solid #f3f4f6;border-radius:.75rem;overflow-x:auto}.rcp-ingredients-table{border-collapse:collapse;margin-top:0;width:100%}.rcp-ingredients-table td,.rcp-ingredients-table th{border-bottom:1px solid #f3f4f6;padding:1rem .75rem;text-align:left}.rcp-ingredients-table th{background-color:#fafbfc;color:#1a202c;font-size:.875rem;font-weight:600}.rcp-ingredients-table td{color:#4a5568;font-size:.9rem}.rcp-ingredients-table tfoot th{background-color:#f3f4f6;color:#1a202c;font-weight:700}.rcp-text-right{text-align:right}.rcp-remove-ingredient-button{align-items:center;background-color:#718096!important;border:none;border-radius:.5rem;color:#fff!important;cursor:pointer;display:flex;justify-content:center;padding:.5rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.rcp-remove-ingredient-button:hover{background-color:#4a5568!important;transform:scale(1.05)}.rcp-remove-ingredient-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.rcp-summary-section{display:flex;flex-direction:column;gap:1.5rem}.rcp-summary-cards{display:flex;flex-wrap:wrap;gap:1.5rem}.rcp-summary-card{border:1px solid #f3f4f6;border-radius:1rem;box-shadow:0 1px 2px 0 #00000008;flex:1 1;min-width:300px;overflow:hidden}.rcp-summary-card-header{background-color:#fafbfc;border-bottom:1px solid #f3f4f6;color:#1a202c;font-size:1rem;font-weight:600;margin:0;padding:1rem 1.25rem}.rcp-summary-card-content{padding:1.25rem}.rcp-summary-item{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.rcp-summary-label{color:#4a5568;font-size:.9rem;font-weight:500}.rcp-summary-value{color:#1a202c;font-size:.9rem;font-weight:600}.rcp-profit-value{color:#1a202c!important;font-weight:600}.rcp-preparation-instructions{background-color:#fafbfc;border:1px solid #f3f4f6;border-radius:1rem;padding:1.5rem}.rcp-preparation-instructions h3{color:#1a202c;font-size:1.125rem;font-weight:600;margin-bottom:1rem;margin-top:0}.rcp-instructions-text{color:#4a5568;line-height:1.6;margin:0;white-space:pre-line}.rcp-modal-footer{background-color:#fafbfc;border-top:1px solid #f3f4f6;display:flex;gap:.75rem;justify-content:flex-end;padding:1.5rem 2rem}.rcp-cancel-button{background-color:#fafbfc;border:1px solid #e5e7eb;border-radius:.75rem;color:#4a5568;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.rcp-cancel-button:hover{background-color:#f3f4f6;border-color:#e5e7eb}.rcp-cancel-button:disabled{cursor:not-allowed;opacity:.6}.rcp-save-button{align-items:center;background-color:#2563eb;border:none;border-radius:.75rem;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.rcp-save-button:hover{background-color:#3b82f6;box-shadow:0 4px 6px -1px #2563eb33;transform:translateY(-1px)}.rcp-save-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.rcp-button-spinner{animation:rcpSpin 1s linear infinite;border:2px solid #ffffff4d;border-left-color:#fff;border-radius:50%;height:16px;width:16px}.rcp-error-message{background-color:#f3f4f6!important;border:1px solid #e5e7eb!important;border-radius:.75rem;color:#4a5568!important;font-weight:500;margin-bottom:1.5rem;padding:1rem 1.25rem!important}.rcp-error-message.small{font-size:.875rem;padding:.75rem 1rem!important}.rcp-info-message{background-color:#2563eb0d;border:1px solid #2563eb33;border-radius:.75rem;color:#2563eb;font-weight:500;margin-bottom:1.5rem;padding:1rem 1.25rem;text-align:center}.rcp-info-message.small{font-size:.875rem;padding:.75rem 1rem}@keyframes rcpFadeIn{0%{opacity:0}to{opacity:1}}@keyframes rcpSlideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes rcpSpin{to{transform:rotate(1turn)}}@media (max-width:768px){.rcp-modal{margin:1rem;max-height:95vh;width:95%}.rcp-modal-body,.rcp-modal-footer,.rcp-modal-header{padding-left:1.5rem;padding-right:1.5rem}.rcp-form-row,.rcp-summary-cards{flex-direction:column}.rcp-form-row{gap:.75rem}.rcp-form-group.quarter{width:100%}.rcp-modal-tabs{overflow-x:scroll}.rcp-tab{font-size:.875rem;padding:.875rem 1.25rem}.rcp-ingredients-table td,.rcp-ingredients-table th{font-size:.8rem;padding:.75rem .5rem}}.recipe-management{margin:0;padding:0;width:100%}.filter-panel{background-color:#fff;background-color:var(--bg-card,#fff);border:1px solid #f3f4f6;border:1px solid var(--border-light,#f3f4f6);border-radius:1rem;box-shadow:0 1px 2px 0 #00000008;display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;padding:1.5rem}.filter-label{font-size:.875rem;font-weight:600;margin-bottom:.5rem}.filter-label,.filter-select{color:#1a202c;color:var(--text-primary,#1a202c)}.filter-select{background-color:var(--bg-card,#fff);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:.75rem;font-family:inherit;font-size:.9rem;padding:.75rem 1rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.filter-select:focus{border-color:#2563eb;border-color:var(--accent-primary,#2563eb);box-shadow:0 0 0 3px #2563eb1a;outline:none}.reset-button{align-self:flex-end;background-color:#fafbfc;background-color:var(--bg-primary,#fafbfc);border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:.75rem;color:#4a5568;color:var(--text-secondary,#4a5568);font-size:.9rem;gap:.5rem;padding:0 1.25rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.reset-button:hover{background-color:#f3f4f6;background-color:var(--border-light,#f3f4f6);border-color:#e5e7eb;border-color:var(--border-color,#e5e7eb);color:#1a202c;color:var(--text-primary,#1a202c)}.add-button{align-self:flex-end;background-color:#059669;background-color:var(--accent-green,#059669);border-radius:.75rem;font-size:.9rem;font-weight:600;gap:.5rem;padding:0 1.25rem;transition:all .2s cubic-bezier(.4,0,.2,1)}.add-button:hover{background-color:#047857;box-shadow:0 4px 6px -1px #05966933;transform:translateY(-1px)}.add-button:disabled{transform:none}.button-icon{font-size:.875rem}.recipe-table-container{background-color:#fff;background-color:var(--bg-card,#fff);border:1px solid #f3f4f6;border:1px solid var(--border-light,#f3f4f6);border-radius:1rem;box-shadow:0 1px 2px 0 #00000008;overflow-x:auto;width:100%}.recipe-table{border-collapse:collapse;margin-bottom:0;width:100%}.recipe-table td,.recipe-table th{border-bottom:1px solid #f3f4f6;border-bottom:1px solid var(--border-light,#f3f4f6);padding:1rem .75rem;text-align:left;vertical-align:middle}.recipe-table th{background-color:#2563eb08;color:#1a202c;color:var(--text-primary,#1a202c);font-size:.875rem;font-weight:600;position:sticky;top:0;z-index:1}.recipe-table td{color:#4a5568;color:var(--text-secondary,#4a5568);font-size:.9rem}.recipe-table tr:last-child td{border-bottom:none}.recipe-table tr:hover{background-color:#2563eb05}.profit-badge{border-radius:.5rem;display:inline-block;font-size:.8rem;font-weight:600;padding:.375rem .75rem}.profit-badge.positive{background-color:#0596691a;color:#059669;color:var(--accent-green,#059669)}.profit-badge.negative{background-color:#dc26261a;color:#dc2626;color:var(--accent-red,#dc2626)}.action-buttons{display:flex;gap:.5rem}.delete-button,.edit-button{align-items:center;border:none;border-radius:.5rem;cursor:pointer;display:flex;font-size:.8rem;font-weight:500;gap:.375rem;padding:.5rem .875rem;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap}.edit-button{background-color:#2563eb;background-color:var(--accent-primary,#2563eb);color:#fff}.delete-button{background-color:#dc2626;background-color:var(--accent-red,#dc2626)}.edit-button:hover{background-color:#3b82f6;background-color:var(--accent-secondary,#3b82f6);box-shadow:0 2px 4px -1px #2563eb33;transform:translateY(-1px)}.delete-button:hover{background-color:#b91c1c;box-shadow:0 2px 4px -1px #dc262633;transform:translateY(-1px)}.delete-button:disabled,.edit-button:disabled{cursor:not-allowed;opacity:.5;transform:none}.loading-container{background-color:#fff;background-color:var(--bg-card,#fff);border:1px solid #f3f4f6;border:1px solid var(--border-light,#f3f4f6);border-radius:1rem;min-height:250px;padding:3rem 0}.loading-spinner{border:3px solid #2563eb33;border-left:3px solid var(--accent-primary,#2563eb)}.loading-text{color:#4a5568;color:var(--text-secondary,#4a5568);font-weight:500;margin-top:1rem}.error-message{align-items:center;background-color:#dc26260d;border:1px solid #dc262633;border-radius:.75rem;color:#dc2626;color:var(--accent-red,#dc2626);display:flex;font-weight:500;gap:.75rem;margin-bottom:1.5rem;padding:1rem 1.25rem}.error-message:before{content:"⚠️";font-size:1.125rem}.info-message{background-color:#2563eb0d;border:1px solid #2563eb33;border-radius:1rem;color:#2563eb;color:var(--accent-primary,#2563eb);font-weight:500;margin-bottom:1.5rem;padding:3rem 1.5rem}@media (max-width:768px){.filter-panel{flex-direction:column;gap:.75rem;padding:1.25rem}.add-button,.reset-button{align-self:stretch;justify-content:center}.action-buttons{flex-direction:column;gap:.375rem}.delete-button,.edit-button{justify-content:center;padding:.625rem .875rem;width:100%}.recipe-table td,.recipe-table th{font-size:.8rem;padding:.75rem .5rem}}@media (max-width:1024px){.recipe-table td:nth-child(3),.recipe-table td:nth-child(4),.recipe-table th:nth-child(3),.recipe-table th:nth-child(4){display:none}}@media (max-width:768px){.recipe-table td:nth-child(2),.recipe-table td:nth-child(6),.recipe-table th:nth-child(2),.recipe-table th:nth-child(6){display:none}}@media (max-width:480px){.filter-panel{padding:1rem}.recipe-table td,.recipe-table th{font-size:.75rem;padding:.625rem .375rem}.profit-badge{font-size:.7rem;padding:.25rem .5rem}}.toast-container{display:flex;flex-direction:column;gap:10px;max-width:450px;pointer-events:none;position:fixed;right:20px;top:20px;z-index:9999}.toast-notification{align-items:center;animation:toast-in .3s ease forwards;background-color:#fff;border-left:4px solid #999;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;margin-bottom:10px;max-width:100%;min-width:300px;padding:12px 16px;pointer-events:auto;will-change:transform,opacity}.toast-notification.exiting{animation:toast-out .3s ease forwards}@keyframes toast-in{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@keyframes toast-out{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(100%)}}.toast-notification.success{border-left-color:#4caf50}.toast-notification.error{border-left-color:#f44336}.toast-notification.warning{border-left-color:#ff9800}.toast-notification.info{border-left-color:#2196f3}.toast-icon{align-items:center;display:flex;font-size:20px;justify-content:center;margin-right:12px}.toast-notification.success .toast-icon{color:#4caf50}.toast-notification.error .toast-icon{color:#f44336}.toast-notification.warning .toast-icon{color:#ff9800}.toast-notification.info .toast-icon{color:#2196f3}.toast-message{color:#333;flex:1 1;font-size:14px;font-weight:500;line-height:1.5;word-break:break-word}.toast-close{align-items:center;background:none;border:none;border-radius:50%;color:#777;cursor:pointer;display:flex;font-size:16px;justify-content:center;margin-left:8px;padding:4px;transition:color .2s}.toast-close:hover{background-color:#0000000d;color:#333}@media (prefers-color-scheme:dark){.toast-notification{background-color:#333;box-shadow:0 4px 12px #0000004d}.toast-message{color:#fff}.toast-close{color:#aaa}.toast-close:hover{background-color:#ffffff1a;color:#fff}}.confirm-dialog-overlay{align-items:center;animation:overlay-in .2s ease forwards;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.confirm-dialog-overlay.exiting{animation:overlay-out .2s ease forwards}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}@keyframes overlay-out{0%{opacity:1}to{opacity:0}}.confirm-dialog{animation:dialog-in .3s ease forwards;background-color:#fff;border-radius:8px;box-shadow:0 4px 20px #0003;display:flex;flex-direction:column;max-width:500px;overflow:hidden;width:90%}.confirm-dialog.exiting{animation:dialog-out .2s ease forwards}@keyframes dialog-in{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes dialog-out{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.9)}}.confirm-dialog-header{align-items:center;border-bottom:1px solid #eee;display:flex;padding:16px 20px}.confirm-dialog.warning .confirm-dialog-header{border-bottom-color:#ff980033}.confirm-dialog.error .confirm-dialog-header{border-bottom-color:#f4433633}.confirm-dialog.info .confirm-dialog-header{border-bottom-color:#2196f333}.confirm-dialog-icon{align-items:center;display:flex;font-size:20px;justify-content:center;margin-right:12px}.confirm-dialog.warning .confirm-dialog-icon{color:#ff9800}.confirm-dialog.error .confirm-dialog-icon{color:#f44336}.confirm-dialog.info .confirm-dialog-icon{color:#2196f3}.confirm-dialog-title{color:#333;flex:1 1;font-size:18px;font-weight:600;margin:0}.confirm-dialog-close{align-items:center;background:none;border:none;border-radius:50%;color:#777;cursor:pointer;display:flex;font-size:16px;justify-content:center;padding:4px}.confirm-dialog-close:hover{background-color:#0000000d;color:#333}.confirm-dialog-content{flex:1 1;padding:20px}.confirm-dialog-message{color:#444;font-size:15px;line-height:1.5;margin:0}.confirm-dialog-actions{border-top:1px solid #eee;display:flex;gap:12px;justify-content:flex-end;padding:16px 20px}.confirm-dialog-button{align-items:center;border:none;border-radius:4px;cursor:pointer;display:flex;font-size:14px;font-weight:500;justify-content:center;padding:8px 16px;transition:background-color .2s}.confirm-dialog-button.cancel{background-color:#f5f5f5;color:#333}.confirm-dialog-button.cancel:hover{background-color:#e0e0e0}.confirm-dialog-button.confirm{background-color:#2196f3;color:#fff}.confirm-dialog.warning .confirm-dialog-button.confirm{background-color:#ff9800}.confirm-dialog.error .confirm-dialog-button.confirm{background-color:#f44336}.button-icon{margin-right:6px}@media (prefers-color-scheme:dark){.confirm-dialog{background-color:#333}.confirm-dialog-header{border-bottom-color:#444}.confirm-dialog-title{color:#fff}.confirm-dialog-message{color:#ddd}.confirm-dialog-actions{border-top-color:#444}.confirm-dialog-button.cancel{background-color:#444;color:#fff}.confirm-dialog-button.cancel:hover{background-color:#555}.confirm-dialog-close:hover{background-color:#ffffff1a}}.ingredient-manager{width:100%}.actions-bar{align-items:flex-end;display:flex;justify-content:space-between;margin-bottom:20px}.filter-container{display:flex;flex:1 1;flex-wrap:wrap;gap:15px}.filter-group{flex:1 1;min-width:200px}.filter-label{display:block;font-weight:500;margin-bottom:8px}.filter-select{background-color:#fff;border:1px solid #ddd;border-radius:4px;padding:10px;width:100%}.search-input-container{position:relative}.search-icon{color:#666;left:10px;position:absolute;top:50%;transform:translateY(-50%)}.search-input{padding:10px 10px 10px 35px;width:100%}.reset-button,.search-input{border:1px solid #ddd;border-radius:4px}.reset-button{align-items:center;background-color:#f5f5f5;cursor:pointer;display:flex;font-weight:500;height:42px;padding:0 15px}.reset-button:hover{background-color:#e9e9e9}.reset-button:disabled{cursor:not-allowed;opacity:.5}.add-button{align-items:center;background-color:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-weight:500;height:42px;margin-left:15px;padding:0 15px}.add-button:hover{background-color:#218838}.add-button:disabled{cursor:not-allowed;opacity:.5}.button-icon{margin-right:8px}.form-container{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.form{background-color:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;flex-direction:column;max-width:600px;width:90%}.form-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:15px 20px}.form-header h3{font-size:18px;margin:0}.close-button{background:none;border:none;color:#666;cursor:pointer;font-size:24px}.form-body{max-height:60vh;overflow-y:auto;padding:20px}.form-group{margin-bottom:15px}.form-group label{display:block;font-weight:500;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:inherit;padding:10px;width:100%}.form-group textarea{resize:vertical}.form-row{display:flex;gap:15px;margin-bottom:15px}.form-row .form-group{flex:1 1;margin-bottom:0}.checkbox-group,.checkbox-group label{align-items:center;display:flex}.checkbox-group label{cursor:pointer;margin-bottom:0}.checkbox-group input{margin-right:8px;width:auto}.form-help-text{color:#666;font-size:12px;margin-top:5px}.form-footer{border-top:1px solid #eee;display:flex;gap:10px;justify-content:flex-end;padding:15px 20px}.cancel-button{background-color:#f5f5f5;border:1px solid #ddd;border-radius:4px;cursor:pointer;padding:8px 15px}.cancel-button:hover{background-color:#e9e9e9}.save-button{background-color:#0d6efd;border:none;border-radius:4px;color:#fff;cursor:pointer;padding:8px 15px}.save-button:hover{background-color:#0b5ed7}.cancel-button:disabled,.save-button:disabled{cursor:not-allowed;opacity:.5}.ingredient-table-container{border:1px solid #ddd;border-radius:4px;margin-bottom:20px;overflow-x:auto;width:100%}.ingredient-table{border-collapse:collapse;width:100%}.ingredient-table td,.ingredient-table th{border-bottom:1px solid #ddd;padding:12px 15px;text-align:left}.ingredient-table th{background-color:#f8f9fa;font-weight:700}.ingredient-table tr:last-child td{border-bottom:none}.ingredient-table tr:hover{background-color:#f5f5f5}.inactive-row{background-color:#f9f9f9;color:#888}.ingredient-name{font-weight:500}.ingredient-description{color:#666;font-size:12px;margin-top:4px}.linked-product{color:#0d6efd}.linked-product,.no-product{align-items:center;display:flex;gap:5px}.no-product{color:#6c757d;font-style:italic}.link-icon,.status-badge{font-size:12px}.status-badge{border-radius:4px;display:inline-block;font-weight:500;padding:4px 8px}.status-badge.active{background-color:#d4edda;color:#155724}.status-badge.inactive{background-color:#f8d7da;color:#721c24}.table-actions{display:flex;gap:8px}.table-actions button{align-items:center;border:none;border-radius:4px;cursor:pointer;display:flex;height:32px;justify-content:center;width:32px}.edit-button{background-color:#ffc107;color:#212529}.delete-button{background-color:#dc3545;color:#fff}.edit-button:hover{background-color:#e0a800}.delete-button:hover{background-color:#c82333}.table-actions button:disabled{cursor:not-allowed;opacity:.5}.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:200px}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #0000001a;border-left-color:#1890ff;border-radius:50%;height:40px;width:40px}.loading-text{color:#666;margin-top:15px}.error-message{background-color:#fff1f0;border:1px solid #ffa39e;border-radius:5px;color:#cf1322}.error-message,.info-message{margin-bottom:20px;padding:15px}.info-message{background-color:#e6f7ff;border:1px solid #91d5ff;border-radius:5px;color:#06c;text-align:center}@media (max-width:768px){.actions-bar,.filter-container{flex-direction:column}.actions-bar{align-items:stretch}.add-button{margin-left:0;margin-top:10px}.form-row{flex-direction:column;gap:10px}}.employee-login-container{align-items:center;background:linear-gradient(135deg,#2c3e50,#4ca1af);display:flex;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;justify-content:center;min-height:100vh;padding:20px}.employee-login-card{background-color:#fffffff2;border-radius:12px;box-shadow:0 15px 30px #0003;max-width:420px;overflow:hidden;padding:40px;position:relative;transition:transform .3s ease,box-shadow .3s ease;width:100%}.employee-login-card:hover{box-shadow:0 20px 40px #00000040;transform:translateY(-5px)}.employee-login-card:before{background:linear-gradient(90deg,#ff7e5f,#feb47b);content:"";height:6px;left:0;position:absolute;top:0;width:100%}.employee-login-card h2{color:#2c3e50;font-size:28px;font-weight:600;margin-bottom:30px;text-align:center}.employee-login-container .form-group{margin-bottom:24px}.employee-login-container label{color:#546e7a;display:block;font-size:14px;font-weight:500;margin-bottom:8px;transition:color .3s}.employee-login-container input{background-color:#f5f5f5;border:2px solid #e0e0e0;border-radius:8px;color:#37474f;font-size:16px;padding:14px 16px;transition:all .3s;width:100%}.employee-login-container input:focus{background-color:#fff;border-color:#4ca1af;box-shadow:0 2px 8px #4ca1af33;outline:none}.employee-login-container input:focus+label{color:#4ca1af}.employee-login-container .login-button{background:linear-gradient(90deg,#4ca1af,#2c3e50);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:10px;overflow:hidden;padding:14px;position:relative;transition:all .3s;width:100%}.employee-login-container .login-button:hover{background:linear-gradient(90deg,#2c3e50,#4ca1af);box-shadow:0 4px 12px #2c3e504d}.employee-login-container .login-button:disabled{background:#b0bec5;cursor:not-allowed}.employee-login-container .login-button:after{background:#ffffff4d;border-radius:50%;content:"";height:10px;left:50%;position:absolute;top:50%;transform:scale(0) translate(-50%,-50%);transform-origin:top left;transition:transform .5s;width:10px}.employee-login-container .login-button:active:after{transform:scale(25) translate(-50%,-50%)}.employee-login-container .error-message{animation:shake .5s ease-in-out;background-color:#f443361a;border-left:4px solid #f44336;border-radius:8px;color:#f44336;font-size:14px;margin-bottom:20px;padding:12px 16px}@keyframes shake{0%,to{transform:translateX(0)}10%,30%,50%,70%,90%{transform:translateX(-5px)}20%,40%,60%,80%{transform:translateX(5px)}}@media (max-width:480px){.employee-login-card{padding:30px 20px}.employee-login-container input{padding:12px 14px}}.employee-login-container input:focus-visible{outline:2px solid #4ca1af;outline-offset:1px}.employee-login-container .login-button:focus-visible{outline:2px solid #fff;outline-offset:1px}.employee-sidebar{background:linear-gradient(180deg,#ff7e5f,#feb47b);box-shadow:0 0 20px #0000001a;color:#fff;display:flex;flex-direction:column;height:100vh;left:0;overflow-y:auto;position:fixed;top:0;transition:all .3s ease;width:260px;z-index:100}.employee-sidebar.closed{transform:translateX(-100%)}.employee-sidebar.open{transform:translateX(0)}.employee-sidebar-header{border-bottom:1px solid #fff3;padding:20px;text-align:center}.employee-sidebar-header h1{font-size:24px;font-weight:600;letter-spacing:.5px;margin:0 0 10px}.employee-info{background-color:#0000001a;border-radius:20px;color:#ffffffe6;display:inline-block;font-size:14px;padding:5px 15px}.employee-name{font-weight:500}.employee-sidebar-menu{flex-grow:1;padding:20px 0}.employee-sidebar-menu ul{list-style:none;margin:0;padding:0}.employee-sidebar-menu li{align-items:center;border-left:4px solid #0000;cursor:pointer;display:flex;padding:15px 20px;transition:all .2s ease}.employee-sidebar-menu li:hover{background-color:#ffffff1a}.employee-sidebar-menu li.active{background-color:#fff3;border-left:4px solid #fff}.employee-sidebar-icon{align-items:center;display:flex;margin-right:15px}.employee-sidebar-label{font-size:16px;font-weight:500}.employee-sidebar-footer{border-top:1px solid #fff3;padding:20px}.employee-logout-button{align-items:center;background:#0000001a;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;padding:10px 15px;transition:all .2s ease;width:100%}.employee-logout-button:hover{background:#0003}.employee-logout-button svg{margin-right:10px}.employee-sidebar-toggle-button{align-items:center;background-color:#ff7e5f;border:none;border-radius:50%;box-shadow:0 2px 10px #0003;color:#fff;cursor:pointer;display:flex;height:50px;justify-content:center;left:15px;position:fixed;top:15px;transition:background-color .3s;width:50px;z-index:101}.employee-sidebar-toggle-button:hover{background-color:#e86e53}.employee-sidebar-overlay{background-color:#00000080;height:100%;left:0;position:fixed;top:0;width:100%;z-index:99}@media screen and (max-width:768px){.employee-sidebar{width:240px}.employee-sidebar-header h1{font-size:20px}.employee-sidebar-menu li{padding:12px 15px}.employee-sidebar-label{font-size:15px}body.sidebar-open{overflow:hidden}}@media screen and (min-width:769px){.employee-dashboard-content{margin-left:260px;transition:margin-left .3s ease}.employee-dashboard-content.sidebar-closed{margin-left:0}}.employee-shift-view{background-color:#f8f9fa;border-radius:12px;box-shadow:0 2px 10px #0000000d;padding:20px}.employee-section-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.employee-section-header h2{font-size:26px}.employee-view-toggle{background-color:#e9ecef;border-radius:30px;display:flex;overflow:hidden;padding:3px}.employee-view-toggle button{background:none;border:none;border-radius:25px;color:#555;cursor:pointer;font-size:14px;padding:8px 20px;transition:all .3s ease}.employee-view-toggle button.active{background-color:#ff7e5f;color:#fff;font-weight:500}.employee-calendar-controls{margin-bottom:20px}.employee-month-navigation,.employee-week-navigation{align-items:center;display:flex;gap:10px}.employee-nav-button{align-items:center;background-color:#fff;border:1px solid #ddd;border-radius:20px;color:#444;cursor:pointer;display:flex;padding:6px 12px;transition:all .2s}.employee-nav-button:hover{background-color:#f0f0f0}.employee-icon{color:#ff7e5f;font-size:18px}.employee-nav-text{font-size:14px;margin:0 5px}.employee-current-button{background-color:#febf63;border:none;border-radius:20px;cursor:pointer;font-weight:500;padding:6px 15px;transition:all .2s}.employee-current-button:hover{background-color:#f5a742}.employee-month-display h3,.employee-week-display h3{color:#444;font-size:18px;font-weight:500;margin:0}.employee-weekly-calendar{background-color:#fff;border-radius:10px;box-shadow:0 2px 8px #00000014;margin-bottom:20px;overflow:hidden}.employee-calendar-header{background-color:#f5f7f9;border-bottom:1px solid #e6e9ed;display:grid;grid-template-columns:repeat(7,1fr)}.employee-day-header{border-right:1px solid #e6e9ed;padding:12px 8px;text-align:center}.employee-day-header:last-child{border-right:none}.employee-day-name{color:#444;font-size:14px;font-weight:600}.employee-day-date{color:#666;font-size:13px;margin-top:3px}.employee-calendar-body{display:grid;grid-template-columns:repeat(7,1fr);min-height:150px}.employee-day-column{border-right:1px solid #e6e9ed;min-height:150px;padding:8px}.employee-day-column:last-child{border-right:none}.employee-day-shifts{display:flex;flex-direction:column;gap:8px}.employee-shift-card{background-color:#f9f9f9;border-radius:6px;box-shadow:0 1px 3px #0000000d;font-size:13px;padding:8px 10px;transition:transform .2s}.employee-shift-card:hover{box-shadow:0 3px 8px #00000014;transform:translateY(-2px)}.employee-shift-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.employee-shift-type{color:#333;font-weight:600}.employee-shift-time{color:#555;margin-bottom:5px}.employee-shift-notes{color:#777;font-size:12px;font-style:italic;word-break:break-word}.employee-no-shifts{color:#999;font-size:13px;font-style:italic;padding:20px 0;text-align:center}.employee-monthly-calendar{background-color:#fff;border-radius:10px;box-shadow:0 2px 8px #00000014;margin-bottom:20px;overflow:hidden;padding:15px}.employee-calendar-weekdays{border-bottom:1px solid #eee;display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:10px;padding-bottom:10px;text-align:center}.employee-weekday{color:#444;font-size:14px;font-weight:600}.employee-calendar-days{grid-gap:2px;display:grid;gap:2px;grid-template-columns:repeat(7,1fr)}.employee-calendar-day{aspect-ratio:1;border:1px solid #eee;border-radius:5px;padding:5px;position:relative;transition:all .2s}.employee-calendar-day:hover,.employee-other-month{background-color:#f9f9f9}.employee-other-month{opacity:.5}.employee-has-shift{background-color:#f8f9fa;border-color:#e0e0e0}.employee-day-number{color:#333;font-size:14px;font-weight:500;margin-bottom:5px}.employee-day-shift-indicator{display:flex;flex-wrap:wrap;gap:3px;margin-top:3px}.employee-shift-dot{border-radius:50%;height:8px;margin-right:2px;width:8px}.employee-shift-summary{display:flex;gap:20px;margin-top:20px}.employee-summary-card{background-color:#fff;border-radius:10px;box-shadow:0 2px 8px #00000014;flex-grow:1;padding:15px 20px}.employee-summary-card h4{color:#444;font-size:16px;font-weight:500;margin:0 0 10px}.employee-total-hours{color:#ff7e5f;font-size:24px;font-weight:600}.employee-shift-legend{background-color:#fff;border-radius:10px;box-shadow:0 2px 8px #00000014;min-width:200px;padding:15px 20px}.employee-shift-legend h4{color:#444;font-size:16px;font-weight:500;margin:0 0 10px}.employee-legend-items{display:flex;flex-direction:column;gap:8px}.employee-legend-item{align-items:center;display:flex;font-size:13px}.employee-legend-color{border-radius:3px;height:12px;margin-right:8px;width:12px}.employee-legend-label{color:#555}.employee-error-message{border-radius:5px;margin:20px 0;padding:15px}@media screen and (max-width:768px){.employee-calendar-controls,.employee-section-header{align-items:flex-start;flex-direction:column;gap:15px}.employee-day-name{font-size:12px}.employee-day-date{font-size:11px}.employee-shift-summary{flex-direction:column}.employee-view-toggle button{font-size:13px;padding:8px 15px}}.employee-image-upload-component{background-color:#fff;border-radius:12px;box-shadow:0 2px 10px #0000000d;overflow:hidden;padding-bottom:20px}.employee-content-layout{gap:20px;padding:0 20px}.employee-calendar-container{border-right:1px solid #eee;flex-basis:300px;min-width:280px;padding-right:20px}.employee-calendar-header{margin-bottom:20px;padding-top:20px}.employee-calendar-header h3{color:#444;font-size:18px;font-weight:500;margin:0 0 10px}.employee-date-display{background-color:#f5f5f5;border-radius:8px;padding:10px;text-align:center}.employee-selected-date{color:#ff7e5f;font-weight:500}.employee-selector-heading{color:#444;font-size:16px;font-weight:500;margin:15px 0 10px}.employee-months-selector{margin-bottom:20px}.employee-month-buttons{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(4,1fr)}.employee-month-button{background-color:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:14px;padding:8px 0;text-align:center;transition:all .2s}.employee-month-button:hover{background-color:#f8f8f8;border-color:#ccc}.employee-month-button.active{background-color:#ff7e5f;border-color:#ff7e5f;color:#fff;font-weight:500}.employee-days-grid{grid-gap:5px;display:grid;gap:5px;grid-template-columns:repeat(7,1fr)}.employee-day-button{background-color:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:13px;padding:8px 0;position:relative;text-align:center;transition:all .2s}.employee-day-button:hover{background-color:#f8f8f8;border-color:#ccc}.employee-day-button.active{background-color:#ff7e5f;border-color:#ff7e5f;color:#fff;font-weight:500}.employee-day-count{align-items:center;background-color:#4caf50;border-radius:50%;color:#fff;display:flex;font-size:11px;height:18px;justify-content:center;position:absolute;right:-5px;top:-5px;width:18px}.employee-gallery-container{flex-grow:1;padding-top:20px}.employee-upload-form-container{background-color:#f9f9f9;border-radius:8px;margin-bottom:25px;padding:20px}.employee-upload-form-container h3{color:#444;font-size:18px;font-weight:500;margin:0 0 15px}.employee-upload-form{grid-gap:15px;align-items:end;display:grid;gap:15px;grid-template-columns:1fr 2fr 1fr}.employee-form-group{display:flex;flex-direction:column;gap:5px}.employee-form-group label{color:#555;font-size:14px;font-weight:500}.employee-form-control{border:1px solid #ddd;border-radius:6px;color:#333;font-size:14px;padding:10px 12px}.employee-file-group{position:relative}.employee-file-input-container{align-items:center;display:flex;gap:10px}.employee-file-input{height:.1px;opacity:0;overflow:hidden;position:absolute;width:.1px;z-index:-1}.employee-file-button{background-color:#6c757d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:10px 15px;transition:all .2s;white-space:nowrap}.employee-file-button:hover{background-color:#5a6268}.employee-file-name{color:#666;font-size:13px;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.employee-upload-button{background-color:#ff7e5f;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.employee-upload-button:hover{background-color:#e86e53}.employee-upload-button:disabled{background-color:#ccc;cursor:not-allowed}.employee-error-message,.employee-success-message{border-radius:6px;font-size:14px;margin-top:15px;padding:10px 15px}.employee-image-display h3{align-items:center;color:#444;display:flex;font-size:18px;font-weight:500;margin:0 0 15px}.employee-loading-indicator{color:#666;font-size:14px;font-style:italic;font-weight:400}.employee-image-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.employee-image-item{background-color:#fff;border-radius:8px;box-shadow:0 2px 6px #0000001a;overflow:hidden;transition:all .3s}.employee-image-item:hover{box-shadow:0 5px 15px #00000026;transform:translateY(-5px)}.employee-image-item img{display:block;height:180px;object-fit:cover;width:100%}.employee-image-details{padding:12px}.employee-image-category{background-color:#ff7e5f1a;border-radius:20px;color:#ff7e5f;display:inline-block;font-size:12px;font-weight:600;margin-bottom:8px;padding:3px 8px}.employee-image-date,.employee-image-uploader{color:#666;display:block;font-size:13px;margin-top:5px}.employee-loading-message,.employee-no-images{background-color:#f8f8f8;border-radius:8px;color:#888;font-style:italic;grid-column:1/-1;padding:30px;text-align:center}@media screen and (max-width:992px){.employee-content-layout{flex-direction:column}.employee-calendar-container{border-bottom:1px solid #eee;border-right:none;flex-basis:auto;padding-bottom:20px;padding-right:0}.employee-upload-form{grid-template-columns:1fr}.employee-image-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}}.employee-check-in-component{padding:1rem;width:100%}.employee-section-header{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color,#e5e7eb);margin-bottom:1.5rem;padding-bottom:.5rem}.employee-section-header h2{color:#111827;color:var(--heading-color,#111827);font-size:1.5rem}.employee-content-layout{display:flex;flex-direction:column;gap:1.5rem}@media (min-width:768px){.employee-content-layout{flex-direction:row}.employee-check-in-main{flex:3 1}.employee-check-in-sidebar{flex:1 1}}.employee-check-in-status{background-color:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:.5rem;box-shadow:0 1px 3px #0000001a;margin-bottom:1.5rem;overflow:hidden}.employee-checked-in,.employee-not-checked-in{padding:1.25rem}.employee-status-header{align-items:center;display:flex;margin-bottom:1rem}.employee-status-header h3{font-size:1.25rem;font-weight:600;margin:0}.employee-status-icon{align-items:center;display:flex;height:24px;justify-content:center;margin-right:.75rem;width:24px}.employee-status-icon.success{color:#10b981;color:var(--success-color,#10b981)}.employee-status-icon.warning{color:#f59e0b;color:var(--warning-color,#f59e0b)}.employee-status-details{background-color:#f9fafb;border-radius:.375rem;margin-bottom:1rem;padding:1rem}.employee-status-item{border-bottom:1px dashed #e5e7eb;border-bottom:1px dashed var(--border-color,#e5e7eb);display:flex;justify-content:space-between;padding:.5rem 0}.employee-status-item:last-child{border-bottom:none}.employee-status-label{color:#4b5563;color:var(--text-medium,#4b5563);font-weight:500}.employee-status-value{color:#111827;color:var(--text-dark,#111827);font-weight:600}.employee-location-prompt{color:#4b5563;color:var(--text-medium,#4b5563);line-height:1.5;margin-bottom:1.25rem}.employee-verify-again-button,.employee-verify-button{align-items:center;border:none;border-radius:.375rem;cursor:pointer;display:flex;font-weight:500;justify-content:center;padding:.75rem 1rem;transition:all .2s ease;width:100%}.employee-verify-button{background-color:#2563eb;background-color:var(--primary-color,#2563eb);color:#fff}.employee-verify-button:hover{background-color:#1d4ed8;background-color:var(--primary-dark,#1d4ed8)}.employee-verify-button:disabled{cursor:not-allowed;opacity:.7}.employee-verify-again-button{background-color:#f3f4f6;border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);color:#4b5563;color:var(--text-medium,#4b5563)}.employee-verify-again-button:hover{background-color:#e5e7eb}.employee-button-icon{margin-right:.5rem}.employee-loading-spinner{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;display:inline-block;height:18px;margin-right:.5rem;width:18px}.employee-permission-warning{background-color:#fff7ed;border-left:4px solid #f97316;border-radius:.375rem;color:#9a3412;font-size:.875rem;margin-top:1rem;padding:.75rem}.employee-error-message,.employee-success-message{border-radius:.375rem;margin-bottom:1.5rem;padding:1rem}.employee-error-message{background-color:#fee2e2;border:1px solid #fecaca;color:#b91c1c}.employee-success-message{align-items:flex-start;background-color:#d1fae5;border:1px solid #a7f3d0;color:#047857;display:flex;flex-direction:column}.employee-message-icon{margin-bottom:.5rem}.employee-message-time{align-items:center;display:flex;font-size:.875rem;margin-bottom:0;margin-top:.5rem}.employee-message-icon-small{margin-right:.25rem}.employee-location-map{background-color:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:.5rem;box-shadow:0 1px 3px #0000001a;margin-bottom:1.5rem;overflow:hidden;padding:1.25rem}.employee-location-map h3{color:#111827;color:var(--heading-color,#111827);font-size:1.125rem;font-weight:600;margin-bottom:1rem;margin-top:0}.employee-map-container{align-items:center;display:flex;flex-direction:column}.employee-distance-info{margin-top:1rem;text-align:center}.employee-distance-value{font-size:1rem;margin-bottom:.5rem}.employee-radius-status{font-size:.875rem;font-weight:600}.employee-radius-status.success{color:#10b981;color:var(--success-color,#10b981)}.employee-radius-status.error{color:#ef4444;color:var(--error-color,#ef4444)}.employee-check-in-history{background-color:#fff;border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:.5rem;box-shadow:0 1px 3px #0000001a;overflow:hidden;padding:1.25rem}.employee-check-in-history h3{color:#111827;color:var(--heading-color,#111827);font-size:1.125rem;font-weight:600;margin-bottom:1rem;margin-top:0}.employee-history-list{display:flex;flex-direction:column;gap:.75rem}.employee-history-item{background-color:#f9fafb;border:1px solid #e5e7eb;border:1px solid var(--border-color,#e5e7eb);border-radius:.375rem;display:flex;flex-direction:column;padding:.75rem}.employee-history-date{color:#4b5563;color:var(--text-medium,#4b5563);font-size:.875rem;font-weight:500;margin-bottom:.5rem}.employee-history-status{align-items:center;display:flex}.employee-status-badge{border-radius:.25rem;display:inline-flex;font-size:.75rem;font-weight:600;padding:.25rem .5rem}.employee-status-badge.success{background-color:#d1fae5;color:#047857}.employee-status-badge.error{background-color:#fee2e2;color:#b91c1c}.employee-history-distance{color:#6b7280;color:var(--text-light,#6b7280);font-size:.75rem;margin-top:.25rem}@media (max-width:640px){.employee-status-item{flex-direction:column;gap:.25rem}.employee-status-label{font-size:.875rem}}.employee-todo-list{background-color:#fff;border-radius:12px;box-shadow:0 2px 10px #0000000d;overflow:hidden}.employee-section-header{background-color:#f8f9fa;border-bottom:1px solid #e9ecef;padding:20px}.employee-section-header h2{color:#333;font-size:24px;font-weight:600;margin:0}.employee-todo-container{padding:0 20px 20px}.employee-todo-header{border-bottom:1px solid #eee;justify-content:space-between;margin-bottom:20px;padding:20px 0}.employee-date-selector,.employee-todo-header{align-items:center;display:flex}.employee-date-selector label{color:#555;font-weight:500;margin-right:10px}.employee-date-input{border:1px solid #ddd;border-radius:6px;font-size:14px;padding:8px 12px}.employee-view-buttons{display:flex;gap:10px}.employee-view-button{background-color:#f0f0f0;border:1px solid #ddd;border-radius:6px;color:#555;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;position:relative;transition:all .2s ease}.employee-view-button:hover{background-color:#e9e9e9}.employee-view-button.active{background-color:#ff7e5f;border-color:#ff7e5f;color:#fff}.employee-task-count{align-items:center;background-color:#0000001a;border-radius:50%;display:inline-flex;font-size:12px;height:20px;justify-content:center;margin-left:6px;width:20px}.employee-view-button.active .employee-task-count{background-color:#fff;color:#ff7e5f}.employee-error-message,.employee-success-message{border-radius:6px;font-size:14px;margin:10px 0 20px;padding:12px 15px}.employee-error-message{background-color:#ffebee;color:#c62828}.employee-success-message{background-color:#e8f5e9;color:#2e7d32}.employee-loading{color:#666;font-style:italic;padding:30px;text-align:center}.employee-no-tasks{background-color:#f9f9f9;border-radius:8px;color:#888;font-style:italic;margin-top:10px;padding:40px 0;text-align:center}.employee-section-title{align-items:center;color:#333;display:flex;font-size:18px;font-weight:600;margin:20px 0 15px}.employee-tasks-remaining{color:#888;font-size:14px;font-weight:400;margin-left:8px}.employee-custom-tasks{margin-bottom:30px}.employee-task-list{display:flex;flex-direction:column;gap:15px}.employee-task-item{background-color:#fff;border:1px solid #eee;border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:15px;transition:all .2s ease}.employee-task-item:hover{box-shadow:0 4px 8px #00000014}.employee-task-item.completed{background-color:#f9f9f9;border-left:3px solid #4caf50}.employee-task-header{margin-bottom:8px}.employee-task-checkbox-label{align-items:center;cursor:pointer;display:flex}.employee-task-checkbox{cursor:pointer;height:18px;margin-right:10px;width:18px}.employee-task-title{color:#333;font-size:16px;font-weight:500}.employee-task-title.completed{color:#999;text-decoration:line-through}.employee-task-description{color:#666;font-size:14px;margin-bottom:12px;padding-left:28px}.employee-task-notes-container{margin-bottom:12px}.employee-task-notes{border:1px solid #ddd;border-radius:6px;color:#555;font-size:14px;min-height:80px;padding:10px;resize:vertical;width:100%}.employee-task-image-container{margin-top:15px}.employee-task-image img{border-radius:6px;display:block;margin:0 auto;max-height:300px;max-width:100%}.employee-task-image-upload{align-items:center;background-color:#f9f9f9;border:2px dashed #ddd;border-radius:6px;display:flex;flex-direction:column;gap:10px;padding:15px}.employee-image-upload-btn-wrapper{display:inline-block;overflow:hidden;position:relative}.employee-btn-upload-file{background-color:#fff;border:1px solid #ccc;border-radius:6px;color:#555;cursor:pointer;font-size:14px;padding:8px 15px}.employee-image-upload-input{cursor:pointer;height:100%;left:0;opacity:0;position:absolute;top:0;width:100%}.employee-uploading-status{color:#666;font-size:14px;font-style:italic;margin-top:5px}.employee-completion-info{color:#4caf50;font-size:13px;font-style:italic;margin-top:10px}.employee-template-entries{margin-top:30px}.employee-entry-card{background-color:#fff;border:1px solid #eee;border-radius:8px;box-shadow:0 2px 4px #0000000d;margin-bottom:20px;overflow:hidden}.employee-entry-header{background-color:#f8f9fa;border-bottom:1px solid #eee;padding:15px}.employee-entry-header h4{color:#333;font-size:17px;font-weight:600;margin:0 0 5px}.employee-entry-notes{color:#666;font-size:14px;margin-top:5px}.employee-entry-items{padding:0 15px 15px}.employee-entry-item{background-color:#fff;border:1px solid #eee;border-radius:6px;margin-top:15px;padding:15px;transition:all .2s ease}.employee-entry-item:hover{box-shadow:0 2px 8px #00000014}.employee-entry-item.completed{background-color:#f9f9f9;border-left:3px solid #4caf50}.employee-item-header{margin-bottom:8px}.employee-item-checkbox-label{align-items:center;cursor:pointer;display:flex}.employee-item-checkbox{cursor:pointer;height:18px;margin-right:10px;width:18px}.employee-item-title{color:#333;font-size:16px;font-weight:500}.employee-item-title.completed{color:#999;text-decoration:line-through}.employee-item-description{color:#666;font-size:14px;margin-bottom:12px;padding-left:28px}.employee-item-notes-container{margin-bottom:12px}.employee-item-notes{border:1px solid #ddd;border-radius:6px;color:#555;font-size:14px;min-height:80px;padding:10px;resize:vertical;width:100%}.employee-item-image-container{margin-top:15px}.employee-item-image img{border-radius:6px;display:block;margin:0 auto;max-height:300px;max-width:100%}.employee-item-image-upload{align-items:center;background-color:#f9f9f9;border:2px dashed #ddd;border-radius:6px;display:flex;flex-direction:column;gap:10px;padding:15px}@media screen and (max-width:768px){.employee-todo-header{align-items:flex-start;flex-direction:column;gap:15px}.employee-view-buttons{justify-content:space-between;width:100%}.employee-view-button{flex:1 1;font-size:13px;padding:8px 10px;text-align:center}.employee-item-title,.employee-task-title{font-size:15px}.employee-item-description,.employee-task-description{font-size:13px}.employee-item-notes,.employee-task-notes{min-height:60px}}.employee-dashboard{background-color:#f5f5f5;display:flex;min-height:100vh}.employee-dashboard-content{flex-grow:1;margin-left:260px;padding:30px;transition:margin-left .3s ease}.employee-dashboard-content.sidebar-closed{margin-left:0}.employee-loading-screen{align-items:center;color:#666;display:flex;font-size:18px;height:100vh;justify-content:center}@media screen and (max-width:768px){.employee-dashboard-content{margin-left:0;padding:70px 15px 15px}}*{box-sizing:border-box}.employee-availability *{float:none;position:static}.employee-availability{box-sizing:border-box;display:flex;flex-direction:column;gap:20px;max-width:100%;padding:20px;width:100%}.employee-section-header{margin-bottom:0;width:100%}.employee-section-header h2{color:#2c3e50;font-size:1.5em;margin-bottom:8px}.employee-instructions{color:#7f8c8d;font-size:.95em;margin-bottom:0}.employee-calendar-controls{align-items:center;background-color:#f8f9fa;border-radius:8px;box-sizing:border-box;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:0;padding:15px;width:100%}.employee-week-navigation{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.employee-current-button,.employee-nav-button{align-items:center;border:none;border-radius:4px;cursor:pointer;display:flex;font-size:.9em;font-weight:500;padding:8px 15px;transition:all .2s}.employee-nav-button{background-color:#e9ecef;color:#495057}.employee-nav-button:hover{background-color:#dee2e6}.employee-nav-button:disabled{cursor:not-allowed;opacity:.6}.employee-current-button{background-color:#007bff;color:#fff}.employee-current-button:hover{background-color:#0069d9}.employee-icon{font-size:1.2em;margin:0 4px}.employee-nav-text{white-space:nowrap}.employee-week-display{text-align:center}.employee-week-display h3{color:#495057;font-size:1.1em;font-weight:600;margin:0}.employee-availability-table-container{background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;box-sizing:border-box;margin-bottom:0;overflow-x:auto;width:100%}.employee-availability-table{border-collapse:collapse;min-width:900px;width:100%}.employee-availability-table td,.employee-availability-table th{border:1px solid #e0e0e0;padding:12px;text-align:center;vertical-align:middle}.employee-shift-type-header{text-align:left!important;width:200px}.employee-day-header,.employee-shift-type-header{background-color:#f8f9fa;color:#495057;font-weight:700}.employee-day-header{min-width:120px}.employee-day-name{font-size:.9em;font-weight:700;margin-bottom:4px}.employee-day-date{color:#6c757d;font-size:.8em;font-weight:400}.employee-shift-type-row:nth-child(2n){background-color:#fafafa}.employee-shift-type-cell{background-color:#fbfbfb;border-left-style:solid!important;border-left-width:4px!important;position:relative;text-align:left!important}.employee-shift-type-name{color:#2c3e50;font-size:.95em;font-weight:700;margin-bottom:4px}.employee-shift-type-time{color:#6c757d;font-size:.85em}.employee-availability-cell{padding:8px;text-align:center;vertical-align:middle}.employee-availability-checkbox{align-items:center;cursor:pointer;display:flex;flex-direction:column;gap:4px;justify-content:center;min-height:40px;position:relative;-webkit-user-select:none;user-select:none}.employee-availability-checkbox input{cursor:pointer;height:0;opacity:0;position:absolute;width:0}.employee-checkbox-custom{background-color:#f0f0f0;border:2px solid #ccc;border-radius:4px;display:inline-block;height:20px;position:relative;transition:all .2s;width:20px}.employee-availability-checkbox:hover .employee-checkbox-custom{background-color:#e0e0e0;border-color:#999}.employee-availability-checkbox input:checked~.employee-checkbox-custom{background-color:#4caf50;border-color:#4caf50}.employee-availability-checkbox input:disabled~.employee-checkbox-custom{background-color:#e9ecef;border-color:#dee2e6;cursor:not-allowed;opacity:.6}.employee-availability-checkbox input:disabled{cursor:not-allowed}.employee-availability-checkbox.employee-status-disabled{cursor:not-allowed;opacity:.6}.employee-checkbox-custom:after{border:solid #fff;border-width:0 2px 2px 0;content:"";display:none;height:10px;left:6px;position:absolute;top:2px;transform:rotate(45deg);width:4px}.employee-availability-checkbox input:checked~.employee-checkbox-custom:after{display:block}.employee-availability-status{font-size:.75em;font-weight:500;margin-top:2px;text-align:center;white-space:nowrap}.employee-status-approved .employee-availability-status{color:#28a745}.employee-status-pending .employee-availability-status{color:#ffc107}.employee-status-rejected .employee-availability-status{color:#dc3545}.employee-status-approved .employee-checkbox-custom{background-color:#28a745;border-color:#28a745}.employee-status-pending .employee-checkbox-custom{background-color:#ffc107;border-color:#ffc107}.employee-status-rejected .employee-checkbox-custom{background-color:#dc3545;border-color:#dc3545}.employee-success-message{background-color:#d4edda;border:1px solid #c3e6cb;border-radius:4px;color:#155724}.employee-error-message,.employee-success-message{box-sizing:border-box;margin-bottom:0;padding:12px;text-align:center;width:100%}.employee-error-message{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24}.employee-login-link{color:#007bff;margin:0 4px;text-decoration:none}.employee-login-link:hover{text-decoration:underline}.employee-processing .employee-checkbox-custom{position:relative}.employee-processing-spinner{animation:employee-spin .8s linear infinite;border:2px solid #f3f3f3;border-radius:50%;border-top-color:#007bff;height:12px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:12px}@keyframes employee-spin{0%{transform:translate(-50%,-50%) rotate(0deg)}to{transform:translate(-50%,-50%) rotate(1turn)}}.employee-processing{opacity:.8}.loading-indicator{color:#6c757d;padding:40px 20px;text-align:center}.loading-indicator .spinner{animation:spin 1s linear infinite;border:3px solid #f3f3f3;border-radius:50%;border-top-color:#007bff;height:30px;margin:0 auto 15px;width:30px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){.employee-availability{padding:10px}.employee-calendar-controls{align-items:stretch;flex-direction:column;text-align:center}.employee-week-navigation{justify-content:center;margin-bottom:10px}.employee-current-button,.employee-nav-button{font-size:.8em;padding:6px 12px}.employee-nav-text{display:none}.employee-availability-table{min-width:700px}.employee-shift-type-header{width:150px}.employee-day-header{min-width:80px}.employee-availability-table td,.employee-availability-table th{padding:8px 4px}}@media (max-width:480px){.employee-week-navigation{flex-direction:column;gap:8px}.employee-current-button,.employee-nav-button{justify-content:center;width:100%}.employee-nav-text{display:inline}}
/*# sourceMappingURL=main.8aa6f105.css.map*/