:root{--go-green: #8cc63f;--go-green-dark: #5a9216;--go-red: #d8121a;--ink: #1d1d1f;--muted: #6b7280;--border: #c9ccd1;--bg: #f4f5f7;--panel: #ffffff;--pink: #f7c6dd;--blue: #bfe0f5;--shadow: 0 1px 3px rgba(0, 0, 0, .12);--radius: 8px;font-family:Segoe UI,system-ui,-apple-system,Microsoft YaHei,sans-serif;color:var(--ink)}*{box-sizing:border-box}body{margin:0;background:var(--bg)}button{font:inherit;cursor:pointer;border:1px solid var(--border);background:var(--panel);border-radius:6px;padding:7px 14px;transition:background .15s,border-color .15s}button:hover{border-color:var(--go-green-dark)}button.primary{background:var(--go-green);border-color:var(--go-green-dark);color:#14310a;font-weight:600}button.primary:hover{background:var(--go-green-dark);color:#fff}button.danger{border-color:var(--go-red);color:var(--go-red)}button:disabled{opacity:.5;cursor:not-allowed}input,select,textarea{font:inherit;padding:6px 8px;border:1px solid var(--border);border-radius:6px;background:#fff;max-width:100%}textarea{width:100%;resize:vertical}a{color:var(--go-green-dark)}.app-header{display:flex;align-items:center;gap:12px;padding:8px 20px;background:var(--panel);border-bottom:2px solid var(--go-green);box-shadow:var(--shadow);position:sticky;top:0;z-index:10;flex-wrap:nowrap}.app-header .brand{display:flex;align-items:center;gap:10px;font-weight:700;flex-shrink:0}.app-header .nav-toggle{display:none;font-size:20px;line-height:1;padding:5px 10px}.app-header.compact .nav-toggle{display:inline-flex}.app-header .app-nav{display:flex;gap:6px;margin-left:4px;white-space:nowrap;overflow:hidden}.app-header.compact .app-nav{position:absolute;left:-9999px;top:0;visibility:hidden;pointer-events:none}.app-header .app-nav a{padding:6px 10px;border-radius:6px;text-decoration:none;color:var(--ink);white-space:nowrap}.app-header .app-nav a.active{background:var(--go-green);color:#14310a;font-weight:600}.app-header .spacer{flex:1}.app-header .header-controls{display:flex;align-items:center;gap:10px;flex-shrink:0}.app-header .user{color:var(--muted);font-size:.9rem;white-space:nowrap}.app-header button{white-space:nowrap}.nav-backdrop{position:fixed;inset:0;background:#0006;z-index:200}.nav-drawer{position:fixed;top:0;left:0;height:100vh;width:250px;max-width:82vw;background:var(--panel);box-shadow:2px 0 12px #0003;z-index:201;display:flex;flex-direction:column;overflow-y:auto;animation:drawer-in .18s ease-out}@keyframes drawer-in{0%{transform:translate(-100%)}to{transform:translate(0)}}.nav-drawer-head{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border)}.drawer-nav{display:flex;flex-direction:column;padding:8px;gap:2px}.drawer-nav a{padding:12px 14px;border-radius:6px;text-decoration:none;color:var(--ink)}.drawer-nav a.active{background:var(--go-green);color:#14310a;font-weight:600}.app-footer{text-align:center;color:var(--muted);font-size:.85rem;padding:18px 16px;margin-top:24px;border-top:1px solid var(--border)}.app-footer a{color:var(--go-green-dark);font-weight:600;text-decoration:none}.app-footer a:hover{text-decoration:underline}.lang-switch button{padding:4px 8px;font-size:.85rem}.lang-switch button.active{background:var(--go-green);font-weight:700}main{padding:20px;max-width:1280px;margin:0 auto}.panel{background:var(--panel);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px;margin-bottom:18px}.toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}.notice{padding:10px 14px;border-radius:6px;margin:10px 0}.notice.ok{background:#e6f5d9;color:#2f5d12}.notice.err{background:#fde2e1;color:#8a1216}.notice.warn{background:#fff3cd;color:#8a6100;border:1px solid #f0c674;display:flex;align-items:center}.login-wrap{min-height:90vh;display:grid;place-items:center}.login-card{width:360px;max-width:92vw}.login-card .field{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.login-card label{font-size:.85rem;color:var(--muted)}.login-card input{width:100%}.grid-scroll{overflow-x:auto}table.schedule{border-collapse:collapse;width:100%;font-size:12px;background:#fff}table.schedule th,table.schedule td{border:1px solid #9aa0a6;text-align:center;padding:2px 4px;white-space:nowrap}table.schedule .title-row td{border:none;padding:6px}table.schedule .corner{background:#fff}table.schedule thead th{background:#fff;font-weight:700}table.schedule .name-cell{text-align:left;padding:3px 8px;font-weight:600;min-width:90px}table.schedule .name-cell.f{background-color:var(--pink)}table.schedule .name-cell.m{background-color:var(--blue)}.report-status{flex:0 0 220px;align-self:flex-start}.report-status .rs-item{display:flex;align-items:center;gap:8px;padding:3px 0}.report-status .rs-dot{width:12px;height:12px;border-radius:50%;flex:0 0 12px}.report-status .rs-dot.reported{background:#14b8a6}.report-status .rs-dot.pending{background:#ffb300}.report-status .rs-name.clickable{cursor:pointer;text-decoration:underline dotted}.schedule-row{display:flex;gap:16px;align-items:flex-start;flex-wrap:wrap}.diff-scroll{overflow-x:auto}table.diff-grid{border-collapse:collapse;width:100%}table.diff-grid th,table.diff-grid td{border:1px solid var(--border);padding:6px 8px;text-align:center;font-size:13px;white-space:nowrap}table.diff-grid th.rowlabel{text-align:right;background:var(--bg);font-weight:700;white-space:nowrap}table.diff-grid td.diff{outline:2px dashed var(--go-red);outline-offset:-2px}.schedule-row>.grid-col{flex:1;min-width:0}table.schedule td.day{min-width:52px;height:22px;font-variant-numeric:tabular-nums}table.schedule td.sum{font-weight:700;background:#fafafa;min-width:56px}table.schedule tfoot td{font-weight:700;background:#f0f0f0}table.schedule td.day.editable{cursor:pointer}table.schedule td.day.diff{outline:2px solid var(--go-red);outline-offset:-2px}.grid-header-meta{display:flex;align-items:center;gap:18px;justify-content:space-between;font-weight:700}.grid-header-meta .logo{display:flex;align-items:center;gap:8px;font-size:20px;color:var(--go-red)}.grid-header-meta .logo .dot{background:var(--go-red);color:#fff;border-radius:50%;width:30px;height:30px;display:grid;place-items:center;font-weight:800}.grid-header-meta .branch{font-size:22px;letter-spacing:1px}.grid-header-meta .period{font-size:18px}.legend{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.legend .chip{display:inline-flex;align-items:center;padding:3px 10px;border-radius:4px;font-size:12px;border:1px solid #9aa0a6}table.data{border-collapse:collapse;width:100%}table.data th,table.data td{border-bottom:1px solid var(--border);padding:8px 10px;text-align:left}table.data th{color:var(--muted);font-weight:600}table.data th,table.data td{white-space:nowrap}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.table-scroll table.data{min-width:max-content}table.data th.audit-detail,table.data td.audit-detail{white-space:normal;min-width:220px;max-width:420px}.modal-backdrop{position:fixed;inset:0;background:#0006;display:grid;place-items:center;z-index:50}.modal{background:#fff;border-radius:var(--radius);padding:20px;width:460px;max-width:94vw;max-height:90vh;overflow:auto}.modal h3{margin-top:0}.row{display:flex;gap:10px;align-items:center;margin-bottom:10px;flex-wrap:wrap}.row label{min-width:120px;color:var(--muted)}.row.time-row{flex-wrap:nowrap}.row.time-row label{min-width:auto}.row.time-row input{min-width:0;flex:1}.center{display:grid;place-items:center;min-height:60vh;color:var(--muted)}table.schedule tr.dim td.day{opacity:.3}table.schedule tr.dim td.name-cell,table.schedule tr.dim td.sum{opacity:.45}table.schedule td.day.locked,.grid-scroll.locked,.grid-scroll.locked *{cursor:not-allowed}@keyframes ants-x{to{background-position:16px 0,-16px 100%}}@keyframes ants-left{to{background-position:16px 0,-16px 100%,0 -16px}}@keyframes ants-right{to{background-position:16px 0,-16px 100%,100% 16px}}table.schedule tr.own-row td{background-image:linear-gradient(to right,#ff8c00 50%,transparent 50%),linear-gradient(to right,#ff8c00 50%,transparent 50%);background-repeat:repeat-x;background-size:16px 2px;background-position:0 0,0 100%;animation:ants-x .7s linear infinite}table.schedule tr.own-row td:first-child{background-image:linear-gradient(to right,#ff8c00 50%,transparent 50%),linear-gradient(to right,#ff8c00 50%,transparent 50%),linear-gradient(to bottom,#ff8c00 50%,transparent 50%);background-repeat:repeat-x,repeat-x,repeat-y;background-size:16px 2px,16px 2px,2px 16px;background-position:0 0,0 100%,0 0;animation:ants-left .7s linear infinite}table.schedule tr.own-row td:last-child{background-image:linear-gradient(to right,#ff8c00 50%,transparent 50%),linear-gradient(to right,#ff8c00 50%,transparent 50%),linear-gradient(to bottom,#ff8c00 50%,transparent 50%);background-repeat:repeat-x,repeat-x,repeat-y;background-size:16px 2px,16px 2px,2px 16px;background-position:0 0,0 100%,100% 0;animation:ants-right .7s linear infinite}.btn-like{display:inline-flex;align-items:center;padding:7px 14px;border:1px solid var(--border, #ccc);border-radius:6px;background:#fff;font:inherit}.btn-like:hover{background:#f3f4f6}table.schedule td.day.pending{outline:2px dashed #f59e0b;outline-offset:-2px}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:999px;font-weight:700;font-size:.85rem;border:1px solid transparent}.status-badge.submitted{background:#e6f5d9;color:#2f5d12;border-color:#9bce6e}.status-badge.pending{background:#fff3cd;color:#8a6100;border-color:#f0c674}.legend .chip{cursor:help}.export-legend{display:none;padding:10px 4px 4px}.export-legend strong{display:block;margin-bottom:6px;font-size:13px}.grid-scroll.exporting .export-legend{display:block}@media(max-width:760px){main{padding:12px}.app-header{gap:6px;padding:8px 10px}.app-header .user{display:none}.app-header .brand img,.app-header .brand svg{height:30px!important;width:auto}.app-header .header-controls{gap:6px}.app-header .nav-toggle,.app-header .header-controls button{padding:5px 8px;font-size:.85rem}.panel{padding:12px}.modal{width:96vw;padding:16px}table.schedule{font-size:11px}table.schedule td.day{min-width:40px}button{padding:9px 14px}.row label{min-width:96px}}.today-duty{border-left:4px solid var(--go-green)}.compose-fields{display:grid;gap:8px}.compose-subject{width:100%}.rte{border:1px solid var(--border);border-radius:6px;overflow:hidden;background:#fff}.rte-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:2px;padding:4px 6px;border-bottom:1px solid var(--border);background:var(--bg)}.rte-toolbar button,.rte-toolbar .rte-color,.rte-toolbar .rte-img{min-width:30px;height:28px;display:inline-flex;align-items:center;justify-content:center;padding:0 6px;border:1px solid var(--border);border-radius:4px;background:#fff;cursor:pointer;font-size:14px}.rte-toolbar button.active{background:var(--go-green)}.rte-toolbar .rte-color input[type=color]{width:18px;height:18px;padding:0;border:none;background:none;margin-left:2px;cursor:pointer}.rte-toolbar select{height:28px;padding:0 4px}.rte-area,.rte-source{display:block;width:100%;min-height:140px;padding:10px;box-sizing:border-box;font:inherit;border:none;outline:none}.rte-area:empty:before{content:attr(data-placeholder);color:var(--muted)}.rte-source{resize:vertical;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12px}.rte-content img{max-height:140px;max-width:100%;height:auto;border-radius:6px;vertical-align:middle;cursor:zoom-in}.rte-content a{color:var(--go-green-dark)}.rte-area img{max-width:100%;height:auto}.lightbox-backdrop{position:fixed;inset:0;z-index:300;background:#000000d9;display:flex;align-items:center;justify-content:center;padding:24px;cursor:zoom-out}.lightbox-img{max-width:96vw;max-height:92vh;object-fit:contain;border-radius:4px;box-shadow:0 6px 28px #0000008c;cursor:default}.lightbox-close{position:fixed;top:12px;right:16px;width:40px;height:40px;padding:0;display:flex;align-items:center;justify-content:center;font-size:20px;line-height:1;color:#fff;background:#00000073;border:1px solid rgba(255,255,255,.5);border-radius:50%;cursor:pointer;z-index:301}.msg-toast{position:fixed;right:16px;bottom:16px;z-index:320;max-width:320px;padding:12px 14px;background:var(--panel);border-left:4px solid var(--go-green);border-radius:8px;box-shadow:0 6px 24px #00000040;cursor:pointer;animation:toast-in .2s ease-out}.msg-toast-body{color:var(--muted);font-size:13px;margin-top:4px}@keyframes toast-in{0%{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}.recipient-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.recipient-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border:1px solid var(--border);border-radius:999px;cursor:pointer;-webkit-user-select:none;user-select:none}.recipient-chip.on{border-color:var(--go-green-dark);background:#eef7e3}.msg-card{border:1px solid var(--border);border-radius:var(--radius);padding:12px;background:var(--panel)}.msg-card.unread{border-left:4px solid var(--go-red);background:#fff7f7}.msg-head{display:flex;justify-content:space-between;gap:12px;color:var(--muted);font-size:13px}.msg-subject{font-weight:600;margin-top:4px}.msg-body{white-space:pre-wrap;margin:6px 0}.msg-meta{display:flex;align-items:center;gap:10px;margin:6px 0}.msg-recipients{font-size:13px;color:var(--muted);display:flex;flex-wrap:wrap;gap:6px;align-items:center}.ack-chip{display:inline-flex;padding:2px 8px;border-radius:999px;border:1px solid var(--border)}.ack-chip.acked{color:var(--go-green-dark);border-color:var(--go-green)}.ack-chip.pending{color:var(--muted)}.modal.wide{width:880px}.nav-badge{display:inline-block;min-width:18px;margin-left:6px;padding:0 5px;font-size:11px;line-height:18px;text-align:center;color:#fff;background:var(--go-red);border-radius:999px;vertical-align:middle}.dash-head .panel{margin-bottom:0}.dash-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:18px}.dash-cards .stat-card{margin:0}.stat-label{color:var(--muted);font-size:13px}.stat-value{font-size:28px;font-weight:700;margin-top:4px}.stat-unit{font-size:14px;font-weight:400;color:var(--muted)}.dash-charts{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px;margin-bottom:18px}.today-task-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.today-task-chip{padding:4px 10px;border-radius:6px;font-size:13px;border:1px solid var(--border)}.bar-chart{display:flex;align-items:flex-end;gap:10px;height:180px;padding-top:8px}.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}.bar-value{font-size:11px;color:var(--muted);height:16px}.bar-track{flex:1;width:60%;display:flex;align-items:flex-end;background:var(--bg);border-radius:4px 4px 0 0}.bar-fill{width:100%;border-radius:4px 4px 0 0;min-height:2px;transition:height .2s}.bar-label{font-size:12px;margin-top:4px}.dash-section{margin:22px 0 10px;font-size:15px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);padding-bottom:6px}.stat-sub{margin-top:6px;font-size:12px;color:var(--muted)}.delta-up{color:var(--go-green-dark)}.delta-down{color:#c0392b}a.stat-link{display:block;text-decoration:none;color:inherit;transition:border-color .15s,transform .1s}a.stat-link:hover{border-color:var(--go-green);transform:translateY(-1px)}a.stat-link.alert{border-color:#f0a202;background:#fff8e8}a.stat-link.alert .stat-value{color:#b86e00}.bar-track.dual{position:relative}.bar-track.dual .bar-fill{position:absolute;bottom:0;left:0}.bar-track.dual .bar-fill:last-child{width:58%;left:21%}.chart-legend{display:flex;gap:16px;margin-top:8px;font-size:12px;color:var(--muted)}.chart-legend i{display:inline-block;width:12px;height:12px;border-radius:3px;margin-right:4px;vertical-align:-1px}.dash-roster{display:grid;gap:8px}.roster-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:7px 0;border-bottom:1px solid var(--border)}.roster-row:last-child{border-bottom:none}.roster-name{font-weight:600;min-width:120px}.roster-time{font-variant-numeric:tabular-nums;color:var(--muted);min-width:110px}.roster-chips{display:flex;gap:6px;flex-wrap:wrap;flex:1}.g-f{color:#c2185b}.g-m{color:#1565c0}.att-pill{font-size:12px;font-weight:700;padding:2px 8px;border-radius:999px;border:1px solid transparent;white-space:nowrap}.att-pill.verified{background:#e6f5d9;color:#2f5d12;border-color:#9bce6e}.att-pill.present{background:#fff3cd;color:#8a6100;border-color:#f0c674}.att-pill.none{background:var(--bg);color:var(--muted);border-color:var(--border)}.att-summary{display:flex;gap:8px;margin-top:6px}.dash-confirm-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}.dash-cta-link{color:var(--go-green-dark);font-weight:600;text-decoration:none}.dash-cta-link:hover{text-decoration:underline}.upcoming-title{font-weight:600;margin:4px 0 8px}.dash-week-note{margin:0 0 4px;font-size:13px;color:#8a6100;background:#fff8e8;border:1px solid #f0c674;border-radius:6px;padding:5px 10px;display:inline-block}.clock-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.break-cell{display:flex;flex-direction:column;gap:4px;align-items:flex-start}.break-btn{font-size:12px;padding:2px 8px;white-space:nowrap}.break-btn.on{background:#ffe1e1;border-color:#e0a0a0;color:#a11;font-weight:700}.break-period{font-size:11px;color:var(--muted);font-variant-numeric:tabular-nums;white-space:nowrap}.note-btn{font-size:12px;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left;color:var(--muted)}.note-btn.has-note{color:var(--text);background:#fff8e8;border-color:#f0c674}.day-tabs{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.day-tab{display:inline-flex;align-items:center;gap:6px}.day-tab.active{border-color:var(--go-green-dark);background:#eef7e3;font-weight:700}.day-tab-count{font-size:11px;color:var(--muted);background:var(--bg);border-radius:999px;padding:0 6px}.attendance-table input[type=time]{padding:4px}.center-week-list{display:none;list-style:none;margin:10px 0 0;padding:0}.center-week-list li+li{margin-top:8px}.center-week-list .my-day{width:100%;display:flex;align-items:center;gap:10px;padding:12px;border:1px solid var(--border);border-radius:8px;background:#fff;text-align:left;cursor:pointer}.center-week-list .my-day:disabled{cursor:default;opacity:.9}.my-day-name{flex:0 0 44px;font-weight:700}.my-day-body{flex:1;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.my-day-time{font-variant-numeric:tabular-nums}.my-day-task{padding:2px 8px;border-radius:6px;font-size:12px}.my-day-empty{color:var(--muted)}.my-day-edit{color:var(--go-green-dark);font-weight:700}@media(max-width:760px){.center-grid{display:none}.center-week-list{display:block}}@media(max-width:760px){.schedule-row{flex-direction:column;align-items:stretch}.schedule-row>.report-status{flex:0 0 auto;width:100%}.schedule-row>.grid-col{width:100%;min-width:0}table.schedule{font-size:12px}table.schedule thead tr:nth-child(2) th:first-child,table.schedule tbody td.name-cell:nth-child(1){position:sticky;left:0;z-index:3;min-width:56px;max-width:56px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}table.schedule thead tr:nth-child(2) th:nth-child(2),table.schedule tbody td.name-cell:nth-child(2){position:sticky;left:56px;z-index:3;min-width:68px;max-width:68px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}table.schedule thead tr:nth-child(2) th:first-child,table.schedule thead tr:nth-child(2) th:nth-child(2){background:#fff}table.schedule tfoot td:first-child{position:sticky;left:0;z-index:3;background:#fff}}
