:root{--bg:#f3f7fb;--bg-deep:#17384a;--text:#15202b;--muted:#66778a;--line:#d8e2ec;--soft-line:#e8eef5;--surface:#fff;--surface-cool:#eef5f9;--accent:#0d6b84;--accent-strong:#09546b;--teal:#1b8a8f;--indigo:#456a9d;--danger:#a04458;--success:#23745d;--shadow:0 14px 34px #1f364e14}*{box-sizing:border-box}html{background:var(--bg);min-width:320px}body{color:var(--text);letter-spacing:0;margin:0;font-family:Microsoft YaHei,PingFang SC,system-ui,sans-serif}button,input,select{font:inherit}button{border:1px solid var(--line);background:var(--surface);min-height:40px;color:var(--text);cursor:pointer;border-radius:8px}button:hover{border-color:var(--accent)}input,select{border:1px solid var(--line);width:100%;min-height:40px;color:var(--text);background:#fff;border-radius:8px;padding:0 12px}.pageShell{width:min(1180px,100% - 28px);margin:0 auto;padding:18px 0 42px}.heroPanel{background:linear-gradient(135deg, #17384afa, #0f5569f0), var(--bg-deep);color:#fff;min-height:0;box-shadow:var(--shadow);text-align:center;border-radius:8px;grid-template-columns:1fr;place-items:center;gap:0;padding:32px 24px;display:grid}.loadingHero{min-height:132px}.heroCopy{min-width:0}.eyebrow{color:#b9d6e4;margin:0 0 8px;font-size:13px}.eyebrow.dark{color:var(--accent)}h1,h2,p{margin-top:0}h1{margin-bottom:10px;font-size:36px;line-height:1.12}.heroPanel h1{margin-bottom:0}h2{margin-bottom:4px;font-size:20px}.heroMeta{color:#d9edf4;margin:0}.weekTag,.overrideTag,.loadingPill,.statusText{white-space:nowrap;border-radius:999px;align-items:center;min-height:28px;padding:0 10px;font-size:13px;display:inline-flex}.loadingPill{color:#fff;background:#ffffff29}.notice{color:#36576d;background:#edf6fb;border:1px solid #c6d7e3;border-radius:8px;gap:10px;margin-top:14px;padding:13px 14px;display:grid}.noticeButton{width:fit-content;padding:0 16px}.controlPanel{border:1px solid var(--line);background:var(--surface);border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:14px;margin-top:14px;padding:12px;display:grid}.controlBlock{gap:8px;min-width:0;display:grid}.controlLabel{color:var(--muted);font-size:13px}.chipGroup,.controlActions,.adminActions,.shiftLine,.assignee{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.chip{align-items:center;gap:7px;min-width:74px;padding:0 12px;display:inline-flex}.chip.active{border-color:var(--accent);background:var(--accent);color:#fff}.memberDot{width:24px;height:24px;color:var(--accent-strong);background:#dcecf4;border-radius:999px;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:inline-flex}.chip.active .memberDot{color:#fff;background:#fff3}.controlActions{justify-content:flex-end}.segmented{border:1px solid var(--line);background:var(--surface-cool);border-radius:8px;grid-template-columns:1fr 1fr;padding:3px;display:inline-grid}.segmented button{background:0 0;border:0;min-width:64px;min-height:34px}.segmented button.active{color:var(--accent-strong);background:#fff;box-shadow:0 4px 12px #1f364e17}.primaryGhost{min-width:92px;color:var(--accent-strong);border-color:#b6ccd9}.primaryButton{border-color:var(--accent);background:var(--accent);color:#fff}.adminModeBar{color:#244b5f;background:#edf8fb;border:1px solid #b8d6df;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;margin-top:12px;padding:10px 12px;display:flex}.adminModeBar div{gap:2px;min-width:0;display:grid}.adminModeBar strong{font-size:14px}.adminModeBar span{color:var(--muted);font-size:13px}.adminModeBar button{min-height:34px;color:var(--accent-strong);border-color:#b6ccd9;padding:0 14px}.overviewGrid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:14px;display:grid}.overviewCard{border:1px solid var(--line);background:var(--surface);border-radius:8px;gap:5px;min-width:0;min-height:70px;padding:12px 14px;display:grid;box-shadow:0 8px 22px #1f364e0a}.overviewCard span,.sectionTitle p,.field span{color:var(--muted)}.overviewCard strong{overflow-wrap:anywhere;font-size:19px}.adminPanel{margin-top:14px}.adminPanel,.monthSection{border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow);border-radius:8px}.adminPanel{padding:18px}.panelHeader,.sectionTitle{justify-content:space-between;align-items:center;gap:12px;display:flex}.sectionTitle h2,.sectionTitle p{margin-bottom:0}.statusText{color:var(--muted);background:#edf3f7}.statusText.error{color:var(--danger);background:#f6e9ed}.statusText.saved{color:var(--success);background:#e7f3ef}.adminGrid{grid-template-columns:260px 1fr;gap:14px;margin-top:16px;display:grid}.field{gap:6px;font-size:14px;display:grid}.memberEditor{grid-template-columns:repeat(4,minmax(120px,1fr));gap:12px;display:grid}.adminActions{grid-column:1/-1}.adminActions button{padding:0 16px}.scheduleArea{grid-template-columns:repeat(var(--schedule-columns,1), minmax(0, 1fr));align-items:start;gap:12px;margin-top:14px;display:grid}.scheduleColumn{align-content:start;gap:12px;min-width:0;display:grid}.monthSection{width:100%;min-width:0;padding:14px}.monthSection+.monthSection{margin-top:0}.scheduleList{gap:8px;margin-top:10px;display:grid}.scheduleCard{border:1px solid var(--soft-line);background:#fbfdff;border-radius:8px;grid-template-columns:96px minmax(0,1fr) 170px;align-items:center;gap:10px;min-height:66px;padding:8px;display:grid}.scheduleCard:not(:has(select)){grid-template-columns:96px minmax(0,1fr);min-width:0}.dateTile{background:#edf5fa;border-radius:8px;gap:2px;padding:9px 10px;display:grid}.dateTile strong{color:var(--accent-strong);font-size:23px;line-height:1}.dateTile span{color:var(--muted);font-size:12px}.shiftInfo{gap:7px;min-width:0;display:grid}.assignee{gap:7px}.assignee strong{overflow-wrap:anywhere;font-size:17px}.weekTag.big{color:var(--accent-strong);background:#dcecf4}.weekTag.small{color:var(--indigo);background:#e7edf8}.weekTag.holiday{color:var(--success);background:#e7f3ef}.overrideTag{color:var(--danger);background:#f5e7ec}.calendarGrid{grid-template-columns:repeat(7,minmax(0,1fr));gap:6px;min-width:0;margin-top:10px;display:grid}.calendarHead{min-width:0;color:var(--muted);text-align:center;font-size:13px}.calendarCell{border:1px solid var(--soft-line);background:#fbfdff;border-radius:8px;align-content:start;gap:6px;min-width:0;min-height:92px;padding:7px;display:grid;overflow:hidden}.calendarCell.empty{opacity:.55;background:0 0;border-style:dashed}.calendarDate{color:var(--muted);font-size:13px}.calendarShift{gap:3px;width:100%;min-width:0;max-width:100%;padding:2px 0 0;display:grid;overflow:hidden}.calendarShift .weekTag{background:0 0;border-radius:0;justify-content:flex-start;min-width:0;max-width:100%;min-height:0;padding:0;font-size:clamp(10px,.72vw,12px);line-height:1.12}.calendarShift strong{text-align:left;text-overflow:ellipsis;white-space:nowrap;min-width:0;max-width:100%;font-size:clamp(11px,.86vw,14px);line-height:1.15;overflow:hidden}.calendarShift select{min-height:34px;padding:0 8px}.calendarEditor,.calendarAddForm{gap:3px;min-width:0;margin-top:2px;display:grid}.calendarEditor select,.calendarAddForm select,.calendarEditor button,.calendarAddForm button{border-radius:5px;width:100%;min-height:24px;padding:0 4px;font-size:11px}.calendarEditor button,.calendarAddForm button{color:var(--accent-strong);border-color:#b6ccd9}.calendarAddType{min-height:24px;color:var(--success);background:#e7f3ef;border-radius:5px;align-items:center;padding:0 5px;font-size:11px;display:inline-flex}@media (max-width:900px){.heroPanel,.controlPanel,.adminGrid{grid-template-columns:1fr}.controlActions{justify-content:flex-start}.overviewGrid,.memberEditor{grid-template-columns:repeat(2,minmax(0,1fr))}.scheduleCard:not(:has(select)){grid-template-columns:82px minmax(0,1fr);min-width:0}.scheduleCard{grid-template-columns:82px minmax(0,1fr)}.scheduleCard select{grid-column:1/-1}.calendarGrid{gap:6px}.calendarCell{min-height:82px;padding:8px}}@media (max-width:560px){.pageShell{width:min(100% - 18px,1180px);padding-top:10px}.heroPanel,.adminPanel,.monthSection{padding:12px}h1{font-size:32px}.overviewGrid,.memberEditor{grid-template-columns:1fr}:is(.scheduleCard,.scheduleCard:not(:has(select))){grid-template-columns:78px minmax(0,1fr);min-width:0}.dateTile{padding:8px}.dateTile strong{font-size:22px}.panelHeader,.adminModeBar,.controlActions{flex-direction:column;align-items:stretch}.chip{flex:42%}.calendarGrid{grid-template-columns:repeat(2,minmax(0,1fr))}.calendarHead,.calendarCell.empty{display:none}}
