:root{--bg-primary: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--bg-container: rgba(255, 255, 255, .95);--bg-container-secondary: rgba(255, 255, 255, .9);--bg-table: white;--bg-cell: #f8f9fa;--bg-cell-hover: #fff3cd;--bg-time-slot: linear-gradient(135deg, #f8f9fa, #e9ecef);--bg-modal: rgba(0, 0, 0, .5);--bg-footer: rgba(255, 255, 255, .1);--text-primary: #2c3e50;--text-secondary: #495057;--text-muted: #6c757d;--text-accent: #667eea;--text-footer: rgba(255, 255, 255, .8);--text-footer-link: rgba(255, 255, 255, .9);--border-primary: #e0e6ed;--border-accent: rgba(102, 126, 234, .2);--border-dashed: #667eea;--shadow-light: 0 8px 25px rgba(0, 0, 0, .1);--shadow-medium: 0 25px 50px rgba(0, 0, 0, .15);--shadow-heavy: 0 10px 30px rgba(0, 0, 0, .1)}@media (hover: hover) and (pointer: fine){.minimize-maximize-btn:hover{background-color:#f7fafc!important;transform:scale(1.1)}body.dark-mode .minimize-maximize-btn:hover{background-color:#4a5568!important;transform:scale(1.1)}.close-btn:hover{background-color:#ff453a!important;transform:scale(1.1)}}@media (hover: none){.minimize-maximize-btn:active,.minimize-maximize-btn:focus{background-color:#f7fafc!important;transform:scale(1.05);transition:all .1s ease}body.dark-mode .minimize-maximize-btn:active,body.dark-mode .minimize-maximize-btn:focus{background-color:#4a5568!important;transform:scale(1.05);transition:all .1s ease}.close-btn:active,.close-btn:focus{background-color:#ff453a!important;transform:scale(1.05);transition:all .1s ease}}.schedule-dropdown,.tools-dropdown{position:relative;display:inline-block}.btn-schedule{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:25px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d;display:flex;align-items:center;gap:8px}@media (hover: hover) and (pointer: fine){.btn-schedule:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}}@media (hover: none){.btn-schedule:active{transform:translateY(-1px);box-shadow:0 6px 20px #667eea4d;transition:all .1s ease}}.btn-tools{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;border:none;padding:12px 24px;border-radius:25px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #28a7454d;display:flex;align-items:center;gap:8px}@media (hover: hover) and (pointer: fine){.btn-tools:hover{transform:translateY(-2px);box-shadow:0 8px 25px #28a74566}}@media (hover: none){.btn-tools:active{transform:translateY(-1px);box-shadow:0 6px 20px #28a7454d;transition:all .1s ease}}.dropdown-menu{position:absolute;top:100%;left:0;background:var(--bg-container);border-radius:15px;box-shadow:0 10px 30px #0003;min-width:220px;z-index:1000;margin-top:8px;border:2px solid var(--border-accent);backdrop-filter:blur(10px);animation:dropdownSlideIn .3s ease-out;overflow:hidden}@keyframes dropdownSlideIn{0%{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.dropdown-item{width:100%;background:none;border:none;padding:12px 20px;text-align:left;cursor:pointer;transition:all .2s ease;color:var(--text-primary);font-weight:500;display:flex;align-items:center;gap:8px;font-size:.9em}@media (hover: hover) and (pointer: fine){.dropdown-item:hover{background:var(--bg-cell-hover);transform:translate(2px)}}@media (hover: none){.dropdown-item:active{background:var(--bg-cell-hover);transform:translate(1px);transition:all .1s ease}}@media (hover: hover) and (pointer: fine){.dropdown-item:first-child:hover{border-radius:13px 13px 0 0}}@media (hover: none){.dropdown-item:first-child:active{border-radius:13px 13px 0 0}}@media (hover: hover) and (pointer: fine){.dropdown-item:last-child:hover{border-radius:0 0 13px 13px}}@media (hover: none){.dropdown-item:last-child:active{border-radius:0 0 13px 13px}}.dropdown-divider{height:1px;background:var(--border-primary);margin:8px 0;opacity:.5}body.dark-mode .dropdown-menu{box-shadow:0 10px 30px #0006;border-color:var(--border-accent)}@media (hover: hover) and (pointer: fine){body.dark-mode .dropdown-item:hover{background:#7c8cf01a}}@media (hover: none){body.dark-mode .dropdown-item:active{background:#7c8cf01a;transition:all .1s ease}}.btn-add-style{color:#28a745!important}.btn-add-style:hover{background:#28a7451a!important}.btn-save-style{color:#20c997!important}.btn-save-style:hover{background:#20c9971a!important}.btn-load-style{color:#17a2b8!important}.btn-load-style:hover{background:#17a2b81a!important}.btn-clear-unpinned-style{color:#ff9a56!important}.btn-clear-unpinned-style:hover{background:#ff9a561a!important}.btn-clear-style{color:#fa709a!important}.btn-clear-style:hover{background:#fa709a1a!important}.btn-calendar-style{color:#007bff!important}.btn-calendar-style:hover{background:#007bff1a!important}.btn-pomodoro-style{color:#fd7e14!important}.btn-pomodoro-style:hover{background:#fd7e141a!important}.btn-notes-style{color:#6f42c1!important}.btn-notes-style:hover{background:#6f42c11a!important}@media (max-width: 768px){.dropdown-menu{min-width:200px;left:50%;transform:translate(-50%)}.dropdown-item{padding:14px 16px;font-size:.85em}.btn-schedule,.btn-tools{padding:10px 18px;font-size:.85em}}@media (hover: none) and (pointer: coarse){.minimize-maximize-btn:active{background-color:#f7fafc!important;transform:scale(1.1);transition:all .1s ease}body.dark-mode .minimize-maximize-btn:active{background-color:#4a5568!important;transform:scale(1.1);transition:all .1s ease}.close-btn:active{background-color:#ff453a!important;transform:scale(1.1);transition:all .1s ease}.minimize-maximize-btn:focus-visible{background-color:#f7fafc!important;transform:scale(1.05);outline:2px solid var(--text-accent);outline-offset:2px}body.dark-mode .minimize-maximize-btn:focus-visible{background-color:#4a5568!important}.close-btn:focus-visible{background-color:#ff453acc!important;transform:scale(1.05);outline:2px solid #ff4757;outline-offset:2px}.minimize-maximize-btn,.close-btn{min-width:32px;min-height:32px;padding:8px!important}}body.dark-mode{--bg-primary: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);--bg-container: rgba(30, 30, 40, .95);--bg-container-secondary: rgba(40, 40, 50, .9);--bg-table: #2a2a3a;--bg-cell: #343444;--bg-cell-hover: #4a4a5a;--bg-time-slot: linear-gradient(135deg, #343444, #2a2a3a);--bg-modal: rgba(0, 0, 0, .7);--bg-footer: rgba(0, 0, 0, .3);--text-primary: #e8e8e8;--text-secondary: #b8b8b8;--text-muted: #888888;--text-accent: #7c8cf0;--text-footer: rgba(255, 255, 255, .9);--text-footer-link: rgba(255, 255, 255, .8);--border-primary: #4a4a5a;--border-accent: rgba(124, 140, 240, .3);--border-dashed: #7c8cf0;--shadow-light: 0 8px 25px rgba(0, 0, 0, .3);--shadow-medium: 0 25px 50px rgba(0, 0, 0, .4);--shadow-heavy: 0 10px 30px rgba(0, 0, 0, .3)}*{margin:0;padding:0;box-sizing:border-box;transition:background-color .3s ease,color .3s ease,border-color .3s ease}.App{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:var(--bg-primary);min-height:100vh;padding:20px;transition:all .3s ease}.container{background:var(--bg-container);border-radius:20px;padding:30px;box-shadow:var(--shadow-medium);backdrop-filter:blur(10px);max-width:1600px;margin:0 auto;transition:all .3s ease}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;flex-wrap:wrap;gap:20px;font-size:.9rem}.header h1{color:var(--text-primary);font-size:2.8em;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.1);flex:1;min-width:300px;transition:color .3s ease}.datetime-info{display:flex;align-items:center;gap:30px;flex:1;justify-content:center}.current-datetime{text-align:center;background:var(--bg-container-secondary);padding:15px 30px;border-radius:15px;box-shadow:var(--shadow-light);border:2px solid var(--border-accent);min-width:160px;transition:all .3s ease}.date-display{font-size:1.1em;font-weight:600;color:var(--text-primary);margin-bottom:4px;transition:color .3s ease}.time-display{font-size:1.3em;font-weight:700;color:var(--text-accent);font-family:Courier New,monospace;transition:color .3s ease}.week-info{text-align:center;background:var(--bg-container-secondary);padding:15px 30px;border-radius:15px;box-shadow:var(--shadow-light);border:2px solid var(--border-accent);min-width:160px;transition:all .3s ease}.week-display{font-size:1.1em;font-weight:600;color:var(--text-primary);margin-bottom:8px;transition:color .3s ease}.week-navigation{display:flex;align-items:center;gap:15px;justify-content:center;margin-bottom:8px}.time-month-header{position:relative;padding:8px!important;width:80px}.diagonal-header{position:relative;width:100%;height:40px;display:flex;align-items:center;justify-content:center}.time-label{position:absolute;bottom:2px;left:4px;font-size:.8em;font-weight:600;color:var(--text-primary)}.month-label{position:absolute;top:2px;right:4px;font-size:.8em;font-weight:600;color:var(--text-primary)}.diagonal-line{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(to bottom left,transparent 47%,var(--text-primary) 47%,var(--text-primary) 53%,transparent 53%);pointer-events:none}.week-progress{width:100%;height:8px;background:var(--border-primary);border-radius:4px;overflow:hidden;position:relative}.week-progress-bar{height:100%;background:linear-gradient(135deg,#43e97b,#38f9d7);border-radius:4px;transition:width .3s ease;box-shadow:0 2px 8px #43e97b4d}body.dark-mode .week-progress-bar{box-shadow:0 2px 8px #43e97b66}.theme-toggle{display:flex;align-items:center}.btn-theme-toggle{background:var(--bg-container-secondary);color:var(--text-primary);border:2px solid var(--border-accent);padding:12px 16px;border-radius:50px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-light);display:flex;align-items:center;gap:8px;font-size:.9em;min-width:100px;justify-content:center}.btn-theme-toggle:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea66;border-color:var(--text-accent)}.btn-theme-toggle:active{transform:translateY(-1px) scale(.98)}.btn-theme-toggle:focus{outline:none;box-shadow:0 0 0 3px #7c8cf04d}.theme-icon{font-size:1.2em;transition:transform .3s ease}.theme-text{font-size:.85em;font-weight:500}.btn-theme-toggle:hover .theme-icon{transform:rotate(20deg)}.user-info{display:flex;align-items:center;gap:15px;padding:10px 15px;background:var(--bg-container-secondary);border-radius:15px;border:2px solid var(--border-accent);box-shadow:var(--shadow-light);transition:all .3s ease;min-width:120px;width:auto;flex-shrink:0}.user-profile{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.user-avatar{width:40px;height:40px;border-radius:50%;border:2px solid var(--border-accent);transition:all .3s ease}.user-avatar:hover{transform:scale(1.05);border-color:var(--text-accent)}.user-details{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0;overflow:hidden}.user-name{font-size:.9em;font-weight:600;color:var(--text-primary);transition:color .3s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:.75em;color:var(--text-muted);transition:color .3s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-logout{background:linear-gradient(135deg,#ff6b6b,#ee5a52);color:#fff;border:none;padding:6px 12px;border-radius:15px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #ff6b6b4d;font-size:.8em;white-space:nowrap;flex-shrink:0}.btn-logout:hover{transform:translateY(-2px);box-shadow:0 8px 25px #ff6b6b66;background:linear-gradient(135deg,#ff5252,#e53935)}.btn-logout:active{transform:translateY(0)}.controls{display:flex;gap:15px;flex-wrap:wrap}.btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:25px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea4d}.btn:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea66}.btn-add{background:linear-gradient(135deg,#43e97b,#38f9d7);box-shadow:0 4px 15px #43e97b4d}.btn-add:hover{box-shadow:0 8px 25px #43e97b66}.btn-clear{background:linear-gradient(135deg,#fa709a,#fee140);box-shadow:0 4px 15px #fa709a4d;color:#333!important}.btn-clear:hover{box-shadow:0 8px 25px #fa709a66}.btn-clear-unpinned{background:linear-gradient(135deg,#ff9a56,#ff6b6b);box-shadow:0 4px 15px #ff9a564d;color:#333!important}.btn-clear-unpinned:hover{box-shadow:0 8px 25px #ff9a5666}.btn-cancel{background:#6c757d;box-shadow:0 4px 15px #6c757d4d}body.dark-mode .btn:hover{box-shadow:0 8px 25px #7c8cf066}body.dark-mode .btn-add:hover{box-shadow:0 8px 25px #43e97b66}body.dark-mode .btn-clear:hover{box-shadow:0 8px 25px #fa709a66}body.dark-mode .btn-clear-unpinned:hover{box-shadow:0 8px 25px #ff9a5666}body.dark-mode .btn-clear,body.dark-mode .btn-clear-unpinned{color:#333!important}.table-container{width:100%;overflow-x:auto;margin-bottom:30px}.schedule-table{width:100%;border-collapse:collapse;border-radius:15px;overflow:hidden;box-shadow:var(--shadow-heavy);background:var(--bg-table);transition:all .3s ease}.schedule-table th{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:18px 10px;text-align:center;font-weight:600;font-size:1.1em;border:none;position:sticky;top:0;z-index:10}.schedule-table td{padding:8px 6px;text-align:center;border:1px solid var(--border-primary);vertical-align:middle;position:relative;transition:all .3s ease;cursor:pointer;min-height:60px;height:60px}.schedule-table tr:nth-child(2n){background-color:var(--bg-cell)}.schedule-table tr:hover{background-color:var(--bg-cell-hover)}body.dark-mode .schedule-table tr:hover{background-color:#7c8cf01a}.time-slot{font-weight:700;color:var(--text-secondary);background:var(--bg-time-slot)!important;width:100px;font-size:.95em;position:sticky;left:0;z-index:5;transition:all .3s ease}.day-cell{background:var(--bg-cell);border:1px solid var(--border-primary);padding:4px;transition:all .3s ease;min-width:120px;position:relative}.day-cell:hover:not(.drop-target){background-color:var(--bg-cell-hover)!important;border:2px dashed var(--border-dashed)}body.dark-mode .day-cell:hover:not(.drop-target){background-color:#7c8cf026!important;border:2px dashed var(--text-accent)}.day-cell.drop-target{background:linear-gradient(135deg,#e3f2fd,#bbdefb)!important;border:2px dashed #2196f3!important;transform:scale(1.02);box-shadow:inset 0 0 10px #2196f34d;animation:pulse-drop-target 1s infinite}body.dark-mode .day-cell.drop-target{background:linear-gradient(135deg,#1e3a8a,#1e40af)!important;border:2px dashed #3b82f6!important;box-shadow:inset 0 0 10px #3b82f666;animation:pulse-drop-target-dark 1s infinite}@keyframes pulse-drop-target{0%{box-shadow:inset 0 0 10px #2196f34d,0 0 #2196f366}70%{box-shadow:inset 0 0 10px #2196f34d,0 0 0 10px #2196f300}to{box-shadow:inset 0 0 10px #2196f34d,0 0 #2196f300}}@keyframes pulse-drop-target-dark{0%{box-shadow:inset 0 0 10px #3b82f666,0 0 #3b82f666}70%{box-shadow:inset 0 0 10px #3b82f666,0 0 0 10px #3b82f600}to{box-shadow:inset 0 0 10px #3b82f666,0 0 #3b82f600}}.day-cell.drop-target:before{content:"여기에 놓기";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#2196f3e6;color:#fff;padding:5px 10px;border-radius:5px;font-size:.8em;font-weight:600;white-space:nowrap;z-index:5;animation:bounceIn .3s ease-out}body.dark-mode .day-cell.drop-target:before{background:#3b82f6e6}@keyframes bounceIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.3)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.1)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.schedule-item{color:#fff;padding:2px 4px;border-radius:4px;margin:0;font-size:.85em;font-weight:600;box-shadow:0 3px 10px #4facfe4d;transition:all .3s ease;cursor:grab;position:relative;word-break:break-word;text-shadow:0 1px 2px rgba(0,0,0,.3);height:100%;width:100%;display:flex;flex-direction:column;justify-content:center;user-select:none}.schedule-item:hover{transform:translateY(-2px);box-shadow:0 5px 20px #4facfe66}.schedule-item:active{cursor:grabbing}body.dark-mode .schedule-item:hover{box-shadow:0 5px 20px #7c8cf04d}.schedule-item.being-dragged{opacity:.5;transform:rotate(5deg) scale(1.05);z-index:1000;cursor:grabbing;box-shadow:0 10px 30px #0006;border:2px solid #000000}.schedule-item.pinned{border:2px solid #ffd700;box-shadow:0 3px 15px #ffd70066}.schedule-item.pinned:before{content:"📌";position:absolute;top:-8px;left:-8px;background:gold;color:#2c3e50;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;box-shadow:0 2px 8px #ffd7004d}.schedule-item.start-block{border-top:3px solid rgba(255,255,255,.8);border-left:3px solid rgba(255,255,255,.8);border-right:3px solid rgba(255,255,255,.8)}.schedule-item.continuation-block{opacity:.8;border-left:3px solid rgba(255,255,255,.6);border-right:3px solid rgba(255,255,255,.6);border-top:1px dashed rgba(255,255,255,.4);border-bottom:1px dashed rgba(255,255,255,.4)}.schedule-item.continuation-block:last-child{border-bottom:3px solid rgba(255,255,255,.8)}.duration-badge{background:#0000004d;color:#fff;padding:2px 6px;border-radius:10px;font-size:.75em;font-weight:700;margin-left:5px;display:inline-block;text-shadow:none;border:1px solid rgba(255,255,255,.3)}.continuation-indicator{font-size:.75em;opacity:.95;font-style:italic;text-shadow:0 1px 2px rgba(0,0,0,.3)}.item-title{font-weight:600;margin-bottom:2px;display:flex;align-items:center;justify-content:space-between}.item-duration{font-size:.75em;opacity:.8}.close-btn{position:absolute;top:-5px;right:-5px;background:#ff4757;color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:12px;cursor:pointer;display:none;align-items:center;justify-content:center;z-index:10}.schedule-item:hover .close-btn{display:flex}.schedule-item.start-block:after{content:"⋮⋮";position:absolute;top:2px;left:2px;font-size:10px;opacity:.7;color:#fff;cursor:grab;z-index:5;transition:opacity .2s ease;pointer-events:none}.schedule-item.start-block:hover:after{opacity:1}.theme-work{background:linear-gradient(135deg,#4a90e2,#357abd)!important}.theme-study{background:linear-gradient(135deg,#27ae60,#16a085)!important}.theme-exercise{background:linear-gradient(135deg,#e74c3c,#c0392b)!important}.theme-meal{background:linear-gradient(135deg,#f39c12,#e67e22)!important}.theme-rest{background:linear-gradient(135deg,#9b59b6,#8e44ad)!important}.theme-hobby{background:linear-gradient(135deg,#ff6b9d,#c44569)!important}.theme-social{background:linear-gradient(135deg,#17a2b8,#138496)!important}.theme-health{background:linear-gradient(135deg,#fd7e14,#e55353)!important}.theme-gray{background:linear-gradient(135deg,#6c757d,#495057)!important}.theme-custom{background:linear-gradient(135deg,#667eea,#764ba2)!important}.App.dragging-mode{cursor:grabbing}.App.dragging-mode *{pointer-events:none}.App.dragging-mode .day-cell,.App.dragging-mode .schedule-item.being-dragged{pointer-events:auto}.App.dragging-mode .schedule-item:not(.being-dragged){opacity:.3;filter:grayscale(50%)}.App.dragging-mode .day-cell:not(.drop-target){opacity:.7;filter:grayscale(30%)}.success-toast{position:fixed;top:20px;right:20px;background:linear-gradient(135deg,#43e97b,#38f9d7);color:#fff;padding:15px 20px;border-radius:10px;box-shadow:0 4px 15px #43e97b4d;z-index:10000;font-weight:600;max-width:300px;animation:slideInRight .3s ease-out}.success-toast.fade-out{animation:slideOutRight .3s ease-in forwards}.drag-guide-overlay{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000d9;color:#fff;padding:20px 30px;border-radius:15px;z-index:10000;text-align:center;backdrop-filter:blur(10px);box-shadow:0 10px 30px #0000004d;font-size:1.1em;font-weight:600;border:2px solid rgba(255,255,255,.2);animation:fadeInScale .3s ease-out}body.dark-mode .drag-guide-overlay{background:#000000e6;border-color:#ffffff4d}@keyframes fadeInScale{0%{opacity:0;transform:translate(-50%,-50%) scale(.8)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOutRight{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}.modal{position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;background-color:var(--bg-modal);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;transition:all .3s ease}.modal-content{background:var(--bg-container);padding:30px;border-radius:20px;width:90%;max-width:500px;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .3s ease-out;max-height:90vh;overflow-y:auto;transition:all .3s ease}body.dark-mode .modal-content{box-shadow:0 20px 60px #0009}@keyframes modalSlideIn{0%{transform:translateY(-50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-content h2{color:var(--text-primary);margin-bottom:20px;text-align:center;transition:color .3s ease}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:var(--text-secondary);transition:color .3s ease}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px;border:2px solid var(--border-primary);border-radius:10px;font-size:1em;transition:all .3s ease;background:var(--bg-container-secondary);color:var(--text-primary)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--text-accent);box-shadow:0 0 0 3px #667eea1a}body.dark-mode input::placeholder,body.dark-mode textarea::placeholder{color:var(--text-muted)}body.dark-mode select option{background:var(--bg-container);color:var(--text-primary)}.form-actions{display:flex;gap:15px;justify-content:flex-end;margin-top:30px}.color-picker{display:grid;grid-template-columns:repeat(5,1fr);grid-template-rows:repeat(2,1fr);gap:6px;margin-top:10px;padding:8px;background:var(--bg-container-secondary);border-radius:8px;border:1px solid var(--border-primary);max-width:350px;margin-left:auto;margin-right:auto}.color-option{transition:all .3s ease;width:100%;height:32px;border-radius:8px}.color-option:hover{transform:scale(1.05);box-shadow:0 2px 8px #0003}.checkbox-group{display:flex;align-items:center;gap:10px;margin-top:10px;cursor:pointer}.checkbox-group input[type=checkbox]{width:20px;height:20px;cursor:pointer}.checkbox-group label{margin:0!important;cursor:pointer;color:var(--text-secondary);font-weight:500;transition:color .3s ease}.stats{margin-top:30px;padding:25px;background:var(--bg-container-secondary);border-radius:15px;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;transition:all .3s ease}.stat-item{text-align:center;padding:20px;background:var(--bg-container);border-radius:12px;box-shadow:0 4px 15px #0000000d;transition:all .3s ease;border:1px solid var(--border-primary);cursor:pointer}.stat-item:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000001a}body.dark-mode .stat-item{box-shadow:0 4px 15px #0003}body.dark-mode .stat-item:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000004d}.stat-number{font-size:2.5em;font-weight:700;color:var(--text-accent);margin-bottom:5px;transition:color .3s ease}.stat-label{color:var(--text-muted);font-weight:500;transition:color .3s ease}footer{background:var(--bg-footer)!important;transition:all .3s ease}footer p{color:var(--text-footer)!important}footer button{color:var(--text-footer-link)!important}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.container{padding:15px}.header{flex-direction:column;text-align:center}.header h1{font-size:2em;min-width:auto}.datetime-info{flex-direction:column;gap:15px;width:100%;justify-content:center}.current-datetime,.week-info,.btn-theme-toggle{padding:10px 15px}.date-display,.week-display{font-size:1em}.time-display{font-size:1.1em}.schedule-table th,.schedule-table td{padding:6px 4px;font-size:.8em}.day-cell{min-width:80px}.controls{justify-content:center}.modal-content{width:95%;padding:20px;max-height:85vh;height:auto;min-height:70vh}.color-picker{grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(2,1fr);gap:4px;padding:6px;max-width:220px}.color-option{min-height:22px!important}.color-option div{font-size:10px!important}.duration-badge{font-size:.65em;padding:1px 4px}.continuation-indicator{font-size:.65em}.table-container{overflow-x:auto}.schedule-item{touch-action:none;-webkit-user-select:none;user-select:none}.drag-guide-overlay{font-size:1em;padding:15px 20px;max-width:90vw}.day-cell.drop-target:before{font-size:.7em;padding:3px 8px}.schedule-item.start-block:after{font-size:12px;top:3px;left:3px}.btn-theme-toggle{min-width:80px;padding:10px 12px}.theme-text{display:none}.theme-icon{font-size:1.4em}.user-info{padding:8px 12px;gap:10px}.user-profile{gap:8px}.user-avatar{width:32px;height:32px}.user-name{font-size:.8em}.user-email{font-size:.7em;display:none}.btn-logout{padding:6px 12px;font-size:.8em}}@media (prefers-contrast: high){:root{--border-primary: #000000;--text-primary: #000000}body.dark-mode{--border-primary: #ffffff;--text-primary: #ffffff}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-color-scheme: dark){:root{transition:all .3s ease}}@media print{body.dark-mode{--bg-primary: white;--bg-container: white;--text-primary: black;--text-secondary: #333}.btn-theme-toggle{display:none}.controls,footer,.theme-toggle{display:none!important}.schedule-item{border:1px solid #333!important;background:#fff!important;color:#000!important;box-shadow:none!important}.schedule-table{box-shadow:none!important}.container{box-shadow:none!important;padding:10px!important}}body.dark-mode .App{animation:darkModeTransition .5s ease-out}@keyframes darkModeTransition{0%{filter:brightness(1)}50%{filter:brightness(.8)}to{filter:brightness(1)}}button:focus,input:focus,select:focus,textarea:focus{outline:2px solid var(--text-accent);outline-offset:2px}body.dark-mode button:focus,body.dark-mode input:focus,body.dark-mode select:focus,body.dark-mode textarea:focus{outline-color:var(--text-accent)}.schedule-item:focus,.day-cell:focus,.btn:focus{z-index:100;position:relative}.btn-theme-toggle.transitioning{animation:themeToggleTransition .6s ease-in-out}@keyframes themeToggleTransition{0%,to{transform:scale(1) rotate(0)}25%{transform:scale(1.1) rotate(90deg)}50%{transform:scale(1.2) rotate(180deg)}75%{transform:scale(1.1) rotate(270deg)}}.App.dragging-mode,.App.dragging-mode *{cursor:grabbing!important}.App.dragging-mode .day-cell{cursor:copy!important}.drag-selected{border:2px solid rgba(102,126,234,.6)!important;box-shadow:inset 0 0 10px #667eea33!important}.day-cell{user-select:none}@media (-webkit-min-device-pixel-ratio: 2),(min-resolution: 192dpi){.schedule-item,.btn,.modal-content{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}}@media (max-width: 1024px) and (orientation: portrait){.header{gap:15px}.modal-content{width:90%;max-width:600px;max-height:80vh;min-height:60vh}.datetime-info{gap:20px}.controls{gap:10px}.btn{padding:10px 20px;font-size:.9em}}@media (max-width: 1024px) and (orientation: landscape){.header h1{font-size:2.2em}.datetime-info{flex-direction:row;gap:20px}}body.dark-mode .schedule-table th{background:linear-gradient(135deg,#4c5fd7,#6366f1)}body.dark-mode .time-slot{color:var(--text-primary);font-weight:600}.schedule-item,.btn,.modal-content,.drag-guide-overlay{will-change:transform;transform:translateZ(0)}@media (hover: none) and (pointer: coarse){.schedule-item:hover,.btn:hover,.stat-item:hover{transform:none}.schedule-item:active,.btn:active{transform:scale(.98)}}:root{font-family: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}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
