*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#f9fafb;color:#1f2937;display:flex;flex-direction:column;min-height:100vh;padding:2rem 1rem}.header{text-align:center;margin-bottom:1rem}.container{max-width:1600px;margin:0 auto;width:100%;flex:1;display:flex;flex-direction:column}.title{font-size:2rem;font-weight:700;color:#111827;text-align:center}.subtitle{margin-top:.5rem;color:#6b7280;text-align:center}.card{background:#fff;border-radius:.75rem;box-shadow:0 10px 25px -5px #0000001a;padding:2rem}.upload-area{border:2px dashed #d1d5db;border-radius:.5rem;padding:3rem 2rem;text-align:center;cursor:pointer;transition:border-color .3s}.upload-area:hover{border-color:#818cf8}.upload-area.dragging{border-color:#4f46e5;background-color:#f0f9ff}.upload-icon{width:48px;height:48px;margin:0 auto 1rem;color:#9ca3af}.upload-text{font-size:1rem;color:#6b7280}.upload-highlight{color:#4f46e5}.upload-hint{margin-top:.25rem;color:#9ca3af;font-size:.75rem}.file-input{display:none}.name-input{display:block;margin-top:1rem;width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.5rem;font-size:1rem}.name-input:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.preview-section{margin-top:1.5rem}.preview-title{font-size:1.25rem;font-weight:600;color:#1f2937;margin-bottom:1rem}.table-container{overflow-x:auto;border:1px solid #e5e7eb;border-radius:.5rem;max-height:500px}.schedule-table{width:100%;border-collapse:collapse;min-width:1400px}.schedule-table th,.schedule-table td{padding:1rem .75rem;text-align:center;border-bottom:1px solid #e5e7eb;min-width:50px}.table-header th{font-weight:600;color:#374151;position:sticky;top:0;z-index:10}.table-row{transition:background-color .2s}.even-row{background-color:#f9fafb}.table-row:hover{background-color:#f3f4f6}.sticky-col{position:sticky;left:0;background-color:#fff;z-index:5;font-weight:600;color:#1f2937}.day-header{font-weight:600;color:#374151}.day-cell{text-align:center}.shift-work{background-color:#dbeafe;color:#1e40af;font-weight:600;border-radius:.375rem;padding:.375rem .75rem;display:inline-block;min-width:40px}.shift-rest{background-color:#fef2f2;color:#b91c1c;font-weight:600;border-radius:.375rem;padding:.375rem .75rem;display:inline-block;min-width:40px}.progress-container{margin-top:1rem}.progress-bar{height:6px;background-color:#e5e7eb;border-radius:3px;overflow:hidden}.progress-fill{height:100%;background-color:#4f46e5;transition:width .4s}.status-container{display:flex;align-items:center;flex-direction:row;gap:.75rem;margin-top:1.5rem;padding:1.5rem;background-color:#f0fdf4;border-radius:.5rem;border:1px solid #bbf7d0}.status-icon{width:24px;height:24px;color:#16a34a}.status-text{color:#16a34a;font-weight:500}.download-btn{margin-left:auto;padding:.5rem 1.5rem;background-color:#4f46e5;color:#fff;font-weight:600;border:none;border-radius:.5rem;cursor:pointer;transition:background-color .3s}.download-btn:hover{background-color:#4338ca}.status-info{display:flex;align-items:center;gap:.5rem}.schedule-table thead th{background-color:#f9fafb;position:sticky;top:0;z-index:20;font-weight:600;color:#374151}.schedule-table thead th.sticky-col{left:0;z-index:30;background-color:#f9fafb}.footer{margin-top:auto;text-align:center;padding-top:2rem;color:#9ca3af;font-size:.875rem}@media (max-width: 768px){body{padding:2rem 0}.card{padding:.5rem}.upload-area{margin:1rem}}
