:root{--glass-blur:40px;--glass-opacity:.12;--glass-bg:rgba(255, 255, 255, var(--glass-opacity));--glass-border:#ffffff40;--glass-shadow:0 10px 40px #00000026;--text-primary:#1d1d1f;--text-secondary:#515154;--accent-color:#0071e3;--body-bg:radial-gradient(at 0% 0%, #ffecd2 0%, transparent 50%), radial-gradient(at 100% 0%, #fcb69f 0%, transparent 50%), radial-gradient(at 100% 100%, #a8edea 0%, transparent 50%), radial-gradient(at 0% 100%, #fed6e3 0%, transparent 50%), #fdfcfb}body.dark-mode{--glass-border:#ffffff38;--glass-shadow:0 15px 50px #00000080;--text-primary:#fff;--text-secondary:#fffc;--body-bg:radial-gradient(at 0% 0%, #450a0a 0%, transparent 70%), radial-gradient(at 100% 0%, #1e1b4b 0%, transparent 70%), radial-gradient(at 100% 100%, #0c0a09 0%, transparent 70%), radial-gradient(at 0% 100%, #1e1b4b 0%, transparent 70%), #020617;background:var(--body-bg);color:var(--text-primary)}body.dark-mode .modal-content{background:var(--glass-bg);border:1px solid var(--glass-border)}body.dark-mode input,body.dark-mode textarea,body.dark-mode select{color:var(--text-primary)}body.dark-mode .form-group input,body.dark-mode .form-group textarea,body.dark-mode .form-group select{background:#00000040;border-color:#ffffff1a}body.dark-mode .form-group input:focus,body.dark-mode .form-group textarea:focus,body.dark-mode .form-group select:focus{background:#0006}body.dark-mode .btn-upload-label{background:#ffffff0d;border-color:#007aff4d}body.dark-mode .btn-upload-label.shared{border-color:#34c75966}body.dark-mode .editor-block.shared{background:#0003;border-color:#34c75933}body.dark-mode .editor-block textarea{color:var(--text-primary);background:#00000040;border-color:#ffffff1a}body.dark-mode .item-row{border-bottom-color:#ffffff0d}*{box-sizing:border-box;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}body{background:var(--body-bg);color:var(--text-primary);background-position:top;background-repeat:no-repeat;background-size:cover;background-attachment:fixed;flex-direction:column;justify-content:flex-start;align-items:center;min-height:100dvh;margin:0;padding:0;transition:background .5s ease-in-out;display:flex}#root{width:100%;transition:all .3s}header{flex-direction:column;align-items:center;width:100%;margin-bottom:24px;display:flex;position:relative}.header-top{justify-content:center;align-items:center;width:100%;margin-bottom:4px;display:flex;position:relative}.main-logo{color:#fff;text-shadow:0 4px 12px #00000026;align-items:center;gap:4px;font-size:1.6rem;font-weight:850;display:flex}.main-logo span{color:var(--accent-blue)}p.subtitle{color:#ffffffe6;text-shadow:0 2px 8px #0000001a;font-size:1.1rem}.header-actions{align-items:center;gap:12px;margin-left:auto;display:flex}.action-btn{background:var(--glass-bg);width:44px;height:44px;-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:14px;justify-content:center;align-items:center;padding:0;font-size:1.3rem;transition:all .3s cubic-bezier(.25,.8,.25,1);display:flex}.action-btn:hover{background:#ffffff40;transform:translateY(-3px)scale(1.05);box-shadow:0 8px 24px #0003}.action-btn:active{transform:translateY(-1px)scale(.98)}.pdf-icon-btn{color:#fff;flex-shrink:0;gap:8px;width:max-content;padding:0 16px;font-size:.95rem;font-weight:600}.pdf-icon-btn span.btn-text{display:inline}.glass-container{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(200%);border:1px solid var(--glass-border);box-shadow:inset 0 1px 1px #ffffff73, var(--glass-shadow);border-radius:20px;padding:24px}.scroll-wrapper{-webkit-overflow-scrolling:touch;flex-direction:column;padding-bottom:8px;display:flex;overflow-x:auto}.scroll-wrapper::-webkit-scrollbar{height:6px}.scroll-wrapper::-webkit-scrollbar-track{background:#0000000d;border-radius:4px}.scroll-wrapper::-webkit-scrollbar-thumb{background:#fff6;border-radius:4px}.timeline-grid{gap:12px;display:grid}.grid-header{text-align:center;background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(180%);border:1px solid var(--glass-border);box-shadow:inset 0 1px 1px #fff6, var(--glass-shadow);color:var(--text-primary);letter-spacing:.05em;border-radius:16px;padding:14px 0;font-weight:700}.grid-time{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(180%);border:1px solid var(--glass-border);box-shadow:inset 0 1px 1px #fff6, var(--glass-shadow);color:var(--text-secondary);border-radius:16px;flex-direction:column;justify-content:center;align-items:center;font-weight:700;display:flex}.modal-content{-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(180%);width:95%;max-width:500px;max-height:90vh;box-shadow:inset 0 1px 1px #fff6, var(--glass-shadow);color:var(--text-primary);scrollbar-width:thin;background:#ffffffd9;border:1px solid #0000001a;border-radius:20px;padding:24px;transition:transform .3s cubic-bezier(.34,1.56,.64,1);overflow-y:auto;transform:scale(.9)}.grid-time .period-num{font-size:1rem}.grid-time .period-num.is-long{font-size:.7rem}.grid-time .period-time{color:var(--text-secondary);text-align:center;margin-top:2px;font-size:.7rem;font-weight:400;line-height:1.1}.timetable-slot{background:rgba(255, 255, 255, var(--glass-opacity));cursor:pointer;border:1px solid var(--glass-border);text-align:center;border-radius:16px;flex-direction:column;justify-content:center;min-height:100px;padding:12px;transition:all .3s cubic-bezier(.25,.8,.25,1);display:flex;overflow:hidden;box-shadow:inset 0 1px 1.5px #fff6}.timetable-slot:hover{z-index:10;background:#ffffff40;transform:translateY(-8px);box-shadow:inset 0 1px 1px #ffffff80,0 15px 35px #00000026}body.dark-mode .timetable-slot{background:var(--glass-bg);border:1px solid #ffffff26}body.dark-mode .timetable-slot:hover{z-index:10;background:#ffffff40;transform:translateY(-8px);box-shadow:inset 0 1px 1px #fff3,0 15px 35px #ffffff26}.timetable-slot.filled,body.dark-mode .timetable-slot.filled{background:var(--glass-bg)}.slot-subject{color:var(--text-primary);-webkit-line-clamp:3;line-clamp:3;word-break:break-all;-webkit-box-orient:vertical;margin-bottom:6px;font-size:.9rem;font-weight:800;line-height:1.25;display:-webkit-box;overflow:hidden}.slot-room{color:var(--text-secondary);margin-bottom:4px;font-size:.72rem;font-weight:600}.slot-prof{color:var(--text-secondary);white-space:pre-line;margin-top:2px;font-size:.8rem}.modal-overlay{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:9999;opacity:0;pointer-events:none;background:#0006;justify-content:center;align-items:center;transition:opacity .3s;display:flex;position:fixed;inset:0}.modal-overlay.active{opacity:1;pointer-events:auto}.modal-overlay.active .modal-content{transform:translateY(0)scale(1)}.modal-content.modal-large{border:1px solid #fff3;flex-direction:column;width:1200px;max-width:95vw;max-height:95vh;padding:0 0 20px;display:flex;box-shadow:0 25px 50px -12px #00000080;overflow:hidden!important}.gradio-container{background:#fff3;border-radius:16px;flex:1;width:100%;min-height:500px;margin-top:10px;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-header h2{font-size:1.5rem}.close-btn{cursor:pointer;width:32px;height:32px;color:var(--text-secondary);background:#0000001a;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:1.2rem;font-weight:700;transition:background .2s;display:flex}.close-btn:hover{background:#0003}.form-group{margin-bottom:16px}.form-group label{color:var(--text-primary);margin-bottom:6px;font-size:.9rem;font-weight:600;display:block}.form-group input,.form-group textarea,.form-group select{width:100%;color:var(--text-primary);background:#ffffff80;border:1px solid #0000001f;border-radius:12px;outline:none;padding:12px 16px;font-size:1rem;transition:all .2s;box-shadow:inset 0 2px 4px #00000005}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--accent-color);background:#fff;box-shadow:0 0 0 3px #0071e333}.composite-input{background:#ffffff80;border:1px solid #0000001f;border-radius:12px;align-items:center;padding:0 0 0 16px;transition:all .2s;display:flex;overflow:hidden;box-shadow:inset 0 2px 4px #00000005}.composite-input:focus-within{border-color:var(--accent-color);background:#fffc;box-shadow:0 0 0 3px #0071e333}.prefix-input{text-align:right;outline:none;flex:1;min-width:0;font-size:1rem;box-shadow:none!important;background:0 0!important;border:none!important;padding:12px 8px 12px 0!important}.domain-suffix{color:var(--text-secondary);-webkit-user-select:none;user-select:none;white-space:nowrap;background:#0000000f;border-left:1px solid #00000014;padding:12px 14px;font-size:.9rem;font-weight:500}.btn-submit{background:var(--accent-color);color:#fff;cursor:pointer;border:none;border-radius:14px;width:100%;margin-top:10px;padding:14px;font-size:1.1rem;font-weight:600;transition:all .2s;box-shadow:0 4px 12px #0071e366}.btn-submit:hover{background:#005bb5;transform:translateY(-2px);box-shadow:0 6px 16px #0071e380}.btn-delete{background:#ff3b30;margin-top:10px;box-shadow:0 4px 12px #ff3b3066}.btn-delete:hover{background:#d63026;box-shadow:0 6px 16px #ff3b3080}.btn-back,.btn-edit{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);color:var(--text-primary);cursor:pointer;border-radius:12px;padding:8px 16px;font-size:.9rem;font-weight:600;transition:all .2s}.btn-back:hover,.btn-edit:hover{background:#fff3;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.btn-logout{color:#ff3b30;cursor:pointer;background:#ffffff4d;border:1px solid #0000001a;border-radius:14px;width:100%;padding:12px;font-size:1rem;font-weight:600;transition:all .2s}.btn-logout:hover{background:#ff3b301a;transform:translateY(-1px)}.term-switcher{-webkit-backdrop-filter:blur(10px);color:#fff;cursor:pointer;background:#ffffff26;border:1px solid #fff3;border-radius:12px;outline:none;padding:8px 12px;font-size:1rem;font-weight:500}.term-switcher option{color:#fff;background:#282828e6}.switch{width:51px;height:31px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.slider{cursor:pointer;background-color:#0000001a;border-radius:34px;transition:all .4s;position:absolute;inset:0}.slider:before{content:"";background-color:#fff;border-radius:50%;width:27px;height:27px;transition:all .4s;position:absolute;bottom:2px;left:2px;box-shadow:0 3px 8px #00000026}input:checked+.slider{background-color:#34c759}input:focus+.slider{box-shadow:0 0 1px #34c759}input:checked+.slider:before{transform:translate(20px)}.spinner{border:4px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:40px;height:40px;margin:40px auto;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.timetable-slot:before{content:"";background:var(--slot-accent-color,var(--accent-blue));border-radius:4px 0 0 4px;width:4px;position:absolute;top:0;bottom:0;left:0}.detail-header-nav{z-index:100;background:inherit;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);justify-content:space-between;margin-bottom:16px;padding:12px 0;display:flex;position:sticky;top:-16px}.detail-view-wrapper{z-index:2000;background:0 0;width:100%;height:100%;padding:16px;position:fixed;inset:0;overflow-y:auto}@media (width>=768px){.detail-view-wrapper{background:#ffffff0d;padding:32px}}.lesson-detail-container{flex-direction:column;gap:16px;max-width:800px;margin:0 auto;padding-bottom:40px;display:flex}.detail-header-nav{justify-content:space-between;align-items:center;display:flex}.glass-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(180%);border:1px solid var(--glass-border);box-shadow:inset 0 1px 1px #fff6, var(--glass-shadow);border-radius:20px;padding:20px}.subject-info h2{color:var(--text-primary);margin-bottom:8px;font-size:1.8rem}.subject-meta{color:var(--text-secondary);gap:16px;margin-bottom:12px;font-size:.95rem;display:flex}.subject-memo{color:var(--text-primary);background:#ffffff4d;border-radius:12px;padding:10px;font-size:.9rem}.detail-sections{grid-template-columns:1fr;gap:16px;display:grid}@media (width>=768px){.detail-sections{grid-template-columns:1fr 1fr}}.section-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.btn-small{background:var(--accent-color);color:#fff;cursor:pointer;border:none;border-radius:12px;padding:6px 12px;font-size:.8rem;font-weight:600;box-shadow:0 2px 8px #0071e34d}.upload-btn{cursor:pointer;display:inline-block}.empty-text{text-align:center;color:var(--text-secondary);padding:20px 0;font-style:italic}.record-list,.material-list{flex-direction:column;gap:12px;list-style:none;display:flex}.record-item,.material-item{background:#fff6;border:1px solid #fff3;border-radius:12px;padding:12px}.record-head{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:6px;display:flex}.record-date{font-size:.9rem;font-weight:700}.status-badge{color:#fff;border-radius:8px;padding:2px 8px;font-size:.75rem;font-weight:600}.status-出席{background:#34c759}.status-欠席{background:#ff3b30}.status-遅刻{background:#ff9500}.status-休講{background:#8e8e93}.btn-text{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;margin-left:auto;font-size:1rem}.record-memo{color:var(--text-primary);margin-top:4px;font-size:.85rem}.material-link{color:var(--accent-color);word-break:break-all;flex:1;align-items:center;gap:8px;font-weight:500;text-decoration:none;display:flex}.material-item-row{justify-content:space-between;align-items:center;gap:8px;width:100%;display:flex}.btn-material-delete{cursor:pointer;opacity:.8;color:var(--text-primary);background:#0000000d;border:none;border-radius:6px;justify-content:center;align-items:center;padding:4px 8px;font-size:.9rem;transition:all .2s;display:flex}body.dark-mode .btn-material-delete{opacity:1;background:#ffffff26}.btn-material-delete:hover{opacity:1;color:#ff3b30;background:#ff3b3033}.material-size{color:var(--text-secondary);font-size:.75rem}.session-timeline{flex-direction:column;gap:10px;display:flex}.session-card{border-radius:16px;padding:14px 16px;transition:all .2s}.session-card.upcoming{opacity:.7;border-style:dashed}.session-card.has-record-attend,.session-card.has-record-attend.is-holiday{border-left:4px solid var(--accent-color)}.session-card.has-record-absent,.session-card.has-record-absent.is-holiday{border-left:4px solid #ff3b30}.session-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.session-info{align-items:center;gap:10px;display:flex}.session-num{color:var(--accent-color);white-space:nowrap;background:#0071e326;border-radius:8px;padding:2px 8px;font-size:.7rem;font-weight:700}.session-date{color:var(--text-primary);font-size:.95rem;font-weight:600}.session-badges{align-items:center;gap:6px;display:flex}.upcoming-badge{color:var(--text-secondary);background:#00000014;border-radius:8px;padding:2px 8px;font-size:.7rem}.session-memo{color:var(--text-primary);white-space:pre-wrap;background:#ffffff4d;border-radius:10px;margin-bottom:8px;padding:8px 10px;font-size:.85rem;line-height:1.5}.session-materials{flex-direction:column;gap:4px;margin-bottom:8px;list-style:none;display:flex}.session-materials li{font-size:.82rem}.session-actions{flex-direction:column;gap:10px;min-height:36px;margin-top:12px;display:flex}.action-row{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.btn-session-action{color:var(--text-primary);cursor:pointer;background:#ffffff80;border:1px solid #0000001a;border-radius:10px;align-items:center;gap:4px;padding:5px 10px;font-size:.8rem;font-weight:500;transition:all .1s ease-in-out;display:inline-flex}.btn-session-action:active{background:#0000000d;transform:scale(.96)}.btn-session-action:hover{background:#fffc;transform:translateY(-1px)}.btn-session-delete{cursor:pointer;opacity:.6;background:0 0;border:none;margin-left:auto;font-size:1rem;transition:opacity .2s}.btn-session-delete:hover{opacity:1}.attendance-segment{border:1px solid var(--glass-border);background:#ffffff1a;border-radius:12px;min-width:140px;height:38px;padding:2px;display:flex;position:relative;overflow:hidden}.segment-indicator{opacity:0;z-index:0;background:#fff;border-radius:10px;width:calc(50% - 2px);transition:transform .18s cubic-bezier(.4,0,.2,1);position:absolute;top:2px;bottom:2px;left:2px;transform:translate(-110%);box-shadow:0 2px 8px #00000026}.attendance-segment[data-active=attend] .segment-indicator{opacity:1;background:#34c759;transform:translate(0)}.attendance-segment[data-active=absent] .segment-indicator{opacity:1;background:#ff3b30;transform:translate(100%)}.segment-btn{cursor:pointer;color:var(--text-secondary);z-index:10;background:0 0;border:none;border-radius:10px;flex:1;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;transition:all .25s;display:flex}.segment-btn.active{color:#fff}.segment-btn:active,.btn-session-kyuko:active{opacity:.9;transform:scale(.95)}.btn-session-kyuko{border:1px solid var(--glass-border);background:var(--glass-bg);color:var(--text-primary);cursor:pointer;white-space:nowrap;border-radius:12px;padding:5px 12px;font-size:.85rem;font-weight:700;transition:all .2s}.btn-session-kyuko:active{background:#8e8e934d;transform:scale(.96)}.btn-session-kyuko:hover{color:#fff;background:#8e8e93;border-color:#8e8e93}.btn-session-kyuko.active{color:#fff;background:#8e8e93;border-color:#8e8e93;box-shadow:0 0 10px #8e8e9366}body.dark-mode .btn-session-kyuko.active{background:#636366;border-color:#636366}.is-pending{pointer-events:none;animation:1s cubic-bezier(.4,0,.6,1) infinite pendingPulse}@keyframes pendingPulse{0%{opacity:.7;transform:scale(1)}50%{opacity:.4;transform:scale(.98)}to{opacity:.7;transform:scale(1)}}.session-card.is-kyuko{opacity:.65;border-left:4px solid #8e8e93!important}.session-card.is-holiday{border-left:4px solid #ff9500}.holiday-badge{color:#c06000;white-space:nowrap;background:#ff950026;border-radius:8px;padding:2px 8px;font-size:.65rem;font-weight:600}.session-num.extra{color:#c06000;background:#ff950033}.add-extra-section{justify-content:center;margin-top:4px;display:flex}.btn-add-extra{color:var(--accent-color);cursor:pointer;background:#0071e30d;border:2px dashed #0071e34d;border-radius:16px;width:100%;padding:10px 24px;font-size:.9rem;font-weight:600;transition:all .2s}.btn-add-extra:hover{border-color:var(--accent-color);background:#0071e31f}.add-extra-form{flex-wrap:wrap;align-items:center;gap:8px;width:100%;padding:12px 14px;display:flex}.attendance-stats{border-radius:16px;justify-content:space-around;align-items:center;padding:14px 8px;display:flex}.stat-item{flex-direction:column;align-items:center;gap:2px;display:flex}.stat-num{color:var(--text-primary);font-size:1.6rem;font-weight:700;line-height:1}.stat-num.attend{color:#34c759}.stat-num.absent{color:#ff3b30}.stat-num.kyuko{color:#8e8e93}.stat-num.unrecorded{color:#c8c8cc}.stat-label{color:var(--text-secondary);font-size:.7rem;font-weight:500}.stat-sep{background:#00000014;flex-shrink:0;width:1px;height:30px}.slot-room.is-suggested{color:#34c759;justify-content:center;align-items:center;gap:2px;font-weight:500;display:flex}.lesson-room.is-suggested:before{content:""}.settings-section{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:12px;margin-top:10px;padding:12px}.shared-section{border-left:4px solid #34c759}.shared-note-list{margin-bottom:12px}.shared-note-item{background:#34c75914;border:1px solid #34c75933;border-radius:12px;margin-bottom:8px;padding:10px 12px}.shared-note-header{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:6px;display:flex}.content-block{border-radius:12px;margin:8px 0;padding:8px 12px;font-size:.88rem}.content-block.personal{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(200%);border:1px solid var(--glass-border)}.content-block.shared{-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(200%);background:#34c7591a;border:1px solid #34c75933}.block-label{color:var(--text-primary);text-transform:uppercase;margin-bottom:2px;font-size:1.1rem;font-weight:700;display:block}.inline-shared-list{margin:0;padding:0;list-style:none}.inline-shared-item{color:var(--text-primary);word-break:break-all;padding:2px 0;line-height:1.4}.inline-shared-list.materials .inline-shared-item a{color:#007aff;text-decoration:none}.editor-expand-area{background:#00000005;border-top:1px solid #0000000d;border-radius:0 0 16px 16px;margin-top:12px;padding:16px;animation:.25s ease-out slideDown}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.editor-block{flex-direction:column;gap:10px;display:flex}.editor-block textarea{resize:vertical;background:#fff;border:1px solid #0000001a;border-radius:10px;width:100%;padding:10px;font-size:.9rem}.btn-save{color:#fff;background:#007aff;border:none;border-radius:8px;align-self:flex-end;padding:6px 20px;font-weight:600;transition:all 50ms ease-in-out}.btn-save:active{opacity:.9;transform:scale(.96)}.btn-save:disabled{opacity:.5}.editor-block.shared{background:#fff;border:1px solid #34c75933;border-radius:12px;padding:12px}.editor-list{max-height:150px;margin-bottom:10px;overflow-y:auto}.item-row{border-bottom:1px solid #00000008;justify-content:space-between;align-items:center;padding:6px 0;font-size:.85rem;display:flex}.item-row:last-child{border-bottom:none}.item-row .text{flex:1;padding-right:8px}.btn-del{color:#ff3b30;cursor:pointer;opacity:.6;background:0 0;border:none}.btn-del:hover{opacity:1}.editor-form{gap:8px;display:flex}.editor-form textarea{flex:1}.editor-form button{color:#fff;background:#34c759;border:none;border-radius:8px;padding:0 16px;font-weight:600}.btn-upload-label{text-align:center;cursor:pointer;color:#007aff;background:#fff;border:2px dashed #007aff33;border-radius:12px;padding:16px;font-weight:600;display:block}.btn-upload-label.shared{color:#34c759;border-color:#34c7594d}.feedback-toast{color:#fff;z-index:2000;background:#323232;border-radius:24px;align-items:center;gap:10px;padding:12px 24px;font-size:.9rem;font-weight:500;animation:.3s ease-out slideUp;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #00000026}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%)}}.feedback-toast.success{background:#34c759}.feedback-toast.error{background:#ff3b30}.feedback-toast.loading{background:#007aff}.spinner-small{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.8s linear infinite spin}.btn-session-action.active{color:#fff!important;background:#007aff!important}.btn-session-action.btn-shared.active{background:#34c759!important}.pwa-guide-banner{-webkit-backdrop-filter:blur(20px);z-index:3000;background:#ffffffd9;border-top:1px solid #ffffff4d;border-radius:24px 24px 0 0;flex-direction:column;gap:12px;padding:20px;animation:.5s slideUpBanner;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -5px 20px #0000001a}@keyframes slideUpBanner{0%{transform:translateY(100%)}to{transform:translateY(0)}}.pwa-guide-content{align-items:flex-start;gap:12px;display:flex}.pwa-guide-icon{background:#fff;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.8rem;display:flex;box-shadow:0 4px 10px #0000000d}.pwa-guide-text h4{color:var(--text-primary);margin:0 0 4px;font-size:1rem}.pwa-guide-text p{color:#86868b;margin:0;font-size:.85rem;line-height:1.4}.pwa-guide-actions{justify-content:flex-end;gap:16px;padding-top:8px;display:flex}.pwa-guide-btn-close{color:#86868b;cursor:pointer;background:0 0;border:none;font-size:.8rem;text-decoration:underline}.pwa-guide-btn-dismiss{color:#007aff;cursor:pointer;background:#007aff1a;border:none;border-radius:8px;padding:6px 12px;font-size:.8rem;font-weight:600}.compact-footer{text-align:center;border-top:1px solid #ffffff0d;flex-direction:column;align-items:center;width:100%;margin-top:24px;padding:20px 20px 40px;display:flex}.footer-pdf-btn{width:100%;max-width:320px;height:54px;color:var(--text-primary);background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(180%);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:18px;margin-bottom:20px;font-size:.95rem;transition:all .3s cubic-bezier(.25,.8,.25,1)}.footer-pdf-btn:hover{background:#ffffff40;transform:translateY(-2px);box-shadow:0 8px 24px #00000026}.whisper-btn{border-color:#007aff4d;position:relative;overflow:hidden}.whisper-btn:after{content:"";opacity:0;background:radial-gradient(circle,#0071e31a 0%,#0000 70%);width:200%;height:200%;transition:opacity .3s;position:absolute;top:-50%;left:-50%}.whisper-btn:hover:after{opacity:1}.btn-small-outline{width:100%;color:var(--text-primary);cursor:pointer;background:#ffffff14;border:1px solid #ffffff26;border-radius:12px;padding:12px;font-size:.9rem;font-weight:600;transition:all .2s}.btn-small-outline:hover{background:#ffffff26;border-color:#ffffff4d}.footer-copy{color:var(--text-secondary);opacity:.7;font-size:.65rem}.info-modal{flex-direction:column;max-width:600px;max-height:80vh;display:flex}.info-body{background:var(--glass-bg);max-height:calc(90vh - 120px);-webkit-backdrop-filter:blur(var(--glass-blur));color:var(--text-primary);border-radius:0 0 16px 16px;padding:20px;overflow-y:auto;box-shadow:inset 0 1px 1px #ffffff4d}.settings-accordion{flex-direction:column;gap:12px;margin-top:10px;display:flex}.settings-section{background:#ffffff08;border:1px solid #ffffff1a;border-radius:12px;transition:all .3s;overflow:hidden}.settings-section[open]{background:#ffffff0f;border-color:#fff3}.settings-section summary{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:14px 16px;font-size:.95rem;font-weight:600;list-style:none;display:flex}.settings-section summary::-webkit-details-marker{display:none}.settings-section summary:after{content:"▼";opacity:.5;font-size:.75rem;transition:transform .3s}.settings-section[open] summary:after{content:"▲";transform:none}.settings-section summary:hover{background:#ffffff0d}.section-content{border-top:1px solid #ffffff0d;flex-direction:column;gap:16px;padding:16px;display:flex}.flex-between{justify-content:space-between;align-items:center;display:flex}.date-input,.term-switcher{color:#fff;background:#0003;border:1px solid #fff3;border-radius:10px;outline:none;padding:8px 12px;font-size:.9rem}.glass-preview-box{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:14px;padding:16px}input[type=range]{appearance:none;cursor:pointer;background:0 0;width:100%;margin:0;padding:8px 0}input[type=range]:focus{outline:none}input[type=range]::-webkit-slider-runnable-track{background:#fff3;border:none;border-radius:3px;width:100%;height:6px}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:#fff;border-radius:50%;width:22px;height:22px;margin-top:-8px;transition:transform .1s;box-shadow:0 2px 6px #0000004d}input[type=range]:active::-webkit-slider-thumb{transform:scale(1.1)}input[type=range]::-moz-range-track{background:#fff3;border-radius:3px;width:100%;height:6px}input[type=range]::-moz-range-thumb{background:#fff;border:none;border-radius:50%;width:22px;height:22px;box-shadow:0 2px 6px #0000004d}.grid-corner{box-shadow:none!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;background:0 0!important;border:none!important}.timeline-grid{background:0 0!important}@media (width<=767px){html,body{height:100dvh;overflow:hidden}body{flex-direction:column;padding:0 4px;display:flex}#root{flex-direction:column;height:100%;display:flex;overflow:hidden}main{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.scroll-wrapper{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden auto}.timetable-container.glass-container{box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;background:0 0;border:none;flex-direction:column;display:flex;overflow:hidden;padding:2px!important}.timeline-grid{--grid-row-height:minmax(0, 1fr);flex:1;gap:4px;height:100%;min-height:0;display:grid}.grid-header,.grid-time,.timetable-slot{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur)) saturate(180%);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);text-align:center;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden;container-type:size}.grid-header,.grid-time .period-num{font-size:.85rem;font-weight:800}.grid-time .period-time{opacity:.8;font-size:.58rem}.timetable-slot{gap:0;min-height:0;padding:2px 4px 2px 10px}.timetable-slot:before{content:"";background:var(--slot-accent-color,var(--accent-blue));opacity:.8;border-radius:4px 0 0 4px;width:4px;position:absolute;top:0;bottom:0;left:0}.slot-subject{-webkit-line-clamp:3;line-clamp:3;word-break:break-all;color:var(--text-primary);-webkit-box-orient:vertical;margin-bottom:1px;font-size:.75rem;font-weight:700;line-height:1.1;display:-webkit-box;overflow:hidden}.slot-room,.slot-prof{white-space:nowrap;text-overflow:ellipsis;opacity:.95;color:var(--text-secondary);font-size:.62rem;line-height:1.1;overflow:hidden}@container (height<=85px){.slot-subject{-webkit-line-clamp:2;line-clamp:3}}@container (height<=62px){.slot-subject{-webkit-line-clamp:1;line-clamp:3}}header.compact-header{text-align:left;width:100%;padding:10px 4px 4px}.header-top{justify-content:space-between;align-items:center;width:100%;display:flex}.main-logo{letter-spacing:-.01em;color:var(--text-primary);white-space:nowrap;flex-shrink:1;margin:0;font-size:.85rem;font-weight:850}.main-logo span{color:var(--accent-blue)}p.subtitle{opacity:.8;margin:0;font-size:.65rem;font-weight:500}.settings-trigger{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff38;border:1px solid #fff3;border-radius:12px;padding:6px 10px;font-size:1rem}.pdf-icon-btn{color:#fff!important;flex-direction:row!important;flex-shrink:0!important;justify-content:center!important;align-items:center!important;gap:8px!important;width:max-content!important;height:32px!important;padding:0 16px!important;font-size:.68rem!important;font-weight:600!important;display:flex!important}.pdf-icon-btn span.btn-text{white-space:nowrap!important;line-height:1!important;display:block!important}.action-btn{width:32px;height:32px;font-size:1rem}.header-actions{flex-shrink:0;gap:8px}.compact-footer{margin-top:16px;padding:15px 16px 30px}.footer-pdf-btn{max-width:100%;height:48px;margin-bottom:15px;font-size:.88rem}.footer-copy{font-size:.6rem;display:block}}@media (width>=768px){body{--time-column-width:60px;padding:32px 16px 40px}#root{max-width:1100px;position:relative}.timetable-container.glass-container{box-shadow:none;-webkit-backdrop-filter:none;background:0 0;border:none;padding:0}.grid-header,.grid-time{border-radius:12px;background:var(--glass-bg)!important;border:1px solid var(--glass-border)!important;box-shadow:var(--glass-shadow)!important;-webkit-backdrop-filter:blur(var(--glass-blur))!important}}.syllabus-chips{flex-direction:column;gap:10px;margin-top:10px;display:flex}.syllabus-chip{background:var(--glass-bg);text-align:left;cursor:pointer;width:100%;color:var(--text-primary);border:1px solid #ffffff26;border-radius:16px;flex-direction:column;gap:4px;padding:14px 16px;transition:all .3s cubic-bezier(.25,.8,.25,1);display:flex;box-shadow:0 4px 12px #0000001a}.syllabus-chip:hover{background:#ffffff26;border-color:#ffffff4d;transform:translateY(-3px);box-shadow:0 8px 20px #00000026}.syllabus-chip:active{transform:scale(.97)}.chip-main{align-items:center;gap:10px;display:flex}.chip-icon{filter:drop-shadow(0 2px 4px #0003);font-size:1.2rem}.chip-name{letter-spacing:-.01em;font-size:1rem;font-weight:700}.chip-details{opacity:.8;gap:12px;padding-left:30px;font-size:.78rem;display:flex}.chip-item{position:relative}.chip-item:not(:last-child):after{content:"•";opacity:.5;margin-left:10px}.syllabus-chip{position:relative}.chip-actions{z-index:10;position:absolute;top:14px;right:14px}.btn-detail-text{color:var(--accent-color,#0071e3);cursor:pointer;background:#0071e31a;border:1px solid #0071e333;border-radius:8px;padding:4px 10px;font-size:.75rem;font-weight:700;transition:all .2s}.btn-detail-text:hover{background:var(--accent-color,#0071e3);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #0071e340}.syllabus-detail-modal{flex-direction:column!important;width:90%!important;max-width:800px!important;max-height:90vh!important;padding:0!important;display:flex!important;overflow:hidden!important}.syllabus-detail-view{background:#ffffff0d;flex:1;padding:24px;overflow-y:auto}.sb-hero{border-bottom:1px solid #ffffff1a;margin-bottom:24px;padding-bottom:16px}.sb-title{margin-bottom:8px;font-size:1.4rem;font-weight:850}.sb-meta{opacity:.8;gap:12px;font-size:.8rem;display:flex}.sb-grid{grid-template-columns:1fr;gap:16px;display:grid}@media (width>=600px){.sb-grid{grid-template-columns:repeat(2,1fr)}}.sb-card{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:16px;padding:16px}.sb-card h4{color:var(--accent-color,#0071e3);margin-bottom:8px;font-size:.85rem;font-weight:800}.sb-card-content{white-space:pre-wrap;font-size:.9rem;line-height:1.6}.sb-card.highlight{background:#0071e30d;border-color:#0071e333;grid-column:1/-1}.sb-card.contact{border-left:4px solid #ff9500;grid-column:1/-1}.chip-name{padding-right:60px}.sb-card-content{overflow-wrap:break-word;word-break:break-word}.modal-header{z-index:100;-webkit-backdrop-filter:blur(20px);background:#ffffffe6;border-bottom:1px solid #ffffff1a;justify-content:space-between;align-items:center;margin:-24px -24px 20px;padding:16px 24px;display:flex;position:sticky;top:0}body.dark-mode .modal-header{background:#1e1e1ee6}.modal-content{padding-top:24px}.btn-syllabus-view{color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #fff3;border-radius:20px;align-items:center;gap:6px;padding:6px 14px;font-size:.85rem;font-weight:600;transition:all .2s;display:flex}.btn-syllabus-view:hover{background:#fff3;transform:translateY(-1px)}.header-titles{flex-direction:column;align-items:flex-start;gap:2px;display:flex}.header-credits{color:var(--text-secondary);opacity:.8;white-space:nowrap;background:#0071e31a;border-radius:10px;padding:2px 8px;font-size:.72rem;font-weight:600}body.dark-mode .header-credits{color:#ffffffe6;background:#ffffff26}.admin-view-selector{margin-right:8px}.admin-select{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--glass-border);color:var(--text-primary);cursor:pointer;text-overflow:ellipsis;border-radius:10px;outline:none;max-width:140px;padding:6px 12px;font-size:.85rem;font-weight:600;transition:all .2s}.admin-select:hover{background:#fff3}.admin-mode-indicator{color:#fff;z-index:9999;white-space:nowrap;background:#ff9500;border-radius:25px;align-items:center;gap:12px;padding:10px 20px;font-size:.9rem;font-weight:700;display:flex;position:fixed;bottom:20px;left:50%;transform:translate(-50%);box-shadow:0 10px 30px #ff950066}.admin-mode-indicator button{color:#fff;cursor:pointer;background:#ffffff40;border:none;border-radius:15px;padding:4px 12px;font-size:.8rem;font-weight:700;transition:all .2s}.admin-mode-indicator button:hover{background:#fff6}@media (width<=600px){.admin-select{max-width:100px;padding:4px 8px;font-size:.75rem}}.footer-buttons-container{justify-content:center;gap:10px;width:100%;max-width:600px;margin:0 auto;display:flex}.footer-pdf-btn{white-space:nowrap;flex:1;justify-content:center;align-items:center;min-height:48px;text-decoration:none;display:flex;width:100%!important;padding:0 10px!important}.footer-pdf-btn .btn-text{margin-left:6px;font-size:.9rem}.footer-pdf-btn .btn-icon{font-size:1.1rem}@media (width<=480px){.footer-pdf-btn{flex-direction:column;min-height:56px;padding:8px 4px!important}.footer-pdf-btn .btn-icon{margin-bottom:4px}.footer-pdf-btn .btn-text{white-space:normal;text-align:center;margin-left:0;font-size:.75rem;line-height:1.2}}*{-webkit-tap-highlight-color:transparent}.whisper-btn{border:1px solid var(--glass-border)!important;background:var(--glass-bg)!important}.action-btn,.btn-submit,.btn-small,.whisper-btn,.footer-pdf-btn{-webkit-tap-highlight-color:transparent;outline:none!important}.action-btn:focus,.action-btn:active,.action-btn:focus-visible,.btn-submit:focus,.btn-submit:active,.whisper-btn:focus,.whisper-btn:active,.footer-pdf-btn:focus,.footer-pdf-btn:active{box-shadow:none!important;border:1px solid var(--glass-border)!important;outline:none!important}.wake-lock-guide{color:#ff9500;margin-top:8px;font-size:.85rem;font-weight:600;animation:2s infinite pulse}@keyframes pulse{0%{opacity:1}50%{opacity:.6}to{opacity:1}}
