body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.touch-menu{background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026,0 0 0 1px #0000001a;z-index:1000;min-width:200px;animation:touch-menu-appear .15s ease-out}@keyframes touch-menu-appear{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.touch-menu-header{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-bottom:1px solid #e0e0e0;font-weight:600;font-size:14px;color:#333}.touch-menu-close{background:none;border:none;font-size:18px;color:#666;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.touch-menu-close:hover{background-color:#f0f0f0}.touch-menu-close:active{background-color:#e0e0e0}.touch-menu-actions{display:flex;flex-direction:column;padding:4px;gap:4px}.touch-menu-btn{display:flex;align-items:center;gap:12px;padding:12px;background:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:15px;transition:all .2s;text-align:left;width:100%}.touch-menu-btn:hover{background-color:#f5f5f5;border-color:#ccc}.touch-menu-btn:active{transform:scale(.98)}.touch-menu-btn.active{background-color:#e3f2fd;border-color:#2196f3;color:#1976d2}.touch-menu-btn.active .touch-menu-icon{transform:scale(1.1)}.touch-menu-icon{font-size:20px;width:24px;text-align:center;transition:transform .2s}.touch-menu-label{flex:1;font-weight:500}@media (max-width: 768px){.touch-menu{min-width:180px}.touch-menu-btn{padding:14px 12px;font-size:16px}.touch-menu-icon{font-size:22px}}.touch-menu *{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.planning-grid-container{width:100%;min-height:100%;position:relative}.planning-grid{display:flex;height:100%;position:relative;min-width:fit-content}.planning-grid-loading,.planning-grid-error{display:flex;justify-content:center;align-items:center;height:100vh;font-size:18px;color:#666}.planning-grid-error{color:#e74c3c}.grid-sidebar{width:250px;background-color:#fff;border-right:1px solid #ddd;overflow-y:auto;flex-shrink:0}.sidebar-header{padding:20px;border-bottom:1px solid #ddd;background-color:#f8f9fa}.sidebar-header h3{margin:0;font-size:18px;color:#333}.sidebar-section{padding:15px;border-bottom:1px solid #eee}.sidebar-section h4{margin:0 0 10px;font-size:14px;color:#666;text-transform:uppercase;font-weight:600}.sidebar-list{display:flex;flex-direction:column;gap:8px}.sidebar-item{display:flex;align-items:center;gap:8px;padding:5px;border-radius:4px;transition:background-color .2s;position:relative}.sidebar-item:hover{background-color:#f0f0f0}.item-actions{position:absolute;right:5px;display:flex;gap:4px;background-color:inherit}.action-btn{background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;font-size:14px;transition:all .2s;display:flex;align-items:center;justify-content:center}.action-btn.edit{color:#007bff}.action-btn.edit:hover{background-color:#e7f3ff;transform:scale(1.1)}.action-btn.delete{color:#dc3545}.action-btn.delete:hover{background-color:#ffe5e5;transform:scale(1.1)}.employee-filter-icon{background:none;border:none;cursor:pointer;padding:2px 4px;margin-left:6px;border-radius:4px;font-size:16px;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;opacity:.6}.employee-filter-icon:hover{background-color:#f0f0f0;opacity:1;transform:scale(1.15)}.employee-filter-icon:active{background-color:#e0e0e0;transform:scale(1.05)}.color-indicator{width:12px;height:12px;border-radius:50%;flex-shrink:0}.item-name{flex:1;font-size:14px;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-role{font-size:12px;color:#999;white-space:nowrap}.item-revenue{font-size:12px;color:#2ecc71;font-weight:600;white-space:nowrap;margin-left:auto;padding-right:5px}.grid-content{flex:1;display:flex;flex-direction:column;overflow:visible;min-width:fit-content}.grid-header{background-color:#fff;border-bottom:2px solid #ddd;position:sticky;top:0;z-index:10}.grid-header-row{display:flex;padding-left:200px;min-width:fit-content}.grid-header-cell{width:50px;min-width:50px;padding:10px 5px;text-align:center;border-right:1px solid #eee;background-color:#fff;position:relative;transition:all .2s;user-select:none}.grid-header-cell:hover{transform:translateY(-2px);box-shadow:0 2px 4px #0000001a;z-index:11}.grid-header-cell.date-weekend{background-color:#f0f0f0}.grid-header-cell.date-holiday{background-color:#ffb3b3;border-bottom:3px solid #ff8080}.grid-header-cell.date-holiday:hover{background-color:#f99}.grid-header-cell.date-weekend:hover{background-color:#e0e0e0}.grid-header-cell.date-workday:hover{background-color:#f0f8ff}.grid-header-cell.date-today{background-color:#fff3cd;border:2px solid #ffc107;border-bottom:3px solid #ffc107;font-weight:700}.grid-header-cell.date-today .date-number{color:#856404;font-weight:700}.date-day{font-size:11px;color:#666;text-transform:uppercase;margin-bottom:2px}.date-number{font-size:16px;font-weight:700;color:#333}.date-month{font-size:10px;color:#999;position:absolute;top:2px;right:2px}.grid-body{flex:1;overflow:visible;background-color:#fff;min-width:fit-content}.grid-section{border-bottom:2px solid #ddd}.section-label{padding:10px 15px;background-color:#f8f9fa;font-weight:600;color:#666;text-transform:uppercase;font-size:12px;position:sticky;left:0}.group-header-row{display:flex;min-height:36px;background-color:#e8eaed;border-bottom:2px solid #bbb;cursor:pointer;user-select:none;position:sticky;z-index:2}.group-header-row:hover{background-color:#dfe1e5}.group-header-sidebar{width:250px;padding:8px 15px;display:flex;align-items:center;gap:8px;font-weight:600;font-size:14px;position:sticky;left:0;background-color:inherit;border-right:1px solid #ddd}.group-header-sidebar .expand-icon{font-size:10px;color:#666}.group-header-sidebar .group-name{flex:1;font-weight:700}.group-header-sidebar .group-count{color:#666;font-size:12px;font-weight:400}.group-header-cell{width:50px;min-width:50px;border-right:1px solid #ddd}.grid-row{display:flex;border-bottom:1px solid #eee;min-height:40px;min-width:fit-content}.grid-row:hover{background-color:#fafafa}.grid-row.sub-row:hover{background-color:#f0f1f3}.grid-row.draggable .grid-row-header{cursor:move}.grid-row.draggable .grid-row-header:hover{background-color:#f0f8ff}.grid-row.draggable .grid-row-header:active{opacity:.5}.grid-row.project-drag-over{border-top:3px solid #3498db;transition:border-top .2s ease}.grid-row.draggable.project-drag-over .grid-row-header{background-color:#e8f4fd}.grid-row-header{width:200px;min-width:200px;padding:10px;display:flex;align-items:center;gap:8px;background-color:#fff;border-right:1px solid #ddd;position:sticky;left:0;z-index:5}.assigned-days-badge{margin-left:auto;padding:2px 8px;background-color:#e8f4fd;color:#2563eb;border-radius:12px;font-size:11px;font-weight:600;white-space:nowrap;flex-shrink:0}.expand-btn{width:20px;height:20px;padding:0;border:1px solid #ddd;background-color:#f8f9fa;border-radius:3px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.expand-btn:hover{background-color:#e9ecef;border-color:#adb5bd}.sub-row,.sub-row .grid-row-header{background-color:#f8f9fa}.sub-row-indent{width:20px;flex-shrink:0}.sub-row .entity-name{font-size:13px}.sub-row .grid-cell{opacity:.9}.entity-color-indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0}.entity-name{flex:1;font-size:14px;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.entity-role{font-size:12px;color:#999;white-space:nowrap}.grid-row-cells{display:flex;flex:1;min-width:fit-content}.grid-cell{width:50px;min-width:50px;height:40px;border-right:1px solid #eee;cursor:pointer;position:relative;transition:background-color .2s;display:flex;align-items:center;justify-content:center;outline:none}.grid-cell:focus{box-shadow:inset 0 0 0 2px #2196f3;z-index:1}.grid-cell:hover{background-color:#e8f4fd}.grid-cell.calendar-holiday:hover{background-color:#ffd0d0}.grid-cell.calendar-weekend:hover{background-color:#ebebeb}.grid-cell.calendar-weekend{background-color:#f5f5f5}.grid-cell.calendar-holiday{background-color:#ffe5e5;border-left:1px solid #ffcccc;border-right:1px solid #ffcccc}.grid-cell.assigned{background-color:#d4edda}.grid-cell.assigned:hover{background-color:#c3e6cb}.grid-cell.calendar-holiday.assigned{background-color:#fda}.grid-cell.calendar-holiday.assigned:hover{background-color:#fc9}.grid-cell.calendar-weekend.assigned{background-color:#e0f0e0}.grid-cell.calendar-weekend.assigned:hover{background-color:#d0e5d0}.grid-cell.status-tentative{background-color:#fff3cd}.grid-cell.status-conflict{background-color:#f8d7da}.grid-cell.disabled{background-color:#f5f5f5;cursor:not-allowed;opacity:.5}.grid-cell.disabled:hover{background-color:#f5f5f5}.grid-cell.drop-zone{position:relative}.grid-cell.drop-zone:after{content:"";position:absolute;inset:2px;border:2px dashed transparent;border-radius:4px;pointer-events:none;transition:all .2s}.grid-cell.drag-over{background-color:#e3f2fd!important;position:relative}.grid-cell.drag-over:after{content:"";position:absolute;inset:2px;border:2px dashed #2196f3;border-radius:4px;pointer-events:none;animation:pulse 1s infinite}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.grid-cell.cell-today{background-color:#fffbf0!important;position:relative}.grid-cell.cell-today:before{content:"";position:absolute;inset:0;border-left:2px solid #ffc107;border-right:2px solid #ffc107;pointer-events:none}.grid-cell.cell-today.assigned{background-color:#e8f5e9!important}.grid-cell.cell-today.calendar-weekend{background-color:#fff8e1!important}.cell-indicator{width:20px;height:20px;border-radius:50%;transition:transform .2s}.cell-indicator.full{width:20px;height:20px}.cell-indicator.assigned{background-color:#28a745}.cell-indicator.tentative{background-color:#ffc107;border:2px solid #ff9800}.cell-indicator.conflict{background-color:#dc3545}.cell-half-day-container{width:100%;height:100%;display:flex;flex-direction:column;gap:2px;padding:4px;position:relative}.cell-indicator.half-day{width:100%;height:calc(50% - 1px);border-radius:4px;cursor:pointer;position:relative;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.cell-indicator.half-day:hover{transform:scale(1.05);box-shadow:0 2px 4px #0003}.cell-indicator.half-day.morning{align-self:stretch}.cell-indicator.half-day.morning:after{content:"AM";font-size:9px;opacity:.9}.cell-indicator.half-day.afternoon{align-self:stretch}.cell-indicator.half-day.afternoon:after{content:"PM";font-size:9px;opacity:.9}.cell-indicator.half-day.assigned{background-color:#28a745}.cell-indicator.half-day.tentative{background-color:#ffc107;border:1px solid #ff9800}.cell-indicator.half-day.conflict{background-color:#dc3545}.cell-indicator.half-day.empty{background-color:transparent;border:1px dashed #ccc;opacity:.4}.cell-indicator.half-day.empty:after{content:"FREE";font-size:8px;color:#999;text-shadow:none}.grid-cell.has-half-day{padding:2px}.conference-section{margin:30px 20px;border:2px solid #e0e0e0;border-radius:8px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.conference-header{padding:20px;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-bottom:3px solid #dee2e6;display:flex;flex-wrap:wrap;align-items:center;gap:15px}.conference-header h3{margin:0;font-size:24px;font-weight:700;flex:1;min-width:200px}.conference-location{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;background-color:#fff;border:1px solid #dee2e6;border-radius:20px;font-size:14px;color:#495057}.conference-location:before{content:"📍";font-size:16px}.conference-dates{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;background-color:#e3f2fd;border:1px solid #90caf9;border-radius:20px;font-size:14px;color:#1976d2;font-weight:500}.conference-dates:before{content:"📅";font-size:16px}.no-tracks{padding:40px;text-align:center;color:#6c757d;font-size:16px;background-color:#f8f9fa}.tracks-grid{background-color:#fff;overflow:auto;max-height:70vh;position:relative}.participation-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px;position:relative}.participation-table thead{background:linear-gradient(180deg,#2c3e50,#34495e);color:#fff;position:sticky;top:0;z-index:11}.participation-table th{padding:12px 10px;text-align:left;font-weight:600;border-right:1px solid rgba(255,255,255,.1);white-space:nowrap}.participation-table th:nth-child(1){position:sticky;left:0;z-index:12;background:linear-gradient(180deg,#2c3e50,#34495e)}.participation-table th:nth-child(2){position:sticky;left:120px;z-index:12;background:linear-gradient(180deg,#2c3e50,#34495e)}.participation-table th:nth-child(3){position:sticky;left:220px;z-index:12;background:linear-gradient(180deg,#2c3e50,#34495e)}.participation-table th:last-child{border-right:none}.participation-table tbody tr{border-bottom:1px solid #e9ecef;transition:background-color .2s}.participation-table tbody tr:hover{background-color:#f8f9fa}.participation-table tbody tr:last-child{border-bottom:none}.participation-table td{padding:12px 10px;border-right:1px solid #e9ecef}.participation-table td:last-child{border-right:none}.track-name{font-weight:600;color:#2c3e50;min-width:120px;max-width:300px;word-wrap:break-word;position:sticky;left:0;z-index:5;background-color:#fff}.participation-table tbody tr:hover .track-name{background-color:#f8f9fa}.track-time{color:#495057;font-size:13px;line-height:1.6;min-width:100px;white-space:nowrap;position:sticky;left:120px;z-index:5;background-color:#fff}.participation-table tbody tr:hover .track-time{background-color:#f8f9fa}.track-room{color:#6c757d;font-style:italic;min-width:80px;max-width:150px;word-wrap:break-word;position:sticky;left:220px;z-index:5;background-color:#fff}.participation-table tbody tr:hover .track-room{background-color:#f8f9fa}.participation-cell{text-align:center;background-color:#fff;transition:all .2s;min-width:80px;font-size:20px}.participation-cell:hover{background-color:#e3f2fd;transform:scale(1.05);box-shadow:0 2px 4px #0000001a;cursor:pointer}.participation-cell.attending{background-color:#d4edda;color:#155724}.participation-cell.attending:hover{background-color:#c3e6cb}.participation-cell.taking-notes{background-color:#fff3cd;color:#856404}.participation-cell.attending.taking-notes{background:linear-gradient(135deg,#d4edda,#fff3cd)}.notes-indicator{display:inline-block;margin-left:4px;animation:bounce 2s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.no-conferences{padding:60px 20px;text-align:center;color:#6c757d}.no-conferences p{font-size:18px;margin:0}@media (max-width: 768px){.grid-sidebar{display:none}.grid-header-row{padding-left:150px}.grid-row-header{width:150px;min-width:150px}.grid-header-cell,.grid-cell{width:40px;min-width:40px}.conference-header{flex-direction:column;align-items:flex-start}.participation-table{font-size:12px}.participation-table th,.participation-table td{padding:8px 6px}.participation-cell{min-width:60px}}.participation-cell.conflict-error{background-color:#ffebee!important;border:2px solid #ef5350}.participation-cell.conflict-error:hover{background-color:#ffcdd2!important;box-shadow:0 2px 8px #ef53504d}.participation-cell.conflict-error.attending{background-color:#ffcdd2!important;border:2px solid #e53935}.participation-cell.conflict-unavailable{background-color:#ffebee!important;opacity:.7}.participation-cell.conflict-unavailable:hover{background-color:#ffcdd2!important;opacity:.85;box-shadow:0 2px 8px #ef53504d}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:8px;width:90%;max-width:500px;max-height:90vh;overflow:hidden;box-shadow:0 10px 40px #0003;animation:slideUp .3s ease-out}.modal-content.large{max-width:600px}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{padding:20px;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;align-items:center;background-color:#f8f9fa}.modal-header h2{margin:0;font-size:20px;color:#333}.modal-close{background:none;border:none;font-size:28px;color:#999;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.modal-close:hover{background-color:#f0f0f0;color:#333}.modal-body{padding:20px;overflow-y:auto;max-height:calc(90vh - 140px)}.form-row{display:flex;gap:15px;margin-bottom:20px}.form-row .form-group{flex:1;margin-bottom:0}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#333;font-size:14px}.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;transition:border-color .2s;background-color:#fff}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.form-group input.error,.form-group textarea.error{border-color:#e74c3c}.form-group input.error:focus,.form-group textarea.error:focus{box-shadow:0 0 0 3px #e74c3c1a}.error-message{display:block;color:#e74c3c;font-size:12px;margin-top:4px}.read-only-field{padding:8px 12px;background-color:#f5f5f5;border-radius:4px;color:#666;font-size:14px}.field-hint{color:#999;font-size:12px;font-weight:400}.field-help{font-size:12px;color:#999;margin-top:4px;display:block}.btn-danger{background-color:#e74c3c;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .2s}.btn-danger:hover{background-color:#c0392b}.form-group textarea{resize:vertical;min-height:80px;font-family:inherit}.color-picker{display:flex;align-items:center;gap:15px}.color-picker input[type=color]{width:60px;height:40px;padding:2px;cursor:pointer}.color-presets{display:flex;gap:8px;flex-wrap:wrap}.color-preset{width:30px;height:30px;border-radius:4px;border:2px solid transparent;cursor:pointer;transition:all .2s}.color-preset:hover{transform:scale(1.1);border-color:#333}.modal-footer{padding:20px;border-top:1px solid #e0e0e0;display:flex;justify-content:flex-end;gap:10px;background-color:#f8f9fa}.filter-section{background-color:#f8f9fa;padding:15px;border-radius:6px;margin-bottom:20px}.filter-section h3{margin:0 0 15px;font-size:16px;color:#333}.filter-row{display:grid;grid-template-columns:1fr 1fr;gap:15px;margin-bottom:15px}.filter-group{display:flex;flex-direction:column}.filter-group label{font-size:13px;margin-bottom:5px;color:#666}.date-range{display:grid;grid-template-columns:1fr auto 1fr;gap:10px;align-items:center}.date-range span{text-align:center;color:#999}.checkbox-group{display:flex;flex-wrap:wrap;gap:15px;margin-top:10px}.checkbox-item{display:flex;align-items:center;gap:5px}.checkbox-item input[type=checkbox]{width:auto}.checkbox-item label{margin:0;font-size:14px;cursor:pointer}.search-box{position:relative}.search-box input{padding-left:35px}.search-box:before{content:"🔍";position:absolute;left:10px;top:50%;transform:translateY(-50%);color:#999}.copy-assignment-info{background-color:#f8f9fa;padding:15px;border-radius:6px;margin-bottom:20px;border-left:4px solid #3498db}.copy-assignment-info p{margin:5px 0;font-size:14px}.copy-assignment-form .form-group{margin-bottom:20px}.checkbox-label{display:flex;align-items:center;cursor:pointer;font-size:14px;gap:10px}.checkbox-label input[type=checkbox]{width:auto;margin:0}.checkmark{flex-shrink:0}.copy-preview{background-color:#e8f5e8;border:1px solid #d4edda;border-radius:4px;padding:12px;margin-bottom:20px}.preview-text{margin:0;font-size:14px;color:#155724}.preview-text strong{color:#0f5132}.required{color:#e74c3c}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.cell-copy-button{position:absolute;top:2px;right:2px;width:16px;height:16px;background:#3498dbcc;border:none;border-radius:2px;color:#fff;font-size:10px;cursor:pointer;display:none;align-items:center;justify-content:center;transition:background-color .2s}.grid-cell:hover .cell-copy-button{display:flex}.cell-copy-button:hover{background:#3498db}@media (max-width: 600px){.modal-content{width:95%;max-height:95vh}.filter-row,.date-range{grid-template-columns:1fr}.date-range span{display:none}.modal-actions{flex-direction:column}.modal-actions button{width:100%}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-box{background:#fff;padding:40px;border-radius:10px;box-shadow:0 10px 40px #0003;width:100%;max-width:400px;text-align:center}.login-box h1{margin:0 0 10px;color:#2c3e50;font-size:32px}.login-subtitle{color:#7f8c8d;margin-bottom:30px;font-size:14px}.form-group{margin-bottom:20px}.form-group input{width:100%;padding:12px 15px;border:2px solid #e0e0e0;border-radius:5px;font-size:16px;transition:border-color .3s}.form-group input:focus{outline:none;border-color:#667eea}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.error-message{color:#e74c3c;margin-bottom:15px;font-size:14px;padding:10px;background-color:#ffe5e5;border-radius:5px}button[type=submit]{width:100%;padding:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:5px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s,opacity .2s}button[type=submit]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}button[type=submit]:disabled{opacity:.6;cursor:not-allowed}.notification-container{position:fixed;top:70px;right:20px;z-index:2000;display:flex;flex-direction:column;gap:10px;pointer-events:none}.notification{display:flex;align-items:center;padding:12px 16px;border-radius:6px;box-shadow:0 4px 12px #00000026;min-width:300px;max-width:500px;background:#fff;pointer-events:auto;cursor:pointer;animation:slideInRight .3s ease-out;transition:all .3s ease}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.notification:hover{transform:translate(-5px);box-shadow:0 6px 16px #0003}.notification-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;margin-right:12px;font-weight:700;flex-shrink:0}.notification-message{flex:1;font-size:14px;line-height:1.4}.notification-close{background:none;border:none;font-size:20px;color:#0006;cursor:pointer;padding:0;margin-left:12px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.notification-close:hover{background-color:#0000001a;color:#000000b3}.notification-success{border-left:4px solid #28a745}.notification-success .notification-icon{background-color:#28a745;color:#fff}.notification-error{border-left:4px solid #dc3545}.notification-error .notification-icon{background-color:#dc3545;color:#fff}.notification-warning{border-left:4px solid #ffc107}.notification-warning .notification-icon{background-color:#ffc107;color:#fff}.notification-info{border-left:4px solid #17a2b8}.notification-info .notification-icon{background-color:#17a2b8;color:#fff}@media (max-width: 600px){.notification-container{left:10px;right:10px;top:60px}.notification{min-width:auto;width:100%}}*{margin:0;padding:0;box-sizing:border-box}.App{display:flex;flex-direction:column;height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-header{background-color:#2c3e50;color:#fff;padding:15px 20px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a;z-index:100}.header-left{display:flex;align-items:center;gap:20px}.period-label{font-size:16px;color:#ecf0f1;font-weight:400;padding:5px 12px;background-color:#ffffff1a;border-radius:4px}.revenue-label{font-size:16px;color:#2ecc71;font-weight:600;padding:5px 12px;background-color:#2ecc711a;border-radius:4px}.app-header h1{font-size:24px;font-weight:600;margin:0}.header-controls{display:flex;gap:15px;align-items:center}.btn{padding:8px 16px;border:none;border-radius:4px;font-size:14px;cursor:pointer;transition:background-color .2s,transform .1s;font-weight:500}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn-primary{background-color:#3498db;color:#fff}.btn-primary:hover{background-color:#2980b9}.btn-secondary{background-color:#95a5a6;color:#fff}.btn-secondary:hover{background-color:#7f8c8d}.navigation-controls{display:flex;align-items:center;gap:10px}.nav-arrow{background-color:#3498db;color:#fff;border:none;padding:8px 12px;border-radius:4px;cursor:pointer;font-size:16px;transition:background-color .2s,opacity .2s}.nav-arrow:hover:not(:disabled){background-color:#2980b9}.nav-arrow:disabled{opacity:.5;cursor:not-allowed}.view-selector{display:flex;background-color:#ffffff1a;border-radius:4px;overflow:hidden}.view-btn{padding:8px 16px;border:none;background-color:transparent;color:#fff;cursor:pointer;font-size:14px;transition:background-color .2s}.view-btn:hover{background-color:#ffffff1a}.view-btn.active{background-color:#3498db}.app-main{flex:1;overflow:auto;position:relative;background-color:#f5f5f5}.app-footer{background-color:#f8f9fa;padding:10px 20px;border-top:1px solid #dee2e6}.legend{display:flex;gap:30px;justify-content:center;align-items:center}.legend-item{display:flex;align-items:center;gap:8px;font-size:14px;color:#666}.legend-color{width:16px;height:16px;border-radius:3px;border:1px solid #ddd}.legend-color.assigned{background-color:#28a745}.legend-color.tentative{background-color:#ffc107}.legend-color.conflict{background-color:#dc3545}.legend-color.weekend{background-color:#f0f0f0}.legend-color.holiday{background-color:#ffb3b3}.export-menu{position:relative}.export-dropdown{position:absolute;top:100%;right:0;margin-top:5px;background:#fff;border:1px solid #ddd;border-radius:4px;box-shadow:0 4px 12px #00000026;z-index:1000;min-width:150px;animation:dropdownSlide .2s ease-out}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.export-dropdown button{display:block;width:100%;padding:10px 15px;border:none;background:none;text-align:left;cursor:pointer;transition:background-color .2s;font-size:14px;color:#333}.export-dropdown button:hover{background-color:#f0f0f0}.export-dropdown button:first-child{border-radius:4px 4px 0 0}.export-dropdown button:last-child{border-radius:0 0 4px 4px}.loading-container{display:flex;justify-content:center;align-items:center;height:100%;font-size:18px;color:#666;background-color:#f5f5f5;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.btn-link{background:none;border:none;color:#3498db;text-decoration:underline;cursor:pointer;padding:0;font-size:inherit}.btn-link:hover{color:#2980b9;transform:none}
