:root{--line: #06c755;--line-dark: #039a42;--ink: #10243a;--muted: #66788b;--soft: #eef8fc;--surface: #ffffff;--glass: #ffffff;--border: rgba(19, 72, 105, .16);--blue: #1388c9;--harbor: #73c8e8;--navy: #123d5a;--lobster: #e8503f;--amber: #e99200;--red: #d83d35;--green-soft: #e7f8ed;--blue-soft: #e6f7fd;--amber-soft: #fff4db;--red-soft: #ffebec;--shadow: 0 16px 34px rgba(14, 59, 91, .1);--hairline: 0 1px 0 rgba(255, 255, 255, .95) inset;font-family:Noto Sans TC,PingFang TC,Microsoft JhengHei,Inter,system-ui,sans-serif;color:var(--ink);background:#eaf7fb}*{box-sizing:border-box}body{margin:0;min-width:320px;background:linear-gradient(90deg,rgba(19,136,201,.045) 0 1px,transparent 1px 36px),linear-gradient(180deg,#f5fcff,#e4f5fb)}button,input,select,textarea{font:inherit}button,a{-webkit-tap-highlight-color:transparent}.employee-shell{min-height:100vh;display:grid;place-items:start center;padding:24px;background:linear-gradient(135deg,rgba(115,200,232,.16) 0 25%,transparent 25% 50%,rgba(115,200,232,.16) 50% 75%,transparent 75%) 0 0 / 56px 56px,linear-gradient(180deg,#f5fcff,#e2f4fb)}.phone-frame{width:min(100%,430px);min-height:min(900px,calc(100vh - 48px));background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow);overflow:hidden;padding-bottom:78px;position:relative}.liff-header{min-height:78px;padding:18px 22px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);background:linear-gradient(90deg,#ffffffe0,#ffffffe0),repeating-linear-gradient(90deg,var(--harbor) 0 12px,#ffffff 12px 24px);box-shadow:var(--hairline)}.mini-label{display:block;color:var(--lobster);font-size:13px;font-weight:700}.liff-header h1,.page-title-row h1,.panel-heading h2,.record-list h2,.section-title h2,.section-heading h2{margin:0}.liff-header h1{font-size:25px;line-height:1.2}.line-profile-badge{min-height:38px;border:1px solid var(--border);border-radius:8px;display:inline-flex;align-items:center;gap:8px;padding:5px 10px 5px 6px;background:#fff;color:var(--navy);font-size:12px;font-weight:850}.line-profile-badge img,.line-link-identity img{width:28px;height:28px;border-radius:50%;object-fit:cover}.line-profile-badge svg{color:var(--line)}.clock-panel,.validation-panel,.record-list,.line-link-panel{margin:16px;border:1px solid var(--border);border-radius:8px;background:#fff;box-shadow:var(--hairline)}.clock-panel{overflow:hidden}.status-row{display:flex;align-items:center;gap:10px;padding:16px;background:#e8f8fe;border-bottom:1px solid rgba(19,136,201,.18)}.status-row strong{font-size:22px;color:var(--blue);margin-right:auto}.status-row span:last-child{color:var(--muted);font-weight:600}.status-dot,.tiny-dot{width:12px;height:12px;border-radius:999px;display:inline-block;background:#a8b0bd}.status-dot.active,.tiny-dot.active,.tiny-dot.completed{background:var(--line)}.status-dot.completed{background:var(--blue)}.status-dot.exception,.tiny-dot.exception{background:var(--red)}.status-dot.missing,.tiny-dot.missing{background:var(--amber)}.time-face{text-align:center;font-size:clamp(40px,13vw,58px);font-weight:800;letter-spacing:0;margin:28px 16px 6px}.shift-line{text-align:center;color:var(--muted);font-weight:650;margin-bottom:20px}.admin-exempt-banner{margin:0 16px 16px;min-height:38px;border-radius:8px;display:grid;place-items:center;background:var(--green-soft);color:var(--line-dark);font-size:14px;font-weight:850}.clock-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:0 16px}.primary-action,.secondary-action,.export-button,.approval-item button{min-height:48px;border-radius:8px;border:1px solid transparent;display:inline-flex;align-items:center;justify-content:center;gap:10px;cursor:pointer;font-weight:800}.primary-action{color:#fff;background:var(--line);box-shadow:0 12px 26px #06c7553d}.primary-action:hover{background:var(--line-dark)}.secondary-action{color:var(--navy);background:#fff;border-color:#13486938}.primary-action:disabled,.secondary-action:disabled{cursor:wait;opacity:.7}.inline-message{margin:14px 16px 18px;color:var(--muted);text-align:center;font-size:14px}.inline-message.danger{color:var(--red)}.line-link-panel{padding:18px}.line-link-identity{min-height:68px;border:1px solid rgba(6,199,85,.18);border-radius:8px;background:#e7f8edb8;display:flex;align-items:center;gap:12px;padding:12px;margin-bottom:18px}.line-link-identity svg{color:var(--line)}.line-link-identity div{display:grid;gap:2px}.line-link-identity span{color:var(--line-dark);font-size:13px;font-weight:850}.line-link-identity strong{font-size:18px}.line-link-panel form{display:grid;gap:12px}.line-link-panel label{display:grid;gap:8px;color:var(--muted);font-weight:850}.line-link-panel input{width:100%;height:46px;border:1px solid var(--border);border-radius:8px;background:#ffffffd6;padding:0 13px;color:var(--ink);outline:0}.line-link-panel input:focus{border-color:#007aff8c;box-shadow:0 0 0 3px #007aff1f}.validation-panel{padding:16px}.section-title,.section-heading,.panel-heading{display:flex;align-items:center;gap:10px}.section-title h2,.section-heading h2,.record-list h2{font-size:20px}.section-title svg:first-child{color:var(--line-dark)}.icon-button,.row-action{width:38px;height:38px;border-radius:8px;border:1px solid var(--border);background:#ffffffb8;color:var(--ink);display:inline-grid;place-items:center;cursor:pointer}.icon-button{margin-left:auto}.validation-row{display:flex;gap:12px;align-items:center;padding:16px 0 0}.validation-row+.validation-row{border-top:1px solid var(--border);margin-top:16px}.validation-row svg{width:34px;height:34px}.validation-row .ok{color:var(--line)}.validation-row .muted{color:#aab3bf}.validation-row div{display:grid;gap:3px}.validation-row strong{font-size:18px}.validation-row span{color:var(--muted)}.summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:16px}.metric-card{border:1px solid var(--border);border-radius:8px;background:#fff;padding:16px;box-shadow:var(--hairline)}.metric-label{display:flex;align-items:center;gap:8px;font-weight:800}.metric-card.blue .metric-label svg,.metric-card.blue strong{color:var(--blue)}.metric-card.amber .metric-label svg,.metric-card.amber strong{color:var(--amber)}.metric-card strong{display:block;text-align:center;font-size:30px;margin-top:16px}.quick-links{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:16px}.quick-links button{border:1px solid var(--border);border-radius:8px;background:#fff;min-height:56px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:0 14px;cursor:pointer;font-weight:800}.quick-links svg:first-child{color:var(--blue)}.record-list{padding:16px}.section-heading{justify-content:space-between;margin-bottom:12px}.section-heading a{color:var(--line-dark);font-weight:800;text-decoration:none}.record-row{display:grid;grid-template-columns:auto 88px 1fr auto;align-items:center;gap:10px;min-height:48px;border-top:1px solid var(--border);color:#354052}.record-row strong{color:var(--blue)}.record-row span,.record-row strong{white-space:nowrap}.bottom-tabs{position:absolute;left:0;right:0;bottom:0;height:70px;background:#fff;border-top:1px solid var(--border);display:grid;grid-template-columns:repeat(3,1fr)}.bottom-tabs a{color:#525b6a;display:grid;place-items:center;align-content:center;gap:4px;text-decoration:none;font-size:13px;font-weight:750}.bottom-tabs .active{color:var(--line-dark)}.admin-shell{min-height:100vh;display:grid;grid-template-columns:238px 1fr;background:linear-gradient(90deg,rgba(19,136,201,.05) 0 1px,transparent 1px 44px),linear-gradient(180deg,#f7fcff,#e7f5fb)}.sidebar{background:linear-gradient(180deg,#123d5a,#0e3047);color:#fff;border-right:1px solid rgba(255,255,255,.16);padding:24px 18px}.sidebar-close,.sidebar-backdrop{display:none}.brand-lockup{display:flex;align-items:center;gap:12px;font-size:22px;margin-bottom:28px}.brand-lockup div{display:grid;gap:2px}.brand-lockup small{color:#9bd7ee;font-size:12px;font-weight:800}.line-mark{width:44px;height:34px;border-radius:8px;background:#fff;color:var(--navy);display:grid;place-items:center;font-size:11px;font-weight:900;position:relative;box-shadow:0 0 0 3px #73c8e83d}.line-mark:before,.line-mark:after{content:"";position:absolute;top:8px;right:8px;bottom:8px;left:8px;border:2px solid var(--harbor);border-radius:50%}.line-mark:after{top:14px;right:7px;bottom:14px;left:7px;border-width:1px 0;border-radius:0}.sidebar nav{display:grid;gap:7px}.sidebar button{min-height:48px;border:0;border-radius:8px;color:#d9edf6;background:transparent;display:flex;align-items:center;gap:12px;padding:0 13px;cursor:pointer;font-size:16px;font-weight:760}.sidebar .sidebar-close{display:none}.sidebar button.active,.sidebar button:hover{background:#73c8e82e;box-shadow:var(--hairline);color:#fff}.sidebar button.active svg,.sidebar button:hover svg{color:var(--harbor)}.sidebar button svg{color:#9bd7ee;transition:color .18s ease}.dashboard-main{min-width:0}.dashboard-main,.admin-content{position:relative}.dashboard-main:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(180deg,rgba(255,255,255,.56),transparent 30%)}.dashboard-main>*{position:relative}.admin-topbar{height:74px;background:#fff;border-bottom:1px solid var(--border);display:grid;grid-template-columns:auto minmax(260px,420px) 1fr auto;gap:16px;align-items:center;padding:0 28px;box-shadow:var(--hairline)}.icon-button.dark{background:#ffffffb8}.search-box{height:42px;border:1px solid var(--border);border-radius:8px;display:flex;align-items:center;gap:10px;padding:0 13px;color:var(--muted);background:#f8fbfd}.search-box input{border:0;outline:0;width:100%;color:var(--ink);background:transparent}.store-select,.ghost-link{height:42px;border:1px solid var(--border);border-radius:8px;background:#fff;color:var(--ink);display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 14px;text-decoration:none;font-weight:760;box-shadow:var(--hairline)}.ghost-link{color:var(--lobster)}.admin-content{padding:28px}.page-title-row{display:flex;align-items:end;justify-content:space-between;gap:16px;margin-bottom:22px}.page-title-row span{color:var(--muted);font-weight:700}.page-title-row h1{font-size:30px;line-height:1.2}.admin-actions{display:flex;gap:12px}.admin-actions select{height:42px;border-radius:8px;border:1px solid var(--border);background:#fff;padding:0 12px}.export-button{color:#fff;background:var(--lobster);padding:0 16px}.metrics-row{display:grid;grid-template-columns:repeat(5,minmax(140px,1fr));gap:16px;margin-bottom:18px}.admin-metric{min-height:100px;border:1px solid var(--border);border-radius:8px;background:var(--glass);display:flex;align-items:center;gap:14px;padding:16px;box-shadow:var(--hairline),0 10px 28px #0f172a0d;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.admin-metric>span{width:44px;height:44px;border-radius:8px;display:grid;place-items:center;background:#eef2f6;color:var(--ink)}.admin-metric.green>span{background:var(--green-soft);color:var(--line-dark)}.admin-metric.blue>span{background:var(--blue-soft);color:var(--blue)}.admin-metric.red>span{background:var(--red-soft);color:var(--red)}.admin-metric.amber>span{background:var(--amber-soft);color:var(--amber)}.admin-metric small{display:block;color:var(--muted);font-weight:750}.admin-metric strong{display:block;font-size:25px;margin-top:4px}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1fr) 390px;gap:18px}.operations-layout{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:18px;align-items:start}.primary-operations{min-width:0}.operations-grid{display:grid;grid-template-columns:360px minmax(0,1fr);gap:18px;align-items:start;margin-bottom:18px}.table-panel,.approval-panel,.payroll-panel,.ops-panel,.site-summary-panel,.audit-panel,.line-integration-panel{border:1px solid var(--border);border-radius:8px;background:#fff;box-shadow:var(--hairline),0 14px 28px #0e3b5b14}.ops-panel{min-width:0}.attendance-panel{margin-top:18px}.employee-roster-panel{margin-bottom:18px}.panel-heading{justify-content:space-between;padding:16px;border-bottom:3px solid var(--harbor);background:linear-gradient(180deg,#153f61,#0f3451);color:#fff}.panel-heading h2{display:inline-flex;align-items:center;gap:8px;font-size:18px}.panel-heading span{color:#bde9f8;font-weight:800}.panel-actions{display:flex;gap:8px}.save-button{min-height:38px;border:1px solid transparent;border-radius:8px;background:var(--blue);color:#fff;display:inline-flex;align-items:center;gap:8px;padding:0 12px;cursor:pointer;font-weight:850}.settings-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;padding:16px}.settings-form-grid label,.edit-modal label{min-width:0}.settings-form-grid label{display:grid;gap:7px;color:var(--muted);font-size:13px;font-weight:850}.settings-form-grid input{width:100%;height:40px;border:1px solid var(--border);border-radius:8px;background:#fbfdfe;padding:0 11px;color:var(--ink);outline:0}.settings-form-grid input:focus,.edit-modal input:focus,.edit-modal select:focus,.edit-modal textarea:focus,.search-box:focus-within{border-color:#007aff8c;box-shadow:0 0 0 3px #007aff1f}.switch-row{margin:0 16px 16px;min-height:56px;display:grid;grid-template-columns:auto 1fr;column-gap:10px;row-gap:2px;align-items:center;border:1px solid #bceccd;border-radius:8px;background:#f5fff8;padding:12px;color:var(--line-dark);font-weight:850}.switch-row input{width:18px;height:18px;accent-color:var(--line)}.switch-row small{grid-column:2;color:#557064;font-weight:700}.admin-notice{margin:-4px 16px 16px;color:var(--blue);font-weight:850}.shift-template-row{display:flex;flex-wrap:wrap;gap:8px;padding:14px 16px 0}.shift-chip,.schedule-shift,.role-pill,.flag-pill{border-radius:8px;display:inline-flex;align-items:center;font-weight:850}.shift-chip{min-height:30px;padding:0 10px;font-size:12px}.shift-chip.green,.schedule-shift.green{background:var(--green-soft);color:var(--line-dark)}.shift-chip.blue,.schedule-shift.blue{background:var(--blue-soft);color:var(--blue)}.shift-chip.amber,.schedule-shift.amber{background:var(--amber-soft);color:#a86400}.shift-chip.slate,.schedule-shift.slate{background:#eef2f6;color:#3f4a59}.schedule-scroll{overflow:auto;padding:16px}.schedule-table th,.schedule-table td{padding:10px;vertical-align:middle}.schedule-table th{text-align:center}.schedule-table th:first-child,.schedule-table td:first-child{text-align:left;position:sticky;left:0;background:#fffffff0;z-index:1}.compact-cell img{width:28px;height:28px}.schedule-shift{min-width:86px;min-height:46px;justify-content:center;flex-direction:column;gap:2px;font-size:13px}.schedule-shift small{font-size:11px;font-weight:750}.schedule-off{display:inline-grid;place-items:center;width:42px;height:32px;border-radius:8px;background:#f4f6f8;color:var(--muted);font-weight:850}.ops-rail{min-width:0}.site-summary-list{display:grid}.summary-row{display:grid;grid-template-columns:auto 1fr;column-gap:10px;row-gap:2px;padding:14px 16px;border-bottom:1px solid var(--border)}.summary-row>span{width:34px;height:34px;border-radius:8px;display:grid;place-items:center;background:var(--green-soft);color:var(--line-dark);grid-row:span 2}.summary-row small{color:var(--muted);font-weight:750}.summary-row strong{color:var(--ink)}.line-health-grid{display:grid;gap:8px;padding:14px 16px}.line-status-row{min-height:42px;border:1px solid var(--border);border-radius:8px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:0 11px;background:#ffffffa3}.line-status-row>span{width:10px;height:10px;border-radius:999px;background:#aab3bf}.line-status-row.active>span{background:var(--line)}.line-status-row strong{font-size:13px}.line-status-row small{color:var(--muted);font-weight:800}.line-status-row.active small{color:var(--line-dark)}.line-bind-progress{min-height:48px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 16px}.line-bind-progress span{color:var(--muted);font-weight:800}.line-bind-progress strong{color:var(--blue);font-size:22px}.audit-list{display:grid}.audit-row{display:grid;gap:3px;padding:12px 16px;border-bottom:1px solid var(--border)}.audit-row strong{color:var(--ink);font-size:14px}.audit-row span,.audit-row small{color:var(--muted);font-size:12px;font-weight:720}.table-scroll{overflow:auto}table{width:100%;border-collapse:collapse}th,td{border-bottom:1px solid var(--border);padding:13px 14px;text-align:left;white-space:nowrap}th{background:#f8fafcdb;color:#4e5868;font-size:13px}.employee-cell{display:flex;align-items:center;gap:10px;font-weight:800}.employee-cell img,.approval-item img{width:34px;height:34px;border-radius:50%;object-fit:cover;background:#edf1f5}.employee-meta{display:grid;gap:2px}.employee-meta strong{color:var(--ink)}.employee-meta small{color:var(--muted);font-size:12px;font-weight:760}.rate-cell{color:var(--blue);font-weight:850}.line-chip{min-height:26px;border-radius:8px;padding:0 9px;display:inline-flex;align-items:center;background:#eef2f6;color:#5f6876;font-size:12px;font-weight:850}.line-chip.linked{background:var(--green-soft);color:var(--line-dark)}.status-pill{display:inline-flex;align-items:center;min-height:26px;border-radius:8px;padding:0 10px;font-size:13px;font-weight:800}.status-pill.active{background:var(--blue-soft);color:var(--blue)}.status-pill.completed{background:var(--green-soft);color:var(--line-dark)}.status-pill.missing{background:var(--amber-soft);color:#b36900}.status-pill.exception{background:var(--red-soft);color:var(--red)}.role-pill{min-height:26px;padding:0 9px;background:#eef2f6;color:#4f5d70;font-size:12px}.role-pill.admin{background:var(--green-soft);color:var(--line-dark)}.flag-stack{display:flex;flex-wrap:wrap;gap:4px}.flag-pill{min-height:24px;padding:0 8px;font-size:12px}.flag-pill.clean{background:#eef2f6;color:#5f6876}.flag-pill.warning{background:var(--amber-soft);color:#a86400}.flag-pill.exempt{background:var(--green-soft);color:var(--line-dark)}.location-cell{display:grid;grid-template-columns:auto auto;column-gap:6px;row-gap:2px;align-items:center}.location-cell svg{color:var(--line-dark)}.location-cell small{grid-column:2;color:var(--muted)}.right-rail{display:grid;gap:18px;align-content:start}.approval-item{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;padding:14px 16px;border-bottom:1px solid var(--border)}.approval-item div{display:grid;gap:2px}.approval-item span{font-weight:760}.approval-item small{color:var(--muted)}.approval-item button{min-height:34px;padding:0 12px;color:var(--line-dark);background:var(--green-soft)}.payroll-panel td{font-weight:760}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0c131f73;display:grid;place-items:center;padding:20px;z-index:60}.edit-modal{width:min(100%,430px);border-radius:8px;background:#ffffffeb;box-shadow:var(--shadow);padding:18px;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px)}.employee-modal{width:min(100%,620px)}.edit-modal header,.edit-modal footer{display:flex;align-items:center;justify-content:space-between;gap:12px}.edit-modal h2{margin:0;font-size:21px}.edit-modal label{display:grid;gap:8px;margin-top:16px;color:var(--muted);font-weight:800}.edit-modal input,.edit-modal select,.edit-modal textarea{border:1px solid var(--border);border-radius:8px;padding:12px;color:var(--ink);background:#fff}.edit-modal textarea{min-height:92px;resize:vertical}.edit-modal footer{justify-content:end;margin-top:18px}.employee-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:16px}.employee-form-grid label{margin-top:0}.employee-form-grid .full-span{grid-column:1 / -1}.compact{min-height:42px;padding:0 18px}.loading-state{display:grid;place-items:center;min-height:100vh;font-weight:800;color:var(--muted)}@media(max-width:1100px){.admin-shell{grid-template-columns:1fr}.sidebar{position:fixed;inset:0 auto 0 0;z-index:50;width:min(82vw,300px);transform:translate(-105%);transition:transform .2s ease;box-shadow:26px 0 44px #0c131f3d}.admin-shell.sidebar-open .sidebar{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:45;border:0;padding:0;background:#0c131f6b;opacity:0;pointer-events:none;transition:opacity .2s ease}.admin-shell.sidebar-open .sidebar-backdrop{opacity:1;pointer-events:auto}.sidebar .sidebar-close{width:38px;height:38px;min-height:38px;border-radius:8px;border:1px solid rgba(255,255,255,.22);background:#ffffff1a;color:#fff;display:inline-grid;place-items:center;cursor:pointer;margin-left:auto;padding:0}.metrics-row{grid-template-columns:repeat(2,minmax(0,1fr))}.dashboard-grid,.operations-layout,.operations-grid{grid-template-columns:1fr}}@media(max-width:720px){.employee-shell{padding:0}.phone-frame{min-height:100vh;border:0;border-radius:0}.admin-topbar{grid-template-columns:auto 1fr;height:auto;padding:14px}.store-select,.ghost-link{display:none}.admin-content{padding:16px}.page-title-row,.admin-actions{align-items:stretch;flex-direction:column}.metrics-row{grid-template-columns:1fr}.summary-grid,.quick-links{grid-template-columns:repeat(2,minmax(0,1fr))}.settings-form-grid,.employee-form-grid{grid-template-columns:1fr}.employee-form-grid .full-span{grid-column:auto}.employee-modal{max-height:calc(100vh - 32px);overflow:auto}.panel-actions{flex-direction:column}}
