@import "https://fonts.googleapis.com/css2?family=Noto+Sans+Thai:wght@400;500;600;700&family=Outfit:wght@500;600;700&display=swap";:root{color:#183028;font-synthesis:none;--green-900:#12372a;--green-700:#24634a;--green-100:#e2f1e9;--orange:#ef8b3b;--line:#e3e7e1;--muted:#718078;--shadow:0 9px 30px #1f392d0f;background:#f4f6f2;font-family:Noto Sans Thai,sans-serif}*{box-sizing:border-box}html,body,#root{width:100%;max-width:100%}body{min-width:320px;min-height:100vh;margin:0;overflow-x:hidden}button{font:inherit}button:focus-visible{outline-offset:2px;outline:3px solid #24634a38}.app-shell{grid-template-columns:252px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{background:var(--green-900);color:#fff;z-index:20;flex-direction:column;height:100vh;padding:22px 18px;display:flex;position:sticky;top:0}.brand{align-items:center;gap:11px;padding:0 6px 22px;display:flex}.brand-mark{width:40px;height:40px;color:var(--green-900);background:#f2a65a;border-radius:13px;place-items:center;font:700 17px Outfit;display:grid;box-shadow:inset 0 -4px #00000014}.brand strong{letter-spacing:.1px;font:700 18px Outfit;display:block}.brand span{color:#a9c1b6;text-transform:uppercase;letter-spacing:1.15px;margin-top:2px;font-size:10px;display:block}.workspace-chip{background:#ffffff0e;border:1px solid #ffffff1a;border-radius:12px;align-items:center;gap:9px;margin-bottom:23px;padding:11px;display:flex}.workspace-chip>svg{color:#96aa9f;margin-left:auto}.workspace-chip b,.workspace-chip small{display:block}.workspace-chip b{font-size:12px}.workspace-chip small{color:#a9c1b6;font-size:10px}.workspace-avatar{background:#2d6b51;border-radius:9px;place-items:center;width:31px;height:31px;font:600 11px Outfit;display:grid}.nav-label{color:#759487;text-transform:uppercase;letter-spacing:1px;margin:0 10px 9px;font-size:10px}nav{gap:4px;display:grid}nav button,.sidebar-bottom>button{color:#b7c9c1;cursor:pointer;text-align:left;background:0 0;border:0;border-radius:10px;align-items:center;gap:12px;width:100%;padding:10px 12px;font-size:13px;display:flex}nav button:hover,nav button.active,.sidebar-bottom>button:hover{color:#fff;background:#ffffff17}nav button.active{box-shadow:inset 3px 0 #f2a65a}.nav-count{color:#fff;background:#ef8b3b;border-radius:50%;place-items:center;min-width:21px;height:21px;margin-left:auto;font-size:10px;display:grid}.sidebar-bottom{margin-top:auto}.profile-mini{border-top:1px solid #ffffff1a;align-items:center;gap:9px;margin-top:12px;padding:14px 7px 0;display:flex}.profile-mini>svg{color:#8ea59a;margin-left:auto}.profile-logout{color:#8ea59a;cursor:pointer;background:0 0;border:0;margin-left:auto;padding:6px}.profile-mini b,.profile-mini small{display:block}.profile-mini b{font-size:12px}.profile-mini small{color:#89a095;font-size:10px}.avatar{color:#fff;background:#3f7d61;border-radius:50%;place-items:center;width:32px;height:32px;font-weight:700;display:grid}main{min-width:0}header{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);z-index:10;background:#ffffffe0;align-items:center;height:75px;padding:0 32px;display:flex;position:sticky;top:0}header h1{margin:0;font-size:20px}header p{color:var(--muted);margin:2px 0 0;font-size:11px}.header-actions{align-items:center;gap:12px;margin-left:auto;display:flex}.icon-button{border:1px solid var(--line);color:#53645c;cursor:pointer;background:#fff;border-radius:10px;place-items:center;width:37px;height:37px;display:grid}.notification{position:relative}.notification i{background:#e26942;border:2px solid #fff;border-radius:50%;width:7px;height:7px;position:absolute;top:7px;right:7px}.connection{color:#7b8881;align-items:center;gap:6px;font-size:10px;display:flex}.connection>span{background:#d79a5d;border-radius:50%;width:7px;height:7px}.connection.online>span{background:#4aa579}.content{width:100%;min-width:0;max-width:1480px;margin:0 auto;padding:28px 32px 45px;overflow-x:clip}.welcome{color:#fff;min-height:126px;box-shadow:var(--shadow);background:radial-gradient(circle at 86% 30%,#f2a65a4d,#0000 18%),linear-gradient(115deg,#143d2e,#286047);border-radius:18px;align-items:center;padding:26px 30px;display:flex;overflow:hidden}.welcome h2{margin:7px 0 5px;font-size:24px}.welcome p{color:#c5d8d0;margin:0;font-size:12px}.eyebrow,.section-kicker{text-transform:uppercase;letter-spacing:1.1px;font-size:9px;font-weight:700}.eyebrow{color:#f4b876;align-items:center;gap:5px;display:flex}.welcome-date{background:#ffffff14;border:1px solid #ffffff1f;border-radius:13px;min-width:180px;margin-left:auto;padding:13px 18px}.welcome-date span,.welcome-date strong{display:block}.welcome-date span{color:#a7c0b5;font-size:9px}.welcome-date strong{margin-top:3px;font-size:12px}.metric-grid{grid-template-columns:repeat(4,1fr);gap:15px;margin:17px 0;display:grid}.metric-card,.card,.quick-actions{border:1px solid var(--line);box-shadow:var(--shadow);background:#fff;border-radius:16px}.metric-card{min-height:136px;padding:17px;position:relative}.metric-icon{border-radius:11px;place-items:center;width:37px;height:37px;display:grid;position:absolute;top:15px;right:15px}.metric-icon.green,.approval-icon.green{color:#28714e;background:#e3f2e9}.metric-icon.blue,.approval-icon.blue{color:#39729b;background:#e5f0f7}.metric-icon.orange,.approval-icon.orange{color:#b76628;background:#faecdf}.metric-icon.purple,.approval-icon.purple{color:#765f99;background:#eee9f5}.metric-top{color:var(--muted);font-size:11px;display:flex}.metric-top svg{margin-left:auto}.metric-card>strong{color:#173a2d;margin-top:12px;font:700 30px Outfit;display:block}.metric-card p{color:var(--muted);margin:0;font-size:10px}.metric-card small{margin-top:6px;font-size:9px;display:block}.metric-card small.green{color:#2f8059}.metric-card small.orange{color:#c56a2b}.metric-card small.blue{color:#39729b}.metric-card small.purple{color:#765f99}.dashboard-grid{grid-template-columns:minmax(0,1.45fr) minmax(310px,.75fr);gap:17px;margin-bottom:17px;display:grid}.dashboard-grid.lower{grid-template-columns:repeat(3,minmax(0,1fr))}.card{padding:21px}.card-heading{align-items:flex-start;margin-bottom:16px;display:flex}.card-heading>:last-child{margin-left:auto}.section-kicker{color:#8b9791;margin-bottom:3px;display:block}.card h3,.quick-actions h3{margin:0;font-size:15px}.shift-badge,.quality-pill,.filter-button{color:#28714e;background:#e6f3eb;border:0;border-radius:20px;padding:6px 10px;font-size:9px}.clock-face{text-align:center;padding:5px 0 17px}.clock-face small,.clock-face span{color:var(--muted);font-size:10px;display:block}.clock-face strong{letter-spacing:-1px;color:#173a2d;margin:3px 0;font:700 46px Outfit;display:block}.clock-face span{justify-content:center;align-items:center;gap:4px;display:flex}.check-button{background:var(--green-900);color:#fff;text-align:left;cursor:pointer;border:0;border-radius:13px;align-items:center;gap:12px;width:100%;padding:14px;display:flex;box-shadow:0 8px 18px #12372a26}.check-button.checked{background:#307854}.check-button>span{flex:1}.check-button b,.check-button small{display:block}.check-button b{font-size:12px}.check-button small{color:#b9d0c6;margin-top:2px;font-size:9px}.location-quality{color:#46735f;align-items:center;gap:10px;padding:12px 5px 0;display:flex}.location-quality>div{flex:1}.location-quality b,.location-quality span{display:block}.location-quality b{font-size:10px}.location-quality div span{color:var(--muted);font-size:9px}.text-button,.row-link{color:#397158;cursor:pointer;background:0 0;border:0;align-items:center;font-size:10px;display:flex}.approval-row{text-align:left;cursor:pointer;background:#fff;border:0;border-bottom:1px solid #edf0ec;align-items:center;gap:10px;width:100%;padding:9px 0;display:flex}.approval-row>span:nth-child(2){flex:1}.approval-row b,.approval-row small{display:block}.approval-row b{font-size:11px}.approval-row small{color:var(--muted);margin-top:2px;font-size:9px}.approval-icon{border-radius:10px;place-items:center;width:34px;height:34px;display:grid}.outline-button{color:#315e49;cursor:pointer;background:#fff;border:1px solid #cbd8d1;border-radius:9px;width:100%;margin-top:13px;padding:9px;font-size:10px}.filter-button{color:#66746d;border:1px solid var(--line);background:#f4f6f3}.team-row{border-bottom:1px solid #eef0ed;grid-template-columns:34px 1fr 58px 95px;align-items:center;gap:9px;min-height:55px;display:grid}.person-dot{border-radius:50%;place-items:center;width:31px;height:31px;font-size:10px;font-weight:700;display:grid}.person-dot.green{color:#28714e;background:#e2f1e9}.person-dot.orange{color:#b76628;background:#f9eadb}.person-dot.blue{color:#39729b;background:#e3eef5}.person-dot.purple{color:#765f99;background:#ede8f5}.person-name b,.person-name small{display:block}.person-name b{font-size:13px;line-height:1.35}.person-name small,.person-time{color:var(--muted);font-size:11px}.status-pill{white-space:nowrap;border-radius:20px;justify-self:end;padding:6px 9px;font-size:10px}.status-pill.green{color:#28714e;background:#e6f3eb}.status-pill.orange{color:#b76628;background:#faecdf}.status-pill.blue{color:#39729b;background:#e5f0f7}.status-pill.purple{color:#765f99;background:#eee9f5}.row-link{margin:13px auto 0}.event-list{gap:3px;display:grid}.event-item{border-bottom:1px solid #eef0ed;align-items:center;gap:11px;min-height:59px;display:flex}.event-item>div{flex:1}.event-item b,.event-item span{display:block}.event-item b{font-size:12px;line-height:1.4}.event-item div span{color:var(--muted);margin-top:3px;font-size:10px}.event-date{text-align:center;border-radius:9px;flex:none;width:51px;padding:10px 4px;font-size:10px;font-weight:700}.event-date.orange{color:#b76628;background:#faecdf}.event-date.green{color:#28714e;background:#e6f3eb}.event-date.blue{color:#39729b;background:#e5f0f7}.factory-list{gap:3px;display:grid}.factory-item{color:#263d33;text-align:left;cursor:pointer;background:0 0;border:0;border-bottom:1px solid #eef0ed;align-items:center;gap:9px;width:100%;min-height:61px;padding:8px 0;display:flex}.factory-icon{border-radius:10px;flex:none;place-items:center;width:36px;height:36px;display:grid}.factory-icon.orange{color:#b76628;background:#faecdf}.factory-icon.blue{color:#39729b;background:#e5f0f7}.factory-icon.purple{color:#765f99;background:#eee9f5}.factory-icon.green{color:#28714e;background:#e3f2e9}.factory-info{flex:1;min-width:0}.factory-info b,.factory-info small,.factory-count b,.factory-count small{display:block}.factory-info b{font-size:12px}.factory-info small{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:9px;overflow:hidden}.factory-count{text-align:right;flex:none}.factory-count b{color:#285f48;font:700 13px Outfit}.factory-count small{color:var(--muted);font-size:8px}.quick-actions{grid-template-columns:1.25fr repeat(4,1fr);align-items:center;gap:12px;padding:19px 21px;display:grid}.quick-actions button{border:1px solid var(--line);color:#315e49;text-align:left;cursor:pointer;background:#fbfcfa;border-radius:11px;align-items:center;gap:9px;min-height:56px;padding:10px;display:flex}.quick-actions button:hover{background:#f6faf7;border-color:#a8c4b6}.quick-actions b,.quick-actions small{display:block}.quick-actions b{font-size:9px}.quick-actions small{color:var(--muted);margin-top:2px;font-size:8px}.mobile-bottom-nav,.mobile-more-sheet,.more-backdrop{display:none}.app-loading{background:#f4f6f2;place-content:center;justify-items:center;gap:13px;min-height:100vh;display:grid}.app-loading p{color:var(--muted);margin:0;font-size:13px}.auth-page{background:#f6f7f4;grid-template-columns:minmax(360px,.9fr) minmax(430px,1.1fr);min-height:100vh;display:grid}.auth-brand-panel{color:#fff;background:radial-gradient(circle at 75% 25%,#ef8b3b3d,#0000 25%),linear-gradient(145deg,#103326,#255d45);flex-direction:column;justify-content:space-between;padding:50px clamp(35px,6vw,90px);display:flex}.auth-logo,.auth-mobile-logo{align-items:center;gap:10px;font:700 20px Outfit;display:flex}.auth-logo>span,.auth-mobile-logo>span{color:#173a2d;background:#f2a65a;border-radius:13px;place-items:center;width:42px;height:42px;display:grid}.auth-kicker{color:#e89d58;letter-spacing:1.4px;text-transform:uppercase;font-size:10px;font-weight:700;display:block}.auth-brand-panel h1{margin:12px 0;font-size:clamp(34px,4vw,55px);line-height:1.24}.auth-brand-panel>div:nth-child(2) p{color:#c3d6cd;max-width:530px;font-size:14px;line-height:1.8}.auth-security{background:#ffffff0f;border:1px solid #ffffff1f;border-radius:13px;align-items:center;gap:11px;padding:15px;display:flex}.auth-security b,.auth-security small{display:block}.auth-security b{font-size:11px}.auth-security small{color:#aac0b6;margin-top:2px;font-size:9px}.auth-form-panel{place-items:center;padding:35px;display:grid}.auth-form{border:1px solid var(--line);width:min(420px,100%);box-shadow:var(--shadow);background:#fff;border-radius:22px;padding:38px}.auth-mobile-logo{color:#173a2d;margin-bottom:28px;display:none}.auth-form h2{margin:6px 0 2px;font-size:30px}.auth-form>p{color:var(--muted);margin:0 0 25px;font-size:12px}.auth-form label{color:#455b51;margin-top:15px;font-size:11px;font-weight:600;display:block}.auth-input{color:#718078;border:1px solid #dce3de;border-radius:11px;align-items:center;gap:9px;height:49px;margin-top:6px;padding:0 13px;display:flex}.auth-input:focus-within{border-color:#6b9c84;box-shadow:0 0 0 3px #34745417}.auth-input input{min-width:0;font:inherit;color:#183028;background:0 0;border:0;outline:0;flex:1}.auth-input button{color:#718078;cursor:pointer;background:0 0;border:0}.auth-submit{background:var(--green-900);color:#fff;cursor:pointer;border:0;border-radius:11px;justify-content:center;align-items:center;gap:8px;width:100%;min-height:49px;margin-top:21px;font-weight:700;display:flex}.auth-submit:disabled{opacity:.65}.auth-link,.auth-preview{color:#397158;cursor:pointer;background:0 0;border:0;width:100%;padding:11px;font-size:10px}.auth-preview{color:#7a8881;border-top:1px solid #edf0ed}.auth-message{color:#9b4b32;background:#fff0ea;border-radius:9px;margin-top:13px;padding:10px 11px;font-size:10px}.capture-overlay{z-index:80;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#0b1d169e;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.capture-sheet{background:#fff;border-radius:22px;width:min(520px,100%);max-height:calc(100vh - 30px);padding:22px;overflow:auto;box-shadow:0 25px 80px #04120c4d}.capture-header{-webkit-backdrop-filter:none;backdrop-filter:none;background:0 0;border:0;align-items:flex-start;height:auto;padding:0;display:flex;position:static}.capture-header>button{margin-left:auto}.capture-header span{color:var(--orange);text-transform:uppercase;letter-spacing:1px;font-size:9px;font-weight:700}.capture-header h2{margin:3px 0 0;font-size:20px}.capture-steps{grid-template-columns:repeat(3,1fr);gap:8px;margin:20px 0;display:grid}.capture-steps span{color:#9aa49f;align-items:center;gap:5px;font-size:9px;display:flex}.capture-steps i{background:#edf0ed;border-radius:50%;place-items:center;width:22px;height:22px;font-size:9px;font-style:normal;display:grid}.capture-steps span.active{color:#2d6b51;font-weight:700}.capture-steps span.active i{color:#fff;background:#2d6b51}.capture-stage{text-align:center}.capture-stage h3{margin:11px 0 4px;font-size:18px}.capture-stage>p{max-width:390px;color:var(--muted);margin:0 auto 20px;font-size:11px;line-height:1.65}.location-stage{padding:35px 15px 15px}.capture-hero-icon{color:#2d6b51;background:#e5f2eb;border-radius:20px;place-items:center;width:68px;height:68px;margin:auto;display:grid}.capture-primary,.capture-secondary{cursor:pointer;border-radius:11px;justify-content:center;align-items:center;gap:8px;min-height:48px;padding:0 17px;font-weight:700;display:inline-flex}.capture-primary{color:#fff;background:var(--green-900);border:0}.capture-primary:disabled{opacity:.6}.capture-secondary{color:#436153;background:#fff;border:1px solid #d5ded9}.camera-frame{aspect-ratio:4/5;background:#12241c;border-radius:18px;max-height:480px;position:relative;overflow:hidden}.camera-frame video{object-fit:cover;width:100%;height:100%;transform:scaleX(-1)}.camera-loading{color:#fff;justify-content:center;align-items:center;gap:8px;font-size:11px;display:flex;position:absolute;inset:0}.face-guide{aspect-ratio:.78;border:2px dashed #fff9;border-radius:48%;width:54%;position:absolute;top:12%;left:23%}.location-confirm{color:#327054;align-items:center;gap:8px;width:max-content;max-width:100%;margin:12px auto 0;display:flex}.location-confirm b,.location-confirm small{text-align:left;display:block}.location-confirm b{font-size:10px}.location-confirm small{color:var(--muted);font-size:9px}.camera-shutter{color:#fff;background:var(--green-900);cursor:pointer;border:6px solid #e1ece6;border-radius:50%;place-items:center;width:67px;height:67px;margin:15px auto 8px;display:grid}.camera-hint{margin-bottom:0!important}.photo-preview{aspect-ratio:4/4.3;background:#e7ebe8;border-radius:17px;overflow:hidden}.photo-preview img{object-fit:cover;width:100%;height:100%}.capture-summary{text-align:left;grid-template-columns:1fr 1fr;gap:8px;margin:13px 0;display:grid}.capture-summary>div{background:#f4f6f3;border-radius:9px;padding:10px 11px}.capture-summary span,.capture-summary b{display:block}.capture-summary span{color:var(--muted);font-size:8px}.capture-summary b{margin-top:2px;font-size:10px}.capture-actions{grid-template-columns:.8fr 1.2fr;gap:9px;display:grid}.telegram-note{background:#eef6f1;border-radius:9px;padding:9px;color:#43705b!important;margin:12px auto 0!important;font-size:9px!important}.capture-error{color:#9b4b32;background:#fff0ea;border-radius:9px;margin-top:12px;padding:10px;font-size:10px}.spin{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.attendance-toast{z-index:70;color:#fff;background:#226047;border-radius:13px;align-items:center;gap:9px;max-width:420px;padding:13px;display:flex;position:fixed;bottom:20px;right:20px;box-shadow:0 12px 35px #0c2d2040}.attendance-toast>span{flex:1}.attendance-toast b,.attendance-toast small{display:block}.attendance-toast b{font-size:11px}.attendance-toast small{color:#c5dbd1;margin-top:2px;font-size:9px}.attendance-toast button{color:#fff;background:0 0;border:0}.attendance-toast.attendance-warning{background:#9a6426}.telegram-setup{background:#fff;border-radius:22px;width:min(500px,100%);max-height:calc(100vh - 30px);padding:23px;overflow:auto;box-shadow:0 25px 80px #04120c4d}.telegram-explainer{color:#2d6b51;background:#edf6f1;border-radius:13px;gap:11px;margin:20px 0;padding:14px;display:flex}.telegram-explainer b{font-size:12px}.telegram-explainer p{color:#61756b;margin:3px 0 0;font-size:10px;line-height:1.5}.telegram-setup form>label:not(.telegram-check){color:#4c6056;margin:13px 0;font-size:10px;font-weight:700;display:block}.telegram-setup form>label input[type=text],.telegram-setup form>label:not(.telegram-check) input{width:100%;height:46px;font:inherit;border:1px solid #d8e0db;border-radius:10px;outline:0;margin-top:5px;padding:0 12px}.telegram-check{cursor:pointer;margin:8px 0;display:block}.telegram-check input{opacity:0;position:absolute}.telegram-check span{color:#52675d;border:1px solid #dce3de;border-radius:10px;align-items:center;gap:8px;padding:11px;font-size:10px;display:flex}.telegram-check input:checked+span{color:#28684b;background:#edf6f1;border-color:#8dbba4}.telegram-save{width:100%;margin-top:13px}.telegram-secret-note{color:#567166;border-top:1px solid #edf0ed;align-items:center;gap:9px;margin-top:15px;padding-top:13px;display:flex}.telegram-secret-note b,.telegram-secret-note small{display:block}.telegram-secret-note b{font-size:10px}.telegram-secret-note small{color:var(--muted);margin-top:2px;font-size:8px}.shift-page{gap:17px;width:100%;min-width:0;max-width:100%;display:grid}.shift-hero{color:#fff;width:100%;min-width:0;min-height:135px;box-shadow:var(--shadow);background:linear-gradient(120deg,#153e2f,#316c50);border-radius:18px;align-items:center;padding:25px 28px;display:flex;overflow:hidden}.shift-hero>div{min-width:0}.shift-hero h2{margin:7px 0 4px;font-size:24px}.shift-hero p{color:#c5d8d0;margin:0;font-size:11px}.shift-primary-button{color:#18382b;cursor:pointer;background:#f4ae67;border:0;border-radius:10px;justify-content:center;align-items:center;gap:7px;min-height:43px;margin-left:auto;padding:0 15px;font-size:10px;font-weight:700;display:inline-flex}.shift-overview{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.shift-overview>div{border:1px solid var(--line);color:#397158;box-shadow:var(--shadow);background:#fff;border-radius:13px;align-items:center;gap:11px;padding:15px;display:flex}.shift-overview b,.shift-overview small{display:block}.shift-overview b{color:#18382b;font:700 22px Outfit}.shift-overview small{color:var(--muted);font-size:9px}.shift-section{border:1px solid var(--line);width:100%;min-width:0;max-width:100%;box-shadow:var(--shadow);background:#fff;border-radius:16px;padding:21px;overflow:hidden}.shift-section-heading{align-items:center;margin-bottom:16px;display:flex}.shift-section-heading>:last-child{margin-left:auto}.shift-section-heading h3{margin:0;font-size:16px}.shift-text-button{color:#397158;cursor:pointer;background:0 0;border:0;align-items:center;gap:6px;font-size:10px;display:flex}.shift-type-grid{grid-template-columns:repeat(4,1fr);gap:11px;display:grid}.shift-type-card{border:1px solid var(--line);color:#263d33;text-align:left;cursor:pointer;background:#fbfcfa;border-radius:13px;min-height:174px;padding:15px;position:relative}.shift-type-card.selected{border-color:#79a78f;box-shadow:0 0 0 3px #3e7d5e17}.shift-type-icon{border-radius:11px;place-items:center;width:38px;height:38px;display:grid}.shift-type-icon.green{color:#28714e;background:#e3f2e9}.shift-type-icon.orange{color:#b76628;background:#faecdf}.shift-type-icon.purple{color:#765f99;background:#eee9f5}.shift-type-icon.blue{color:#39729b;background:#e5f0f7}.shift-type-label{color:#66766e;background:#eef1ee;border-radius:20px;padding:4px 7px;font-size:8px;position:absolute;top:15px;right:13px}.shift-type-card>b,.shift-type-card>strong,.shift-type-card>small{display:block}.shift-type-card>b{margin-top:12px;font-size:11px}.shift-type-card>strong{margin:2px 0;font:700 19px Outfit}.shift-type-card>small{color:var(--muted);font-size:8px}.shift-people{color:#397158;align-items:center;gap:4px;margin-top:11px;font-size:9px;display:flex}.week-controls{gap:5px;display:flex}.week-controls button{border:1px solid var(--line);color:#53645c;cursor:pointer;background:#fff;border-radius:8px;place-items:center;height:32px;padding:0 9px;display:grid}.week-controls .today-button{font-size:9px}.schedule-toolbar{gap:8px;margin-bottom:13px;display:flex}.schedule-toolbar label{border:1px solid var(--line);color:#7e8b84;border-radius:9px;align-items:center;gap:7px;min-width:220px;height:36px;padding:0 10px;display:flex}.schedule-toolbar input{min-width:0;font:inherit;border:0;outline:0}.schedule-toolbar button{border:1px solid var(--line);color:#52665c;cursor:pointer;background:#fff;border-radius:9px;align-items:center;gap:6px;min-height:36px;padding:0 11px;font-size:9px;display:flex}.schedule-toolbar .auto-shift-button{color:#fff;border-color:var(--green-900);background:var(--green-900);margin-left:auto}.schedule-scroll{overscroll-behavior-x:contain;width:100%;max-width:100%;padding-bottom:5px;overflow-x:auto}.schedule-grid{grid-template-columns:185px repeat(7,minmax(105px,1fr));gap:5px;min-width:960px;display:grid}.schedule-row{display:contents}.schedule-header{text-align:center;color:#728078;background:#f3f5f2;border-radius:8px;padding:8px;font-size:9px}.schedule-header span,.schedule-header b{display:block}.schedule-header b{color:#263d33;font:700 14px Outfit}.schedule-header.employee-column{text-align:left;align-items:center;font-weight:700;display:flex}.employee-cell{border-bottom:1px solid #eef0ed;align-items:center;gap:8px;min-height:59px;padding:7px;display:flex}.employee-cell>span{color:#347156;background:#e6f1eb;border-radius:50%;place-items:center;width:30px;height:30px;font-size:9px;font-weight:700;display:grid}.employee-cell b,.employee-cell small{display:block}.employee-cell b{font-size:9px}.employee-cell small{color:var(--muted);font-size:8px}.shift-cell{text-align:center;cursor:pointer;border:1px solid #0000;border-radius:8px;min-height:52px;margin:3px 0;padding:6px}.shift-cell b,.shift-cell small{display:block}.shift-cell b{font-size:9px}.shift-cell small{opacity:.75;margin-top:2px;font-size:7px}.shift-cell.day{color:#286b4b;background:#e8f4ed}.shift-cell.early{color:#39729b;background:#e8f2f8}.shift-cell.staggered{color:#b76628;background:#fbede1}.shift-cell.night{color:#70558f;background:#f0ebf6}.shift-cell.off{color:#7a8580;background:#f0f2ef}.shift-cell.leave{color:#3c759d;background:#e8f2f8;border-style:dashed}.schedule-legend{flex-wrap:wrap;gap:12px;margin-top:12px;display:flex}.schedule-legend span{color:#6f7e76;align-items:center;gap:5px;font-size:8px;display:flex}.schedule-legend i{border-radius:3px;width:9px;height:9px}.schedule-legend i.day{background:#a8d1b8}.schedule-legend i.early{background:#a7cde1}.schedule-legend i.staggered{background:#efc19b}.schedule-legend i.night{background:#c4b2d8}.schedule-legend i.leave{background:#8ec2df}.schedule-legend i.off{background:#cdd2ce}.shift-notice{color:#876023;background:#fff9eb;border:1px solid #ead5a8;border-radius:13px;align-items:center;gap:11px;padding:15px 18px;display:flex}.shift-notice>div{flex:1}.shift-notice b{font-size:10px}.shift-notice p{margin:2px 0 0;font-size:8px}.shift-notice button{color:#9a6620;cursor:pointer;background:0 0;border:0;font-size:8px;font-weight:700}.shift-editor{background:#fff;border-radius:22px;width:min(520px,100%);max-height:calc(100vh - 30px);padding:23px;overflow:auto}.shift-editor-form{gap:12px;margin-top:18px;display:grid}.shift-editor-form>label,.time-input-row label{color:#52645b;font-size:9px;font-weight:700}.shift-editor-form input:not([type=checkbox]),.shift-editor-form select{width:100%;height:43px;font:inherit;background:#fff;border:1px solid #d8e0db;border-radius:9px;margin-top:5px;padding:0 10px}.time-input-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.next-day-toggle input{opacity:0;position:absolute}.next-day-toggle>span{border:1px solid #dce3de;border-radius:11px;grid-template-columns:24px 1fr;column-gap:8px;padding:12px;display:grid}.next-day-toggle svg{grid-row:1/3}.next-day-toggle b,.next-day-toggle small{display:block}.next-day-toggle small{color:var(--muted);margin-top:2px;font-size:8px}.next-day-toggle input:checked+span{color:#665080;background:#f3eff8;border-color:#a897c0}.shift-editor-summary{color:#327054;background:#edf6f1;border-radius:10px;align-items:center;gap:8px;padding:11px;display:flex}.shift-editor-summary b,.shift-editor-summary small{display:block}.shift-editor-summary b{font-size:9px}.shift-editor-summary small{margin-top:2px;font-size:8px}.save-shift{color:#fff;background:var(--green-900);width:100%;margin:2px 0 0}.shift-message{color:#994d34;background:#fff0e9;border-radius:10px;padding:11px 13px;font-size:10px}.shift-loading,.shift-empty{min-height:120px;color:var(--muted);justify-content:center;align-items:center;gap:8px;font-size:10px;display:flex}.shift-empty{text-align:center;flex-direction:column}.shift-empty b{color:#314d40;font-size:12px}.shift-empty p{margin:0}.shift-cell.empty{color:#789087;background:0 0;border:1px dashed #cfdad4;align-content:center;place-items:center;display:grid}.assignment-person{background:#f2f5f2;border-radius:11px;align-items:center;gap:9px;margin:18px 0 5px;padding:12px;display:flex}.assignment-person>span{color:#2e6b50;background:#dfeee6;border-radius:50%;place-items:center;width:36px;height:36px;font-weight:700;display:grid}.assignment-person b,.assignment-person small{display:block}.assignment-person b{font-size:11px}.assignment-person small{color:var(--muted);margin-top:2px;font-size:8px}.master-page{gap:17px;width:100%;min-width:0;display:grid}.master-hero{color:#fff;min-height:135px;box-shadow:var(--shadow);background:linear-gradient(120deg,#163c2e,#326c51);border-radius:18px;align-items:center;padding:25px 28px;display:flex}.master-hero h2{margin:7px 0 4px;font-size:24px}.master-hero p{color:#c5d8d0;margin:0;font-size:11px}.master-primary{color:#18382b;cursor:pointer;background:#f4ae67;border:0;border-radius:10px;justify-content:center;align-items:center;gap:7px;min-height:43px;padding:0 15px;font-size:10px;font-weight:700;display:inline-flex}.master-hero .master-primary{margin-left:auto}.master-primary.compact{color:#fff;background:var(--green-900);min-height:37px}.master-primary:disabled{opacity:.65}.master-stats{grid-template-columns:repeat(4,1fr);gap:12px;display:grid}.master-stats>div{border:1px solid var(--line);color:#397158;box-shadow:var(--shadow);background:#fff;border-radius:13px;align-items:center;gap:11px;padding:15px;display:flex}.master-stats b,.master-stats small{display:block}.master-stats b{color:#18382b;font:700 22px Outfit}.master-stats small{color:var(--muted);font-size:9px}.master-panel{border:1px solid var(--line);min-width:0;box-shadow:var(--shadow);background:#fff;border-radius:16px;overflow:hidden}.master-tabs{border-bottom:1px solid var(--line);background:#f8faf7;gap:5px;padding:10px;display:flex;overflow-x:auto}.master-tabs button{color:#718078;cursor:pointer;background:0 0;border:0;border-radius:9px;align-items:center;gap:6px;min-width:max-content;padding:9px 12px;font-size:10px;display:flex}.master-tabs button.active{color:#28654a;background:#fff;box-shadow:0 3px 12px #1e3c2e14}.master-content{padding:22px}.master-content-heading{align-items:flex-start;margin-bottom:17px;display:flex}.master-content-heading>button{margin-left:auto}.master-content-heading h3{margin:0;font-size:17px}.master-content-heading p{color:var(--muted);margin:4px 0 0;font-size:9px}.master-message{color:#994d34;background:#fff0e9;border-radius:10px;margin:14px 20px 0;padding:11px 13px;font-size:10px}.master-loading,.master-empty{min-height:140px;color:var(--muted);justify-content:center;align-items:center;gap:8px;font-size:10px;display:flex}.master-search{border:1px solid var(--line);color:#78877f;border-radius:10px;align-items:center;gap:8px;height:43px;margin-bottom:13px;padding:0 12px;display:flex}.master-search input{min-width:0;font:inherit;border:0;outline:0;flex:1}.employee-directory{display:grid}.employee-directory-row{color:#263d33;text-align:left;cursor:pointer;background:#fff;border:0;border-bottom:1px solid #edf0ed;grid-template-columns:42px minmax(190px,1.4fr) minmax(130px,.9fr) 75px 82px 22px;align-items:center;gap:11px;width:100%;min-height:72px;padding:10px 5px;display:grid}.directory-avatar{color:#2f6b50;background:#e2f1e9;border-radius:50%;place-items:center;width:39px;height:39px;font-weight:700;display:grid}.directory-person b,.directory-person small,.directory-scope b,.directory-scope small{display:block}.directory-person b{font-size:12px}.directory-person b i{color:#7a8981;font-size:9px;font-style:normal;font-weight:500}.directory-person small,.directory-scope small{color:var(--muted);margin-top:2px;font-size:9px}.directory-scope b{font-size:10px}.employment-pill,.record-state{white-space:nowrap;border-radius:20px;justify-self:start;padding:5px 8px;font-size:8px}.employment-pill.daily{color:#b76628;background:#faecdf}.employment-pill.monthly{color:#39729b;background:#e5f0f7}.record-state{color:#28714e;background:#e6f3eb}.record-state.inactive{color:#7b8580;background:#edf0ed}.simple-record-list{display:grid}.simple-record-list>button{color:#263d33;text-align:left;cursor:pointer;background:#fff;border:0;border-bottom:1px solid #edf0ed;grid-template-columns:43px 1fr auto 28px;align-items:center;gap:11px;width:100%;min-height:69px;padding:9px 5px;display:grid}.record-icon{color:#2f6b50;background:#e4f1e9;border-radius:11px;place-items:center;width:39px;height:39px;font-size:10px;font-weight:700;display:grid}.simple-record-list b,.simple-record-list small{display:block}.simple-record-list b{font-size:12px}.simple-record-list small{color:var(--muted);margin-top:2px;font-size:9px}.role-list{gap:9px;display:grid}.role-person{border:1px solid var(--line);border-radius:12px;gap:10px;padding:12px;display:flex}.role-person>div{flex:1;min-width:0}.role-person b,.role-person small{display:block}.role-person b{font-size:11px}.role-person small{color:var(--muted);font-size:8px}.role-chips{flex-wrap:wrap;gap:5px;margin-top:7px;display:flex}.role-chips button,.role-chips>span{color:#306b51;cursor:pointer;background:#e7f3ec;border:0;border-radius:20px;align-items:center;gap:4px;padding:5px 8px;font-size:8px;display:flex}.master-editor{background:#fff;border-radius:22px;width:min(640px,100%);max-height:calc(100vh - 30px);padding:23px;overflow:auto;box-shadow:0 25px 80px #04120c4d}.master-form{gap:12px;margin-top:18px;display:grid}.form-grid{gap:10px;display:grid}.form-grid.two{grid-template-columns:1fr 1fr}.master-field{color:#52645b;min-width:0;font-size:9px;font-weight:700}.master-field>span{margin-bottom:5px;display:block}.master-field input,.master-field select{color:#263d33;width:100%;height:43px;font:inherit;background:#fff;border:1px solid #d8e0db;border-radius:9px;outline:0;padding:0 10px}.master-field input:focus,.master-field select:focus{border-color:#6b9c84;box-shadow:0 0 0 3px #34745417}.active-toggle{color:#7a8580;text-align:left;cursor:pointer;background:#f7f8f6;border:1px solid #dce3de;border-radius:10px;align-items:center;gap:9px;width:100%;padding:11px;display:flex}.active-toggle.active{color:#2f6b50;background:#edf6f1;border-color:#a9caba}.active-toggle b,.active-toggle small{display:block}.active-toggle b{font-size:9px}.active-toggle small{color:var(--muted);margin-top:2px;font-size:8px}.master-save{color:#fff;background:var(--green-900);width:100%;margin-top:15px}.location-help{color:#327054;background:#edf6f1;border-radius:10px;align-items:center;gap:8px;padding:11px;display:flex}.location-help b,.location-help small{display:block}.location-help b{font-size:9px}.location-help small{color:#698078;font-size:8px}@media (width<=1100px){.metric-grid{grid-template-columns:repeat(2,1fr)}.dashboard-grid.lower{grid-template-columns:1fr 1fr}.dashboard-grid.lower .factory-card{grid-column:1/-1}.quick-actions{grid-template-columns:repeat(2,1fr)}.quick-actions>div{grid-column:1/-1}.shift-type-grid{grid-template-columns:1fr 1fr}}@media (width<=820px){.app-shell{display:block}.sidebar{display:none}header{padding:0 18px}.connection{display:none}.content{padding:20px 18px 112px}.dashboard-grid,.dashboard-grid.lower{grid-template-columns:1fr}.dashboard-grid.lower .factory-card{grid-column:auto}.mobile-bottom-nav{z-index:40;left:12px;right:12px;bottom:max(10px, env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#fffffff5;border:1px solid #dae1dbf2;border-radius:21px;grid-template-columns:repeat(5,1fr);min-height:70px;padding:7px 5px 6px;display:grid;position:fixed;box-shadow:0 12px 40px #12372a2e}.mobile-bottom-nav button{color:#829088;cursor:pointer;background:0 0;border:0;border-radius:15px;flex-direction:column;justify-content:center;align-items:center;gap:3px;padding:5px 2px;display:flex}.mobile-bottom-nav button.active{color:var(--green-700);background:#edf6f1}.mobile-bottom-nav small{font-size:9px;font-weight:600}.mobile-nav-icon{place-items:center;height:25px;display:grid;position:relative}.mobile-nav-icon i{background:var(--orange);color:#fff;border:2px solid #fff;border-radius:50%;place-items:center;width:16px;height:16px;font-size:7px;font-style:normal;display:grid;position:absolute;top:-5px;right:-11px}.more-backdrop{z-index:45;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0d201873;border:0;display:block;position:fixed;inset:0}.mobile-more-sheet{z-index:50;padding:8px 18px calc(22px + env(safe-area-inset-bottom));background:#fff;border-radius:25px 25px 0 0;animation:.2s ease-out sheet-up;display:block;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -15px 50px #0d20182e}.sheet-handle{background:#dce2de;border-radius:8px;width:42px;height:4px;margin:0 auto 13px}.sheet-heading{align-items:center;margin-bottom:14px;display:flex}.sheet-heading>button{margin-left:auto}.sheet-heading span{color:var(--orange);text-transform:uppercase;letter-spacing:1px;font-size:8px;font-weight:700}.sheet-heading h2{margin:2px 0 0;font-size:19px}.more-menu-grid{gap:9px;display:grid}.more-menu-grid>button{border:1px solid var(--line);color:#263d33;text-align:left;background:#fbfcfa;border-radius:14px;align-items:center;gap:11px;width:100%;min-height:65px;padding:10px 12px;display:flex}.more-menu-grid>button>span:nth-child(2){flex:1}.more-menu-grid b,.more-menu-grid small{display:block}.more-menu-grid b{font-size:12px}.more-menu-grid small{color:var(--muted);margin-top:2px;font-size:9px}.more-menu-icon{border-radius:12px;place-items:center;width:40px;height:40px;display:grid}.more-menu-icon.orange{color:#b76628;background:#faecdf}.more-menu-icon.green{color:#28714e;background:#e3f2e9}.more-menu-icon.blue{color:#39729b;background:#e5f0f7}.more-menu-icon.purple{color:#765f99;background:#eee9f5}.more-secondary{grid-template-columns:1fr 1fr;gap:9px;margin-top:12px;display:grid}.more-secondary button{color:#53645c;background:#f2f5f2;border:0;border-radius:11px;justify-content:center;align-items:center;gap:7px;padding:11px;font-size:10px;display:flex}@keyframes sheet-up{0%{opacity:.5;transform:translateY(35px)}to{opacity:1;transform:translateY(0)}}.auth-page{background:#fff;display:block}.auth-brand-panel{display:none}.auth-form-panel{min-height:100vh;padding:24px 18px}.auth-form{box-shadow:none;border:0;padding:27px 22px}.auth-mobile-logo{display:flex}.capture-overlay{place-items:end center;padding:0}.capture-sheet{max-height:96vh;padding:19px 17px calc(19px + env(safe-area-inset-bottom));border-radius:24px 24px 0 0}.telegram-setup{max-height:92vh;padding:20px 17px calc(20px + env(safe-area-inset-bottom));border-radius:24px 24px 0 0}.attendance-toast{bottom:92px;left:12px;right:12px}.shift-page{max-width:calc(100vw - 36px)}.shift-hero{padding:21px;display:block}.shift-hero h2{overflow-wrap:anywhere;max-width:100%;font-size:21px;line-height:1.4}.shift-hero p{line-height:1.6}.shift-primary-button{width:100%;max-width:100%;margin:18px 0 0}.shift-overview{grid-template-columns:1fr 1fr;gap:9px}.shift-overview>div{padding:12px}.shift-overview b{font-size:20px}.shift-type-grid{scroll-snap-type:x mandatory;padding-bottom:5px;display:flex;overflow-x:auto}.shift-type-card{scroll-snap-align:start;min-width:220px}.shift-section{padding:17px}.shift-section-heading{align-items:flex-start;min-width:0}.shift-section-heading>div:first-child{min-width:0}.shift-section-heading h3{overflow-wrap:anywhere}.shift-text-button{display:none}.schedule-toolbar{grid-template-columns:1fr 1fr;display:grid}.schedule-toolbar label{grid-column:1/-1;min-width:0}.schedule-toolbar .auto-shift-button{margin:0}.schedule-scroll{margin:0;padding:0 0 7px}.shift-notice{align-items:flex-start}.shift-notice button{display:none}.shift-editor{max-height:94vh;padding:20px 17px calc(20px + env(safe-area-inset-bottom));border-radius:24px 24px 0 0}.master-page{max-width:calc(100vw - 36px)}.master-hero{padding:21px;display:block}.master-hero h2{font-size:21px}.master-hero p{line-height:1.6}.master-hero .master-primary{width:100%;margin:18px 0 0}.master-stats{grid-template-columns:1fr 1fr;gap:9px}.master-stats>div{padding:12px}.master-stats b{font-size:20px}.master-content{padding:17px}.master-content-heading{gap:8px}.master-content-heading .master-primary{padding:0 10px}.employee-directory-row{grid-template-columns:42px minmax(0,1fr) 22px;padding:11px 2px}.directory-scope,.employment-pill,.employee-directory-row>.record-state{display:none}.simple-record-list>button{grid-template-columns:43px minmax(0,1fr) 24px}.simple-record-list .record-state{display:none}.master-editor{max-height:94vh;padding:20px 17px calc(20px + env(safe-area-inset-bottom));border-radius:24px 24px 0 0}}@media (width<=560px){header h1{font-size:17px}.header-avatar{display:none}.welcome{align-items:flex-start;min-height:156px;padding:22px}.welcome h2{font-size:20px;line-height:1.45}.welcome-date{display:none}.metric-grid{grid-template-columns:1fr 1fr;gap:10px}.metric-card{min-height:125px;padding:14px}.metric-card>strong{font-size:27px}.metric-icon{width:33px;height:33px}.card{padding:17px}.clock-face strong{font-size:40px}.team-row{grid-template-columns:32px 1fr 73px}.person-time{display:none}.person-name b{font-size:15px}.person-name small{margin-top:2px;font-size:12px}.status-pill{padding:7px 10px;font-size:11px}.event-item{min-height:70px}.event-item b{font-size:14px}.event-item div span{font-size:12px}.event-date{width:58px;padding:12px 4px;font-size:12px}.factory-item{min-height:73px}.factory-icon{width:43px;height:43px}.factory-info b{font-size:14px}.factory-info small{font-size:11px}.factory-count b{font-size:15px}.factory-count small{font-size:9px}.quick-actions{grid-template-columns:1fr;gap:13px;padding:23px 20px}.quick-actions>div{grid-column:auto;margin-bottom:2px}.quick-actions>div .section-kicker{letter-spacing:1.2px;font-size:12px}.form-grid.two{grid-template-columns:1fr}.quick-actions h3{margin-top:5px;font-size:21px}.quick-actions button{border-radius:15px;gap:15px;min-height:78px;padding:15px 18px}.quick-actions button>svg{flex:none;width:29px;height:29px}.quick-actions b{font-size:16px;line-height:1.35}.quick-actions small{margin-top:3px;font-size:13px;line-height:1.45}}
