*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);color:#333;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}@media (max-width:768px){body{font-size:14px}}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;padding:12px 24px;text-decoration:none;transition:all .3s ease}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 15px #667eea66;color:#fff}.btn-primary:hover{box-shadow:0 6px 20px #667eea99;transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}.btn:disabled{cursor:not-allowed;opacity:.6;transform:none!important}.input{background:#fff;border:2px solid #e1e5e9;border-radius:8px;font-size:16px;padding:12px 16px;transition:all .3s ease;width:100%}.input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.input::placeholder{color:#9ca3af}.card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border-radius:16px;box-shadow:0 10px 25px #0000001a;padding:32px}@media (max-width:768px){.card{margin:16px;padding:24px}}.loading{animation:spin 1s ease-in-out infinite;border:3px solid #ffffff4d;border-radius:50%;border-top-color:#fff;display:inline-block;height:20px;width:20px}.container{margin:0 auto;max-width:1200px;padding:0 16px}@media (max-width:768px){.container{padding:0 12px}}.text-center{text-align:center}.text-primary{color:#667eea}.text-success{color:#10b981}.text-error{color:#ef4444}.text-lg{font-size:18px}.text-xl{font-size:20px}.text-2xl{font-size:24px}.font-bold{font-weight:700}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.w-full{width:100%}.login-page,.min-h-screen{min-height:100vh}.login-page{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;padding:20px;position:relative}.login-page:before{background:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cdefs%3E%3Cpattern id='a' width='100' height='100' patternUnits='userSpaceOnUse'%3E%3Ccircle cx='50' cy='50' r='1' fill='%23fff' opacity='.1'/%3E%3C/pattern%3E%3C/defs%3E%3Cpath fill='url(%23a)' d='M0 0h100v100H0z'/%3E%3C/svg%3E") repeat;bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.login-container{max-width:400px;position:relative;width:100%;z-index:1}.login-card{animation:slideUp .6s ease-out;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border:1px solid #fff3;border-radius:20px;box-shadow:0 20px 40px #0000001a;padding:40px}.login-header{margin-bottom:32px;text-align:center}.logo{margin-bottom:16px}.logo-icon{align-items:center;border-radius:16px;box-shadow:0 8px 16px #667eea4d;color:#fff;display:flex;height:64px;justify-content:center;margin:0 auto;width:64px}.login-title,.logo-icon{background:linear-gradient(135deg,#667eea,#764ba2)}.login-title{-webkit-text-fill-color:#0000;-webkit-background-clip:text;background-clip:text;color:#1f2937;font-size:28px;font-weight:700;margin-bottom:8px}.login-subtitle{color:#6b7280;font-size:16px;line-height:1.5}.login-form{gap:24px}.form-group,.login-form{display:flex;flex-direction:column}.form-group{gap:8px}.form-label{align-items:center;color:#374151;display:flex;font-size:14px;font-weight:600;gap:8px}.label-icon{color:#667eea}.form-input{background:#fff;border:2px solid #e5e7eb;border-radius:12px;color:#1f2937;font-size:16px;padding:14px 16px;transition:all .3s ease;width:100%}.form-input:focus{border-color:#667eea;box-shadow:0 0 0 4px #667eea1a;outline:none}.form-input::placeholder{color:#9ca3af}.form-input:disabled{background-color:#f9fafb;cursor:not-allowed}.password-input-container{align-items:center;display:flex;position:relative}.password-input{padding-right:48px}.password-toggle{align-items:center;background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;display:flex;justify-content:center;padding:4px;position:absolute;right:12px;transition:all .2s ease}.password-toggle:hover{background-color:#667eea1a;color:#667eea}.password-toggle:disabled{cursor:not-allowed;opacity:.5}.login-button{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 12px #667eea66;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;margin-top:8px;padding:16px;transition:all .3s ease;width:100%}.login-button:hover:not(:disabled){box-shadow:0 6px 16px #667eea80;transform:translateY(-2px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{cursor:not-allowed;opacity:.7;transform:none}.button-icon{font-size:18px}.loading-spinner{border:2px solid #ffffff4d;border-top-color:#fff;height:18px;width:18px}.login-footer{margin-top:32px;text-align:center}.footer-text{color:#6b7280;font-size:14px;line-height:1.5}@media (max-width:768px){.login-page{padding:16px}.login-card{border-radius:16px;padding:32px 24px}.login-title{font-size:24px}.login-subtitle{font-size:14px}.form-input{font-size:16px;padding:12px 14px}.login-button{font-size:16px;padding:14px}}@media (max-width:480px){.login-card{padding:24px 20px}.logo-icon{height:56px;width:56px}.login-title{font-size:22px}}.login-status{animation:fadeIn .3s ease-out;background:#3b82f61a;border:1px solid #3b82f633;border-radius:8px;margin:16px 0;padding:12px 16px}.status-indicator{align-items:center;color:#3b82f6;display:flex;font-size:14px;font-weight:500;gap:12px}.loading-spinner{border:2px solid #3b82f633;border-top-color:#3b82f6}@media (prefers-contrast:high){.login-card{background:#fff;border:2px solid #000}.form-input{border-color:#000}.login-button{background:#000}}@media (prefers-reduced-motion:reduce){.login-card{animation:none}.login-button{transition:none}.loading-spinner{animation:none}}.announcement-overlay{align-items:center;animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:9999}.announcement-modal{animation:slideUp .3s ease-out;background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 20px 40px #00000026;display:flex;flex-direction:column;max-height:85vh;max-width:400px;width:100%}.announcement-info{border-top:4px solid #667eea}.announcement-success{border-top:4px solid #10b981}.announcement-warning{border-top:4px solid #f59e0b}.announcement-error{border-top:4px solid #ef4444}.announcement-header{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;gap:.75rem;padding:1.5rem 1.5rem 1rem}.announcement-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:16px;height:32px;justify-content:center;width:32px}.announcement-info .announcement-icon{background:#667eea1a;color:#667eea}.announcement-success .announcement-icon{background:#10b9811a;color:#10b981}.announcement-warning .announcement-icon{background:#f59e0b1a;color:#f59e0b}.announcement-error .announcement-icon{background:#ef44441a;color:#ef4444}.announcement-title{color:#1f2937;flex:1 1;font-size:1.125rem;font-weight:600;line-height:1.4;margin:0}.announcement-close{align-items:center;background:none;border:none;border-radius:50%;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;height:32px;justify-content:center;transition:all .2s ease;width:32px}.announcement-close:hover{background:#f3f4f6;color:#374151}.announcement-body{flex:1 1;min-height:0;overflow-y:auto;padding:0 1.5rem 1.5rem}.announcement-content{word-wrap:break-word;color:#4b5563;font-size:.95rem;line-height:1.6;margin-bottom:1rem;overflow-wrap:break-word;white-space:pre-wrap}.announcement-version{background:#f1f5f9;border-radius:12px;color:#64748b;display:inline-block;font-size:.8rem;font-weight:500;margin-bottom:.75rem;padding:.25rem .75rem}.announcement-date{color:#9ca3af;font-size:.8rem;margin-bottom:1rem}.announcement-footer{background:#fff;border-bottom-left-radius:16px;border-bottom-right-radius:16px;border-top:1px solid #f1f5f9;flex-shrink:0;padding:0 1.5rem 1.5rem}.announcement-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;font-size:.95rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s ease;width:100%}.announcement-btn:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.announcement-btn:active{transform:translateY(0)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width:480px){.announcement-overlay{padding:.75rem}.announcement-modal{border-radius:12px;max-height:90vh;max-width:100%}.announcement-header{padding:1.25rem 1.25rem .75rem}.announcement-body,.announcement-footer{padding:0 1.25rem 1.25rem}.announcement-footer{border-bottom-left-radius:12px;border-bottom-right-radius:12px}.announcement-title{font-size:1rem}.announcement-content{font-size:.9rem}.announcement-btn{font-size:.9rem;padding:.875rem 1.5rem}}@media (max-width:360px){.announcement-overlay{padding:.5rem}.announcement-header{padding:1rem 1rem .5rem}.announcement-body{padding:0 1rem 1rem}.announcement-footer{border-bottom-left-radius:12px;border-bottom-right-radius:12px;padding:0 1rem 1rem}}.dashboard-page{background:linear-gradient(135deg,#f8fafc,#e2e8f0)}.dashboard-loading,.dashboard-page{display:flex;flex-direction:column;min-height:100vh}.dashboard-loading{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;gap:16px;justify-content:center}.dashboard-loading .loading-spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:40px;width:40px}.dashboard-header{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 10px #0000001a;color:#fff;padding:1rem 2rem}.header-content{align-items:center;display:flex;height:64px;justify-content:space-between;margin:0 auto;max-width:1200px}.header-left{gap:.75rem;justify-content:flex-start}.header-center,.header-left{align-items:center;display:flex;flex:1 1}.header-center{justify-content:center}.header-title{font-size:1.5rem;font-weight:600;margin:0;text-align:center}.header-right{flex:1 1;gap:1rem;justify-content:flex-end}.header-right,.logo{align-items:center;display:flex}.logo{color:#1f2937;font-size:18px;font-weight:700;gap:12px}.logo-icon{color:#667eea;font-size:24px}.user-info{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:20px;color:#fff;display:flex;font-weight:500;gap:.5rem;padding:.5rem 1rem}.user-icon{font-size:1rem}.logout-btn,.username{font-weight:500}.logout-btn{align-items:center;background:#ef4444;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;gap:6px;padding:8px 16px;transition:all .2s ease}.logout-btn:hover{background:#dc2626;transform:translateY(-1px)}.logout-icon{font-size:16px}.dashboard-main{flex:1 1;padding:24px}.dashboard-container{display:flex;flex-direction:column;gap:32px;margin:0 auto;max-width:1200px}.welcome-section{margin-bottom:8px}.welcome-card{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;box-shadow:0 10px 25px #667eea4d;color:#fff;display:flex;justify-content:space-between;padding:32px}.welcome-content{flex:1 1}.welcome-title{font-size:28px;font-weight:700;line-height:1.2;margin-bottom:8px}.welcome-subtitle{font-size:16px;margin-bottom:24px;opacity:.9}.welcome-info{display:flex;flex-direction:column;gap:12px}.info-item{align-items:center;display:flex;font-size:14px;gap:8px;opacity:.9}.info-icon{font-size:16px}.info-icon.success{color:#10b981}.welcome-time{text-align:right}.current-time{font-family:Courier New,monospace;font-size:24px;font-weight:600;opacity:.9}.stats-section{margin-bottom:8px}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.stat-card{align-items:center;background:#fff;border:1px solid #f1f5f9;border-radius:12px;box-shadow:0 4px 12px #0000000d;display:flex;gap:16px;padding:24px;transition:all .2s ease}.stat-card:hover{box-shadow:0 8px 20px #0000001a;transform:translateY(-2px)}.stat-icon-container{align-items:center;border-radius:12px;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.stat-icon-container.blue{background:#667eea1a;color:#667eea}.stat-icon-container.green{background:#10b9811a;color:#10b981}.stat-icon-container.orange{background:#f59e0b1a;color:#f59e0b}.stat-icon-container.purple{background:#8b5cf61a;color:#8b5cf6}.stat-icon{font-size:20px}.stat-content{flex:1 1}.stat-title{color:#6b7280;font-size:14px;font-weight:500;margin-bottom:4px}.stat-value{color:#1f2937;font-size:24px;font-weight:700;margin-bottom:4px}.stat-change{font-size:12px;font-weight:500}.stat-change.positive{color:#10b981}.stat-change.negative{color:#ef4444}.actions-section{margin-bottom:8px}.section-title{color:#1f2937;font-size:20px;font-weight:600;margin-bottom:20px}.actions-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.action-card{align-items:center;background:#fff;border:1px solid #f1f5f9;border-radius:12px;cursor:pointer;display:flex;gap:16px;padding:24px;text-align:left;transition:all .2s ease}.action-card:hover{border-color:#667eea;box-shadow:0 8px 20px #0000001a;transform:translateY(-2px)}.action-icon{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff;display:flex;flex-shrink:0;font-size:20px;height:48px;justify-content:center;width:48px}.action-content{flex:1 1}.action-content h3{color:#1f2937;font-size:16px;font-weight:600;margin-bottom:4px}.action-content p{color:#6b7280;font-size:14px;line-height:1.4}@media (max-width:768px){.dashboard-main{padding:16px}.dashboard-container{gap:24px}.header-content{height:56px;padding:0 16px}.logo-text,.logout-text,.user-name{display:none}.welcome-card{flex-direction:column;gap:20px;padding:24px;text-align:center}.welcome-title{font-size:24px}.current-time{font-size:20px}.stats-grid{gap:16px;grid-template-columns:1fr}.stat-card{padding:20px}.actions-grid{gap:16px;grid-template-columns:1fr}.action-card{padding:20px}}@media (max-width:480px){.welcome-card{padding:20px}.welcome-title{font-size:20px}.welcome-subtitle{font-size:14px}.action-card,.stat-card{padding:16px}.action-icon,.stat-icon-container{height:40px;width:40px}.action-icon,.stat-icon{font-size:18px}}@media (prefers-contrast:high){.dashboard-header{border-bottom:2px solid #000}.action-card,.stat-card{border:2px solid #000}}.construction-table-section{background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000000d;overflow:hidden}.table-header{align-items:center;background:#f8fafc;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:24px}.table-title{color:#1f2937;font-size:20px;font-weight:600;margin:0}.table-info{color:#6b7280;font-size:14px}.table-container{overflow-x:auto}.tab-container{margin-bottom:2rem;padding:0 1rem}.tab-buttons{display:flex;gap:1rem;justify-content:center;margin:0 auto;max-width:600px}.tab-button{background:#fff;border:2px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 4px #0000000d;color:#6b7280;cursor:pointer;flex:1 1;font-size:1rem;font-weight:600;padding:1rem 2rem;position:relative;text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1)}.tab-button:hover{box-shadow:0 8px 25px #667eea26;color:#667eea}.tab-button.active,.tab-button:hover{border-color:#667eea;transform:translateY(-2px)}.tab-button.active{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 8px 25px #667eea4d;color:#fff}.tab-button.active:hover{box-shadow:0 12px 35px #667eea66;transform:translateY(-3px)}.filter-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem;padding:1.5rem}.filter-header{border-bottom:2px solid #f3f4f6;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.filter-header,.filter-title{align-items:center;display:flex}.filter-title{color:#374151;cursor:pointer;font-size:1.125rem;font-weight:600;gap:.5rem;margin:0;-webkit-user-select:none;user-select:none}.filter-toggle{font-size:.875rem;transition:transform .2s ease}.filter-toggle.open{transform:rotate(180deg)}.filter-actions{display:flex;gap:1rem}.my-data-btn{background:#fff;border:2px solid #e5e7eb;border-radius:6px;color:#6b7280;cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:all .3s ease}.my-data-btn:hover{border-color:#667eea;color:#667eea}.my-data-btn.active{background:#667eea;border-color:#667eea;color:#fff}.reset-btn{background:#f3f4f6;border:2px solid #e5e7eb;border-radius:6px;color:#6b7280;cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:all .3s ease}.reset-btn:hover{background:#e5e7eb;color:#374151}.filter-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.filter-item{display:flex;flex-direction:column;gap:.5rem}.filter-item label{color:#374151;font-size:.875rem;font-weight:500}.filter-item input,.filter-item select{background:#fff;border:2px solid #e5e7eb;border-radius:6px;font-size:.875rem;padding:.75rem;transition:all .3s ease}.filter-item input:focus,.filter-item select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.filter-item input::placeholder{color:#9ca3af}.table-actions{gap:1rem}.create-btn,.table-actions{align-items:center;display:flex}.create-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;box-shadow:0 2px 4px #667eea4d;color:#fff;cursor:pointer;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.create-btn:hover{box-shadow:0 4px 8px #667eea66;transform:translateY(-1px)}.create-icon{font-size:1rem}.fetch-oa-btn{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:6px;box-shadow:0 2px 4px #10b9814d;color:#fff;cursor:pointer;display:flex;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.fetch-oa-btn:hover:not(:disabled){box-shadow:0 4px 8px #10b98166;transform:translateY(-1px)}.fetch-oa-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.construction-table{border-collapse:collapse;font-size:14px;width:100%}.construction-table th{background:#f9fafb;border-bottom:2px solid #e5e7eb;color:#374151;font-weight:600;padding:16px 12px;text-align:left;white-space:nowrap}.construction-table td{border-bottom:1px solid #f3f4f6;color:#4b5563;padding:16px 12px;vertical-align:middle}.construction-table .no-wrap-col{white-space:nowrap}.construction-table tbody tr:hover{background:#f9fafb}.mobile-data-cards{display:none}.status-badge{border-radius:20px;display:inline-block;font-size:12px;font-weight:500;padding:4px 12px;text-align:center;white-space:nowrap}.status-pending{background:#fef3c7;border:1px solid #fbbf24;color:#d97706}.status-progress{background:#dbeafe;border:1px solid #60a5fa;color:#2563eb}.status-completed{background:#d1fae5;border:1px solid #34d399;color:#059669}.status-default{background:#f3f4f6;border:1px solid #d1d5db;color:#6b7280}.action-buttons{gap:8px}.action-btn,.action-buttons{display:flex;justify-content:center}.action-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;font-size:14px;height:32px;transition:all .2s ease;width:32px}.action-btn svg{flex-shrink:0}.action-btn svg,.copy-btn svg,.delete-btn svg,.edit-btn svg{height:14px!important;width:14px!important}.copy-btn{background:#ecfdf5;color:#059669}.copy-btn:hover{background:#d1fae5;transform:translateY(-1px)}.copy-btn.copying{cursor:not-allowed;opacity:.6}.copy-btn.copying,.copy-btn.copying:hover{background:#0596690d;border-color:#0596691a}.copy-btn.copying:hover{transform:none}.copy-btn:disabled{cursor:not-allowed;opacity:.6}.edit-btn{background:#dbeafe;color:#2563eb}.edit-btn:hover{background:#bfdbfe;transform:translateY(-1px)}.edit-btn.editing{cursor:not-allowed;opacity:.6}.edit-btn.editing,.edit-btn.editing:hover{background:#2563eb0d;border-color:#2563eb1a}.edit-btn.editing:hover{transform:none}.edit-btn:disabled{cursor:not-allowed;opacity:.6}.delete-btn{background:#fee2e2;color:#dc2626}.delete-btn:hover{background:#fecaca;transform:translateY(-1px)}.delete-btn.deleting,.delete-btn:disabled{background:#f3f4f6;color:#9ca3af;cursor:not-allowed;opacity:.6}.delete-btn.deleting:hover,.delete-btn:disabled:hover{background:#f3f4f6;transform:none}@media (max-width:768px){.header-content{flex-direction:column;gap:12px;height:auto;min-height:88px;padding:12px 16px}.header-left,.header-right{align-items:center;display:flex;flex:none;justify-content:space-between;order:1;width:100%}.header-left{justify-content:flex-start}.header-right{justify-content:flex-end;position:absolute;right:16px;top:12px}.header-center{flex:none;justify-content:center;margin-top:4px;order:2;width:100%}.user-info{border-radius:16px;display:flex!important;font-size:14px;left:16px;padding:6px 12px;position:absolute;top:12px}.user-name{display:block!important;font-weight:500}.logout-btn{border-radius:16px;font-size:13px;gap:6px;padding:8px 14px}.logout-btn span{display:inline!important}.header-title{font-size:1.25rem;font-weight:600}.tab-container{padding:0 .5rem}.tab-buttons{flex-direction:row;gap:.5rem;max-width:none;padding:0}.tab-button{flex:1 1;font-size:.875rem;margin:0;min-height:44px;padding:.75rem .5rem;text-align:center}.filter-section{margin-bottom:1.5rem;padding:1rem}.filter-header{align-items:stretch;flex-direction:column;gap:1rem}.filter-actions{justify-content:space-between}.filter-grid{gap:1rem;grid-template-columns:1fr}.my-data-btn,.reset-btn{flex:1 1;text-align:center}.table-header{align-items:flex-start;flex-direction:column;gap:16px;padding:16px}.table-title{font-size:18px;font-weight:600;margin-bottom:8px}.table-actions{display:flex;flex-direction:column;gap:12px;width:100%}.create-btn{align-items:center;border-radius:10px;font-size:15px;font-weight:500;justify-content:center;min-height:48px;padding:14px 20px}.action-buttons,.create-btn{display:flex;gap:8px;width:100%}.fetch-oa-btn,.filter-btn{align-items:center;border-radius:8px;display:flex;flex:1 1;font-size:14px;font-weight:500;gap:6px;justify-content:center;min-height:44px;padding:12px 16px;white-space:nowrap}.filter-btn{background:#f3f4f6;border:2px solid #e5e7eb;color:#6b7280}.filter-btn:hover{background:#e5e7eb;color:#374151}.table-info{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:10px 16px;text-align:center;width:100%}.table-info span{color:#4a5568;font-size:14px;font-weight:500}.table-container{border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:visible}.construction-table{display:none}.mobile-data-cards{background:#fff;border-radius:8px;display:block;overflow:hidden}.mobile-data-card{background:#fff;border-bottom:1px solid #f3f4f6;padding:16px;position:relative}.mobile-data-card:last-child{border-bottom:none}.mobile-data-card:hover{background:#f9fafb}.card-header{align-items:flex-start;border-bottom:1px solid #f3f4f6;display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:8px}.card-title{color:#1f2937;flex:1 1;font-size:15px;font-weight:600;line-height:1.4;margin-right:12px}.card-actions{display:flex;flex-shrink:0;gap:6px}.card-content{grid-gap:12px;display:grid;font-size:13px;gap:12px;grid-template-columns:1fr 1fr}.card-field{display:flex;flex-direction:column;gap:4px}.card-field.full-width{grid-column:1/-1}.field-label{color:#6b7280;font-size:11px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.field-value{color:#374151;font-weight:500;line-height:1.4;word-break:break-word}.field-value.status{display:inline-block}.status-badge{border-radius:12px;font-size:11px;padding:4px 10px}.action-buttons{flex-direction:row;gap:6px}.action-btn{border-radius:6px;font-size:12px;height:28px;width:28px}.dashboard-main{padding:16px 12px}.dashboard-container{gap:20px}.welcome-card{flex-direction:column;gap:16px;padding:24px 20px;text-align:center}.welcome-title{font-size:24px}.welcome-subtitle{font-size:15px}.stats-grid{gap:12px;grid-template-columns:repeat(2,1fr)}.stat-card{padding:16px}.stat-title{font-size:13px}.stat-value{font-size:20px}.actions-grid{gap:12px;grid-template-columns:1fr}.action-card{padding:20px 16px}.action-icon{font-size:18px;height:40px;width:40px}.action-content h3{font-size:15px}.action-content p{font-size:13px}}.bottom-nav{background:#fff;border-top:1px solid #e0e0e0;bottom:0;box-shadow:0 -2px 8px #0000001a;display:flex;height:60px;left:0;position:fixed;right:0;z-index:1000}.nav-item{align-items:center;background:none;border:none;color:#666;cursor:pointer;display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:8px;transition:all .3s ease}.nav-item.active{background:#1976d21a;color:#1976d2}.nav-item:hover{background:#0000000d}.nav-item.active:hover{background:#1976d226}.nav-icon{font-size:20px;margin-bottom:2px}.nav-text{font-size:12px;font-weight:500}.bottom-nav.disabled{opacity:.6;pointer-events:none}.nav-item.disabled{background:#00000005!important;color:#ccc!important;cursor:not-allowed;opacity:.5}.nav-item.disabled:hover{background:#00000005!important;transform:none}.nav-item.disabled .nav-icon,.nav-item.disabled .nav-text{color:#ccc}.dashboard-main{padding-bottom:80px}.filter-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem 1rem 80px;position:fixed;right:0;top:0;z-index:1000}.filter-modal{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;max-height:90vh;max-width:800px;overflow:hidden;width:100%}.filter-modal-header{grid-gap:16px;align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px 12px 0 0;box-shadow:0 2px 8px #0000001a;color:#fff;display:grid;flex-shrink:0;gap:16px;grid-template-columns:1fr auto auto auto;padding:20px 24px}.filter-modal-header h3{color:#fff;font-size:20px;font-weight:600;letter-spacing:.5px;margin:0}.filter-modal .close-btn{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:20px;height:40px;justify-content:center;padding:8px 12px;transition:all .2s ease;width:40px}.filter-modal .close-btn:hover{background:#fff3;border-color:#ffffff4d;transform:scale(1.05)}.close-btn{background:none;border:none;border-radius:4px;color:#718096;font-size:1.5rem;padding:.25rem;transition:all .2s}.close-btn:hover{background:#f7fafc;color:#2d3748}.close-btn:disabled{color:#cbd5e0;cursor:not-allowed;opacity:.5}.close-btn:disabled:hover{background:none;color:#cbd5e0}.filter-modal-content{flex:1 1;overflow-y:auto;padding:1.5rem}.filter-modal-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}.apply-btn{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.apply-btn:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.filter-btn{align-items:center;background:#f3f4f6;border:2px solid #e5e7eb;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;font-weight:500;gap:.5rem;padding:.75rem 1rem;transition:all .2s}.filter-btn:hover{background:#e5e7eb;box-shadow:0 2px 8px #0000001a;color:#374151;transform:translateY(-1px)}.no-data{padding:3rem 1rem;text-align:center}.no-data-message{align-items:center;color:#718096;display:flex;font-size:1rem;font-weight:500;justify-content:center;text-align:center;width:100%}.no-data-message span{background:#f7fafc;border:2px dashed #e2e8f0;border-radius:8px;display:inline-block;padding:1rem 2rem}.mobile-data-card .no-data-message{justify-content:center;padding:2rem 1rem;text-align:center}@media (prefers-reduced-motion:reduce){.action-btn,.action-card,.logout-btn,.stat-card{transition:none}.action-btn:hover,.action-card:hover,.logout-btn:hover,.stat-card:hover{transform:none}.loading-spinner{animation:none}}.create-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem 1rem 80px;position:fixed;right:0;top:0;z-index:1000}.create-modal{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;max-height:90vh;max-width:800px;overflow:hidden;width:100%}.create-modal .modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;flex-shrink:0;justify-content:space-between;padding:1.5rem}.create-modal .modal-header h3{color:#1a202c;font-size:1.25rem;font-weight:600;margin:0}.create-modal .modal-content{display:flex;flex:1 1;flex-direction:column;overflow-y:auto;padding:0}.form-grid{grid-gap:20px;display:grid;flex:1 1;gap:20px;grid-template-columns:1fr 1fr;overflow-y:auto;padding:24px}.form-item{display:flex;flex-direction:column;gap:8px}.form-item.full-width{grid-column:1/-1}.form-item.time-item{position:relative}.form-item label{color:#374151;font-size:14px;font-weight:600}.required{color:#ef4444}.form-item input,.form-item select,.form-item textarea{border:1px solid #d1d5db;border-radius:8px;font-size:14px;padding:12px;transition:border-color .2s ease}.form-item input:focus,.form-item select:focus,.form-item textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-item input.error,.form-item select.error,.form-item textarea.error{border-color:#ef4444}.form-item textarea{min-height:80px;resize:vertical}.disabled-field{background-color:#f5f5f5!important;color:#666!important;cursor:not-allowed!important;opacity:.7}.form-item input:disabled,.form-item select:disabled,.form-item textarea:disabled{background-color:#f9fafb!important;border-color:#e5e7eb!important;color:#9ca3af!important;cursor:not-allowed!important;opacity:.6}.form-item input:disabled:hover,.form-item select:disabled:hover,.form-item textarea:disabled:hover{border-color:#e5e7eb!important;box-shadow:none!important}.checkbox-label input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.checkbox-label input[type=checkbox]:disabled+span{color:#9ca3af;cursor:not-allowed}.time-input-group{align-items:center;display:flex;gap:12px}.time-input-group input[type=time]{flex:1 1}.checkbox-label{align-items:center;color:#6b7280;cursor:pointer;display:flex;font-size:14px;gap:6px;white-space:nowrap}.checkbox-label input[type=checkbox]{margin:0;width:auto}.modal-actions{gap:12px;justify-content:flex-end}.cancel-btn,.submit-btn{border:none;border-radius:8px;cursor:pointer;font-weight:600;padding:12px 24px;transition:all .2s ease}.submit-btn:disabled{color:#d1d5db;opacity:.6}.modal-actions{background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;flex-shrink:0;justify-content:center;padding:24px}.submit-btn{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;min-width:120px;padding:12px 24px;transition:all .2s ease}.submit-btn:hover:not(:disabled){background:#2563eb;box-shadow:0 4px 12px #3b82f64d;transform:translateY(-1px)}.submit-btn:disabled{background:#9ca3af;box-shadow:none;cursor:not-allowed;transform:none}@media (max-width:768px){.create-modal{margin:20px auto;max-width:95vw}.form-grid{gap:16px;grid-template-columns:1fr;padding:20px}.form-item.full-width{grid-column:1}.time-input-group{grid-gap:8px;align-items:end;display:grid;gap:8px;grid-template-columns:1fr 1fr auto}.time-input-group input{width:100%}.checkbox-label{justify-content:flex-start;white-space:nowrap}.modal-actions{padding:16px 24px}.submit-btn{min-width:120px;width:auto}}@media (max-width:480px){.create-modal{border-radius:12px;margin:10px;max-width:100vw}.form-grid,.modal-actions{padding:16px}}.supervisor-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem 1rem 80px;position:fixed;right:0;top:0;z-index:1100}.supervisor-modal{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.supervisor-modal .modal-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px 12px 0 0;box-shadow:0 2px 8px #0000001a;color:#fff;display:flex;justify-content:space-between;padding:20px 24px}.supervisor-modal .modal-header h3{color:#fff;font-size:20px;font-weight:600;letter-spacing:.5px;margin:0}.supervisor-modal .close-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:20px;height:36px;justify-content:center;padding:0;transition:all .3s ease;width:36px}.supervisor-modal .close-btn:hover{background:#fff3;border-color:#ffffff4d;transform:scale(1.05)}.supervisor-hint{background:#f8fafc;border-left:4px solid #3b82f6;border-radius:0 8px 8px 0;color:#6b7280;font-size:14px;line-height:1.5;margin-bottom:1.5rem;padding:1rem 1.5rem}.supervisor-list{display:flex;flex-direction:column;gap:12px;padding:0 1.5rem 1.5rem}.supervisor-item{background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;padding:16px;transition:all .2s ease}.supervisor-item:hover{background:#f8fafc;border-color:#3b82f6;box-shadow:0 4px 12px #3b82f626;transform:translateY(-1px)}.supervisor-item:active{box-shadow:0 2px 8px #3b82f633;transform:translateY(0)}.supervisor-info{display:flex;flex-direction:column;gap:8px}.supervisor-name{color:#1f2937;font-size:16px;font-weight:600}.supervisor-dept,.supervisor-phone{color:#6b7280;font-size:14px}.modal-header{grid-gap:16px;align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px 12px 0 0;box-shadow:0 2px 8px #0000001a;color:#fff;display:grid;gap:16px;grid-template-columns:1fr auto auto;padding:20px 24px}.header-title{align-items:center;display:flex}.modal-header h3{font-size:20px;font-weight:600;letter-spacing:.5px;margin:0}.header-actions{gap:12px}.header-actions,.header-close{align-items:center;display:flex}.save-template-btn,.template-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:1px solid #ffffff40;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:8px 16px;transition:all .3s ease;white-space:nowrap}.save-template-btn:hover,.template-btn:hover{background:#ffffff40;border-color:#fff6;box-shadow:0 4px 12px #00000026;transform:translateY(-1px)}.save-template-btn:active,.template-btn:active{transform:translateY(0)}.close-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:20px;height:36px;justify-content:center;padding:0;transition:all .3s ease;width:36px}.close-btn:hover{background:#fff3;border-color:#ffffff4d;transform:scale(1.05)}.save-template-modal-overlay,.template-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px 20px 80px;position:fixed;right:0;top:0;z-index:1200}.modal-content h4{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-left:4px solid #3b82f6;border-radius:8px;box-shadow:0 2px 4px #0000000d;color:#1f2937;font-size:18px;font-weight:600;letter-spacing:.5px;margin:0 0 20px;padding:12px 16px}.save-template-modal,.template-modal{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;max-height:80vh;max-width:600px;overflow:hidden;width:100%}.save-template-modal .modal-content,.template-modal .modal-content{flex:1 1;overflow-y:auto;padding:20px}.loading-text{font-size:16px;padding:40px}.no-templates{color:#6b7280;padding:40px 20px;text-align:center}.template-search-section{background:#f8fafc;border-bottom:1px solid #e5e7eb;padding:20px}.template-search-input{background:#fff;border:2px solid #e5e7eb;border-radius:8px;box-sizing:border-box;color:#1f2937;font-size:14px;padding:12px 16px;transition:all .3s ease;width:100%}.template-search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.template-search-input::placeholder{color:#9ca3af;font-size:13px}.template-header-actions{border-bottom:1px solid #e5e7eb;display:flex;justify-content:flex-end;padding:15px 20px}.template-header-actions .btn{border:none;border-radius:6px;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .2s}.template-header-actions .btn-secondary{background:#6b7280;color:#fff}.template-header-actions .btn-secondary:hover{background:#4b5563}.create-modal-header-actions{background:#f8fafc;border-bottom:1px solid #e5e7eb;display:flex;flex-shrink:0;gap:12px;justify-content:center;padding:15px 20px}.create-modal-header-actions .template-btn{background:#3b82f6}.create-modal-header-actions .save-template-btn,.create-modal-header-actions .template-btn{align-items:center;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s ease;white-space:nowrap}.create-modal-header-actions .save-template-btn{background:#10b981}.create-modal-header-actions .template-btn:hover{background:#2563eb;box-shadow:0 2px 8px #3b82f64d;transform:translateY(-1px)}.create-modal-header-actions .save-template-btn:hover{background:#059669;box-shadow:0 2px 8px #10b9814d;transform:translateY(-1px)}.shared-badge{background:#10b981}.author-badge,.shared-badge{border-radius:12px;color:#fff;font-size:12px;font-weight:500;margin-left:8px;padding:2px 8px}.author-badge{background:#3b82f6}.template-actions{flex-wrap:wrap}.share-btn{background:#10b981;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:6px 16px;transition:all .2s}.share-btn:hover{background:#059669}.unshare-btn{background:#f59e0b;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:6px 16px;transition:all .2s}.unshare-btn:hover{background:#d97706}.copy-btn{background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;padding:6px 12px;transition:all .2s}.copy-btn:hover{background:#2563eb}.save-template-modal-overlay .form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.save-template-modal-overlay .form-group label{color:#374151;font-size:14px;font-weight:600}.save-template-modal-overlay .form-group input{background:#fff;border:2px solid #e5e7eb;border-radius:8px;box-sizing:border-box;color:#1f2937;font-size:14px;padding:12px 16px;transition:all .3s ease;width:100%}.save-template-modal-overlay .form-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.save-template-modal-overlay .form-group input::placeholder{color:#9ca3af}.template-preview-info{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin-top:20px;padding:15px}.template-preview-info h4{color:#374151;font-size:16px;margin:0 0 10px}.template-preview-info p{color:#6b7280;font-size:14px;margin:5px 0}.modal-footer{border-top:1px solid #e5e7eb;display:flex;gap:10px;justify-content:flex-end;padding:15px 20px}.modal-footer .btn{border:none;border-radius:6px;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .2s}.modal-footer .btn-primary{background:#3b82f6;color:#fff}.modal-footer .btn-primary:hover:not(:disabled){background:#2563eb}.modal-footer .btn-primary:disabled{background:#9ca3af;cursor:not-allowed}.modal-footer .btn-secondary{background:#6b7280;color:#fff}.modal-footer .btn-secondary:hover{background:#4b5563}.no-templates p{line-height:1.5;margin:8px 0}.templates-list{display:flex;flex-direction:column;gap:12px}.template-item{align-items:flex-start;border:1px solid #e5e7eb;border-radius:8px;display:flex;justify-content:space-between;padding:16px;transition:all .2s ease}.template-item:hover{border-color:#3b82f6;box-shadow:0 2px 8px #3b82f61a}.template-info{flex:1 1;margin-right:16px}.template-name{color:#1f2937;font-size:16px;font-weight:600;margin-bottom:8px}.template-preview{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.preview-item{color:#6b7280;font-size:14px;line-height:1.4}.preview-item strong{color:#374151}.template-date{color:#9ca3af;font-size:12px}.template-actions{align-items:center;display:flex;gap:8px}.apply-btn{background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:6px 16px;transition:background .2s ease}.apply-btn:hover{background:#2563eb}.delete-btn{align-items:center;background:#ef4444;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;justify-content:center;padding:6px;transition:background .2s ease}.delete-btn:hover{background:#dc2626}.template-content-preview{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;margin-top:16px;padding:16px}.template-content-preview h4{color:#374151;font-size:14px;font-weight:600;margin:0 0 12px}.template-content-preview .preview-item{color:#6b7280;font-size:14px;line-height:1.4;margin-bottom:8px}.template-content-preview .preview-item:last-child{margin-bottom:0}.save-template-modal .modal-actions{border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;margin-top:20px;padding-top:16px}.cancel-btn{background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .2s ease}.cancel-btn:hover{background:#e5e7eb;border-color:#9ca3af}.save-btn{background:#10b981;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background .2s ease}.save-btn:hover{background:#059669}@media (max-width:768px){.supervisor-modal{margin:20px auto;max-width:95vw}.supervisor-hint{padding:0 1rem}.supervisor-list{padding:0 1rem 1rem}.supervisor-item{padding:12px}.modal-header{gap:8px;grid-template-columns:1fr auto}.header-close{grid-column:2;grid-row:1}.header-actions{flex-wrap:wrap;gap:8px;grid-column:1/-1;grid-row:2;justify-content:center;margin-top:8px}.save-template-btn,.template-btn{font-size:12px;padding:6px 12px}.filter-modal,.save-template-modal,.template-modal{margin:10px;max-height:90vh;max-width:95vw}.filter-modal-header{gap:8px;grid-template-columns:1fr auto;padding:16px 20px}.filter-modal .close-btn{font-size:18px;height:36px;width:36px}.filter-modal-content{padding:16px 20px}.filter-grid{gap:16px;grid-template-columns:1fr}.filter-modal-actions{flex-direction:column;gap:8px;margin-bottom:20px}.my-data-btn,.reset-btn{text-align:center;width:100%}.template-item{align-items:stretch;flex-direction:column;gap:12px}.template-info{margin-right:0}.template-actions{justify-content:flex-end}.save-template-modal .modal-actions{flex-direction:column;gap:8px}.cancel-btn,.save-btn{padding:12px;width:100%}.template-search-section{padding:16px 20px}.template-search-input{font-size:16px;padding:12px 14px}.template-search-input::placeholder{font-size:14px}}.order-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem 1rem 80px;position:fixed;right:0;top:0;z-index:1000}.order-modal{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-height:90vh;max-width:800px;overflow-y:auto;width:100%}.order-modal .modal-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px 12px 0 0;box-shadow:0 2px 8px #0000001a;color:#fff;display:flex;justify-content:space-between;padding:20px 24px}.order-modal .modal-header h3{color:#fff;font-size:20px;font-weight:600;letter-spacing:.5px;margin:0}.order-modal .close-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:20px;height:36px;justify-content:center;padding:0;transition:all .3s ease;width:36px}.order-modal .close-btn:hover{background:#fff3;border-color:#ffffff4d;transform:scale(1.05)}.order-modal .close-btn:disabled{color:#fff6;cursor:not-allowed}.order-modal .close-btn:disabled,.order-modal .close-btn:disabled:hover{background:#ffffff0d;border-color:#ffffff1a;transform:none}.order-modal .modal-content{padding:24px}.date-input-section{background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:24px;padding:20px}.date-input-section label{color:#374151;display:block;font-weight:500;margin-bottom:8px}.date-input-section .required{color:#ef4444}.date-input-section input{border:1px solid #d1d5db;border-radius:6px;font-size:14px;margin-bottom:12px;padding:12px;transition:border-color .2s,box-shadow .2s;width:100%}.date-input-section input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.date-input-section input.error{border-color:#ef4444}.error-text{color:#ef4444;display:block;font-size:12px;margin-top:4px}.query-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:all .2s;width:100%}.query-btn:hover:not(:disabled){box-shadow:0 4px 12px #667eea4d;transform:translateY(-1px)}.query-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.orders-list{margin-top:20px}.orders-header{background:#f3f4f6;border:1px solid #e5e7eb;border-bottom:none;border-radius:6px 6px 0 0;padding:12px 16px}.orders-header label{align-items:center;color:#374151;cursor:pointer;display:flex;font-weight:500;gap:8px}.orders-content{border:1px solid #e5e7eb;border-radius:0 0 6px 6px;max-height:400px;overflow-y:auto}.order-item{border-bottom:1px solid #f3f4f6;padding:16px;transition:background-color .2s}.order-item:last-child{border-bottom:none}.order-item:hover{background-color:#f9fafb}.order-item label{align-items:flex-start;cursor:pointer;display:flex;gap:12px;width:100%}.order-item input[type=checkbox]{flex-shrink:0;margin-top:2px}.order-info{flex:1 1}.order-number{color:#1f2937;font-weight:600;margin-bottom:4px}.order-description{color:#4b5563;line-height:1.4;margin-bottom:8px}.order-details{color:#6b7280;display:flex;flex-wrap:wrap;font-size:12px;gap:16px}.order-details span{background:#f3f4f6;border-radius:4px;padding:4px 8px}.loading-text{color:#6b7280;font-style:italic;padding:40px 20px;text-align:center}.order-modal .modal-actions{background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;gap:12px;justify-content:center;padding:1.5rem}.order-modal .cancel-btn{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:all .2s}.order-modal .cancel-btn:hover{background:#f3f4f6;border-color:#9ca3af}.order-modal .confirm-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:all .2s}.order-modal .confirm-btn:hover:not(:disabled){box-shadow:0 4px 12px #667eea4d;transform:translateY(-1px)}.order-modal .confirm-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}.work-content-container{position:relative}.work-content-container textarea{box-sizing:border-box;width:100%!important}.work-content-buttons{display:flex;gap:8px;margin-top:8px}.order-btn{border:none;border-radius:6px;cursor:pointer;flex:1 1;font-size:12px;font-weight:500;padding:8px 16px;transition:all .2s}.maintenance-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.maintenance-btn:hover:not(:disabled){box-shadow:0 2px 8px #10b9814d;transform:translateY(-1px)}.fault-btn{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.fault-btn:hover:not(:disabled){box-shadow:0 2px 8px #f59e0b4d;transform:translateY(-1px)}.order-btn:disabled{cursor:not-allowed;opacity:.5;transform:none}@media (max-width:768px){.order-modal{margin:20px auto;max-width:95vw}.order-modal .modal-content{padding:20px}.order-modal .modal-actions{padding:24px}.order-details,.work-content-buttons{flex-direction:column}.order-details{gap:8px}.orders-content{max-height:300px}}@media (max-width:480px){.order-modal{border-radius:12px;margin:10px;max-width:100vw}.order-modal .modal-actions,.order-modal .modal-content{padding:16px}}.loading-spinner{animation:spin 1s linear infinite;border:2px solid #9ca3af4d;border-radius:50%;border-top-color:#6b7280;display:inline-block;height:16px;width:16px}@keyframes spin{to{transform:rotate(1turn)}}.App{background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;min-height:100vh;width:100%}.page-container{align-items:center;display:flex;flex:1 1;justify-content:center;padding:20px}@media (max-width:768px){.page-container{padding:16px}}:root{--toastify-color-light:#fff;--toastify-color-dark:#121212;--toastify-color-info:#3498db;--toastify-color-success:#07bc0c;--toastify-color-warning:#f1c40f;--toastify-color-error:#e74c3c;--toastify-color-transparent:#ffffffb3;--toastify-icon-color-info:var(--toastify-color-info);--toastify-icon-color-success:var(--toastify-color-success);--toastify-icon-color-warning:var(--toastify-color-warning);--toastify-icon-color-error:var(--toastify-color-error);--toastify-toast-width:320px;--toastify-toast-background:#fff;--toastify-toast-min-height:64px;--toastify-toast-max-height:800px;--toastify-font-family:sans-serif;--toastify-z-index:9999;--toastify-text-color-light:#757575;--toastify-text-color-dark:#fff;--toastify-text-color-info:#fff;--toastify-text-color-success:#fff;--toastify-text-color-warning:#fff;--toastify-text-color-error:#fff;--toastify-spinner-color:#616161;--toastify-spinner-color-empty-area:#e0e0e0;--toastify-color-progress-light:linear-gradient(90deg,#4cd964,#5ac8fa,#007aff,#34aadc,#5856d6,#ff2d55);--toastify-color-progress-dark:#bb86fc;--toastify-color-progress-info:var(--toastify-color-info);--toastify-color-progress-success:var(--toastify-color-success);--toastify-color-progress-warning:var(--toastify-color-warning);--toastify-color-progress-error:var(--toastify-color-error)}.Toastify__toast-container{box-sizing:border-box;color:#fff;padding:4px;position:fixed;-webkit-transform:translateZ(9999);-webkit-transform:translateZ(var(--toastify-z-index));width:320px;width:var(--toastify-toast-width);z-index:9999;z-index:var(--toastify-z-index)}.Toastify__toast-container--top-left{left:1em;top:1em}.Toastify__toast-container--top-center{left:50%;top:1em;transform:translateX(-50%)}.Toastify__toast-container--top-right{right:1em;top:1em}.Toastify__toast-container--bottom-left{bottom:1em;left:1em}.Toastify__toast-container--bottom-center{bottom:1em;left:50%;transform:translateX(-50%)}.Toastify__toast-container--bottom-right{bottom:1em;right:1em}@media only screen and (max-width:480px){.Toastify__toast-container{left:0;margin:0;padding:0;width:100vw}.Toastify__toast-container--top-center,.Toastify__toast-container--top-left,.Toastify__toast-container--top-right{top:0;transform:translateX(0)}.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-right{bottom:0;transform:translateX(0)}.Toastify__toast-container--rtl{left:auto;right:0}}.Toastify__toast{border-radius:4px;box-shadow:0 1px 10px 0 #0000001a,0 2px 15px 0 #0000000d;box-sizing:border-box;cursor:default;direction:ltr;display:flex;font-family:sans-serif;font-family:var(--toastify-font-family);justify-content:space-between;margin-bottom:1rem;max-height:800px;max-height:var(--toastify-toast-max-height);min-height:64px;min-height:var(--toastify-toast-min-height);overflow:hidden;padding:8px;position:relative;z-index:0}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-body{align-items:center;display:flex;flex:1 1 auto;margin:auto 0;padding:6px}.Toastify__toast-body>div:last-child{flex:1 1;word-break:break-word}.Toastify__toast-icon{display:flex;flex-shrink:0;margin-inline-end:10px;width:20px}.Toastify--animate{animation-duration:.7s;animation-fill-mode:both}.Toastify--animate-icon{animation-duration:.3s;animation-fill-mode:both}@media only screen and (max-width:480px){.Toastify__toast{border-radius:0;margin-bottom:0}}.Toastify__toast-theme--dark{background:#121212;background:var(--toastify-color-dark);color:#fff;color:var(--toastify-text-color-dark)}.Toastify__toast-theme--colored.Toastify__toast--default,.Toastify__toast-theme--light{background:#fff;background:var(--toastify-color-light);color:#757575;color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{background:#3498db;background:var(--toastify-color-info);color:#fff;color:var(--toastify-text-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{background:#07bc0c;background:var(--toastify-color-success);color:#fff;color:var(--toastify-text-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{background:#f1c40f;background:var(--toastify-color-warning);color:#fff;color:var(--toastify-text-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{background:#e74c3c;background:var(--toastify-color-error);color:#fff;color:var(--toastify-text-color-error)}.Toastify__progress-bar-theme--light{background:linear-gradient(90deg,#4cd964,#5ac8fa,#007aff,#34aadc,#5856d6,#ff2d55);background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:#bb86fc;background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:#3498db;background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:#07bc0c;background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:#f1c40f;background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:#e74c3c;background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning{background:#ffffffb3;background:var(--toastify-color-transparent)}.Toastify__close-button{align-self:flex-start;background:#0000;border:none;color:#fff;cursor:pointer;opacity:.7;outline:none;padding:0;transition:.3s ease}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;height:16px;width:14px}.Toastify__close-button:focus,.Toastify__close-button:hover{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{bottom:0;height:5px;left:0;opacity:.7;position:absolute;transform-origin:left;width:100%;z-index:9999;z-index:var(--toastify-z-index)}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{left:auto;right:0;transform-origin:right}.Toastify__spinner{animation:Toastify__spin .65s linear infinite;border:2px solid #e0e0e0;border-color:var(--toastify-spinner-color-empty-area);border-radius:100%;border-right-color:#616161;border-right-color:var(--toastify-spinner-color);box-sizing:border-box;height:20px;width:20px}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,0,0)}to{opacity:0;transform:translate3d(2000px,0,0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,0,0)}to{opacity:0;transform:translate3d(-2000px,0,0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,-10px,0)}40%,45%{opacity:1;transform:translate3d(0,20px,0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,10px,0)}40%,45%{opacity:1;transform:translate3d(0,-20px,0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--bottom-left,.Toastify__bounce-enter--top-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--bottom-right,.Toastify__bounce-enter--top-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--bottom-left,.Toastify__bounce-exit--top-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--bottom-right,.Toastify__bounce-exit--top-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{animation-timing-function:ease-in;opacity:0;transform:perspective(400px) rotateX(90deg)}40%{animation-timing-function:ease-in;transform:perspective(400px) rotateX(-20deg)}60%{opacity:1;transform:perspective(400px) rotateX(10deg)}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:perspective(400px)}30%{opacity:1;transform:perspective(400px) rotateX(-20deg)}to{opacity:0;transform:perspective(400px) rotateX(90deg)}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translateZ(0)}}@keyframes Toastify__slideOutRight{0%{transform:translateZ(0)}to{transform:translate3d(110%,0,0);visibility:hidden}}@keyframes Toastify__slideOutLeft{0%{transform:translateZ(0)}to{transform:translate3d(-110%,0,0);visibility:hidden}}@keyframes Toastify__slideOutDown{0%{transform:translateZ(0)}to{transform:translate3d(0,500px,0);visibility:hidden}}@keyframes Toastify__slideOutUp{0%{transform:translateZ(0)}to{transform:translate3d(0,-500px,0);visibility:hidden}}.Toastify__slide-enter--bottom-left,.Toastify__slide-enter--top-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--bottom-right,.Toastify__slide-enter--top-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--bottom-left,.Toastify__slide-exit--top-left{animation-name:Toastify__slideOutLeft}.Toastify__slide-exit--bottom-right,.Toastify__slide-exit--top-right{animation-name:Toastify__slideOutRight}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown}@keyframes Toastify__spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.eb501be7.css.map*/