.chat-sidebar{position:absolute;top:0;left:0;bottom:0;width:280px;background:#1a1a2e;display:flex;flex-direction:column;transform:translate(-100%);transition:transform .3s ease;z-index:100}.chat-sidebar.open{transform:translate(0)}.sidebar-overlay{position:absolute;inset:0;background:#00000080;z-index:99}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-header h2{color:#fff;font-size:1rem;margin:0}.sidebar-close{background:none;border:none;color:#ffffffb3;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center}.sidebar-close:hover{color:#fff}.new-chat-btn{display:flex;align-items:center;gap:8px;margin:12px;padding:12px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:transform .2s,box-shadow .2s}.new-chat-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.sessions-list{flex:1;overflow-y:auto;padding:8px}.no-sessions{color:#ffffff80;text-align:center;padding:24px 16px;font-size:.875rem}.session-group{margin-bottom:16px}.session-date{color:#ffffff80;font-size:.75rem;font-weight:500;padding:8px 8px 4px;text-transform:uppercase;letter-spacing:.5px}.session-item{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;background:transparent;border:none;border-radius:8px;color:#fffc;font-size:.875rem;text-align:left;cursor:pointer;transition:background-color .2s}.session-item:hover{background:#ffffff1a}.session-item.active{background:#667eea4d;color:#fff}.session-item svg{flex-shrink:0;opacity:.7}.session-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.session-edit-btn{opacity:0;background:none;border:none;color:#fff9;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:opacity .2s,background-color .2s;flex-shrink:0}.session-item:hover .session-edit-btn{opacity:1}.session-edit-btn:hover{background:#ffffff1a;color:#fff}.session-title-input{flex:1;background:#ffffff1a;border:1px solid rgba(102,126,234,.5);border-radius:4px;color:#fff;font-size:.875rem;padding:4px 8px;outline:none}.session-title-input:focus{border-color:#667eea;background:#ffffff26}.sidebar-footer{padding:16px;border-top:1px solid rgba(255,255,255,.1)}.sidebar-note{color:#ffffff80;font-size:.75rem;line-height:1.4;margin:0}@media (min-width: 769px){.chat-sidebar{position:relative;transform:translate(0);border-right:1px solid rgba(255,255,255,.1)}.chat-sidebar:not(.open){display:none}.sidebar-overlay,.sidebar-close{display:none}}.chat-message{display:flex;gap:12px;max-width:85%}.chat-message.user{flex-direction:row-reverse;margin-left:auto}.chat-message.assistant{margin-right:auto}.message-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;flex-shrink:0}.chat-message.user .message-avatar{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.chat-message.assistant .message-avatar{background:#e0e7ff;color:#4f46e5}.message-content{display:flex;flex-direction:column;gap:8px}.message-image{max-width:250px;border-radius:12px;overflow:hidden}.message-image img{width:100%;height:auto;display:block}.message-text{background:#fff;padding:12px 16px;border-radius:16px;font-size:.9375rem;line-height:1.5;color:#333;white-space:pre-wrap;word-wrap:break-word}.chat-message.user .message-text{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-bottom-right-radius:4px}.chat-message.assistant .message-text{background:#fff;border-bottom-left-radius:4px;box-shadow:0 1px 3px #0000001a}.message-time{font-size:.6875rem;color:#999;padding:0 4px}.chat-message.user .message-time{text-align:right}@media (max-width: 768px){.chat-message{max-width:90%}.message-avatar{width:32px;height:32px;font-size:.625rem}.message-text{padding:10px 14px;font-size:.875rem}.message-image{max-width:200px}}.photo-capture{position:relative}.photo-btn{background:none;border:none;color:#667eea;cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.photo-btn:hover{background:#667eea1a}.photo-options-overlay{position:fixed;inset:0;z-index:10}.photo-options{position:absolute;bottom:100%;left:0;margin-bottom:8px;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;overflow:hidden;z-index:11;min-width:160px}.photo-option{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;background:none;border:none;font-size:.875rem;color:#333;cursor:pointer;transition:background-color .2s;text-align:left}.photo-option:hover{background:#f5f5f5}.photo-option:first-child{border-bottom:1px solid #eee}.photo-option svg{color:#667eea}@media (max-width: 768px){.photo-options{left:0;right:auto}}.tutor-page{position:fixed;inset:0;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;z-index:1000}.tutor-header{display:flex;align-items:center;padding:12px 16px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.2)}.tutor-header h1{flex:1;font-size:1.25rem;color:#fff;margin:0;text-align:center}.tutor-menu-btn,.tutor-close-btn{background:#fff3;border:none;border-radius:8px;padding:8px 12px;color:#fff;cursor:pointer;transition:background-color .2s}.tutor-menu-btn:hover,.tutor-close-btn:hover{background:#ffffff4d}.tutor-menu-btn{padding:8px;display:flex;align-items:center;justify-content:center}.tutor-close-btn{font-size:.875rem;font-weight:500}.tutor-content{flex:1;display:flex;overflow:hidden;position:relative}.tutor-main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:#f5f5f5}.tutor-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px}.tutor-welcome{max-width:500px;margin:auto;text-align:center;padding:32px 16px}.tutor-welcome h2{font-size:1.5rem;color:#333;margin-bottom:16px}.tutor-welcome p{color:#666;line-height:1.6;margin-bottom:12px}.tutor-suggestions{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:24px}.tutor-suggestions button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:20px;padding:10px 16px;font-size:.875rem;cursor:pointer;transition:transform .2s,box-shadow .2s}.tutor-suggestions button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.tutor-error{background:#fee2e2;color:#dc2626;padding:12px 16px;border-radius:8px;font-size:.875rem}.image-preview-container{padding:8px 16px;background:#fff;border-top:1px solid #e5e5e5;display:flex;align-items:center;gap:12px}.image-preview{max-height:80px;max-width:120px;border-radius:8px;object-fit:cover}.image-preview-remove{background:#ef4444;color:#fff;border:none;border-radius:4px;padding:4px 12px;font-size:.75rem;cursor:pointer}.image-preview-remove:hover{background:#dc2626}.tutor-input-form{display:flex;align-items:flex-end;gap:8px;padding:12px 16px;background:#fff;border-top:1px solid #e5e5e5}.tutor-input-form textarea{flex:1;border:1px solid #ddd;border-radius:20px;padding:10px 16px;font-size:1rem;resize:none;max-height:120px;min-height:44px;font-family:inherit;outline:none;transition:border-color .2s}.tutor-input-form textarea:focus{border-color:#667eea}.tutor-input-form textarea:disabled{background:#f5f5f5}.send-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s,opacity .2s;flex-shrink:0}.send-btn:hover:not(:disabled){transform:scale(1.05)}.send-btn:disabled{opacity:.5;cursor:not-allowed}.typing{display:flex;gap:4px;padding:8px 0}.typing span{width:8px;height:8px;background:#999;border-radius:50%;animation:typing 1.4s infinite ease-in-out both}.typing span:nth-child(1){animation-delay:-.32s}.typing span:nth-child(2){animation-delay:-.16s}@keyframes typing{0%,80%,to{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}@media (max-width: 768px){.tutor-header h1{font-size:1.1rem}.tutor-close-btn{font-size:.75rem;padding:6px 10px}.tutor-welcome{padding:24px 16px}.tutor-welcome h2{font-size:1.25rem}.tutor-suggestions{flex-direction:column}.tutor-suggestions button{width:100%}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:linear-gradient(135deg,#74b9ff,#0984e3);min-height:100vh;padding:20px}.container{max-width:1200px;margin:0 auto;background:#fffffff2;border-radius:20px;box-shadow:0 20px 40px #0000001a;overflow:hidden}.main-content{display:flex;gap:0}.main-content__left{flex:1;min-width:0;border-right:1px solid #e9ecef}.main-content__right{flex:1;min-width:0;background:#f8f9fa}@media (max-width: 900px){.main-content{flex-direction:column-reverse}.main-content__left{border-right:none;border-top:1px solid #e9ecef}.main-content__right{border-bottom:1px solid #e9ecef}}.banner{padding:10px;border-radius:5px;margin:10px;text-align:center}.banner--offline{background:#fff3cd;color:#856404;font-weight:700}.banner--syncing{background:#cfe2ff;color:#084298}.banner--error{background:#f8d7da;color:#721c24;display:flex;justify-content:space-between;align-items:center}.banner--loading{background:#d4edda;color:#155724}.banner__dismiss{background:none;border:none;font-size:18px;cursor:pointer;padding:0;line-height:1}.header{background:linear-gradient(135deg,#5e72e4,#825ee4);color:#fff;padding:25px;text-align:center;position:relative}.date-display{font-size:1.8em;font-weight:700;margin-bottom:10px}.date-navigation{display:flex;justify-content:center;align-items:center;gap:20px;margin-top:15px}.nav-btn{background:#fff3;border:none;color:#fff;padding:8px 16px;border-radius:8px;cursor:pointer;font-size:1em;transition:all .3s ease}.nav-btn:hover{background:#ffffff4d;transform:translateY(-2px)}.nav-btn-mobile{display:none}.nav-btn-full{display:inline}.settings-btn{position:absolute;top:20px;right:20px;background:#fff3;border:none;color:#fff;padding:8px 12px;border-radius:8px;cursor:pointer;font-size:1.2em}.periods-container{padding:20px}.period-box{margin-bottom:15px;border-radius:12px;overflow:hidden;box-shadow:0 4px 20px #00000026;transition:transform .3s ease}.period-box:hover{transform:translateY(-2px);box-shadow:0 6px 30px #0003}.period-header{padding:15px;color:#fff;font-weight:700;font-size:1.1em;display:flex;justify-content:space-between;align-items:center}.period-header--clickable{cursor:pointer;transition:filter .2s ease}.period-header--clickable:hover{filter:brightness(1.1)}.period-header--clickable:active{filter:brightness(.95)}.task-count{font-size:.85em;opacity:.9}.no-homework-hint{text-align:center;padding:20px;color:#6c757d;cursor:pointer;border:2px dashed #dee2e6;border-radius:8px;transition:all .2s ease;font-size:.95em}.no-homework-hint:hover{background:#e9ecef;border-color:#adb5bd;color:#495057}.period-content{padding:15px;background:#f8f9fa}.homework-item-wrapper{margin-bottom:15px}.homework-item{display:flex;align-items:center;padding:12px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.homework-item input[type=checkbox]{width:20px;height:20px;margin-right:12px;cursor:pointer}.homework-text{flex:1;padding:8px;border:none;background:transparent;font-size:1em}.homework-item.completed .homework-text{text-decoration:line-through;opacity:.6}.add-homework-btn{width:100%;padding:10px;background:#e3e4e6;border:2px dashed #b0b3b8;border-radius:8px;color:#65676b;cursor:pointer;font-size:.95em;transition:all .3s ease}.add-homework-btn:hover{background:#d8dadf;border-color:#8a8d91}.photo-section{margin-top:10px;padding-top:10px;border-top:1px solid #e0e0e0}.photo-upload-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;background:#4caf50;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1.2em;margin-left:8px;transition:all .2s ease}.photo-upload-btn:hover{background:#45a049;transform:scale(1.05)}.photo-preview{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}.photo-preview img{width:60px;height:60px;object-fit:cover;border-radius:6px;cursor:pointer}.delete-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;background:#f44;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:1.2em;margin-left:8px;transition:all .2s ease}.delete-btn:hover{background:#f33;transform:scale(1.05)}.modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:1000;justify-content:center;align-items:center}.modal.active{display:flex}.modal-content{background:#fff;border-radius:15px;padding:30px;max-width:500px;width:90%;max-height:80vh;overflow-y:auto}.modal-header{font-size:1.5em;margin-bottom:20px;color:#333}.recurring-item{display:flex;align-items:center;padding:10px;background:#f8f9fa;border-radius:8px;margin-bottom:10px}.recurring-item input{flex:1;padding:8px;border:1px solid #ddd;border-radius:6px;margin-right:10px}.recurring-item select{margin-right:10px}.recurring-item .delete-btn{display:inline-flex!important;align-items:center!important;justify-content:center!important;width:36px!important;height:36px!important;min-width:36px!important;min-height:36px!important;background:#f44!important;color:#fff!important;border:none!important;border-radius:8px!important;cursor:pointer!important;font-size:1.2em!important;margin-left:0!important;padding:0!important;transition:all .2s ease!important;flex-shrink:0!important}.recurring-item .delete-btn:hover{background:#f33;transform:scale(1.05)}.close-modal{background:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;margin-top:20px}.period-1{background:#ff6b6b}.period-2{background:#4ecdc4}.period-3{background:#45b7d1}.period-4{background:#96ceb4}.period-5{background:#feca57}.period-6{background:plum}.period-7{background:#98d8c8}@media (max-width: 600px){.container{border-radius:0;margin:-20px}.date-display{font-size:1.4em}.homework-item{padding:8px;flex-wrap:nowrap}.homework-text{min-width:0;flex:1;padding:6px;font-size:.9em}.homework-item input[type=checkbox]{width:18px;height:18px;margin-right:8px;flex-shrink:0}.photo-upload-btn,.delete-btn{width:32px!important;height:32px!important;min-width:32px!important;min-height:32px!important;font-size:1em!important;margin-left:6px!important;flex-shrink:0!important}.header{padding:15px 10px;display:flex;flex-direction:column;align-items:center}.header-top{display:flex;justify-content:space-between;align-items:center;width:100%;margin-bottom:12px}.header-spacer{width:36px;height:36px}.settings-btn{position:static;width:36px;height:36px;font-size:1.1em;display:flex;align-items:center;justify-content:center}.date-display{font-size:1.2em;text-align:center;flex:1}.date-navigation{gap:8px}.nav-btn{padding:6px 12px;font-size:.85em;display:flex;align-items:center;justify-content:center}.nav-btn-full{display:none}.nav-btn-mobile{display:inline}}.settings-screen{min-height:100vh;background:#fffffff2;border-radius:0;overflow:hidden}.settings-header{background:linear-gradient(135deg,#5e72e4,#825ee4);color:#fff;padding:20px;display:flex;justify-content:space-between;align-items:center}.back-btn{background:#fff3;border:none;color:#fff;padding:8px 16px;border-radius:8px;cursor:pointer;font-size:1em;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.back-btn:hover{background:#ffffff4d;transform:translateY(-2px)}.settings-title{font-size:1.5em;margin:0;flex:1;text-align:center}.settings-content{padding:20px}.settings-section{margin-bottom:30px}.section-title{font-size:1.3em;color:#333;margin-bottom:8px}.section-description{color:#666;margin-bottom:0;line-height:1.5}.section-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;gap:15px}.section-actions{display:flex;gap:10px;flex-shrink:0}.edit-btn{padding:8px 16px;background:#5e72e4;color:#fff;border:none;border-radius:6px;font-size:.9em;cursor:pointer;transition:all .3s ease}.edit-btn:hover{background:#4a5bc4}.save-btn{padding:8px 16px;background:#2dce89;color:#fff;border:none;border-radius:6px;font-size:.9em;cursor:pointer;transition:all .3s ease}.save-btn:hover:not(:disabled){background:#26af74}.save-btn:disabled{background:#a8e4c0;cursor:not-allowed}.cancel-btn{padding:8px 16px;background:#f5f5f5;color:#666;border:1px solid #ddd;border-radius:6px;font-size:.9em;cursor:pointer;transition:all .3s ease}.cancel-btn:hover:not(:disabled){background:#e8e8e8}.cancel-btn:disabled{opacity:.6;cursor:not-allowed}.delete-btn{width:28px;height:28px;background:#ff6b6b;color:#fff;border:none;border-radius:50%;font-size:1.2em;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;line-height:1}.delete-btn:hover{background:#ee5a5a;transform:scale(1.1)}.no-items-message{color:#888;text-align:center;padding:20px;font-style:italic}.recurring-items{margin-bottom:20px}.settings-recurring-item{background:#fff;border-radius:12px;padding:20px;margin-bottom:15px;box-shadow:0 2px 10px #0000001a;border:1px solid #e0e0e0}.recurring-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.period-label{font-weight:700;color:#5e72e4;font-size:.95em}.recurring-text-input{width:100%;padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:1em;margin-bottom:15px;transition:border-color .3s ease;box-sizing:border-box}.recurring-text-input:focus{outline:none;border-color:#5e72e4}.period-select{width:100%;padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:1em;background:#fff;transition:border-color .3s ease;box-sizing:border-box}.period-select:focus{outline:none;border-color:#5e72e4}.add-recurring-btn{width:100%;padding:15px;background:#5e72e4;color:#fff;border:none;border-radius:8px;font-size:1em;cursor:pointer;transition:all .3s ease}.add-recurring-btn:hover:not(:disabled){background:#4a5bc4;transform:translateY(-2px)}.add-recurring-btn:disabled{background:#ccc;cursor:not-allowed}.no-classes-warning{color:#856404;background:#fff3cd;padding:10px;border-radius:8px;margin-top:10px;text-align:center}.classes-list{margin-bottom:20px}.class-item{background:#fff;border-radius:12px;padding:15px;margin-bottom:12px;box-shadow:0 2px 10px #0000001a;border:1px solid #e0e0e0;transition:all .3s ease}.class-item--disabled{opacity:.6;background:#f5f5f5}.class-item-toggle{display:flex;align-items:center;gap:12px;margin-bottom:12px}.period-number{font-weight:700;color:#5e72e4;font-size:.95em}.class-item-fields{display:flex;gap:10px}.class-input{flex:1;padding:10px 14px;border:2px solid #e0e0e0;border-radius:8px;font-size:.95em;transition:border-color .3s ease}.class-input:focus{outline:none;border-color:#5e72e4}.class-input:disabled{background:#f0f0f0;cursor:not-allowed}.class-input--subject{flex:1.2}.class-input--teacher{flex:1}.toggle-switch{position:relative;display:inline-block;width:48px;height:26px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#ccc;transition:.3s;border-radius:26px}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%;box-shadow:0 2px 4px #0003}.toggle-switch input:checked+.toggle-slider{background:linear-gradient(135deg,#5e72e4,#825ee4)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(22px)}@media (max-width: 600px){.class-item-fields{flex-direction:column;gap:8px}.class-input--subject,.class-input--teacher{flex:1}}.photo-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:#000000e6;z-index:2000;justify-content:center;align-items:center}.photo-modal.active{display:flex}.photo-modal img{max-width:90%;max-height:90%;border-radius:10px}.photo-modal-close{position:absolute;top:20px;right:30px;color:#fff;font-size:2em;cursor:pointer}.tutor-fab{position:fixed;bottom:24px;right:24px;display:flex;align-items:center;gap:8px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:28px;padding:14px 20px;font-size:1rem;font-weight:600;cursor:pointer;box-shadow:0 4px 20px #667eea66;transition:transform .2s,box-shadow .2s;z-index:100}.tutor-fab:hover{transform:translateY(-2px);box-shadow:0 6px 25px #667eea80}.tutor-fab:active{transform:translateY(0)}.tutor-fab svg{flex-shrink:0}@media (max-width: 600px){.tutor-fab{bottom:16px;right:16px;padding:12px 16px;font-size:.875rem}.tutor-fab span{display:none}.tutor-fab{padding:14px;border-radius:50%}}.long-term-section{height:100%;background:#f8f9fa;display:flex;flex-direction:column}.long-term-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:linear-gradient(135deg,#e74c3c,#c0392b);color:#fff;cursor:pointer;-webkit-user-select:none;user-select:none}.long-term-title{display:flex;align-items:center;gap:10px}.long-term-title h2{font-size:1.1em;font-weight:600;margin:0}.long-term-icon{font-size:.75em;opacity:.8}.long-term-badge{background:#ffffff40;color:#fff;padding:2px 8px;border-radius:12px;font-size:.8em;font-weight:600}.long-term-add-btn{background:#fff3;border:none;color:#fff;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:.9em;transition:background .2s}.long-term-add-btn:hover{background:#ffffff4d}.long-term-content{padding:12px;flex:1;overflow-y:auto}.long-term-empty{text-align:center;color:#6c757d;padding:20px;font-style:italic}.long-term-divider{display:flex;align-items:center;margin:16px 0 12px;color:#6c757d;font-size:.8em;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.long-term-divider:before,.long-term-divider:after{content:"";flex:1;height:1px;background:#dee2e6}.long-term-divider:before{margin-right:12px}.long-term-divider:after{margin-left:12px}.long-term-form{background:#fff;padding:12px;border-radius:8px;margin-bottom:12px;box-shadow:0 2px 8px #00000014}.form-row{margin-bottom:10px}.form-row--split{display:flex;gap:10px}.form-row--split>*{flex:1}.form-input,.form-select{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:.95em;transition:border-color .2s}.form-input:focus,.form-select:focus{outline:none;border-color:#6c5ce7}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:12px}.btn{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-size:.9em;font-weight:500;transition:all .2s}.btn--primary{background:#6c5ce7;color:#fff}.btn--primary:hover:not(:disabled){background:#5a4dd1}.btn--primary:disabled{opacity:.5;cursor:not-allowed}.btn--secondary{background:#e9ecef;color:#495057}.btn--secondary:hover{background:#dee2e6}.long-term-list{display:flex;flex-direction:column;gap:8px}.long-term-item{display:flex;align-items:flex-start;gap:10px;padding:12px;background:#fff;border-radius:8px;border-left:4px solid #6c5ce7;box-shadow:0 1px 4px #0000000d;transition:all .2s}.long-term-item.completed{opacity:.6;border-left-color:#adb5bd}.long-term-item.overdue{border-left-color:#dc3545;background:#fff5f5}.long-term-item.urgent{border-left-color:#fd7e14;background:#fff8f0}.long-term-item.soon{border-left-color:#ffc107}.long-term-item-check input[type=checkbox]{width:18px;height:18px;margin-top:2px;cursor:pointer;accent-color:#6c5ce7}.long-term-item-content{flex:1;min-width:0}.long-term-item-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.long-term-type{font-size:1em}.long-term-item-title{font-weight:500;color:#2d3436}.long-term-item.completed .long-term-item-title{text-decoration:line-through;color:#6c757d}.long-term-subject{background:#e9ecef;padding:2px 8px;border-radius:4px;font-size:.8em;color:#495057}.long-term-description{margin-top:4px;font-size:.85em;color:#6c757d}.long-term-item-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.long-term-due{font-size:.8em;font-weight:600;padding:3px 8px;border-radius:4px;background:#e9ecef;color:#495057;white-space:nowrap}.long-term-due.overdue{background:#f8d7da;color:#721c24}.long-term-due.urgent,.long-term-due.soon{background:#fff3cd;color:#856404}.long-term-actions{display:flex;gap:4px}.long-term-action-btn{background:none;border:none;cursor:pointer;padding:2px;font-size:.85em;opacity:.6;transition:opacity .2s}.long-term-action-btn:hover{opacity:1}@media (max-width: 900px){.long-term-section{height:auto}}@media (max-width: 600px){.long-term-item{flex-wrap:wrap}.long-term-item-meta{flex-direction:row;width:100%;justify-content:space-between;margin-top:8px;padding-top:8px;border-top:1px solid #eee}.form-row--split{flex-direction:column}}
