:root{--border-color: #e8ecef;--bg-color: #f6f7f3;--panel-color: rgba(255, 255, 255, .92);--text-color: #243038;--muted-text: #70808c;--accent: #2d7a66;--accent-soft: rgba(45, 122, 102, .12);--today-soft: rgba(45, 122, 102, .08);--header-height: 72px;--shadow: 0 18px 40px rgba(48, 67, 79, .08)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}body{margin:0;padding:0;font-family:PingFang SC,Hiragino Sans GB,Noto Sans SC,Microsoft YaHei,sans-serif;background:radial-gradient(circle at top left,rgba(175,210,190,.35),transparent 34%),linear-gradient(180deg,#f4f8f4 0%,#eef2ef 100%);color:var(--text-color)}button,input,select{font:inherit}button,.cell,.template-item,.color-option,.icon-action,.bottom-nav-item,.todo-toggle{-webkit-tap-highlight-color:transparent}.container{display:flex;flex-direction:column;min-height:100vh;width:100vw;overflow:hidden}.header{min-height:var(--header-height);padding:.9rem 1rem;display:flex;justify-content:space-between;align-items:center;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:rgba(255,255,255,.72);border-bottom:1px solid rgba(255,255,255,.65)}.app-title{font-size:1.25rem;font-weight:700;letter-spacing:.06em}.current-week{margin-top:.2rem;color:var(--muted-text);font-size:.92rem}.actions{display:flex;gap:.55rem}.icon-button{width:38px;height:38px;border:1px solid rgba(45,122,102,.12);border-radius:12px;background:var(--panel-color);color:var(--text-color);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 8px 24px #20343d0f}.icon-button:hover,.icon-button:active{background:#ffffff;color:var(--accent)}.timetable{display:flex;flex-direction:column;margin:.9rem .9rem 0;background:rgba(255,255,255,.82);border:1px solid rgba(255,255,255,.8);border-radius:22px;overflow:hidden;box-shadow:var(--shadow)}.days-row{display:grid;grid-template-columns:58px repeat(7,minmax(0,1fr));min-height:54px;background:linear-gradient(180deg,rgba(255,255,255,.9),rgba(244,249,246,.88));border-bottom:1px solid var(--border-color)}.day-label{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:.18rem;font-size:.82rem;color:var(--muted-text)}.day-label-today{background:var(--accent-soft);color:var(--accent);font-weight:700}.today-tag{padding:.08rem .45rem;border-radius:999px;font-size:.66rem;background:rgba(45,122,102,.12)}.grid-body{flex:1;display:grid;grid-template-columns:58px repeat(7,minmax(0,1fr));grid-template-rows:repeat(8,minmax(86px,1fr))}.period-label{display:flex;flex-direction:column;justify-content:center;align-items:center;border-right:1px solid var(--border-color);border-bottom:1px solid var(--border-color);background:rgba(248,249,247,.95)}.period-num{font-size:.88rem;font-weight:700;color:#56626a}.time-range{font-size:.66rem;color:#8d98a1;line-height:1.15;margin-top:3px}.cell{border-right:1px solid var(--border-color);border-bottom:1px solid var(--border-color);position:relative;overflow:visible;cursor:pointer;background:rgba(255,255,255,.58)}.cell-today{background:linear-gradient(180deg,var(--today-soft),rgba(255,255,255,.72))}.course-card{position:absolute;top:4px;left:4px;right:4px;border-radius:14px;padding:.5rem .45rem;font-size:.72rem;line-height:1.3;display:flex;flex-direction:column;justify-content:flex-start;align-items:center;text-align:center;box-shadow:0 10px 24px #1e372a14;z-index:1;overflow:hidden}.course-name{font-weight:700;margin-bottom:.18rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-clamp:2;overflow:hidden;text-overflow:ellipsis;word-break:break-word}.course-loc{font-size:.64rem;opacity:.9;width:100%;overflow:hidden;text-overflow:ellipsis;word-break:break-word}.hidden-input{display:none}.template-list{max-height:300px;overflow-y:auto;margin-bottom:.5rem}.template-item{display:flex;align-items:center;padding:.85rem;border-bottom:1px solid #edf0f2;cursor:pointer;gap:12px;border-radius:12px}.template-item:hover{background-color:#f7faf8}.template-item.new-item{color:#5f6d76;font-size:.92rem;justify-content:center;border:1px dashed #ced8d2;margin-bottom:.8rem}.template-color{width:32px;height:32px;border-radius:10px;flex-shrink:0}.template-info{flex:1}.template-name{font-size:.92rem;font-weight:700}.template-loc{font-size:.76rem;color:#87949d}.template-delete{color:#c3ccd2;padding:4px}.template-delete:hover{color:#d65555}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(17,24,29,.4);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.modal{background:rgba(255,255,255,.96);padding:1.4rem;border-radius:20px;width:min(100%,360px);max-height:calc(100vh - 2rem);overflow-y:auto;box-shadow:0 22px 50px #1424282e}.settings-modal{width:min(100%,420px)}.modal-heading,.modal-title-row h3{margin:0}.modal-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.plain-icon-button{border:none;background:transparent;padding:0;display:inline-flex;align-items:center;justify-content:center}.icon-action{cursor:pointer;color:#76848e}.content{flex:1;min-height:0;position:relative;z-index:0;overflow-y:auto;padding-bottom:calc(84px + env(safe-area-inset-bottom))}.input-group{margin-bottom:1rem}.input-group label,.section-label{display:block;font-size:.82rem;margin-bottom:.42rem;color:#60707a}.input-group input,.input-group select,.input-group textarea{width:100%;padding:.68rem .8rem;border:1px solid #d6dfe3;border-radius:12px;background:#fff}.color-picker{display:flex;flex-wrap:wrap;gap:8px}.color-option{width:26px;height:26px;border-radius:8px;cursor:pointer;border:1px solid rgba(0,0,0,.08)}.color-option.selected{outline:2px solid #314047;outline-offset:2px}.dual-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.template-save-row{margin-bottom:1rem}.btn-row{display:flex;gap:10px;margin-top:1.2rem}.btn{flex:1;padding:.78rem .9rem;border:none;border-radius:12px;cursor:pointer}.btn-primary{background:#25343a;color:#fff}.btn-secondary{background:#eef2f0;color:#36454d}.btn-danger{background:#fee8e7;color:#cf4d4d}.notification-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.notification-label{display:inline-flex;align-items:center;gap:6px;margin:0}.notification-btn{flex:0 0 auto;padding-inline:.85rem}.notification-actions{margin-top:.6rem}.notification-tip{margin-top:.45rem;color:#83919a;font-size:.75rem;line-height:1.45}.switch-group{display:flex;flex-direction:column}.toggle-button{width:100%;padding:.68rem .8rem;border:1px solid #d6dfe3;border-radius:12px;background:#fff;color:#61707a;cursor:pointer}.toggle-button.active{color:var(--accent);border-color:#2d7a6647;background:rgba(45,122,102,.08)}.period-settings-grid{display:grid;grid-template-columns:42px 1fr 1fr;gap:8px;align-items:center;font-size:.84rem}.period-settings-head{color:#96a2a9;font-size:.76rem}.period-settings-index{text-align:center;color:#5d6b73}.full-width-btn{width:100%;margin-top:.4rem}.todo-panel{padding:.9rem .9rem 0}.todo-card{background:rgba(255,255,255,.85);border:1px solid rgba(255,255,255,.8);border-radius:22px;box-shadow:var(--shadow);padding:1.15rem}.todo-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:1rem}.todo-title{margin:0;font-size:1.15rem}.todo-subtitle{margin:.32rem 0 0;color:var(--muted-text);font-size:.84rem}.todo-clear-btn{flex:0 0 auto;padding-inline:.9rem}.todo-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;margin-bottom:1rem}.todo-add-btn{flex:0 0 auto;padding-inline:1rem}.todo-drag-tip{margin-bottom:.9rem;color:#7b8a93;font-size:.76rem}.todo-list{display:flex;flex-direction:column;gap:.7rem}.todo-item{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:10px;padding:.72rem .8rem;border-radius:16px;background:rgba(244,248,244,.85);border:1px solid rgba(45,122,102,.08);transition:border-color .18s ease,transform .18s ease,box-shadow .18s ease}.todo-item-done{opacity:.72}.todo-item-drop-before{border-top:2px solid var(--accent)}.todo-item-drop-after{border-bottom:2px solid var(--accent)}.todo-drag-handle{border:none;background:transparent;color:#90a0a9;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;cursor:grab;padding:0}.todo-main{border:none;background:transparent;padding:0;text-align:left;min-width:0;cursor:pointer}.todo-title-row{display:flex;align-items:center;gap:8px}.todo-toggle{border:none;background:transparent;color:var(--accent);padding:0;width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.todo-text{line-height:1.45;word-break:break-word;font-weight:600}.todo-meta{margin-top:.42rem;display:flex;flex-wrap:wrap;gap:6px}.todo-item-done .todo-text{text-decoration:line-through;color:var(--muted-text)}.todo-note-mark{flex:0 0 auto;padding:.16rem .45rem;border-radius:999px;background:rgba(36,48,56,.08);color:#687780;font-size:.68rem}.todo-chip{display:inline-flex;align-items:center;gap:4px;border-radius:999px;padding:.24rem .56rem;font-size:.72rem;line-height:1}.todo-chip-important{background:rgba(215,85,85,.12);color:#b04545}.todo-chip-medium{background:rgba(205,144,44,.14);color:#9e7121}.todo-chip-custom{background:rgba(45,122,102,.1);color:var(--accent)}.todo-chip-removable{border:none;cursor:pointer}.todo-delete-btn{width:34px;height:34px;box-shadow:none}.todo-drop-end{padding:.85rem;text-align:center;color:#7e8c95;font-size:.78rem;border:1px dashed rgba(45,122,102,.22);border-radius:16px}.todo-priority-row{display:flex;gap:8px}.todo-priority-btn{flex:1;border:1px solid #d6dfe3;border-radius:12px;background:#fff;color:#61707a;padding:.7rem .8rem;cursor:pointer}.todo-priority-btn.active{border-color:#2d7a6647;background:rgba(45,122,102,.08);color:var(--accent);font-weight:700}.todo-tag-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px}.todo-tag-add-btn{flex:0 0 auto;padding-inline:.85rem}.todo-meta-editor{margin-top:.7rem}.todo-helper-text{color:#83919a;font-size:.75rem}.todo-note-input{resize:vertical}.todo-submenu-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.todo-empty{padding:1.2rem .9rem;border-radius:16px;text-align:center;color:var(--muted-text);background:rgba(244,248,244,.7)}.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:200;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;padding:.7rem .9rem calc(.7rem + env(safe-area-inset-bottom));background:rgba(255,255,255,.92);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-top:1px solid rgba(209,220,214,.85)}.bottom-nav-item{border:none;background:rgba(245,248,246,.88);color:#64727b;border-radius:16px;padding:.72rem .9rem;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer}.bottom-nav-item.active{background:rgba(45,122,102,.12);color:var(--accent);font-weight:700}@media (max-width: 720px){.header{padding:.8rem .85rem}.timetable{margin:.6rem .6rem 0;border-radius:18px}.todo-panel{padding:.6rem .6rem 0}.days-row,.grid-body{grid-template-columns:52px repeat(7,minmax(0,1fr))}.grid-body{grid-template-rows:repeat(8,minmax(80px,1fr))}.day-label{font-size:.74rem}.today-tag{font-size:.6rem}.period-num{font-size:.8rem}.time-range{font-size:.6rem}.course-card{padding:.4rem .28rem;font-size:.68rem}.todo-card{padding:.95rem;border-radius:18px}.todo-card-header{flex-direction:column}.todo-form{grid-template-columns:1fr}.todo-item{grid-template-columns:auto 1fr auto}.todo-delete-btn{grid-column:3;grid-row:1}.todo-toggle{grid-column:3;grid-row:2;justify-self:center}.todo-tag-form{grid-template-columns:1fr}.todo-priority-row{flex-direction:column}.bottom-nav{gap:10px;padding-inline:.6rem}}
