:root{font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;--bc-bg: #f4f8fb;--bc-card: rgba(255, 255, 255, .88);--bc-text: #0b1726;--bc-muted: #5f7284;--bc-border: rgba(15, 47, 61, .12);--bc-primary: #0ea5e9;--bc-success: #10b981;--bc-danger: #ef4444;--bc-shadow: 0 18px 42px rgba(15, 23, 42, .12)}*{box-sizing:border-box}html,body,#root{width:100%;min-height:100%}body{margin:0;color:var(--bc-text);background:linear-gradient(135deg,#0ea5e91a,#0ea5e900 44%),linear-gradient(180deg,#ebfbf4,#f8fbff 48%,#eef6ff)}.app-viewport{--mobile-ui-scale: 1;width:100%;min-height:100dvh;overflow-x:hidden}.app-viewport>.app-shell{width:calc(100% / var(--mobile-ui-scale));min-height:calc(100dvh / var(--mobile-ui-scale));transform:scale(var(--mobile-ui-scale));transform-origin:top left}.app-shell{min-height:100dvh;display:flex;flex-direction:column}.app-shell>.header,.app-shell>.main,.app-shell>.app-footer{transition:filter .18s ease,opacity .18s ease}.app-shell.app-shell--notice-active>.header,.app-shell.app-shell--notice-active>.main,.app-shell.app-shell--notice-active>.app-footer{filter:blur(2px);opacity:.95}.header{position:sticky;top:0;z-index:20;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;padding:12px;border-bottom:1px solid var(--bc-border);background:#f6f8fcdb;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.header-left{justify-self:start}.header-center{justify-self:center}.header-right{justify-self:end}.header-logo{display:block;height:clamp(34px,8.8vw,56px);width:auto;max-width:min(420px,68vw);object-fit:contain}.logo-home-btn{border:0;margin:0;padding:0;background:transparent;display:inline-flex;align-items:center;justify-content:center;position:relative;cursor:pointer}.top-nav-btn{border:1px solid var(--bc-border);background:#ffffffd9;color:var(--bc-text);border-radius:14px;min-height:38px;padding:0 12px;font-weight:700;cursor:pointer}.top-nav-btn--icon{width:44px;min-height:44px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:14px}.top-nav-ico{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;color:#475569}.top-nav-ico svg{width:100%;height:100%}.top-nav-btn:disabled{cursor:not-allowed;opacity:.55}.main{flex:1;width:min(760px,100%);margin:0 auto;padding:12px;display:flex;flex-direction:column;gap:12px}.app-footer{width:100%;padding:10px 12px 14px;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:8px;text-align:center;font-family:Trebuchet MS,Gill Sans,sans-serif;font-size:13px;font-weight:800;letter-spacing:.03em;color:#465a72;text-transform:uppercase}.app-footer__version{white-space:nowrap}.connection-status{min-height:28px;display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(15,23,42,.12);border-radius:999px;padding:4px 9px;font:inherit;font-size:11px;font-weight:900;letter-spacing:0;text-transform:none;color:#334155;background:#ffffffb8;box-shadow:0 2px 8px #0f172a14}.connection-status:disabled{cursor:default;opacity:1}.connection-status:not(:disabled){cursor:pointer}.connection-status__dot{width:9px;height:9px;flex:0 0 auto;border-radius:999px;box-shadow:0 0 0 3px #0f172a0f}.connection-status__label{white-space:nowrap}.connection-status__detail{color:#64748b;white-space:nowrap}.connection-status--online .connection-status__dot{background:#16a34a}.connection-status--pending{border-color:#d977063d;color:#92400e;background:#fffbebe0}.connection-status--pending .connection-status__dot{background:#f59e0b}.connection-status--pending .connection-status__detail{color:#92400e}.connection-status--offline{border-color:#dc26263d;color:#991b1b;background:#fef2f2e6}.connection-status--offline .connection-status__dot{background:#dc2626}.connection-status--offline .connection-status__detail{color:#991b1b}.app-shell--login{background-color:#dfeaf5;background-image:linear-gradient(164deg,#ffffff24,#ffffff0a 48%,#1e408029),url(https://images.pexels.com/photos/4440627/pexels-photo-4440627.jpeg?auto=compress&cs=tinysrgb&w=1600);background-size:cover;background-position:center 24%}.header--login{padding:clamp(8px,2.2vh,14px) 12px clamp(4px,1.2vh,10px);border-bottom:0;background:linear-gradient(180deg,#fffc,#ffffff3d);-webkit-backdrop-filter:none;backdrop-filter:none}.header--login .top-nav-btn--icon{width:40px;min-height:40px;border-color:#0f172a29;background:#ffffffd1}.header--login .top-nav-ico{color:#1e293b}.header--login .header-logo{height:clamp(32px,8vw,48px);filter:drop-shadow(0 1px 3px rgba(2,6,18,.28))}.main--login{width:min(460px,100%);padding:clamp(8px,2vh,14px) 12px 10px;gap:10px;justify-content:flex-end}.app-footer--login{padding:6px 12px 10px;font-size:12px;font-weight:900;color:#f8fbfffa;text-shadow:0 1px 2px rgba(2,6,23,.72)}.card{border:1px solid var(--bc-border);border-radius:20px;background:var(--bc-card);box-shadow:var(--bc-shadow);padding:14px}.col{display:flex;flex-direction:column;gap:12px}.title{margin:0 0 8px;font-size:clamp(24px,7vw,34px);font-weight:900;line-height:1.08}.title-small{margin:0 0 8px;font-size:22px;font-weight:900}.muted{color:var(--bc-muted);font-size:14px;line-height:1.4}.box{border:1px solid var(--bc-border);border-radius:16px;background:#ffffffb8;padding:12px}.input{width:100%;border:1px solid rgba(15,23,42,.16);border-radius:14px;background:#fff;color:var(--bc-text);padding:12px;font-size:16px;outline:none}.btn{width:100%;border:0;border-radius:14px;padding:12px 14px;font-size:16px;font-weight:800;line-height:1.15;cursor:pointer}.btn.primary{color:#fff;background:linear-gradient(180deg,#2e5bff,#2144c9)}.btn.action{color:#04270f;background:linear-gradient(180deg,#32d74b,#18b83f)}.btn.secondary{color:var(--bc-text);border:1px solid rgba(15,23,42,.14);background:#0f172a0f}.login-language{margin-top:4px}.login-language__trigger{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:7px 10px;font-size:12px}.login-language__trigger strong{font-size:10px;letter-spacing:.04em}.login-language__list{margin-top:6px;border:1px solid rgba(30,64,128,.14);border-radius:10px;background:#ffffffeb;padding:4px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:4px;max-height:min(30vh,220px);overflow:auto}.login-language__codes{margin-top:4px;font-size:10px;font-weight:800;color:#0f172a9e;letter-spacing:.02em;line-height:1.25;text-align:center}.login-language__item{width:100%;border:1px solid rgba(148,163,184,.22);border-radius:8px;background:#f1f5f9e6;padding:5px 8px;text-align:left;display:flex;align-items:center;gap:6px;min-height:26px;cursor:pointer}.login-language__item.is-active{border-color:#3b82f694;background:#3b82f624}.login-language__item.is-disabled{opacity:.48;cursor:not-allowed}.login-language__code{min-width:24px;font-size:10px;font-weight:900;color:#1f2937}.login-language__name{font-size:11px;line-height:1.2;font-weight:700;color:#0f172a;white-space:nowrap}.login-card{width:min(420px,100%);margin:0 auto;border:1px solid rgba(59,130,246,.34);border-radius:18px;background:linear-gradient(180deg,#ffffffeb,#f8fbffe6);box-shadow:0 18px 36px #0f172a3d;padding:12px}.login-card .title{margin:0 0 8px;font-size:clamp(20px,6.2vw,24px);line-height:1.04;color:#0f172a;text-shadow:0 1px 0 rgba(255,255,255,.45)}.login-box{border:0;border-radius:14px;background:transparent;padding:0}.login-box.col{gap:8px}.login-card .muted{font-size:13px;line-height:1.25;color:#0f172ab8}.login-card .input{border-radius:10px;border:1px solid rgba(30,64,128,.2);background:#ffffffeb;color:#0f172a;padding:10px 12px;font-size:15px}.login-card .input::placeholder{color:#47556994}.login-card .input:focus{border-color:#6592ffd6;box-shadow:0 0 0 2px #2e5bff38}.login-card .btn{border-radius:10px;padding:11px;font-size:16px}.login-card .btn.primary{background:linear-gradient(180deg,#2e5bff,#1f46cc)}.login-card .login-language__trigger{padding:6px 9px;font-size:12px;color:#0f172a;border-color:#1e408033;background:#ffffffe0}.btn-xl{padding:14px 16px}.link-btn{border:0;border-radius:12px;background:transparent;color:var(--bc-text);padding:8px 10px;font-weight:700;cursor:pointer}.notice-box,.error-inline{border-radius:12px;padding:10px 12px;font-size:14px}.notice-box{color:#1a2438;border:1px solid rgba(15,23,42,.16);background:#fffffffa}.notice-muted{color:#334155;border-color:#0f172a29;background:#fffffffa}.notice-bottom-stack{position:fixed;inset:0;padding:16px;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;z-index:120;pointer-events:none}.notice-box--bottom{display:grid!important;grid-template-columns:1fr!important;justify-items:center!important;gap:7px!important;width:min(280px,100%);border-radius:14px;padding:10px;box-shadow:0 14px 28px #0f172a29;-webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px);pointer-events:auto}.notice-box__badge{display:inline-flex;align-items:center;justify-content:center;width:fit-content;border:1px solid rgba(37,99,235,.26);border-radius:999px;background:#2563eb14;color:#1d4ed8;font-size:10px;font-weight:700;padding:2px 8px}.notice-box__text{width:100%!important;text-align:center!important;font-size:clamp(15px,4.2vw,18px);font-weight:900;line-height:1.16}.notice-ok-btn{display:inline-flex!important;align-items:center!important;justify-content:center!important;width:100%!important;min-height:38px!important;border-radius:11px!important;border:1px solid rgba(22,163,74,.52);background:linear-gradient(180deg,#31d65a,#21c64b);color:#052d13;font-size:17px;font-weight:900;line-height:1.05;padding:8px 14px;cursor:pointer;flex:0 0 auto;text-transform:uppercase}.notice-ok-btn:active{transform:translateY(1px)}.error-inline{color:#991b1b;border:1px solid rgba(220,38,38,.28);background:#dc26261f}.home-hero,.scan-glass{border:1px solid var(--bc-border);border-radius:18px;background:#ffffffc7;box-shadow:0 8px 20px #0f172a0f;padding:12px}.home-hero__top{display:flex;align-items:center;justify-content:space-between;gap:12px}.home-hero__label{color:var(--bc-muted);font-size:13px;font-weight:700}.home-hero__time{font-size:clamp(28px,9vw,42px);font-weight:900;line-height:1}.home-actions{display:flex;align-items:center;gap:8px}.home-action{min-width:44px;min-height:44px;border-radius:999px;border:1px solid transparent;font-size:12px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.home-action svg{width:18px;height:18px}.home-action--pause{color:var(--bc-text);border-color:#0f172a24;background:#0f172a0f}.home-action--stop{color:#fff;background:linear-gradient(180deg,#ef4444,#dc2626)}.home-action--play{color:#fff;background:linear-gradient(180deg,#32d74b,#18b83f)}.home-hero__meta{margin-top:10px;display:flex;flex-wrap:wrap;gap:8px}.pill-dark{border:1px solid rgba(15,23,42,.12);border-radius:999px;background:#0f172a0f;color:#1e293b;font-size:12px;font-weight:700;padding:6px 10px}.pill-dark--alert{background:#f59e0b2e;border-color:#f59e0b57}.tile-grid--home,.tile-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.tile{border:1px solid rgba(15,23,42,.1);border-radius:16px;background:#ffffffc7;min-height:118px;padding:12px;text-align:left;display:flex;flex-direction:column;justify-content:space-between;gap:8px;cursor:pointer}.tile-icon{width:34px;height:34px;border-radius:12px;background:#0f172a0f;display:inline-flex;align-items:center;justify-content:center;color:#0f172a}.tile-icon svg{width:20px;height:20px}.tile--success{color:#04270f;border-color:#22c55e47;background:linear-gradient(180deg,#32d74be0,#22c55ee6)}.tile--success .tile-icon{background:#04270f1f;color:#04270f}.tile--placeholder{color:#475569;border-style:dashed;background:#ffffff80}.tile--placeholder .tile-icon{background:#0f172a14;color:#334155}.tile-label{font-size:15px;font-weight:900}.tile-sub{font-size:12px;font-weight:600;opacity:.85}.scan-title{margin:0 0 8px;font-size:20px;font-weight:900}.scan-sub{color:var(--bc-muted);line-height:1.45}.scan-sub--steps{color:#0f172a;background:#22c55e24;border:1px solid rgba(22,163,74,.32);border-radius:12px;padding:10px 12px;line-height:1.35}.scan-sub__important{margin-bottom:6px;font-size:14px;font-weight:900;color:#166534}.scan-steps{margin:0;padding-left:20px;display:grid;gap:4px;font-size:14px;font-weight:700;color:#0f172a}.scan-steps li::marker{color:#166534;font-weight:900}.checklist-wrap{gap:8px}.checklist-item{display:flex;align-items:flex-start;gap:10px;font-size:15px;font-weight:600;color:#0f172a;line-height:1.35}.checklist-item input[type=checkbox]{margin-top:2px;width:18px;height:18px}.checklist-close-row{display:flex;flex-direction:column;gap:8px;border-top:1px dashed rgba(15,23,42,.16);padding-top:8px}.checklist-close-row:first-of-type{border-top:0;padding-top:0}.list-month-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.day-group{border-top:1px solid var(--bc-border);padding-top:12px}.day-title{display:flex;align-items:baseline;gap:8px}.day-number{font-size:34px;font-weight:900;line-height:1}.day-week{color:var(--bc-muted);font-size:14px;font-weight:700}.event-card{margin-top:8px;padding:10px 12px;border-radius:12px;display:flex;align-items:center;justify-content:space-between;gap:10px}.event-card--start{background:#22c55e29}.event-card--stop{background:#ef444429}.event-badge{font-weight:800}.summary-row{border-radius:12px;border:1px solid var(--bc-border);background:#ffffffb3;padding:10px 12px;display:flex;align-items:center;justify-content:space-between;gap:10px}.summary-value{border:1px solid rgba(15,23,42,.12);border-radius:10px;background:#fff;font-weight:800;padding:6px 10px}.summary-panel{border:1px solid rgba(24,96,94,.14);border-radius:18px;background:linear-gradient(180deg,#fffffff5,#f6fcfce0);box-shadow:0 10px 24px #0f303a1a;padding:10px}.summary-toolbar{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:6px}.summary-nav{min-width:48px;min-height:28px;border:1px solid rgba(24,96,94,.14);border-radius:999px;background:#ffffffc7;color:#145246;font-size:10px;box-shadow:0 4px 10px #0f303a0d}.summary-title-block{min-width:0;display:grid;justify-items:center;gap:2px;text-align:center}.summary-title-block span{color:#25816b;font-size:8px;font-weight:900;letter-spacing:.08em;text-transform:uppercase}.summary-title-block strong{max-width:150px;color:#102033;font-size:14px;line-height:1.14}.summary-period{display:grid;grid-template-columns:32px minmax(0,1fr) 32px;align-items:center;gap:6px;border:1px solid rgba(24,96,94,.12);border-radius:14px;background:#f7fcfbeb;padding:6px}.summary-period__btn{width:28px;height:28px;border:1px solid rgba(24,96,94,.14);border-radius:10px;background:#ffffffd1;color:#145246;font-size:18px;font-weight:900;line-height:1;cursor:pointer}.summary-period__label{min-width:0;display:grid;justify-items:center;gap:2px;text-align:center}.summary-period__label span{color:#5f7284;font-size:9px;font-weight:800}.summary-period__label strong{color:#102033;font-size:15px;font-weight:900;text-transform:capitalize}.summary-metrics{display:grid;grid-template-columns:1fr;gap:7px}.summary-metric{min-height:44px;border:1px solid rgba(24,96,94,.12);border-radius:13px;background:#ffffffd1;box-shadow:0 5px 12px #0f303a0d;padding:8px 10px;display:flex;align-items:center;justify-content:space-between;gap:12px}.summary-metric span{color:#527168;font-size:12px;font-weight:900}.summary-metric strong{color:#102033;font-size:16px;font-weight:900;line-height:1;white-space:nowrap}.summary-metric--primary{order:-1;min-height:48px;border-color:#12816738;background:linear-gradient(180deg,#effbf7f5,#ffffffeb);box-shadow:0 6px 16px #108d7314}.summary-metric--primary span,.summary-metric--primary strong{color:#0f5f4f}.summary-metric--primary strong{font-size:19px}.summary-details-btn{min-height:40px;color:#0f4d42!important;font-size:14px;font-weight:900}.summary-details-panel{border:1px solid rgba(24,96,94,.14);border-radius:18px;background:#ffffffeb;box-shadow:0 10px 24px #0f303a1a;padding:10px}.summary-toolbar--details .summary-title-block strong{max-width:136px}.summary-period--compact{margin-top:-1px}.summary-day-list{display:grid;gap:7px}.summary-day-row{min-height:42px;border:1px solid rgba(24,96,94,.12);border-radius:13px;background:linear-gradient(180deg,#ffffffe6,#f8fcfbe0);box-shadow:0 5px 12px #0f303a0b;padding:7px 9px;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:7px}.summary-day-row span{min-width:22px;color:#102033;font-size:14px;font-weight:800}.summary-day-row strong{min-width:0;color:#5a6f7a;font-size:11px;font-weight:900;letter-spacing:.03em;text-transform:uppercase;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.summary-day-row em{min-width:70px;border:1px solid rgba(24,96,94,.12);border-radius:10px;background:#ffffffdb;color:#0f5f4f;font-style:normal;font-size:14px;font-weight:900;line-height:1;text-align:center;padding:7px 8px;white-space:nowrap}.schedule-sync-meta{font-size:12px;line-height:1.3;color:var(--bc-muted);margin-top:-2px}.schedule-panel{border:1px solid rgba(24,96,94,.14);border-radius:18px;background:#ffffffeb;box-shadow:0 10px 24px #0f303a1a;padding:10px}.schedule-toolbar .summary-title-block strong{max-width:120px}.schedule-worker-card{border:1px solid rgba(24,96,94,.12);border-radius:14px;background:linear-gradient(180deg,#ffffffeb,#f8fcfbdb);padding:9px 10px;display:grid;gap:5px}.schedule-worker-card div{display:flex;align-items:center;justify-content:space-between;gap:10px}.schedule-worker-card span,.schedule-status-row span,.schedule-shift-label{color:#5f7284;font-size:12px;font-weight:850}.schedule-worker-card strong{min-width:0;color:#0f5f4f;font-size:14px;font-weight:900;text-align:right}.schedule-worker-card small{color:#78909a;font-size:10px;font-weight:800}.schedule-day-switch{display:grid;grid-template-columns:32px minmax(0,1fr) 32px;align-items:center;gap:6px;border:1px solid rgba(24,96,94,.12);border-radius:14px;background:#f7fcfbeb;padding:6px}.schedule-day-switch__label{min-width:0;display:grid;justify-items:center;gap:2px;text-align:center}.schedule-day-switch__label strong{color:#102033;font-size:15px;font-weight:900;text-transform:capitalize}.schedule-day-switch__label span{color:#5f7284;font-size:12px;font-weight:800}.schedule-day-card{border:1px solid rgba(24,96,94,.12);border-radius:16px;background:linear-gradient(180deg,#fffffff0,#f8fcfbe0);box-shadow:0 8px 18px #0f303a0f;padding:10px;display:grid;gap:8px}.schedule-status-row{min-height:40px;display:flex;align-items:center;justify-content:space-between;gap:12px}.schedule-status-row strong{color:#102033;font-size:19px;font-weight:900}.schedule-shift-list{display:grid;gap:7px}.schedule-shift-card{border:1px solid rgba(24,96,94,.12);border-radius:13px;background:#ffffffd1;padding:8px 10px;display:grid;gap:4px}.schedule-shift-card strong{color:#102033;font-size:14px;font-weight:900;line-height:1.28}.schedule-shift-card small{color:#5f7284;font-size:12px;font-weight:750;line-height:1.28}.schedule-hint{color:#78909a;font-size:11px;font-weight:800;line-height:1.3;text-align:center}.schedule-extended-work-notice,.schedule-extended-work-chip{border:1px solid rgba(37,99,235,.24);background:#2563eb14;color:#143c8a}.schedule-extended-work-notice{border-radius:14px;display:grid;gap:4px;padding:10px 12px}.schedule-extended-work-notice strong{font-size:13px;font-weight:900}.schedule-extended-work-notice span{font-size:13px;line-height:1.35;font-weight:700}.schedule-extended-work-chip{border-radius:999px;display:inline-flex;font-size:12px;font-weight:800;line-height:1.25;padding:6px 9px}.row-inline{display:flex;align-items:center;gap:10px}.textarea{width:100%;min-height:110px;border:1px solid rgba(15,23,42,.16);border-radius:14px;background:#fff;color:var(--bc-text);padding:10px 12px;font-size:15px;resize:vertical}.scan-video{width:100%;border-radius:14px;border:1px solid rgba(15,23,42,.16);background:#0f172a;aspect-ratio:1 / 1;max-height:240px;object-fit:cover}.scan-status{min-height:20px;color:var(--bc-muted);font-size:13px}.scan-manual{background:#ffffffd1}.modal{position:fixed;inset:0;z-index:180;background:#0f172a73;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:16px}.modal-content{width:min(500px,100%);border:1px solid rgba(15,23,42,.16);border-radius:16px;background:#fffffffc;box-shadow:0 18px 40px #0f172a38;overflow:hidden}.modal-content:before{content:"Best Clean";display:inline-flex;align-items:center;justify-content:center;width:fit-content;margin:12px 12px 0;border:1px solid rgba(37,99,235,.26);border-radius:999px;background:#2563eb14;color:#1d4ed8;font-size:12px;font-weight:700;padding:4px 10px}.version-popup:before{content:none}.version-popup{width:min(360px,100%);padding:14px;display:grid;gap:10px}.version-popup__badge{display:inline-flex;align-items:center;justify-content:center;width:fit-content;border:1px solid rgba(37,99,235,.26);border-radius:999px;background:#2563eb14;color:#1d4ed8;font-size:12px;font-weight:700;padding:4px 10px}.version-popup__title{font-size:26px;font-weight:900;line-height:1.06;letter-spacing:-.02em}.version-popup__text{color:#475569;font-size:15px;line-height:1.4;margin-bottom:2px}.version-popup__hint{display:grid;gap:6px;font-size:13px;color:#334155;padding:10px 12px;border:1px solid rgba(15,23,42,.12);border-radius:12px;background:#f8fafcf2}.scan-modal-content{width:min(410px,100%);max-height:82vh}.close-zone-modal{width:min(460px,100%);max-height:82vh}.close-zone-modal--workday{width:min(334px,calc(100% - 30px));max-height:74vh;border-radius:17px;box-shadow:0 18px 46px #02061738}.close-zone-modal--workday:before{margin:10px 10px 0;font-size:10px;padding:2px 8px}.close-camera-modal{width:min(460px,100%);max-height:82vh}.close-zone-body{max-height:calc(82vh - 64px);overflow-y:auto}.close-zone-body--workday{max-height:calc(74vh - 54px);gap:8px;padding:10px}.close-zone-modal--workday .modal-header{padding:8px 10px;gap:8px}.close-zone-modal--workday .modal-title{font-size:15px;line-height:1.16}.close-zone-modal--workday .link-btn{min-height:30px;border-radius:10px;padding:5px 10px;font-size:12px}.close-zone-body--workday>.muted{color:#5f7284;font-size:12px;line-height:1.3}.close-zone-body--workday .box{border-radius:13px;padding:8px;gap:6px}.close-zone-body--workday .box .muted{font-size:11px;line-height:1.25}.close-zone-body--workday .close-zone-textarea{min-height:72px;max-height:94px;border-radius:12px;padding:8px 10px;font-size:13px;resize:none}.close-zone-body--workday .close-zone-confirm{min-height:40px;border-radius:12px;font-size:14px;padding:8px 12px;text-transform:none}.close-camera-body{max-height:calc(82vh - 64px)}.close-camera-video{width:100%;aspect-ratio:4 / 3;border-radius:14px;background:#0f172a;object-fit:cover;border:1px solid rgba(148,163,184,.4)}.close-camera-preview{width:100%;aspect-ratio:4 / 3;border-radius:14px;object-fit:cover;border:1px solid rgba(148,163,184,.4)}.close-camera-actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.row-between{display:flex;align-items:center;justify-content:space-between;gap:10px}.close-zone-attachments{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.close-zone-attachment{display:grid;gap:8px}.close-zone-photo-preview{width:100%;aspect-ratio:4 / 3;object-fit:cover;border-radius:12px;border:1px solid rgba(15,23,42,.14)}.btn-sm{min-height:34px;padding:6px 10px;font-size:13px}.modal-header{padding:11px 12px;border-bottom:1px solid rgba(15,23,42,.12);display:flex;align-items:center;justify-content:space-between;gap:12px}.modal-title{font-size:17px;font-weight:900}.modal-body{padding:12px}.modal .btn.primary,.modal .btn.action{border-radius:12px;border:1px solid rgba(22,163,74,.5);background:linear-gradient(180deg,#31d65a,#21c64b);color:#052d13;font-size:18px;font-weight:900;line-height:1.12;min-height:48px;padding:10px 16px;text-transform:uppercase;box-shadow:none}.modal .btn.secondary{border-radius:14px;border:1px solid rgba(15,23,42,.18);background:#fffffff5;color:#1f2937;box-shadow:none}.modal .link-btn{border:1px solid rgba(15,23,42,.16);border-radius:12px;background:#fffffff5;color:#1f5f4c}.scan-modal-body{max-height:calc(78vh - 64px);overflow-y:auto;scrollbar-width:thin}.scan-modal-body::-webkit-scrollbar{width:8px}.scan-modal-body::-webkit-scrollbar-thumb{border-radius:999px;background:#3b82f659}.scan-modal-body::-webkit-scrollbar-track{background:#94a3b82e}.settings-sheet .modal-body{display:grid;gap:10px}.settings-item{border:1px solid var(--bc-border);border-radius:12px;background:#ffffffbf;color:var(--bc-text);text-align:left;font:inherit;font-weight:700;padding:12px}.settings-item small{display:block;margin-top:4px;color:var(--bc-muted);font-weight:500}.settings-item--danger{border-color:#dc262657;background:#dc26261f}.settings-language{display:grid;gap:6px}.settings-language__trigger{width:100%}.settings-language__list{margin-top:0}.settings-scale__actions{margin-top:10px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.settings-scale__btn{min-height:38px;border:1px solid rgba(100,116,139,.28);border-radius:10px;background:#ffffffe6;color:var(--bc-text);font:inherit;font-weight:700;cursor:pointer}.settings-scale__btn.is-active{border-color:#2e5bff6b;background:#2e5bff24;color:#1f4ad9}.global-busy-overlay{position:fixed;inset:0;z-index:220;background:#0f172a80;display:grid;place-items:center;padding:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.global-busy-content{display:grid;place-items:center;gap:6px;text-align:center;padding:12px 16px;border-radius:14px;border:1px solid rgba(255,255,255,.28);background:#0f172ad1;box-shadow:0 14px 32px #02061761}.global-busy-spinner{width:44px;height:44px;border-radius:999px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;animation:global-spin .82s linear infinite}.global-busy-text{color:#fff;font-size:13px;font-weight:800;line-height:1.32;text-shadow:0 1px 1px rgba(2,6,23,.35);max-width:250px}@keyframes global-spin{to{transform:rotate(360deg)}}.app-shell:not(.app-shell--login){--bc-bg: #f1faf7;--bc-card: rgba(255, 255, 255, .9);--bc-text: #102033;--bc-muted: #5c7180;--bc-border: rgba(24, 96, 94, .15);--bc-primary: #0ea5e9;--bc-success: #12b981;--bc-danger: #ef4444;--bc-shadow: 0 18px 44px rgba(15, 48, 58, .14);position:relative;overflow:hidden;background:linear-gradient(135deg,#0bb88e2e,#0bb88e00 42%),linear-gradient(225deg,#0ea5e924,#0ea5e900 48%),linear-gradient(180deg,#ecfbf4,#f8fbff 54%,#edf6ff)}.app-shell:not(.app-shell--login):before,.app-shell:not(.app-shell--login):after{content:none}.app-shell:not(.app-shell--login):before{width:auto;height:auto;left:auto;top:auto;background:none}.app-shell:not(.app-shell--login):after{width:auto;height:auto;right:auto;bottom:auto;background:none}.app-shell:not(.app-shell--login)>.header,.app-shell:not(.app-shell--login)>.main,.app-shell:not(.app-shell--login)>.app-footer{position:relative;z-index:1}.app-shell:not(.app-shell--login) .header{padding:8px 12px;border-bottom:1px solid rgba(24,96,94,.14);background:#f7fffcc2;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:0 10px 28px #0f303a14}.app-shell:not(.app-shell--login) .header-logo{position:relative;z-index:1;width:86px;height:auto;max-width:none;filter:saturate(1.12) contrast(1.06);mix-blend-mode:multiply}.app-shell:not(.app-shell--login) .logo-home-btn{width:108px;min-height:38px;padding:6px 10px;border:1px solid rgba(24,96,94,.14);border-radius:16px;background:linear-gradient(135deg,#fffffff5,#effaf8d1),linear-gradient(180deg,#fffc,#d2f4ec85);box-shadow:0 12px 24px #0f303a1a,inset 0 1px #ffffffdb;overflow:hidden}.app-shell:not(.app-shell--login) .logo-home-btn:after{content:"";position:absolute;inset:1px;border-radius:15px;background:linear-gradient(135deg,rgba(255,255,255,.5),transparent 48%,rgba(56,189,248,.08));pointer-events:none}.app-shell:not(.app-shell--login) .logo-home-btn:active{transform:translateY(1px)}.app-shell:not(.app-shell--login) .top-nav-btn{border-color:#18605e29;background:#ffffffd1;color:#11483d;box-shadow:0 8px 18px #0f303a14}.app-shell:not(.app-shell--login) .top-nav-btn--icon{width:38px;min-height:38px;border-radius:12px}.app-shell:not(.app-shell--login) .top-nav-ico{color:#14715d}.app-shell:not(.app-shell--login) .main{gap:10px;padding:12px 14px 10px}.app-shell:not(.app-shell--login) .app-footer{color:#21705f;text-shadow:0 1px 0 rgba(255,255,255,.65)}.app-shell:not(.app-shell--login) .connection-status{border-color:#18605e24;background:#ffffffd1;box-shadow:0 8px 18px #0f303a1a}.app-shell:not(.app-shell--login) .card{border-radius:20px;border-color:#18605e26;background:linear-gradient(180deg,#fffffff5,#f6fcfce6);box-shadow:var(--bc-shadow)}.app-shell:not(.app-shell--login) .home-hero,.app-shell:not(.app-shell--login) .scan-glass{border-radius:20px;border-color:#18605e24;background:linear-gradient(180deg,#fffffff5,#f6fcfce0);box-shadow:0 16px 34px #0f303a1f}.app-shell:not(.app-shell--login) .home-hero__label{color:#467066;letter-spacing:.01em}.app-shell:not(.app-shell--login) .home-hero__time{color:#0b1726;font-size:clamp(30px,8.4vw,40px);letter-spacing:0}.app-shell:not(.app-shell--login) .home-actions{gap:9px}.app-shell:not(.app-shell--login) .home-action{min-width:42px;min-height:42px;border-radius:14px;box-shadow:0 12px 24px #0f303a1a}.app-shell:not(.app-shell--login) .home-action--pause{color:#0f4d42;border-color:#18605e29;background:linear-gradient(180deg,#fffffff5,#e8f2f1eb)}.app-shell:not(.app-shell--login) .home-action--stop{color:#fff;background:linear-gradient(180deg,#ff505c,#e11d48)}.app-shell:not(.app-shell--login) .home-action--play{color:#05291f;background:linear-gradient(180deg,#49e39f,#12b981)}.app-shell:not(.app-shell--login) .btn{min-height:48px;border-radius:16px;border:1px solid transparent;box-shadow:0 14px 28px #0f303a1f}.app-shell:not(.app-shell--login) .btn.primary,.app-shell:not(.app-shell--login) .btn.action{color:#05291f;background:linear-gradient(135deg,#4be3a0,#17c98b 48%,#38bdf8)}.app-shell:not(.app-shell--login) .btn.secondary{color:#164f44;border-color:#18605e26;background:#ffffffd1;box-shadow:0 8px 18px #0f303a14}.app-shell:not(.app-shell--login) .pill-dark{color:#124c41;border-color:#18605e24;background:#f5fffcd6;box-shadow:inset 0 1px #ffffffa3}.app-shell:not(.app-shell--login) .pill-dark--alert{border-color:#f59e0b4d;background:#fcecc4ad}.app-shell:not(.app-shell--login) .tile{min-height:112px;border-radius:18px;border-color:#18605e24;background:linear-gradient(180deg,#fffffff0,#f4fafae6);box-shadow:0 14px 28px #0f303a1a}.app-shell:not(.app-shell--login) .tile-icon{background:#0ea5e91f;color:#0f6c85}.app-shell:not(.app-shell--login) .tile--success{border-color:#12b9816b;color:#05291f;background:linear-gradient(135deg,#5de7aa,#21cf90 54%,#5fc8ff)}.app-shell:not(.app-shell--login) .tile--success .tile-icon{background:#ffffff61;color:#0f4535}.app-shell:not(.app-shell--login) .tile--placeholder{color:#5e8076;border-color:#5ea28a3d;background:#f5fdf9cc}.app-shell:not(.app-shell--login) .scan-sub--steps{color:#124c41;border-color:#12b9813d;background:linear-gradient(180deg,#e7fcf3eb,#f1faffdb)}.app-shell:not(.app-shell--login) .scan-sub__important{color:#1c624d}.app-shell:not(.app-shell--login) .scan-steps,.app-shell:not(.app-shell--login) .scan-sub{color:#466d62}.app-shell:not(.app-shell--login) .scan-steps li::marker{color:#2c7c62}.app-shell:not(.app-shell--login) .notice-box{color:#1a2438;border-color:#0f172a29;background:#fffffffa}.app-shell:not(.app-shell--login) .notice-muted{color:#334155;border-color:#0f172a29;background:#fffffffa}.app-shell:not(.app-shell--login) .notice-ok-btn{min-height:38px!important;border-radius:11px!important;border-color:#12b9817a;background:linear-gradient(135deg,#49e39f,#21cf90 54%,#38bdf8);color:#05291f;box-shadow:0 10px 20px #10b9812e}.notice-bottom-stack .notice-box.notice-box--bottom{width:min(280px,calc(100% - 28px));border-radius:14px;background:#fffffff5!important;border-color:#18605e24!important;box-shadow:0 18px 42px #0f303a33}.notice-bottom-stack .notice-box.notice-box--bottom .notice-box__text{text-align:center!important}.notice-bottom-stack .notice-box.notice-box--bottom .notice-ok-btn{border-radius:11px!important}.app-shell:not(.app-shell--login) .link-btn{color:#2a725c}.app-shell:not(.app-shell--login) .event-card--start{background:#93e5c566}.app-shell:not(.app-shell--login) .event-card--stop{background:#f7afaf57}.app-shell:not(.app-shell--login) .summary-row{border-color:#5fa88c3d;background:#f8fffcdb}.app-shell:not(.app-shell--login) .summary-value{border-color:#5fa88c42;background:#fffffff0;color:#1f5f4c}.app-shell:not(.app-shell--login) .modal{background:#0f172a7a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.app-shell:not(.app-shell--login) .modal-content{border-color:#18605e29;border-radius:20px;background:#fffffffa;box-shadow:0 28px 70px #02061747}.app-shell:not(.app-shell--login) .modal .btn.primary,.app-shell:not(.app-shell--login) .modal .btn.action{min-height:50px;border-color:#12b9817a;background:linear-gradient(135deg,#49e39f,#21cf90 54%,#38bdf8);color:#05291f}.app-shell:not(.app-shell--login) .close-zone-modal--workday{width:min(334px,calc(100% - 30px));max-height:74vh;border-radius:17px;box-shadow:0 18px 46px #02061738}.app-shell:not(.app-shell--login) .close-zone-body--workday .close-zone-confirm{min-height:40px;border-radius:12px;font-size:14px;padding:8px 12px;text-transform:none}.app-shell:not(.app-shell--login) .settings-item{border-color:#0f172a29;background:#f8fafcf5}.app-shell:not(.app-shell--login) .modal-header{border-bottom-color:#0f172a1f}.app-shell:not(.app-shell--login) .version-popup__hint,.app-shell:not(.app-shell--login) .scan-manual{border-color:#0f172a24;background:#f8fafcf2}@media(max-height:760px){.header--login{padding-top:8px;padding-bottom:4px}.main--login{padding-top:6px;padding-bottom:8px;gap:8px}.login-card{padding:10px;border-radius:16px}.login-card .title{font-size:clamp(18px,6vw,21px);margin-bottom:6px}.login-language__list{max-height:min(24vh,180px)}}@media(max-width:540px){.tile-grid{grid-template-columns:1fr}.tile-grid--home{grid-template-columns:repeat(2,minmax(0,1fr))}.row-inline{flex-direction:column;align-items:stretch}.close-zone-attachments{grid-template-columns:1fr}}@media(max-width:340px){.tile-grid--home{grid-template-columns:1fr}}
