:root{color-scheme:light;--bg:#fff9f3;--ink:#17111d;--muted:#655b70;--line:#eee2d9;--panel:rgba(255,255,255,0.88);--navy:#fff7ef;--navy-2:#fff1e7;--blue:#7c4dff;--blue-2:#6040dd;--teal:#12a874;--green:#16a34a;--amber:#ff9f68;--amber-2:#d96f36;--red:#ff5a66;--coral:#ff5a66;--purple:#7c3aed;--shadow:0 24px 70px rgba(90,66,125,0.12);--soft-shadow:0 14px 38px rgba(90,66,125,0.08)}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at 14% 0,rgba(255,159,104,.18),transparent 30%),radial-gradient(circle at 86% 0,rgba(124,58,237,.18),transparent 34%),linear-gradient(180deg,#fffaf5,#fbf8ff 48%,#fffdf9);color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,select,textarea{font:inherit}button{border:0;cursor:pointer}button:disabled{cursor:not-allowed}.product-shell{display:grid;grid-template-columns:264px minmax(0,1fr);min-height:100vh}.side-rail{position:-webkit-sticky;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:24px;padding:24px;background:radial-gradient(circle at 0 0,rgba(255,90,102,.1),transparent 34%),linear-gradient(180deg,rgba(255,255,255,.92),rgba(255,247,239,.92)),var(--navy);color:var(--ink);border-right:1px solid var(--line)}.brand-lockup,.metric-head,.mobile-brand-row,.panel-head,.rail-profile,.section-title{display:flex;align-items:center}.brand-lockup{gap:12px}.brand-lockup.compact .brand-mark{width:42px;height:42px}.brand-lockup span,.brand-lockup strong,.rail-profile span,.rail-profile strong{display:block}.brand-lockup span,.rail-profile span{color:var(--muted);font-size:.82rem}.brand-mark{display:grid;width:48px;height:48px;place-items:center;border-radius:10px;color:#ffffff;background:linear-gradient(135deg,var(--coral),var(--amber) 42%,var(--purple));font-weight:950;box-shadow:0 0 28px rgba(216,182,107,.18)}.rail-nav{display:grid;grid-gap:8px;gap:8px}.rail-nav button{display:flex;align-items:center;gap:10px;min-height:44px;padding:0 12px;border-radius:8px;background:transparent;color:#5f526b;text-align:left;font-weight:800}.rail-nav button.active,.rail-nav button:hover{background:rgba(124,58,237,.09);color:var(--purple)}.rail-nav span{display:grid;width:24px;place-items:center}.rail-profile{margin-top:auto;gap:12px;padding:14px;border:1px solid var(--line);border-radius:8px;background:rgba(255,255,255,.78)}.main-stage{min-width:0;overflow-x:hidden}.staff-phone-shell{min-height:100vh;display:grid;place-items:start center;padding:24px}.phone-frame{width:min(1180px,100%);overflow:hidden;border:1px solid var(--line);border-radius:30px;background:radial-gradient(circle at 12% 0,rgba(255,90,102,.12),transparent 28%),radial-gradient(circle at 92% 0,rgba(124,58,237,.12),transparent 32%),rgba(255,255,255,.72);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.mobile-hero{color:var(--ink);background:linear-gradient(135deg,rgba(255,255,255,.86),rgba(255,247,239,.7))}.mobile-brand-row{justify-content:space-between;gap:18px;padding:26px 30px 22px}.hero-clock{display:grid;justify-items:end;grid-gap:4px;gap:4px}.hero-clock strong{color:var(--purple);font-size:1.2rem}.hero-clock span{color:var(--muted);font-size:.86rem;text-align:right}.staff-tabs{display:flex;gap:10px;padding:0 30px 24px;background:transparent}.staff-tabs button{position:relative;min-height:44px;padding:0 14px;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.76);color:var(--muted);font-size:.9rem;font-weight:900}.staff-tabs button.active{color:#ffffff;background:linear-gradient(135deg,var(--coral),var(--purple));border-color:transparent;box-shadow:0 14px 30px rgba(124,58,237,.16)}.staff-tabs button.active:after{display:none}.mobile-content{display:grid;grid-template-columns:minmax(360px,.9fr) minmax(0,1.1fr);grid-gap:18px;gap:18px;padding:24px 20px 32px}.capture-card,.history-card,.identity-card,.leave-create-card,.request-card,.schedule-card,.summary-card,.today-card{border:1px solid rgba(126,167,196,.24);border-radius:24px;background:rgba(255,255,255,.84);color:var(--ink);box-shadow:var(--soft-shadow)}.identity-card{display:grid;grid-template-columns:78px minmax(0,1fr);grid-gap:18px;gap:18px;align-items:center;padding:26px;background:radial-gradient(circle at 92% 12%,rgba(124,58,237,.16),transparent 32%),linear-gradient(135deg,rgba(255,255,255,.92),rgba(255,247,239,.86));grid-row:span 1}.identity-card h2{margin:0 0 10px;font-size:1.5rem}.avatar{display:grid;place-items:center;border-radius:50%;font-weight:950}.avatar.small,.avatar.tiny{color:#ffffff;background:linear-gradient(135deg,var(--coral),var(--purple))}.avatar.small{width:42px;height:42px}.avatar.tiny{width:40px;height:40px;flex:0 0 40px}.avatar.gold{width:74px;height:74px;color:#ffffff;background:linear-gradient(135deg,var(--coral),var(--amber) 42%,var(--purple));font-size:1.35rem}.chip-row{display:flex;flex-wrap:wrap;gap:8px}.count-pill,.soft-chip,.success-chip,.warning-chip,.work-badge{display:inline-flex;align-items:center;min-height:30px;padding:0 11px;border-radius:999px;font-weight:900;white-space:nowrap}.soft-chip{color:var(--purple);background:rgba(124,58,237,.09)}.success-chip{color:#087857;background:rgba(18,168,116,.1)}.warning-chip{color:#985a10;background:rgba(255,159,104,.14)}.capture-card{display:grid;grid-template-columns:180px minmax(0,1fr);grid-gap:16px;gap:16px;padding:18px;grid-row:span 3}.selfie-box{display:grid;grid-gap:8px;gap:8px}.selfie-box img,.selfie-box video,.thumb img{width:100%;height:100%;object-fit:cover}.selfie-box img,.selfie-box video{aspect-ratio:1;border:2px solid rgba(124,58,237,.22);border-radius:22px;background:#fbf8ff;transform:scaleX(-1)}.selfie-box img,.thumb img{transform:none}.mini-button{min-height:30px;border:1px solid var(--line);border-radius:8px;color:var(--muted);background:rgba(255,255,255,.72)}.capture-copy{min-width:0;display:grid;grid-gap:10px;gap:10px;align-content:start}.capture-copy p{margin:0;color:var(--muted)}.capture-copy h3{margin:0;font-size:clamp(1.4rem,3vw,2.1rem);line-height:1.08}.gps-card{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px;border:1px solid var(--line);border-radius:18px;background:rgba(255,249,243,.78)}.gps-card span,.gps-card strong{display:block}.gps-card span{color:var(--muted);font-size:.88rem}.gps-card.ready strong{color:#087857}.gps-card.blocked strong{color:var(--purple)}.gps-card button{min-height:36px;padding:0 10px;border-radius:8px;color:#ffffff;background:linear-gradient(135deg,var(--coral),var(--purple));font-weight:900}.result-banner{min-height:48px;padding:13px 16px;border-radius:14px;font-weight:900}.result-banner.success{color:#54e884;background:rgba(24,169,87,.13);border:1px solid rgba(24,169,87,.3)}.result-banner.danger{color:#ff8787;background:rgba(214,74,74,.12);border:1px solid rgba(214,74,74,.26)}.result-banner.pending{color:#86c8ff;background:rgba(22,136,232,.12);border:1px solid rgba(22,136,232,.24)}.check-actions{display:grid;grid-template-columns:1fr 1fr;grid-gap:14px;gap:14px}.check-button{min-height:68px;border-radius:18px;color:#ffffff;font-size:1.08rem;font-weight:950;box-shadow:0 18px 44px rgba(22,136,232,.2)}.check-button.in{background:linear-gradient(135deg,#27a7ff,#0d74d6)}.check-button.out{color:rgba(255,255,255,.54);border:1px solid rgba(126,167,196,.32);background:rgba(17,35,49,.92);box-shadow:none}.check-button:disabled{opacity:.45}.history-card,.leave-create-card,.request-card,.schedule-card,.summary-card,.today-card{padding:20px}.today-card{grid-column:1/-1}.section-title{justify-content:space-between;gap:12px;margin-bottom:16px}.eyebrow,.section-title span{color:var(--purple);font-size:.76rem;font-weight:950;text-transform:uppercase;letter-spacing:.08em}.section-title strong{color:var(--muted)}.today-table{overflow:hidden;border:1px solid var(--line);border-radius:16px}.today-head,.today-row{display:grid;grid-template-columns:1.2fr .8fr 1fr .8fr 1.1fr;align-items:center;grid-gap:10px;gap:10px;padding:14px}.today-head{color:var(--purple);background:rgba(124,58,237,.08);font-size:.76rem;font-weight:950;text-transform:uppercase}.today-row{color:var(--ink)}.today-row span,.today-row strong{display:block}.thumb{display:grid;width:42px;height:42px;place-items:center;overflow:hidden;border-radius:10px;color:#ffffff;background:linear-gradient(135deg,var(--coral),var(--purple));font-weight:950}.work-badge{justify-content:center;color:var(--muted);background:rgba(124,58,237,.08)}.work-badge.active{color:#087857;background:rgba(18,168,116,.1)}.summary-card strong{display:block;margin-top:6px;color:var(--ink);font-size:2.4rem}.summary-card span{color:var(--muted)}.progress{overflow:hidden;height:9px;margin-top:14px;border-radius:999px;background:rgba(124,58,237,.1)}.progress b{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--coral),var(--purple))}.leave-form,.settings-form{display:grid;grid-gap:12px;gap:12px}label{display:grid;grid-gap:6px;gap:6px;color:var(--muted);font-size:.88rem;font-weight:850}input,select,textarea{width:100%;min-height:44px;border:1px solid rgba(126,167,196,.3);border-radius:10px;color:var(--ink);background:rgba(255,255,255,.86);padding:10px 12px}textarea{resize:vertical}option{color:var(--ink)}.form-grid,.settings-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.primary-action{display:inline-flex;align-items:center;justify-content:center;min-height:46px;border-radius:10px;color:white;background:linear-gradient(135deg,var(--coral),var(--amber) 42%,var(--purple));font-weight:950}.primary-action.compact{padding:0 16px}.checklist-row,.log-row,.request-row,.shift-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 0;border-top:1px solid rgba(126,167,196,.18)}.log-row span,.request-row span,.shift-row span{display:block;color:var(--muted);font-size:.88rem}.log-row em,.request-row em,.shift-row em{color:var(--purple);font-style:normal;font-weight:900;white-space:nowrap}.request-row em.DaDuyet{color:#4be27e}.request-row em.TuChoi{color:#ff8787}.admin-stage,.settings-stage{display:grid;grid-gap:20px;gap:20px;width:min(1440px,100%);margin:0 auto;padding:24px}.admin-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;padding:28px;border-radius:18px;color:var(--ink);background:linear-gradient(135deg,rgba(255,255,255,.99),rgba(236,247,248,.98)),#ffffff;border:1px solid var(--line);box-shadow:var(--soft-shadow);overflow:hidden}.admin-hero,.admin-hero.quiet{min-height:0}.admin-hero h1{max-width:720px;margin:8px 0;font-size:clamp(1.85rem,3vw,2.85rem);line-height:1.08}.admin-hero p{max-width:640px;margin:0;color:var(--muted)}.admin-hero .eyebrow{color:var(--teal)}.hero-stat{display:grid;grid-gap:5px;gap:5px;flex:0 0 176px;padding:18px;border:1px solid #cfe1e5;border-radius:14px;background:#f7fbfc}.hero-stat span{color:var(--muted)}.hero-stat strong{color:var(--blue-2);font-size:2.4rem}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:14px;gap:14px;min-width:0}.metric-card,.panel{min-width:0;border:1px solid var(--line);border-radius:16px;background:var(--panel);box-shadow:var(--soft-shadow)}.metric-card{display:grid;grid-gap:8px;gap:8px;min-height:132px;padding:18px}.metric-card span{color:var(--muted);font-weight:800}.metric-card strong{font-size:2.25rem}.metric-line{overflow:hidden;height:6px;border-radius:999px;background:#e8eef2}.metric-line b{display:block;width:72%;height:100%;border-radius:inherit;background:var(--blue)}.metric-card.green .metric-line b{background:var(--green)}.metric-card.amber .metric-line b{background:var(--amber-2)}.metric-card.red .metric-line b{background:var(--red)}.admin-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,.72fr);grid-gap:16px;gap:16px;align-items:flex-start;min-width:0}.panel{padding:20px}.panel-head{justify-content:space-between;gap:12px;margin-bottom:16px}.panel h2{margin:4px 0 0;font-size:1.22rem}.attendance-pulse{position:relative;overflow:hidden;min-height:260px}.donut{display:grid;width:142px;height:142px;place-items:center;border-radius:999px;background:radial-gradient(circle closest-side,#fff 68%,transparent 70%),conic-gradient(var(--blue) calc(var(--value) * 1%),#dfe8ee 0)}.donut strong{font-size:1.8rem}.donut span{color:var(--muted);font-size:.78rem;margin-top:-38px}.pulse-bars{position:absolute;right:20px;bottom:20px;left:20px;display:flex;height:54px;align-items:flex-end;gap:9px;opacity:.6}.pulse-bars span{width:38px;border-radius:10px 10px 0 0;background:linear-gradient(180deg,#7cc8ff,#1688e8)}.approval-panel,.missing-panel{grid-row:span 2}.approval-list,.payroll-list{display:grid;grid-gap:10px;gap:10px}.approval-item,.missing-row,.payroll-row{display:flex;gap:12px;align-items:center;padding:12px;border:1px solid #e6eef2;border-radius:12px;background:#f8fbfc}.approval-item{align-items:flex-start}.approval-item>div:nth-child(2){min-width:0;flex:1 1}.approval-item p,.approval-item span,.approval-item strong,.missing-row span,.missing-row strong,.payroll-row span,.payroll-row strong{display:block}.approval-item p,.approval-item span,.missing-row span,.payroll-row em,.payroll-row span{color:var(--muted);font-size:.88rem}.approval-item p{margin:5px 0 0}.approval-actions{display:grid;grid-gap:7px;gap:7px}.approval-actions button{min-height:34px;padding:0 12px;border-radius:8px;color:white;background:var(--green);font-weight:900}.approval-actions button.danger{background:var(--red)}.count-pill{color:#8a5a10;background:#fff4d8}.filter-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}.filter-row label{flex:1 1;min-width:150px;color:var(--muted)}.filter-row input,.filter-row select,.settings-stage input{color:var(--ink);background:#ffffff}.payroll-row{justify-content:space-between}.payroll-row b{color:var(--blue-2)}.payroll-row em{font-style:normal}.empty-state{margin:0;padding:18px;border:1px dashed var(--line);border-radius:12px;text-align:center}.empty-state,.settings-stage .panel label{color:var(--muted)}.checklist-panel{display:grid;align-content:start}.checklist-row{color:var(--ink);font-weight:800}@media (max-width:1120px){.product-shell{grid-template-columns:1fr}.side-rail{position:static;height:auto;padding:16px}.rail-nav{grid-template-columns:repeat(3,1fr)}.rail-profile{display:none}.admin-layout,.metric-grid,.mobile-content,.settings-grid{grid-template-columns:1fr}.capture-card,.today-card{grid-row:auto;grid-column:auto}}@media (max-width:640px){.admin-stage,.settings-stage,.staff-phone-shell{padding:0}.phone-frame{width:100%;min-height:100vh;border:0;border-radius:0}.side-rail{display:none}.mobile-brand-row,.phone-status{padding-right:18px;padding-left:18px}.staff-tabs button{font-size:.9rem}.mobile-content{padding:18px 14px 26px}.capture-card,.check-actions,.form-grid,.identity-card,.today-head,.today-row{grid-template-columns:1fr}.today-head{display:none}.admin-hero,.today-row{align-items:flex-start}.admin-hero{min-height:auto;flex-direction:column}.admin-hero,.metric-card,.panel{border-radius:0}.approval-item,.payroll-row{align-items:flex-start;flex-direction:column}}