:root{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,PingFang SC,Microsoft YaHei,sans-serif;color:#1c1c1e;background:#f2f2f7;font-synthesis:none;--green: #007aff;--green-2: #0a84ff;--paper: rgba(255, 255, 255, .82);--muted: #8e8e93;--line: rgba(60, 60, 67, .16);--gold: #007aff;--danger: #ff3b30}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;font-variant-numeric:tabular-nums}button,input,select{font:inherit}button{cursor:pointer}.app{min-height:100dvh;padding-bottom:94px;background:radial-gradient(circle at 5% 0%,rgba(10,132,255,.14),transparent 25%),radial-gradient(circle at 100% 15%,rgba(175,82,222,.1),transparent 24%),#f2f2f7}.app.view-schedule{height:100dvh;min-height:520px;padding-bottom:0;overflow:hidden;display:grid;grid-template-rows:auto 1fr auto}.hero{color:#1c1c1e;padding:calc(10px + env(safe-area-inset-top)) 16px 10px;background:#f8f8fab8;border-bottom:1px solid rgba(255,255,255,.8);backdrop-filter:saturate(180%) blur(28px);-webkit-backdrop-filter:saturate(180%) blur(28px)}.eyebrow{margin:0 0 4px;color:var(--muted);font-size:12px;letter-spacing:.4px;font-weight:600}h1{margin:0;font-size:32px;letter-spacing:-.8px}.hero-row{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;min-height:42px}.hero-date{margin:0;padding:6px 0;border:0;background:transparent;color:var(--green);font-size:13px;font-weight:600;text-align:left;white-space:nowrap}.hero-date:active{opacity:.55}.hero-shift{display:flex;align-items:baseline;justify-content:center;gap:7px;white-space:nowrap}.hero-shift h1{font-size:20px;letter-spacing:-.4px}.hero-shift span{color:var(--muted);font-size:11px;font-weight:500}.hero-stat{display:flex;align-items:baseline;justify-content:end;gap:5px;color:var(--muted);white-space:nowrap}.hero-stat b{color:var(--green);font-size:20px;letter-spacing:-.5px}.hero-stat span{font-size:11px;font-weight:600}main{max-width:760px;width:100%;margin:0 auto;padding:18px 14px}.view-schedule main{min-height:0;padding:10px 14px 7px;display:grid;grid-template-rows:auto minmax(0,61.8%) minmax(82px,1fr);gap:8px}.toolbar,.card-title,.month-nav,.row,.actions{display:flex;align-items:center;justify-content:space-between;gap:10px}.month-nav{margin:4px 0 16px}.view-schedule .month-nav{margin:0}.month-nav h2{margin:0;font-size:19px;min-width:145px;text-align:center;letter-spacing:-.3px}.icon-btn,.ghost-btn{border:0;background:#ffffffbf;color:var(--green);min-height:42px;border-radius:13px;padding:9px 13px;font-weight:600;box-shadow:0 1px 2px #0000000a,inset 0 0 0 .5px #00000014}.primary-btn{border:0;background:var(--green);color:#fff;min-height:44px;border-radius:12px;padding:10px 17px;font-weight:600}.danger-btn{color:var(--danger)}.calendar-viewport{overflow:hidden;border-radius:20px;touch-action:pan-y}.view-schedule .calendar-viewport{min-height:0}.calendar-track{display:flex;width:300%;height:100%;transform:translate(-33.333333%)}.calendar{flex:0 0 33.333333%;min-width:0;background:var(--paper);border:.5px solid rgba(255,255,255,.9);border-radius:20px;overflow:hidden;box-shadow:0 10px 35px #0000000f;backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px)}.view-schedule .calendar{display:grid;grid-template-rows:auto minmax(0,1fr)}.weekdays,.days{display:grid;grid-template-columns:repeat(7,1fr)}.view-schedule .days{min-height:0;grid-template-rows:repeat(6,minmax(0,1fr))}.weekdays span{padding:11px 2px;text-align:center;color:var(--muted);font-size:12px;font-weight:700}.day{position:relative;min-height:64px;padding:6px 4px;border:0;border-top:1px solid var(--line);border-right:1px solid var(--line);background:transparent;text-align:center;overflow:hidden}.view-schedule .day{min-height:0;padding:clamp(2px,.65vh,6px) 3px}.day:nth-child(7n){border-right:0}.day.outside{color:#c7c7cc;background:#76768006}.day.today .day-num{background:var(--green);color:#fff}.day.selected{background:#007aff14;box-shadow:inset 0 0 0 1.5px var(--green)}.day-top{display:flex;align-items:center;justify-content:center;min-height:24px}.day-num{display:grid;place-items:center;width:24px;height:24px;border-radius:50%;font-size:12px;font-weight:800}.day-top i{position:absolute;top:3px;right:3px;display:grid;place-items:center;width:15px;height:15px;border-radius:4px;font-size:8px;font-style:normal;font-weight:800}.day-top i.off{color:#ff3b30;background:#ff3b301a}.day-top i.work{color:#8e8e93;background:#7676801a}.lunar{display:block;margin:-1px 2px 1px;color:#6e6e73;font-size:9px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lunar.statutory-festival{color:#ff3b30;font-weight:700}.lunar.other-festival{color:var(--green);font-weight:700}.assignment-dot{display:block;margin:0 1px 5px;padding:2px 4px;border-radius:5px;font-size:9px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600;text-align:center;box-shadow:inset 0 0 0 .5px #00000024}.card{margin-top:16px;padding:17px;border:.5px solid rgba(255,255,255,.9);border-radius:20px;background:var(--paper);box-shadow:0 8px 30px #0000000d;backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px)}.view-schedule main>.card{margin-top:0;padding:clamp(8px,1.3vh,14px);border-radius:18px}.view-schedule main>.card{min-height:0;display:flex;align-items:center}.view-schedule main>.card .quick-shifts{width:100%}.card h3{margin:0;font-size:16px}.page-heading{margin:3px 4px 18px}.page-heading .eyebrow{margin-bottom:3px}.page-heading h2{margin:0;font-size:30px;letter-spacing:-.8px}.subtle{color:var(--muted);font-size:12px}.empty{padding:20px 8px;text-align:center;color:var(--muted)}.assignment{padding:12px 0;border-bottom:1px solid var(--line)}.assignment:last-child{border-bottom:0}.person{display:flex;align-items:center;gap:10px}.avatar{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;flex:0 0 auto;box-shadow:inset 0 0 0 .5px #0000001f}.person b{display:block}.person small{color:var(--muted)}.mini-remove{border:0;background:transparent;color:var(--danger);padding:8px}.quick-shifts{display:grid;grid-template-columns:repeat(4,minmax(72px,1fr));gap:8px;margin-top:17px;overflow-x:auto;padding:2px 1px 5px;scrollbar-width:none}.card>.quick-shifts:first-child{margin-top:0}.quick-shifts::-webkit-scrollbar{display:none}.quick-shift{position:relative;min-width:0;border:0;border-radius:14px;padding:12px 3px 10px;color:#3a3a3c;background:#76768012;text-align:center;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;touch-action:none;transition:transform .16s ease,box-shadow .16s ease,opacity .16s ease}.quick-shift.dragging{z-index:3;opacity:.82;transform:scale(1.07);box-shadow:0 12px 28px #00000029,inset 0 0 0 2px var(--green)}.view-schedule .quick-shift{padding:clamp(7px,1vh,11px) 3px}.view-schedule .quick-shift span{width:clamp(18px,3.1vh,26px);height:clamp(18px,3.1vh,26px);margin-bottom:clamp(3px,.5vh,7px)}.quick-shift span{display:block;width:26px;height:26px;margin:0 auto 7px;border-radius:50%;background:var(--shift)}.quick-shift b,.quick-shift small{display:block;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.quick-shift b{font-size:12px}.quick-shift small{margin-top:3px;color:var(--muted);font-size:10px}.quick-shift.active{background:#fff;box-shadow:0 3px 14px #00000017,inset 0 0 0 2px var(--green)}.quick-shift.clear-shift{color:#636366;background:#7676800e}.quick-shift.clear-shift span{position:relative;display:grid;place-items:center;background:#7676801a;color:#636366}.quick-shift.clear-shift span:before{content:"";width:13px;height:9px;border:1.5px solid currentColor;border-radius:3px;transform:rotate(-42deg);background:transparent}.quick-shift.clear-shift span:after{content:"";position:absolute;width:8px;height:1.5px;border-radius:2px;background:currentColor;transform:translate(5px,5px)}.quick-shift.clear-shift:active{color:var(--danger);background:#ff3b300f;transform:scale(.97)}.quick-shift.clear-shift:active span{color:var(--danger);background:#ff3b301a}.fab{position:fixed;right:18px;bottom:calc(78px + env(safe-area-inset-bottom));width:54px;height:54px;border:.5px solid rgba(255,255,255,.7);border-radius:50%;background:#007affe6;color:#fff;font-size:27px;box-shadow:0 10px 28px #007aff52;z-index:5;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;z-index:4;display:grid;grid-template-columns:repeat(3,1fr);padding:8px 10px calc(8px + env(safe-area-inset-bottom));background:#f8f8fac2;border-top:.5px solid rgba(60,60,67,.18);backdrop-filter:saturate(180%) blur(28px);-webkit-backdrop-filter:saturate(180%) blur(28px)}.view-schedule .bottom-nav{position:static}.nav-btn{border:0;background:transparent;color:var(--muted);padding:6px;font-size:11px;font-weight:600}.nav-btn span{display:block;font-size:20px;margin-bottom:2px}.nav-btn.active{color:var(--green)}.sheet-wrap{position:fixed;inset:0;z-index:20;background:#00000052;display:flex;align-items:end;justify-content:center;padding-top:30px;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px)}.sheet{width:min(100%,600px);max-height:88vh;overflow:auto;background:#f9f9fbf5;border-radius:28px 28px 0 0;padding:22px 18px calc(22px + env(safe-area-inset-bottom));box-shadow:0 -12px 40px #0000001f}.sheet h2{margin:0 0 4px}.form-grid{display:grid;gap:13px;margin-top:18px}label{display:grid;gap:6px;color:var(--muted);font-size:12px;font-weight:700}input,select{width:100%;min-height:46px;border:.5px solid rgba(60,60,67,.18);border-radius:12px;padding:10px 12px;background:#ffffffe6;color:#1c1c1e;outline:none}input:focus,select:focus{border-color:var(--green-2);box-shadow:0 0 0 3px #007aff24}.shift-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:9px}.shift-choice{border:2px solid transparent;border-radius:13px;padding:11px;text-align:left}.shift-choice.selected{border-color:var(--green)}.staff-list{display:grid;gap:10px;margin-top:16px}.staff-item{padding:12px;border:.5px solid rgba(60,60,67,.13);border-radius:15px;background:#ffffffb8}.shift-info{display:flex;align-items:center;gap:10px;min-width:0}.shift-info i{width:34px;height:34px;border-radius:11px;flex:0 0 auto;box-shadow:inset 0 0 0 .5px #0000000f}.shift-info b,.shift-info small{display:block}.shift-info small{margin-top:3px;color:var(--muted);font-size:10px}.mini-action{border:0;background:transparent;color:var(--green);padding:8px}.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:14px}.stat{background:#76768014;border-radius:14px;padding:13px}.stat b{display:block;font-size:22px;color:var(--green)}.summary-card{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;overflow:hidden;border-radius:20px;background:var(--line);box-shadow:0 8px 30px #0000000d}.summary-card>div{padding:20px 17px;background:#ffffffdb}.summary-card span,.summary-card small{color:var(--muted);font-size:12px;font-weight:600}.summary-card b{display:block;margin-top:7px;color:#1c1c1e;font-size:30px;letter-spacing:-1px}.bars{display:grid;gap:16px;margin-top:20px}.bar-row{display:grid;grid-template-columns:42px 1fr 20px;align-items:center;gap:10px;font-size:12px}.bar-row>span{color:var(--muted);font-weight:600}.bar-track{height:8px;overflow:hidden;border-radius:99px;background:#76768017}.bar-track i{display:block;min-width:4px;height:100%;border-radius:inherit}.history-row{display:grid;grid-template-columns:12px 1fr auto;align-items:center;gap:11px;padding:13px 0;border-bottom:.5px solid var(--line)}.history-row:last-child{border-bottom:0}.history-dot{width:10px;height:10px;border-radius:50%}.history-row b,.history-row small{display:block}.history-row b{font-size:13px}.history-row small{margin-top:3px;color:var(--muted);font-size:11px}.history-row strong{color:var(--muted);font-size:13px}.settings-actions{display:grid;gap:10px;margin-top:15px}.setting-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 0;border-bottom:.5px solid var(--line)}.setting-row:last-child{border-bottom:0}.setting-row b,.setting-row small{display:block}.setting-row b{font-size:14px}.setting-row small{margin-top:4px;color:var(--muted);font-size:10px;line-height:1.4}.setting-row select{width:auto;min-width:100px;min-height:38px}.setting-row .week-number-input{width:82px;min-height:38px;text-align:center}.file-input{display:none}.time-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.color-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:9px}.color-choice{display:block;aspect-ratio:1;border-radius:50%;box-shadow:inset 0 0 0 .5px #00000014}.color-choice.selected{box-shadow:inset 0 0 0 3px #fff,0 0 0 2px var(--green)}.toast{position:fixed;left:50%;bottom:102px;z-index:50;transform:translate(-50%);background:#1c1c1edb;color:#fff;padding:10px 16px;border-radius:999px;font-size:13px;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}@media(min-width:680px){.app:not(.view-schedule) .day{min-height:105px;padding:9px}.assignment-dot{font-size:10px}.fab{right:calc(50% - 350px)}}@media(max-height:650px){.view-schedule .hero{padding-top:calc(5px + env(safe-area-inset-top));padding-bottom:5px}.view-schedule .hero-row{min-height:34px}.view-schedule main{padding-top:5px;gap:5px}.view-schedule main{grid-template-rows:auto minmax(0,61.8%) minmax(68px,1fr)}.view-schedule .month-nav .icon-btn{min-height:34px;padding:5px 11px}.view-schedule .month-nav h2{font-size:17px}.view-schedule .weekdays span{padding:5px 2px}.view-schedule .lunar{font-size:9px}.view-schedule .assignment-dot{margin:-1px 1px 4px;padding:1px 3px;font-size:8px}.view-schedule .bottom-nav{padding-top:3px;padding-bottom:calc(3px + env(safe-area-inset-bottom))}.view-schedule .nav-btn{padding:2px}.view-schedule .nav-btn span{font-size:16px;margin-bottom:0}}@media(prefers-color-scheme:dark){:root{color:#f2f2f4;background:#000;--green: #0a84ff;--green-2: #409cff;--gold: #0a84ff;--paper: rgba(28, 28, 30, .82);--muted: #9a9aa1;--line: rgba(255, 255, 255, .14)}body{background:#000}.app{background:radial-gradient(circle at 5% 0%,rgba(10,132,255,.2),transparent 26%),radial-gradient(circle at 100% 15%,rgba(175,82,222,.12),transparent 24%),#000}.hero{color:#f2f2f4;background:#1c1c1e94;border-bottom-color:#ffffff0f}.calendar,.card{border-color:#ffffff0f;box-shadow:0 10px 35px #0006}.lunar{color:#98989f}.day.outside{color:#5a5a5e;background:#ffffff04}.day.selected{background:#0a84ff2e}.assignment-dot,.shift-choice b{color:#1c1c1e}.shift-choice small{color:#4a4a4e}.icon-btn,.ghost-btn{background:#7676803d}.bottom-nav{background:#1c1c1eb3;border-top-color:#ffffff1a}.quick-shift{color:#e5e5ea;background:#7676802e}.quick-shift.active{color:#f2f2f4;background:#0a84ff38;box-shadow:inset 0 0 0 2px var(--green)}.quick-shift.clear-shift{color:#aeaeb2;background:#76768024}.quick-shift.clear-shift span{color:#aeaeb2;background:#76768033}input,select{background:#7676802e;color:#f2f2f4;border-color:#ffffff24}.sheet{background:#1c1c1efa}.summary-card{background:#ffffff14}.summary-card>div{background:#1c1c1ee6}.summary-card b{color:#f2f2f4}.stat{background:#76768029}.staff-item{background:#7676801f;border-color:#ffffff14}.bar-track{background:#76768033}.toast{background:#3a3a3ceb}}
