@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";.activity-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:16px;margin-bottom:12px;cursor:grab;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 6px #0000001a;color:#fff;-webkit-user-select:none;user-select:none}.activity-card:hover{transform:translateY(-2px);box-shadow:0 8px 12px #00000026}.activity-card:active{cursor:grabbing}.activity-card.dragging{opacity:.5;cursor:grabbing}.activity-card.completed{background:linear-gradient(135deg,#11998e,#38ef7d)}.activity-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.activity-name{font-size:16px;font-weight:600;margin:0;flex:1;line-height:1.3}.activity-hours{display:flex;flex-direction:column;align-items:flex-end;margin-left:12px}.hours-remaining{font-size:18px;font-weight:700}.hours-total{font-size:12px;opacity:.8}.activity-progress{display:flex;align-items:center;gap:8px;margin-bottom:12px}.progress-bar{flex:1;height:6px;background:#ffffff4d;border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:#fff;border-radius:3px;transition:width .3s ease}.progress-text{font-size:11px;font-weight:600;min-width:35px;text-align:right}.activity-details{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.detail-item{display:flex;align-items:center;gap:8px;font-size:13px}.detail-icon{font-size:14px;opacity:.9}.detail-text{opacity:.95;line-height:1.3}.activity-note{display:flex;align-items:flex-start;gap:8px;margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.2);font-size:12px;opacity:.9}.note-icon{font-size:12px;margin-top:1px}.note-text{flex:1;line-height:1.4}.activity-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:600;color:#ffffffe6}.form-group input,.form-group textarea{padding:10px 12px;border:1px solid rgba(255,255,255,.2);border-radius:6px;background:#ffffff0d;color:#fff;font-size:14px;font-family:inherit;transition:all .3s ease}.form-group input::placeholder,.form-group textarea::placeholder{color:#fff6}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#667eea;background:#ffffff14;box-shadow:0 0 0 3px #667eea1a}.form-group input.error,.form-group textarea.error{border-color:#ff3b30}.error-message{font-size:12px;color:#ff3b30;margin-top:-2px}.days-selector{display:flex;gap:8px;flex-wrap:wrap}.day-btn{padding:8px 16px;border:1px solid rgba(255,255,255,.2);border-radius:6px;background:#ffffff0d;color:#ffffffb3;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s ease}.day-btn:hover{background:#ffffff1a;color:#fff}.day-btn.selected{background:linear-gradient(135deg,#ff3b30,#ff6b6b);border-color:transparent;color:#fff}.form-actions{display:flex;gap:12px;margin-top:8px}.btn-cancel,.btn-submit{flex:1;padding:12px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-cancel{background:#ffffff1a;color:#fff}.btn-cancel:hover{background:#ffffff26}.btn-submit{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 8px #667eea4d}.btn-submit:hover{transform:translateY(-2px);box-shadow:0 6px 12px #667eea66}.btn-submit:active,.btn-cancel:active{transform:translateY(0)}.sidebar{width:350px;height:100vh;background:linear-gradient(180deg,#1a1a2e,#16213e);color:#fff;display:flex;flex-direction:column;box-shadow:4px 0 12px #00000026;overflow:hidden}.sidebar-header{padding:24px 20px;background:#ffffff0d;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center}.sidebar-title{margin:0;font-size:24px;font-weight:700;display:flex;align-items:center;gap:12px}.title-icon{font-size:28px}.btn-add{width:40px;height:40px;border-radius:50%;border:none;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:24px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 8px #667eea4d}.btn-add:hover{transform:scale(1.1) rotate(90deg);box-shadow:0 6px 12px #667eea66}.btn-add:active{transform:scale(.95)}.form-container{padding:16px 20px;background:#ffffff08;border-bottom:1px solid rgba(255,255,255,.1);animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.search-container{padding:16px 20px;background:#ffffff08}.search-input{width:100%;padding:12px 16px;border:1px solid rgba(255,255,255,.2);border-radius:8px;background:#ffffff0d;color:#fff;font-size:14px;transition:all .3s ease}.search-input::placeholder{color:#ffffff80}.search-input:focus{outline:none;border-color:#667eea;background:#ffffff14;box-shadow:0 0 0 3px #667eea1a}.activities-list{flex:1;overflow-y:auto;padding:16px 20px}.activities-list::-webkit-scrollbar{width:8px}.activities-list::-webkit-scrollbar-track{background:#ffffff0d}.activities-list::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.activities-list::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.activity-item{position:relative;margin-bottom:12px}.btn-delete{position:absolute;top:8px;right:8px;width:32px;height:32px;border-radius:50%;border:none;background:#ff3b30e6;color:#fff;font-size:14px;cursor:pointer;opacity:0;transition:all .3s ease;display:flex;align-items:center;justify-content:center;z-index:10}.activity-item:hover .btn-delete{opacity:1}.btn-delete:hover{transform:scale(1.1);background:#ff3b30}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;color:#fff9}.empty-icon{font-size:64px;margin-bottom:16px;opacity:.5}.empty-state p{margin:0 0 20px;font-size:16px}.btn-create-first{padding:12px 24px;border:none;border-radius:8px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-create-first:hover{transform:translateY(-2px);box-shadow:0 6px 12px #667eea4d}.sidebar-footer{padding:20px;background:#ffffff0d;border-top:1px solid rgba(255,255,255,.1)}.stats{display:flex;gap:20px;justify-content:space-around}.stat-item{display:flex;flex-direction:column;align-items:center;gap:4px}.stat-value{font-size:28px;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-label{font-size:12px;opacity:.7;text-transform:uppercase;letter-spacing:.5px}.calendar-container{flex:1;display:flex;flex-direction:column;background:#f5f7fa;overflow:hidden}.calendar-header{padding:24px 32px;background:#fff;border-bottom:2px solid #e1e8ed;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px #0000000d}.calendar-title{margin:0;font-size:28px;font-weight:700;color:#1a1a2e;display:flex;align-items:center;gap:12px}.calendar-navigation{display:flex;gap:12px}.nav-btn{padding:10px 20px;border:1px solid #e1e8ed;border-radius:8px;background:#fff;color:#1a1a2e;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.nav-btn:hover{background:#f5f7fa;border-color:#667eea;color:#667eea;transform:translateY(-1px)}.today-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none}.today-btn:hover{transform:translateY(-1px);box-shadow:0 4px 8px #667eea4d}.calendar-scroll{flex:1;overflow:auto;padding:20px}.calendar-scroll::-webkit-scrollbar{width:10px;height:10px}.calendar-scroll::-webkit-scrollbar-track{background:#f5f7fa}.calendar-scroll::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:5px}.calendar-scroll::-webkit-scrollbar-thumb:hover{background:#a0aec0}.calendar-grid{display:grid;gap:0;background:#fff;border-radius:12px;box-shadow:0 4px 12px #00000014;min-width:fit-content;position:relative}.time-header{background:#f8fafc;border-right:2px solid #e1e8ed;border-bottom:2px solid #e1e8ed;position:sticky;top:0;z-index:20}.date-header{padding:16px 8px;text-align:center;background:#f8fafc;border-bottom:2px solid #e1e8ed;border-right:1px solid #e1e8ed;font-weight:600;transition:all .3s ease;position:sticky;top:0;z-index:20}.date-header.today{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.date-day{font-size:13px;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;opacity:1;color:#2d3748;font-weight:700}.date-number{font-size:18px;font-weight:800;color:#1a202c}.time-header{background:#f8fafc;border-right:2px solid #e1e8ed;border-bottom:2px solid #e1e8ed;position:sticky;top:0;left:0;z-index:30}.time-label{padding:12px 8px;text-align:right;font-size:12px;font-weight:600;color:#64748b;background:#f8fafc;border-right:2px solid #e1e8ed;border-bottom:1px solid #e1e8ed;display:flex;align-items:center;justify-content:flex-end;position:sticky;left:0;z-index:10}.calendar-slot{min-height:60px;border-right:1px solid #e1e8ed;border-bottom:1px solid #e1e8ed;position:relative;transition:background .15s ease}.calendar-slot.placing-mode{background:#667eea0f}.calendar-slot.placing-mode:hover{background:#667eea2e;outline:2px solid #667eea;outline-offset:-2px}.calendar-slot.has-appointments{background:transparent}.calendar-slot.forbidden{background:repeating-linear-gradient(45deg,#ff000026,#ff000026 10px,#ff00004d 10px 20px)!important;cursor:not-allowed!important;border:3px solid #e53e3e!important;position:relative;z-index:50}.calendar-slot.forbidden .slot-content{opacity:.5;pointer-events:none}.calendar-slot.slot-continuation{border-top:none}.calendar-slot.slot-continuation:not(.forbidden){background:#667eea14}.slot-content{display:flex;flex-direction:row;height:100%;width:100%;gap:2px;padding:2px;box-sizing:border-box}.calendar-slot:hover{z-index:1000;overflow:visible}.calendar-slot:has(.appointment-card):hover .slot-content{position:absolute;top:-5px;left:-20%;width:140%;height:auto;min-height:calc(100% + 10px);background:#fff;box-shadow:0 8px 24px #0003;border-radius:8px;padding:6px;z-index:1001;border:1px solid #e1e8ed;transition:all .2s ease}.appointment-card{position:relative;border-radius:6px;overflow:hidden;box-shadow:0 1px 3px #0000001a;transition:transform .2s,box-shadow .2s;z-index:2;flex:1;min-width:0;height:100%}.calendar-slot:hover .slot-content .appointment-card{height:auto;min-height:80px;flex:1;margin-bottom:0}.appointment-card-inner{width:100%;height:100%;border-radius:6px;padding:4px 6px;color:#fff;font-size:11px;display:flex;flex-direction:column;position:relative;overflow:hidden}.appointment-btn{position:absolute;top:2px;width:18px;height:18px;border:none;border-radius:50%;cursor:pointer;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;z-index:10}.appointment-card:hover .appointment-btn,.calendar-slot:hover .appointment-btn{opacity:1}.appointment-btn-delete{right:2px;background:#ffffff4d;color:#fff}.appointment-btn-delete:hover{background:#e53e3e}.appointment-btn-add{right:24px;background:#ffffff4d;color:#fff}.appointment-btn-add:hover{background:#38a169}.appointment-content{margin-top:2px;overflow:hidden;flex:1}.appointment-name{font-weight:700;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.appointment-time{font-size:10px;opacity:.85;display:block}.appointment-details{margin-top:2px;font-size:10px;opacity:.85}.slot-content:has(.appointment-card:nth-child(2)) .appointment-name{font-size:10px}.slot-content:has(.appointment-card:nth-child(2)) .appointment-details,.slot-content:has(.appointment-card:nth-child(2)) .appointment-time{display:none}.calendar-slot:hover .appointment-name{font-size:11px;white-space:normal;overflow:visible}.calendar-slot:hover .appointment-details,.calendar-slot:hover .appointment-time{display:block}.placing-hint{font-size:14px;font-weight:400;color:#667eea;margin-left:8px}.mode-banner{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:10px 24px;display:flex;align-items:center;justify-content:space-between;font-size:14px;font-weight:500;gap:16px}.mode-banner button{background:#ffffff40;border:none;color:#fff;border-radius:6px;padding:4px 12px;cursor:pointer;font-size:13px;white-space:nowrap}.mode-banner button:hover{background:#fff6}.appointment-card.appointment-selected .appointment-card-inner{outline:3px solid white;outline-offset:-3px;box-shadow:0 0 0 4px #667eea99,0 4px 12px #0000004d;animation:pulse-selected 1.2s ease-in-out infinite}@keyframes pulse-selected{0%,to{box-shadow:0 0 0 3px #667eea99,0 4px 12px #0000004d}50%{box-shadow:0 0 0 6px #667eea4d,0 4px 12px #0000004d}}.activity-item.activity-selected{outline:2px solid #667eea;outline-offset:-2px;border-radius:8px;background:#667eea14}.zoom-modal-overlay{position:fixed;inset:0;background:#0006;display:flex;justify-content:center;align-items:center;z-index:9999}.zoom-modal-content{background:#fff;width:400px;max-width:90vw;border-radius:12px;box-shadow:0 10px 40px #0000004d;padding:24px;animation:zoomIn .2s ease-out}@keyframes zoomIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.zoom-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.zoom-header h3{margin:0;font-size:20px;color:#2d3748}.zoom-close-btn{background:#edf2f7;border:none;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:16px;color:#4a5568;display:flex;align-items:center;justify-content:center;transition:background .2s}.zoom-close-btn:hover{background:#e2e8f0}.zoom-list{display:flex;flex-direction:column;gap:16px;max-height:60vh;overflow-y:auto}.zoom-item{background:#f7fafc;border-radius:8px;padding:16px;box-shadow:0 2px 4px #0000000d}.zoom-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.zoom-item-title{margin:0;font-size:16px;font-weight:700;color:#2d3748}.zoom-item-time{font-size:13px;color:#718096;background:#edf2f7;padding:4px 8px;border-radius:4px;font-weight:500}.zoom-item-details{display:flex;flex-direction:column;gap:8px}.zoom-detail-row{font-size:14px;color:#4a5568}.zoom-detail-row strong{color:#2d3748}.zoom-actions{display:flex;gap:12px;margin-top:12px;padding-top:12px;border-top:1px solid #e2e8f0}.zoom-action-btn{flex:1;padding:8px;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;transition:opacity .2s}.zoom-action-btn.delete{background:#fff5f5;color:#c53030}.zoom-action-btn.move{background:#ebf4ff;color:#4299e1}.zoom-action-btn:hover{opacity:.8}.print-modal-overlay{position:fixed;inset:0;width:100%;height:100%;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:10000}.print-modal-content{background:#fff;padding:24px;border-radius:12px;width:400px;max-width:90vw;box-shadow:0 10px 25px #0003}.print-modal-header{margin-bottom:20px;border-bottom:1px solid #eee;padding-bottom:10px}.print-modal-header h2{margin:0;color:#2d3748}.print-form-group{margin-bottom:16px;display:flex;flex-direction:column;gap:6px}.print-form-group label{font-size:14px;font-weight:600;color:#4a5568}.print-form-group input,.print-form-group select{padding:8px 12px;border:1px solid #e2e8f0;border-radius:6px;font-size:14px}.print-modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px}.btn-print-confirm{background:#4299e1;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-weight:600;cursor:pointer}.btn-print-confirm:hover{background:#3182ce}.btn-print-cancel{background:#e2e8f0;color:#4a5568;border:none;padding:8px 16px;border-radius:6px;font-weight:600;cursor:pointer}.btn-print-cancel:hover{background:#cbd5e0}.print-agenda-container{width:100%;font-family:Times New Roman,serif;color:#000;background:#fff}.print-header-info{margin-bottom:20px;border-bottom:2px solid black;padding-bottom:10px}.print-header-info h1{font-size:24px;margin:0 0 5px;text-transform:uppercase}.print-header-info p{font-size:14px;margin:0}.agenda-table{width:100%;border-collapse:collapse;font-size:12px}.agenda-table th,.agenda-table td{border:1px solid #000;padding:4px;vertical-align:top;text-align:left}.agenda-table th{background-color:#f0f0f0!important;font-weight:700;text-align:center;-webkit-print-color-adjust:exact;print-color-adjust:exact}.col-time{width:60px;text-align:center;font-weight:700;background:#fafafa}.cell-content{display:flex;flex-direction:column;gap:2px}.print-activity-name{font-weight:700;font-size:13px;text-transform:uppercase}.print-activity-meta{font-size:11px;font-style:italic}thead{display:table-header-group}tfoot{display:table-footer-group}tr{page-break-inside:avoid}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-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;overflow:hidden}.app{display:flex;height:100vh;width:100vw;overflow:hidden}body.dragging,body.dragging *{cursor:grabbing!important}.loading-screen,.error-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.loading-screen p,.error-screen p{margin-top:20px;font-size:18px}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-screen h2{font-size:32px;margin-bottom:16px}.retry-btn{margin-top:24px;padding:12px 32px;border:2px solid white;border-radius:8px;background:transparent;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease}.retry-btn:hover{background:#fff;color:#667eea;transform:translateY(-2px)}.drag-overlay{opacity:.8;transform:scale(.6);transform-origin:top left;cursor:grabbing}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#888;border-radius:5px}::-webkit-scrollbar-thumb:hover{background:#555}.print-view{display:none}@media print{.no-print,.no-print *{display:none!important}.print-view{display:block!important;width:100%;height:auto;overflow:visible}.app{display:block;height:auto;width:100%;overflow:visible}*{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}::-webkit-scrollbar{display:none}@page{size:landscape;margin:5mm}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}#root{width:100%;height:100vh}
