:root{--bg: #f4f6f9;--card: #ffffff;--line: #e8edf3;--text: #0f172a;--muted: #64748b}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,PingFang SC,Microsoft YaHei,sans-serif}.app-shell{min-height:100vh}.app-wrap{max-width:1280px;margin:0 auto;padding:20px}.card{background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:0 1px #0f172a08;padding:24px}.hero-card,.row,.between,.wrap{display:flex}.hero-card{justify-content:space-between;align-items:center;gap:12px;padding-top:14px;padding-bottom:14px}.between{justify-content:space-between}.wrap{flex-wrap:wrap}.row{align-items:center}.gap-8{gap:8px}.gap-12{gap:12px}.align-center{align-items:center}.top-gap{margin-top:12px}.section-card,.hero-card{margin-bottom:24px}.hero-stats{display:grid;grid-template-columns:minmax(110px,1fr);gap:10px;align-content:center}.hero-title-wrap{display:flex;align-items:center;min-height:100%}.stat-box{background:#fbfbfa;border:1px solid var(--line);border-radius:12px;padding:10px 14px;min-width:110px;cursor:pointer;text-align:left;color:#0f172a;-webkit-text-fill-color:#0f172a}.stat-value{font-size:24px;font-weight:700;margin-top:4px;color:#0f172a;-webkit-text-fill-color:#0f172a}.year-select{width:100%;margin-top:4px;border:1px solid var(--line);border-radius:8px;padding:4px 6px;font-size:16px;background:#fff}.stat-label{color:var(--muted);font-size:12px}h1{margin:0;font-size:34px;font-weight:700;letter-spacing:-.02em}h2{margin:0;font-size:22px}.subtle,.mini-tip,.table-daytype,.notes{color:var(--muted)}.subtle{margin:10px 0 0;line-height:1.5}.mini-tip{font-size:12px}.ai-box{background:#fcfdff;border:1px solid var(--line);border-radius:14px;padding:12px;position:relative}.ai-inline-row{align-items:center;padding-right:48px;flex-wrap:nowrap}.ai-inline-row h2{font-size:18px;white-space:nowrap}.text-input,.select-input{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 14px}.text-input{flex:1;min-width:240px}.primary-btn,.ghost-btn{border:none;border-radius:14px;padding:12px 16px;font-weight:600}.primary-btn{background:#111827;color:#fff}.primary-btn:hover{background:#1f2937}.ghost-btn{background:#fff;color:var(--text);border:1px solid var(--line)}.feedback{margin-top:12px;color:#0369a1;font-size:14px}.menu-wrap{position:absolute;top:12px;right:12px}.menu-trigger{width:36px;height:36px;border:1px solid var(--line);border-radius:10px;background:#fff;color:#334155;font-weight:700;cursor:pointer}.menu-dropdown{position:absolute;right:0;top:calc(100% + 6px);min-width:170px;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:0 8px 18px #0f172a1f;z-index:20;overflow:hidden}.menu-item{width:100%;border:none;background:#fff;text-align:left;padding:10px 12px;color:#0f172a;cursor:pointer}.menu-item:hover{background:#f8fafc}.pill,.status-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;border:1px solid var(--line);padding:6px 10px;font-size:12px;font-weight:600}.pill{background:#f8fafc}.section-head{margin-bottom:16px}.status-office{background:#edf5e8;color:#4b5563;border-color:#d9e8cc}.status-ho,.status-ho-dark{background:#f6f1ff;color:#6b4ab1;border-color:#e8ddff}.status-off,.status-off-dark{background:#fff1f2;color:#9f4b63;border-color:#ffdce1}.status-business{background:#fff3e6;color:#a26428;border-color:#ffe2c0}.status-mixed{background:#eef2ff;color:#4338ca;border-color:#c7d2fe}.weekly-card{width:100%}.week-table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.week-nav-cards{display:flex;gap:8px}.week-jump-card{display:flex;align-items:center;gap:4px;border:1px solid var(--line);border-radius:10px;background:#f8fafc;padding:4px}.week-jump-select{border:1px solid var(--line);border-radius:8px;background:#fff;color:#334155;font-size:12px;font-weight:600;height:28px;padding:0 6px}.week-nav-card{width:36px;height:36px;border-radius:10px;border:1px solid var(--line);background:#f8fafc;font-size:18px;font-weight:700;color:#334155;cursor:pointer}.week-nav-today{font-size:11px;font-weight:600}.weekdays-strip{display:grid;grid-template-columns:120px repeat(7,minmax(110px,1fr));min-width:890px;margin-bottom:8px}.weekday-member-placeholder{min-height:1px}.weekday-label{text-align:center;font-size:12px;font-weight:700;color:var(--muted)}.week-table{width:100%;min-width:890px;border-collapse:separate;border-spacing:0;table-layout:fixed;border:1px solid #e6ecf3;border-radius:14px;overflow:visible;background:#f8fafc}.week-table th,.week-table td{border-right:1px solid #e9eef5;border-bottom:1px solid #e9eef5;padding:10px;text-align:center;background:#fbfdff}.week-table tr:last-child td,.week-table tr:last-child th{border-bottom:none}.week-table th:last-child,.week-table td:last-child{border-right:none}.week-table thead th{font-size:13px;font-weight:700;background:#f5f8fc}.member-head,.member-col{width:120px;min-width:120px;max-width:120px;position:-webkit-sticky;position:sticky;left:0;background:#f5f8fc!important;transform:translateZ(0);will-change:transform}.member-head{z-index:10}.member-col{z-index:9;box-shadow:2px 0 #e9eef5}.week-table thead th:first-child,.week-table tbody th:first-child{width:120px;min-width:120px}.table-date{font-size:17px;font-weight:700;color:#0f172a;margin-top:2px}.table-daytype{font-size:11px;margin-top:2px}.table-weekend-off{background:#fff5f6!important}.table-today-col{border-left:2px solid #f8e8b4!important;border-right:2px solid #f8e8b4!important;background:#fffef8!important}.table-today-start{border-top:2px solid #f8e8b4!important}.table-today-end{border-bottom:2px solid #f8e8b4!important}.table-status{width:100%;border:1px solid #e6ecf3;border-radius:10px;padding:8px 6px;font-size:12px;font-weight:600;cursor:pointer}.table-select{width:100%;border:1px solid var(--line);border-radius:10px;padding:8px;font-size:12px;background:#fff}@media (max-width: 640px){.app-wrap{padding:14px}.card{padding:16px;border-radius:14px}.hero-card{flex-direction:column;align-items:center}.hero-title-wrap{justify-content:center;width:100%}.hero-stats{width:100%;display:flex;justify-content:center}h1{font-size:28px}h2{font-size:18px}.week-table thead th:first-child{width:90px;min-width:90px}.member-head,.member-col{width:90px;min-width:90px;max-width:90px}.stat-box{text-align:center}.weekdays-strip{grid-template-columns:90px repeat(7,minmax(100px,1fr));min-width:790px}.week-table{min-width:790px}.ai-inline-row{gap:8px}.ai-inline-row h2{font-size:16px}.text-input{min-width:110px;padding:9px 10px}.primary-btn{padding:9px 12px}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a52;display:flex;align-items:center;justify-content:center;z-index:40;padding:20px}.confirm-modal{width:min(420px,100%);background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px}.confirm-modal p{margin:0;font-size:16px}.confirm-actions{margin-top:16px;display:flex;justify-content:flex-end;gap:8px}
