.home{gap:var(--space-4);flex-direction:column;width:100%;max-width:1400px;margin:0 auto;display:flex}.home-greeting{flex-direction:column;gap:2px;display:flex}.home-greeting-hi{font-family:var(--font-display);font-size:clamp(var(--text-xl), 2vw, var(--text-2xl));color:var(--text-primary);letter-spacing:-.02em;font-weight:800;line-height:1.1}.home-greeting-date{font-size:var(--text-sm);color:var(--text-tertiary);font-weight:400}.kpi-grid{gap:clamp(10px, 1vw, var(--space-4));grid-template-columns:repeat(2,1fr);display:grid}@media (min-width:640px){.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}}.kpi-card{background:var(--surface-raised);border-radius:var(--radius-lg);border:1px solid var(--surface-sunken);padding:var(--space-4);box-shadow:var(--shadow-sm);gap:var(--space-2);flex-direction:column;animation:.5s cubic-bezier(.175,.885,.32,1.275) both kpi-in;display:flex;position:relative;overflow:hidden}.dark .kpi-card{background:var(--surface);border-color:#ffffff0f}@keyframes kpi-in{0%{opacity:0;transform:translateY(12px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.kpi-card:first-child{animation-delay:0s}.kpi-card:nth-child(2){animation-delay:60ms}.kpi-card:nth-child(3){animation-delay:.12s}.kpi-card:nth-child(4){animation-delay:.18s}.kpi-card:before{content:"";border-radius:var(--radius-lg) var(--radius-lg) 0 0;height:3px;position:absolute;top:0;left:0;right:0}.kpi-card[data-tone=primary]:before{background:var(--gradient-cta)}.kpi-card[data-tone=success]:before{background:var(--status-complete)}.kpi-card[data-tone=warning]:before{background:var(--status-alert)}.kpi-card[data-tone=secondary]:before{background:var(--secondary-container)}.kpi-label{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.kpi-value{font-family:var(--font-display);color:var(--text-primary);letter-spacing:-.02em;font-variant-numeric:tabular-nums;font-size:clamp(22px,2.4vw,28px);font-weight:800;line-height:1}.kpi-value small{font-size:var(--text-base);color:var(--text-secondary);margin-left:2px;font-weight:500}.kpi-trend{align-items:center;gap:var(--space-1);font-size:var(--text-xs);font-variant-numeric:tabular-nums;width:-moz-fit-content;width:fit-content;font-weight:600;display:inline-flex}.kpi-trend.up{color:var(--status-complete)}.kpi-trend.down{color:var(--status-alert)}.kpi-trend .material-symbols-outlined{font-size:14px}.home-section-title{font-family:var(--font-display);font-size:var(--text-sm);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.07em;margin-bottom:var(--space-1);font-weight:700}.qa-row{gap:var(--space-3);padding-bottom:var(--space-1);scrollbar-width:none;-ms-overflow-style:none;display:flex;overflow-x:auto}.qa-row::-webkit-scrollbar{display:none}.qa-btn{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--surface-raised);border:1px solid var(--surface-sunken);border-radius:var(--radius-lg);cursor:pointer;box-shadow:var(--shadow-sm);-webkit-tap-highlight-color:transparent;transition:all var(--transition-base);flex-direction:column;flex-shrink:0;min-width:76px;display:flex}.dark .qa-btn{background:var(--surface);border-color:#ffffff0f}.qa-btn:active{background:var(--surface);transform:scale(.95)}.qa-icon{border-radius:var(--radius-md);background:var(--primary-subtle);width:40px;height:40px;color:var(--primary);place-items:center;display:grid}.qa-icon[data-tone=amber]{background:var(--secondary-subtle);color:var(--secondary)}.qa-icon[data-tone=green]{background:var(--status-complete-bg);color:var(--status-complete)}.qa-icon .material-symbols-outlined{font-size:20px}.qa-label{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap;font-weight:600}.home-card{background:var(--surface-raised);border:1px solid var(--surface-sunken);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.dark .home-card{background:var(--surface);border-color:#ffffff0f}.home-card-header{padding:var(--space-4) var(--space-4) var(--space-3);justify-content:space-between;align-items:center;display:flex}.home-card-header h3{font-family:var(--font-display);font-size:var(--text-base);color:var(--text-primary);font-weight:700}.home-card-link{font-size:var(--text-xs);color:var(--primary);padding:var(--space-1) 0;font-weight:600;text-decoration:none}.order-row{padding:var(--space-3) var(--space-4);align-items:center;gap:var(--space-3);border-top:1px solid var(--surface-sunken);-webkit-tap-highlight-color:transparent;transition:background var(--transition-base);cursor:pointer;display:flex}.dark .order-row{border-top-color:#ffffff0f}.order-row:active{background:var(--hover-overlay)}.order-avatar{border-radius:var(--radius-md);background:var(--primary-subtle);width:36px;height:36px;color:var(--primary);font-family:var(--font-display);font-size:var(--text-sm);flex-shrink:0;place-items:center;font-weight:700;display:grid}.order-info{flex:1;min-width:0}.order-id{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--text-primary);font-variant-numeric:tabular-nums;font-weight:600}.order-client{font-size:var(--text-xs);color:var(--text-tertiary);white-space:nowrap;text-overflow:ellipsis;margin-top:1px;overflow:hidden}.order-progress{margin-top:var(--space-1);align-items:center;gap:var(--space-2);display:flex}.progress-bar{background:var(--surface-sunken);border-radius:var(--radius-full);flex:1;height:4px;overflow:hidden}.dark .progress-bar{background:#ffffff14}.progress-fill{border-radius:var(--radius-full);height:100%;transition:width .6s cubic-bezier(.22,1,.36,1)}.progress-fill[data-fill=green]{background:var(--status-complete)}.progress-fill[data-fill=blue]{background:var(--primary)}.progress-fill[data-fill=amber]{background:var(--status-pending)}.progress-pct{font-family:var(--font-mono);color:var(--text-tertiary);text-align:right;font-variant-numeric:tabular-nums;min-width:28px;font-size:10px;font-weight:600}.order-meta{text-align:right;flex-direction:column;flex-shrink:0;align-items:flex-end;gap:2px;display:flex}.status-badge{padding:2px var(--space-2);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;align-items:center;font-size:10px;font-weight:700;display:inline-flex}.status-badge[data-status=complete]{background:var(--status-complete-bg);color:var(--status-complete)}.status-badge[data-status=active]{background:var(--status-active-bg);color:var(--status-active)}.status-badge[data-status=pending]{background:var(--status-pending-bg);color:var(--status-pending)}.order-date{color:var(--text-tertiary);font-size:10px}.appr-page{gap:var(--space-3);flex-direction:column;width:100%;max-width:720px;margin:0 auto;display:flex}.appr-tabs{top:calc(-1 * var(--space-4));background:var(--canvas);z-index:10;align-items:center;gap:var(--space-1);padding:var(--space-1) 0;display:flex;position:sticky}.appr-tab{justify-content:center;align-items:center;gap:var(--space-2);height:36px;font-family:var(--font-display);font-size:var(--text-sm);color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-full);transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex:1;font-weight:600;display:inline-flex}.appr-tab:hover{color:var(--text-secondary)}.appr-tab.active{background:var(--primary-subtle);color:var(--primary)}.appr-tab-count{min-width:18px;height:18px;padding:0 var(--space-1);background:var(--destructive);color:#fff;font-family:var(--font-mono);border-radius:var(--radius-full);font-variant-numeric:tabular-nums;justify-content:center;align-items:center;font-size:10px;font-weight:700;display:inline-flex}.appr-tab.active .appr-tab-count{background:var(--primary)}.appr-card{background:var(--surface-raised);border:1px solid var(--surface-sunken);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);transition:transform var(--transition-base), box-shadow var(--transition-base);overflow:hidden}.dark .appr-card{background:var(--surface);border-color:#ffffff0f}.appr-card:active{box-shadow:var(--shadow-md);transform:scale(.985)}.appr-stripe{height:3px}.appr-stripe[data-priority=urgent]{background:var(--status-alert)}.appr-stripe[data-priority=normal]{background:var(--primary)}.appr-stripe[data-priority=expense]{background:var(--secondary-container)}.appr-card-body{padding:var(--space-4) var(--space-4) var(--space-3)}.appr-card-header{align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-3);display:flex}.appr-type-icon{border-radius:var(--radius-md);flex-shrink:0;place-items:center;width:40px;height:40px;display:grid}.appr-type-icon .material-symbols-outlined{font-size:20px}.appr-card-header-body{flex:1;min-width:0}.appr-type-label{font-size:10px;font-weight:700;font-family:var(--font-display);letter-spacing:.08em;text-transform:uppercase;margin-bottom:2px}.appr-title{font-family:var(--font-display);font-size:var(--text-base);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:700;overflow:hidden}.appr-time{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:2px}.appr-requester{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--canvas);border-radius:var(--radius-md);margin-bottom:var(--space-3);display:flex}.dark .appr-requester{background:var(--surface-sunken)}.req-avatar{width:28px;height:28px;font-family:var(--font-display);font-size:var(--text-xs);color:#fff;border-radius:50%;flex-shrink:0;place-items:center;font-weight:700;display:grid}.req-info{flex:1;min-width:0}.req-name{font-size:var(--text-sm);color:var(--text-primary);font-weight:600}.req-dept{font-size:var(--text-xs);color:var(--text-tertiary)}.req-amount{font-family:var(--font-mono);font-size:var(--text-base);color:var(--text-primary);font-variant-numeric:tabular-nums;font-weight:700}.appr-actions{gap:var(--space-2);padding-bottom:var(--space-1);grid-template-columns:1fr 1fr;display:grid}.appr-btn{border-radius:var(--radius-lg);height:44px;font-family:var(--font-display);font-size:var(--text-sm);cursor:pointer;justify-content:center;align-items:center;gap:var(--space-1);transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent;border:1.5px solid #0000;font-weight:700;display:inline-flex}.appr-btn .material-symbols-outlined{font-size:18px}.appr-btn[data-variant=approve]{background:var(--status-complete-bg);color:var(--status-complete)}.appr-btn[data-variant=approve]:hover{background:var(--status-complete);color:#fff}.appr-btn[data-variant=approve]:active{background:var(--status-complete);color:#fff;transform:scale(.97)}.appr-btn[data-variant=reject]{background:var(--status-alert-bg);color:var(--status-alert)}.appr-btn[data-variant=reject]:hover{background:var(--status-alert);color:#fff}.appr-btn[data-variant=reject]:active{background:var(--status-alert);color:#fff;transform:scale(.97)}.appr-btn[disabled]{opacity:.5;pointer-events:none}.appr-empty{text-align:center;padding:var(--space-12) var(--space-4);color:var(--text-tertiary);font-size:var(--text-sm)}.appr-empty .material-symbols-outlined{margin:0 auto var(--space-3);color:var(--text-tertiary);opacity:.6;font-size:48px;display:block}.appr-drawer-overlay{z-index:40;background:#00000073;animation:.22s overlay-in;position:fixed;inset:0}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.appr-drawer{z-index:41;background:var(--surface-raised);border-radius:var(--radius-lg) var(--radius-lg) 0 0;flex-direction:column;max-height:92vh;display:flex;position:fixed;bottom:0;left:0;right:0;overflow:hidden;box-shadow:0 -8px 32px #0000002e}.dark .appr-drawer{background:var(--surface)}.appr-drawer-handle{background:var(--surface-sunken);border-radius:999px;flex-shrink:0;width:40px;height:4px;margin:10px auto}.appr-drawer-body{padding:var(--space-2) var(--space-4) var(--space-6);gap:var(--space-4);flex-direction:column;display:flex;overflow-y:auto}.appr-drawer-head{flex-direction:column;gap:4px;display:flex}.appr-drawer-num{font-family:var(--font-mono,"SF Mono", monospace);font-size:var(--text-xs);color:var(--primary);letter-spacing:.05em;font-weight:700}.appr-drawer-title-text{font-family:var(--font-display);font-size:var(--text-xl);color:var(--text-primary);letter-spacing:-.02em;font-weight:800;line-height:1.2}.appr-drawer-sub{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:500}.appr-drawer-section{gap:var(--space-2);flex-direction:column;display:flex}.appr-drawer-section-title{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);font-weight:700}.appr-drawer-body-text{font-size:var(--text-sm);color:var(--text-secondary);white-space:pre-wrap;line-height:1.6}.appr-drawer-grid{gap:var(--space-3);padding:var(--space-3);background:var(--surface-sunken);border-radius:var(--radius-md);grid-template-columns:repeat(auto-fit,minmax(140px,1fr));display:grid}.dark .appr-drawer-grid{background:#ffffff0a}.appr-drawer-field{flex-direction:column;gap:2px;display:flex}.appr-drawer-field-label{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:600}.appr-drawer-field-value{font-size:var(--text-base);color:var(--text-primary);font-weight:700}.appr-drawer-field-value.mono{font-family:var(--font-mono,"SF Mono", monospace);font-variant-numeric:tabular-nums}.appr-status-chip{font-size:var(--text-xs);background:var(--primary-subtle);color:var(--primary);border-radius:999px;padding:2px 10px;font-weight:700;display:inline-block}.appr-status-chip[data-status=APPROVED]{background:var(--status-success-bg,#34c7591a);color:var(--status-success,#34c759)}.appr-status-chip[data-status=REJECTED],.appr-status-chip[data-status=CANCELLED]{background:var(--status-alert-bg,#ff3b301f);color:var(--status-alert,#ff3b30)}.appr-flow-list{gap:var(--space-2);flex-direction:column;padding:0;list-style:none;display:flex}.appr-flow-node{align-items:flex-start;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:1px solid var(--surface-sunken);background:var(--surface-raised);display:flex}.dark .appr-flow-node{background:var(--surface);border-color:#ffffff0f}.appr-flow-node[data-state=active]{border-color:var(--primary);background:var(--primary-subtle)}.appr-flow-node[data-state=done]{opacity:.7}.appr-flow-bullet{background:var(--surface-sunken);width:26px;height:26px;color:var(--text-secondary);font-size:var(--text-sm);border-radius:50%;flex-shrink:0;place-items:center;font-weight:700;display:grid}.appr-flow-node[data-state=active] .appr-flow-bullet{background:var(--primary);color:#fff}.appr-flow-node[data-state=done] .appr-flow-bullet{background:var(--status-success,#34c759);color:#fff}.appr-flow-meta{flex-direction:column;gap:2px;display:flex}.appr-flow-name{font-size:var(--text-sm);color:var(--text-primary);font-weight:700}.appr-flow-approver{font-size:var(--text-xs);color:var(--text-tertiary)}.appr-records-list{gap:var(--space-2);flex-direction:column;padding:0;list-style:none;display:flex}.appr-record-row{padding:var(--space-3);border-radius:var(--radius-md);border-left:3px solid var(--surface-sunken);background:var(--surface-sunken)}.appr-record-row[data-action=approve]{border-left-color:var(--status-success,#34c759)}.appr-record-row[data-action=reject]{border-left-color:var(--status-alert,#ff3b30)}.dark .appr-record-row{background:#ffffff0a}.appr-record-head{align-items:center;gap:var(--space-2);flex-wrap:wrap;margin-bottom:2px;display:flex}.appr-record-approver{font-size:var(--text-sm);color:var(--text-primary);font-weight:700}.appr-record-action{font-size:var(--text-xs);color:var(--primary);font-weight:700}.appr-record-time{font-size:var(--text-xs);color:var(--text-tertiary);margin-left:auto}.appr-record-node{font-size:var(--text-xs);color:var(--text-tertiary)}.appr-record-comment{margin-top:var(--space-1,4px);font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5}.appr-drawer-actions{gap:var(--space-2);padding-top:var(--space-2);border-top:1px solid var(--surface-sunken);background:var(--surface-raised);grid-template-columns:1fr 1fr;display:grid;position:sticky;bottom:0}.dark .appr-drawer-actions{background:var(--surface);border-color:#ffffff0f}.appr-skeleton{background:linear-gradient(90deg, var(--surface-sunken) 0%, #ffffff1a 50%, var(--surface-sunken) 100%);border-radius:var(--radius-md);background-size:200% 100%;height:200px;animation:1.4s infinite skeleton}@keyframes skeleton{0%{background-position:200% 0}to{background-position:-200% 0}}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;position:absolute!important}.login-page{width:100%;min-height:100dvh;padding:var(--space-4);flex-direction:column;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.login-bg-canvas{z-index:0;pointer-events:none;width:100%;height:100%;position:fixed;inset:0}.login-bg-gradient{z-index:1;pointer-events:none;background:radial-gradient(at 30% 20%,#0071e324 0%,#0000 60%),radial-gradient(at 80% 80%,#ff95001a 0%,#0000 50%);position:fixed;inset:0}.dark .login-bg-gradient{background:radial-gradient(at 30% 20%,#0a84ff29 0%,#0000 60%),radial-gradient(at 80% 80%,#ff9f0a1a 0%,#0000 50%)}.login-dark-toggle{top:calc(var(--safe-top) + var(--space-4));right:calc(var(--safe-right) + var(--space-4));z-index:100;border-radius:var(--radius-full);border:1px solid var(--surface-sunken);background:var(--surface-raised);width:40px;height:40px;color:var(--text-secondary);cursor:pointer;box-shadow:var(--shadow-sm);transition:all var(--transition-base);place-items:center;display:grid;position:fixed}.login-dark-toggle:active{transform:scale(.93)}.login-dark-toggle .material-symbols-outlined{font-size:18px}.login-card{z-index:10;width:100%;max-width:343px;padding:var(--space-8) var(--space-6) var(--space-6);flex-direction:column;align-items:center;display:flex;position:relative}.login-logo-area{align-items:center;gap:var(--space-3);margin-bottom:var(--space-8);flex-direction:column;display:flex}.login-logo-mark{background:var(--gradient-cta);width:64px;height:64px;box-shadow:var(--shadow-lg);border-radius:18px;place-items:center;display:grid;position:relative;overflow:hidden}.login-logo-mark:before{content:"";background:#ffffff26;border-radius:50%;width:60%;height:60%;position:absolute;top:-20%;left:-20%}.login-logo-mark .material-symbols-outlined{color:#fff;font-variation-settings:"FILL" 1, "wght" 500;z-index:1;font-size:32px;position:relative}.login-logo-text{text-align:center}.login-logo-name{font-family:var(--font-display);font-size:var(--text-2xl);color:var(--text-primary);letter-spacing:-.02em;font-weight:800;line-height:1}.login-logo-name span{color:var(--primary)}.login-logo-tagline{font-size:var(--text-xs);color:var(--text-tertiary);font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;margin-top:var(--space-1);font-weight:500}.login-form{gap:var(--space-3);width:100%;margin-bottom:var(--space-5);flex-direction:column;display:flex}.login-input-wrap{width:100%;position:relative}.login-input-icon{color:var(--text-tertiary);pointer-events:none;font-size:20px;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.login-input{background:var(--surface-raised);border:1.5px solid var(--surface-sunken);border-radius:var(--radius-md);width:100%;height:48px;color:var(--text-primary);font-family:var(--font-body);font-size:var(--text-base);transition:border-color var(--transition-base), box-shadow var(--transition-base);appearance:none;outline:none;padding:0 14px 0 44px;font-weight:400}.login-input::placeholder{color:var(--text-tertiary)}.login-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--focus-ring)}.login-input[aria-invalid=true]{border-color:var(--destructive)}.login-input[aria-invalid=true]:focus{box-shadow:0 0 0 3px var(--destructive-subtle)}.login-pw-toggle{cursor:pointer;color:var(--text-tertiary);border-radius:var(--radius-sm);transition:color var(--transition-base);background:0 0;border:none;place-items:center;padding:4px;display:grid;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.login-pw-toggle:active{color:var(--primary)}.login-pw-toggle .material-symbols-outlined{font-size:20px}.login-error{width:100%;font-size:var(--text-xs);color:var(--destructive);text-align:center;min-height:1em;font-weight:600}.login-tenant{gap:var(--space-2);width:100%;margin-bottom:var(--space-3);grid-template-columns:repeat(3,1fr);display:grid}.login-tenant-btn{border-radius:var(--radius-md);border:1.5px solid var(--surface-sunken);background:var(--surface-raised);height:48px;color:var(--text-secondary);font-family:var(--font-display);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-base);-webkit-tap-highlight-color:transparent;padding:var(--space-1);flex-direction:column;justify-content:center;align-items:center;gap:2px;font-weight:700;display:inline-flex}.login-tenant-btn:active{transform:scale(.96)}.login-tenant-btn.active{border-color:var(--primary);background:var(--primary-subtle);color:var(--primary)}.login-tenant-code{font-size:9px;font-family:var(--font-mono);color:var(--text-tertiary);letter-spacing:.05em;font-weight:500}.login-tenant-btn.active .login-tenant-code{color:var(--primary);opacity:.7}.login-lang{gap:var(--space-2);width:100%;margin-bottom:var(--space-5);display:flex}.login-lang-btn{border-radius:var(--radius-md);border:1.5px solid var(--surface-sunken);background:var(--surface-raised);height:36px;color:var(--text-secondary);font-family:var(--font-body);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-base);flex:1;font-weight:600}.login-lang-btn.active{background:var(--primary-subtle);border-color:var(--primary);color:var(--primary)}.login-lang-btn:active{transform:scale(.96)}.login-divider{background:var(--surface-sunken);width:100%;height:1px;margin:var(--space-1) 0 var(--space-4)}.login-submit{border-radius:var(--radius-lg);background:var(--gradient-cta);color:#fff;width:100%;height:52px;font-family:var(--font-display);font-size:var(--text-lg);letter-spacing:.01em;cursor:pointer;box-shadow:var(--shadow-md);transition:all var(--transition-base);border:none;place-items:center;font-weight:700;display:grid;position:relative;overflow:hidden}.login-submit:before{content:"";transition:background var(--transition-base);background:#fff0;position:absolute;inset:0}.login-submit:active:before{background:#ffffff1a}.login-submit:active{transform:scale(.98)}.login-submit[disabled]{opacity:.85;pointer-events:none}.login-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite login-spin}@keyframes login-spin{to{transform:rotate(360deg)}}.login-forgot{margin-top:var(--space-4);font-size:var(--text-sm);color:var(--text-tertiary);text-align:center;padding:var(--space-2);border-radius:var(--radius-sm);transition:color var(--transition-base);text-decoration:none;display:block}.login-forgot:active{color:var(--primary)}.login-version{bottom:calc(var(--safe-bottom) + var(--space-5));text-align:center;font-size:var(--text-xs);color:var(--text-tertiary);letter-spacing:.05em;z-index:10;font-family:var(--font-mono);position:fixed;left:0;right:0}.notices-page{gap:var(--space-3);flex-direction:column;width:100%;max-width:720px;margin:0 auto;display:flex}.notice-filter{top:calc(-1 * var(--space-4));z-index:10;gap:var(--space-2);padding:var(--space-1) 0 var(--space-2);background:var(--canvas);scrollbar-width:none;display:flex;position:sticky;overflow-x:auto}.notice-filter::-webkit-scrollbar{display:none}.notice-chip{height:32px;padding:0 var(--space-3);border-radius:var(--radius-full);border:1.5px solid var(--surface-sunken);background:var(--surface-raised);color:var(--text-secondary);font-family:var(--font-display);font-size:var(--text-xs);cursor:pointer;align-items:center;gap:var(--space-1);transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent;flex-shrink:0;font-weight:700;display:inline-flex}.dark .notice-chip{background:#ffffff0a;border-color:#ffffff14}.notice-chip-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.notice-chip.active{border-color:#0000}.notice-chip[data-cat=all].active{background:var(--primary-subtle);color:var(--primary)}.notice-chip[data-cat=important].active{background:var(--status-alert-bg);color:var(--status-alert)}.notice-chip[data-cat=general].active{background:var(--primary-subtle);color:var(--primary)}.notice-chip[data-cat=hr].active{background:var(--status-complete-bg);color:var(--status-complete)}.notice-chip[data-cat=safety].active{background:var(--status-pending-bg);color:var(--status-pending)}.notice-card{background:var(--surface-raised);border:1px solid var(--surface-sunken);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);cursor:pointer;transition:all var(--transition-fast);overflow:hidden}.dark .notice-card{background:var(--surface);border-color:#ffffff0f}.notice-card:active{box-shadow:var(--shadow-md);transform:scale(.99)}.notice-card[data-unread=true]{border-left:3px solid var(--primary)}.notice-stripe{height:3px}.notice-stripe[data-cat=important]{background:var(--status-alert)}.notice-stripe[data-cat=general]{background:var(--primary)}.notice-stripe[data-cat=hr]{background:var(--status-complete)}.notice-stripe[data-cat=safety]{background:var(--status-pending)}.notice-body{padding:var(--space-4)}.notice-meta-top{margin-bottom:var(--space-2);justify-content:space-between;align-items:center;display:flex}.notice-category{align-items:center;gap:var(--space-1);height:20px;padding:0 var(--space-2);border-radius:var(--radius-full);font-size:10px;font-weight:700;font-family:var(--font-display);letter-spacing:.05em;text-transform:uppercase;display:inline-flex}.notice-category .material-symbols-outlined{font-size:12px}.notice-category[data-cat=important]{background:var(--status-alert-bg);color:var(--status-alert)}.notice-category[data-cat=general]{background:var(--primary-subtle);color:var(--primary)}.notice-category[data-cat=hr]{background:var(--status-complete-bg);color:var(--status-complete)}.notice-category[data-cat=safety]{background:var(--status-pending-bg);color:var(--status-pending)}.notice-unread-dot{background:var(--primary);border-radius:50%;flex-shrink:0;width:8px;height:8px}.notice-title{font-family:var(--font-display);font-size:var(--text-base);color:var(--text-primary);margin-bottom:var(--space-1);font-weight:700;line-height:1.3}.notice-preview{font-size:var(--text-sm);color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.5;display:-webkit-box;overflow:hidden}.notice-footer{align-items:center;gap:var(--space-2);margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--surface-sunken);display:flex}.dark .notice-footer{border-top-color:#ffffff0f}.notice-author-avatar{width:22px;height:22px;font-family:var(--font-display);color:#fff;background:var(--gradient-cta);border-radius:50%;flex-shrink:0;place-items:center;font-size:9px;font-weight:700;display:grid}.notice-author{font-size:var(--text-xs);color:var(--text-secondary);font-weight:600}.notice-date{font-size:var(--text-xs);color:var(--text-tertiary);font-variant-numeric:tabular-nums;margin-left:auto}.notice-attach{font-size:var(--text-xs);color:var(--primary);align-items:center;gap:3px;font-weight:600;display:inline-flex}.notice-attach .material-symbols-outlined{font-size:13px}.notice-empty{text-align:center;padding:var(--space-12) var(--space-4);color:var(--text-tertiary);font-size:var(--text-sm)}.notice-empty .material-symbols-outlined{margin:0 auto var(--space-3);opacity:.6;font-size:48px;display:block}.req-page{gap:var(--space-4);flex-direction:column;width:100%;max-width:720px;margin:0 auto;display:flex}.req-form{background:var(--surface-raised);border:1px solid var(--surface-sunken);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);padding:var(--space-5);gap:var(--space-4);flex-direction:column;display:flex}.dark .req-form{background:var(--surface);border-color:#ffffff0f}.req-section-label{font-family:var(--font-display);font-size:var(--text-xs);color:var(--text-tertiary);letter-spacing:.08em;text-transform:uppercase;margin-bottom:var(--space-2);font-weight:700}.req-type-grid{gap:var(--space-2);grid-template-columns:repeat(auto-fit,minmax(96px,1fr));display:grid}.req-type-btn{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-2);background:var(--canvas);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent;border:1.5px solid #0000;flex-direction:column;display:flex}.dark .req-type-btn{background:#ffffff0a}.req-type-btn:hover{background:var(--surface-sunken)}.req-type-btn.active{background:var(--primary-subtle);border-color:var(--primary)}.req-type-icon{border-radius:var(--radius-md);background:var(--surface-raised);width:36px;height:36px;color:var(--text-secondary);place-items:center;display:grid}.req-type-btn.active .req-type-icon{background:var(--primary);color:#fff}.req-type-icon .material-symbols-outlined{font-size:20px}.req-type-label{font-family:var(--font-display);font-size:var(--text-xs);color:var(--text-secondary);font-weight:600}.req-type-btn.active .req-type-label{color:var(--primary);font-weight:700}.req-field{gap:var(--space-1);flex-direction:column;display:flex}.req-field-label{font-family:var(--font-display);font-size:var(--text-xs);color:var(--text-secondary);letter-spacing:.04em;text-transform:uppercase;font-weight:600}.req-field-row{gap:var(--space-3);grid-template-columns:1fr 1fr;display:grid}.req-input,.req-textarea{width:100%;padding:var(--space-3) var(--space-3);background:var(--canvas);border:1.5px solid var(--surface-sunken);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-body);font-size:var(--text-base);transition:border-color var(--transition-base), box-shadow var(--transition-base);outline:none}.dark .req-input,.dark .req-textarea{background:#ffffff0a}.req-input:focus,.req-textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--focus-ring)}.req-textarea{resize:vertical;min-height:88px;font-family:var(--font-body)}.req-input::placeholder,.req-textarea::placeholder{color:var(--text-tertiary)}.req-submit{border-radius:var(--radius-lg);background:var(--gradient-cta);color:#fff;height:48px;font-family:var(--font-display);font-size:var(--text-base);cursor:pointer;justify-content:center;align-items:center;gap:var(--space-2);box-shadow:var(--shadow-sm);transition:all var(--transition-base);border:none;font-weight:700;display:inline-flex}.req-submit:hover{box-shadow:var(--shadow-md)}.req-submit:active{transform:scale(.98)}.req-submit[disabled]{opacity:.6;pointer-events:none}.req-list-card{background:var(--surface-raised);border:1px solid var(--surface-sunken);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);overflow:hidden}.dark .req-list-card{background:var(--surface);border-color:#ffffff0f}.req-list-header{padding:var(--space-4);justify-content:space-between;align-items:center;display:flex}.req-list-header h3{font-family:var(--font-display);font-size:var(--text-base);color:var(--text-primary);font-weight:700}.req-row{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-top:1px solid var(--surface-sunken);display:flex}.dark .req-row{border-top-color:#ffffff0f}.req-row-icon{border-radius:var(--radius-md);background:var(--primary-subtle);width:32px;height:32px;color:var(--primary);flex-shrink:0;place-items:center;display:grid}.req-row-icon .material-symbols-outlined{font-size:18px}.req-row-info{flex:1;min-width:0}.req-row-title{font-family:var(--font-display);font-size:var(--text-sm);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:700;overflow:hidden}.req-row-time{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:2px}.req-status{padding:2px var(--space-2);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;align-items:center;font-size:10px;font-weight:700;display:inline-flex}.req-status[data-state=pending]{background:var(--status-pending-bg);color:var(--status-pending)}.req-status[data-state=approved]{background:var(--status-complete-bg);color:var(--status-complete)}.req-status[data-state=rejected]{background:var(--status-alert-bg);color:var(--status-alert)}.req-empty{text-align:center;padding:var(--space-12) var(--space-4);color:var(--text-tertiary);font-size:var(--text-sm)}.msg-page{background:var(--canvas);width:100%;height:100%;display:flex;overflow:hidden}.msg-list-pane{background:var(--surface-raised);border-right:1px solid var(--surface-sunken);flex-direction:column;flex-shrink:0;width:100%;display:flex}.dark .msg-list-pane{background:var(--surface);border-right-color:#ffffff0f}@media (min-width:768px){.msg-list-pane{width:320px}}.msg-search-wrap{padding:var(--space-3) var(--space-3) var(--space-2);border-bottom:1px solid var(--surface-sunken)}.dark .msg-search-wrap{border-bottom-color:#ffffff0f}.msg-search-input-rel{position:relative}.msg-search-input-rel .material-symbols-outlined{color:var(--text-tertiary);pointer-events:none;font-size:18px;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.msg-search-input{background:var(--canvas);border:1px solid var(--surface-sunken);border-radius:var(--radius-full);width:100%;height:36px;color:var(--text-primary);font-family:var(--font-body);font-size:var(--text-sm);transition:border-color var(--transition-base);outline:none;padding:0 12px 0 38px}.dark .msg-search-input{background:#ffffff0a}.msg-search-input:focus{border-color:var(--primary)}.msg-conv-list{scrollbar-width:thin;scrollbar-color:var(--surface-sunken) transparent;flex:1;overflow-y:auto}.msg-conv-list::-webkit-scrollbar{width:4px}.msg-conv-list::-webkit-scrollbar-thumb{background:var(--surface-sunken);border-radius:2px}.conv-item{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);cursor:pointer;border-bottom:1px solid var(--surface-sunken);transition:background var(--transition-fast);-webkit-tap-highlight-color:transparent;display:flex}.dark .conv-item{border-bottom-color:#ffffff0a}.conv-item:hover{background:var(--hover-overlay)}.conv-item[data-active=true]{background:var(--primary-subtle)}.conv-avatar{width:44px;height:44px;font-family:var(--font-display);font-size:var(--text-sm);color:#fff;border-radius:50%;flex-shrink:0;place-items:center;font-weight:700;display:grid;position:relative}.conv-online-dot{border:2px solid var(--surface-raised);border-radius:50%;width:11px;height:11px;position:absolute;bottom:0;right:0}.dark .conv-online-dot{border-color:var(--surface)}.conv-online-dot[data-state=online]{background:var(--status-complete)}.conv-online-dot[data-state=away]{background:var(--status-pending)}.conv-online-dot[data-state=offline]{background:var(--text-tertiary)}.conv-body{flex:1;min-width:0}.conv-top{justify-content:space-between;align-items:baseline;gap:var(--space-2);margin-bottom:2px;display:flex}.conv-name{font-family:var(--font-display);font-size:var(--text-sm);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:700;overflow:hidden}.conv-time{color:var(--text-tertiary);font-variant-numeric:tabular-nums;flex-shrink:0;font-size:10px}.conv-bottom{justify-content:space-between;align-items:center;gap:var(--space-2);display:flex}.conv-preview{font-size:var(--text-xs);color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.conv-item.unread .conv-preview{color:var(--text-primary);font-weight:600}.conv-badge{min-width:20px;height:20px;padding:0 var(--space-1);background:var(--primary);color:#fff;font-family:var(--font-mono);border-radius:var(--radius-full);font-variant-numeric:tabular-nums;flex-shrink:0;justify-content:center;align-items:center;font-size:10px;font-weight:700;display:inline-flex}.msg-chat-pane{background:var(--canvas);flex-direction:column;flex:1;min-width:0;display:flex}.chat-topbar{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--surface-overlay);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--surface-sunken);z-index:5;flex-shrink:0;display:flex}.dark .chat-topbar{background:#182028d9;border-bottom-color:#ffffff0f}.chat-back-btn{border-radius:var(--radius-md);cursor:pointer;width:36px;height:36px;color:var(--text-secondary);background:0 0;border:none;place-items:center;display:grid}.chat-back-btn .material-symbols-outlined{font-size:22px}@media (min-width:768px){.chat-back-btn{display:none}}.chat-topbar-avatar{width:36px;height:36px;font-family:var(--font-display);font-size:var(--text-xs);color:#fff;border-radius:50%;flex-shrink:0;place-items:center;font-weight:700;display:grid}.chat-topbar-info{flex:1;min-width:0}.chat-topbar-name{font-family:var(--font-display);font-size:var(--text-sm);color:var(--text-primary);font-weight:700}.chat-topbar-status{font-size:var(--text-xs);color:var(--status-complete)}.chat-messages{padding:var(--space-4);gap:var(--space-3);flex-direction:column;flex:1;display:flex;overflow-y:auto}.ts-separator{text-align:center;margin:var(--space-2) 0}.ts-separator span{padding:2px var(--space-2);color:var(--text-tertiary);background:var(--surface-sunken);border-radius:var(--radius-full);font-variant-numeric:tabular-nums;font-size:10px;display:inline-block}.msg-row{align-items:flex-end;gap:var(--space-2);display:flex}.msg-row.recv{justify-content:flex-start}.msg-row.sent{justify-content:flex-end}.msg-avatar{width:28px;height:28px;font-family:var(--font-display);color:#fff;border-radius:50%;flex-shrink:0;place-items:center;font-size:10px;font-weight:700;display:grid}.msg-row.no-avatar .msg-avatar{visibility:hidden}.bubble{max-width:80%;padding:var(--space-2) var(--space-3);font-size:var(--text-sm);word-wrap:break-word;border-radius:14px;line-height:1.4;position:relative}.bubble-recv{background:var(--surface-raised);color:var(--text-primary);border-bottom-left-radius:4px}.dark .bubble-recv{background:var(--surface-raised)}.bubble-sent{background:var(--gradient-cta);color:#fff;border-bottom-right-radius:4px}.bubble-time{font-size:9px;font-family:var(--font-mono);opacity:.65;margin-top:2px;display:block}.msg-status{color:var(--status-complete);font-size:14px}.composer{align-items:center;gap:var(--space-2);padding:var(--space-3);background:var(--surface-raised);border-top:1px solid var(--surface-sunken);flex-shrink:0;display:flex}.dark .composer{background:var(--surface);border-top-color:#ffffff0f}.composer-input{height:40px;padding:0 var(--space-3);background:var(--canvas);border:1px solid var(--surface-sunken);border-radius:var(--radius-full);color:var(--text-primary);font-family:var(--font-body);font-size:var(--text-sm);outline:none;flex:1}.dark .composer-input{background:#ffffff0a}.composer-input:focus{border-color:var(--primary)}.composer-send{background:var(--gradient-cta);color:#fff;cursor:pointer;width:40px;height:40px;transition:all var(--transition-fast);border:none;border-radius:50%;flex-shrink:0;place-items:center;display:grid}.composer-send:hover{box-shadow:var(--shadow-sm)}.composer-send:active{transform:scale(.9)}.composer-send[disabled]{opacity:.4;pointer-events:none}.composer-send .material-symbols-outlined{font-size:20px}.chat-empty{text-align:center;color:var(--text-tertiary);padding:var(--space-8);flex:1;place-items:center;display:grid}.chat-empty .material-symbols-outlined{margin:0 auto var(--space-4);opacity:.4;font-size:64px;display:block}@media (max-width:767px){.msg-page[data-mode=list] .msg-chat-pane,.msg-page[data-mode=chat] .msg-list-pane{display:none}}.composer-plus{background:var(--surface-sunken);width:40px;height:40px;color:var(--text-secondary);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;place-items:center;transition:background .12s,transform .12s;display:grid}.composer-plus:hover{background:var(--primary-subtle);color:var(--primary)}.composer-plus.active{background:var(--primary);color:#fff;transform:rotate(45deg)}.composer-plus .material-symbols-outlined{font-size:22px}.composer-plus-overlay{z-index:30;background:0 0;position:fixed;inset:0}.composer-plus-panel{z-index:31;padding:18px 18px calc(18px + env(safe-area-inset-bottom));background:var(--surface-raised);border-top:1px solid var(--surface-sunken);grid-template-columns:repeat(4,1fr);gap:14px 8px;animation:.22s cubic-bezier(.22,1,.36,1) both plus-panel-slide;display:grid;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -6px 24px #0000001f}.dark .composer-plus-panel{background:var(--surface);border-color:#ffffff0f}@keyframes plus-panel-slide{0%{transform:translateY(100%)}to{transform:translateY(0)}}.composer-plus-tile{cursor:pointer;color:var(--text-primary);border-radius:var(--radius-sm,6px);background:0 0;border:none;flex-direction:column;align-items:center;gap:6px;padding:8px 4px;transition:background .12s;display:flex}.composer-plus-tile:hover{background:var(--surface-sunken)}.composer-plus-tile.disabled{opacity:.55}.composer-plus-icon{background:var(--surface-sunken);width:52px;height:52px;color:var(--text-primary);border-radius:14px;place-items:center;transition:background .12s;display:grid}.dark .composer-plus-icon{background:#ffffff14}.composer-plus-tile:not(.disabled) .composer-plus-icon{background:var(--primary-subtle);color:var(--primary)}.composer-plus-icon .material-symbols-outlined{font-size:26px}.composer-plus-label{color:var(--text-secondary);letter-spacing:.02em;font-size:11px;font-weight:500}.msg-tabs{border-bottom:1px solid var(--surface-sunken);z-index:32;background:var(--surface-raised);gap:6px;padding:8px 12px 4px;display:flex;position:relative}.dark .msg-tabs{background:var(--surface);border-color:#ffffff0f}.msg-tab{cursor:pointer;font-family:var(--font-display);font-size:var(--text-sm);color:var(--text-tertiary);border-radius:var(--radius-md);background:0 0;border:none;flex:1;padding:8px 12px;font-weight:700;transition:all .12s}.msg-tab:hover{color:var(--text-primary)}.msg-tab.active{color:var(--primary);background:var(--primary-subtle)}.call-history-list{flex-direction:column;display:flex}.call-history-row{align-items:center;gap:var(--space-3);border-bottom:1px solid var(--surface-sunken);padding:12px 16px;display:flex}.dark .call-history-row{border-color:#ffffff0f}.call-history-icon{font-size:22px!important}.call-history-info{flex:1;min-width:0}.call-history-name{font-size:var(--text-base);color:var(--text-primary);font-weight:600}.call-history-sub{font-size:var(--text-xs);color:var(--text-tertiary);margin-top:2px}.call-history-time{font-size:var(--text-xs);color:var(--text-tertiary);font-variant-numeric:tabular-nums}.call-history-empty{padding:var(--space-6);text-align:center;color:var(--text-tertiary);font-size:var(--text-sm)}.call-history-empty .material-symbols-outlined{margin:0 auto var(--space-2);opacity:.5;font-size:44px;display:block}.bubble-rich{overflow:hidden;padding:4px!important}.bubble-rich .bubble-time{color:#fff;background:#0000008c;border-radius:8px;padding:2px 6px;font-size:10px;position:absolute;bottom:4px;right:8px}.bubble-image-link{display:block;position:relative}.bubble-image{object-fit:cover;border-radius:12px;max-width:240px;max-height:240px;display:block}.bubble-file{min-width:180px;max-width:240px;color:inherit;align-items:center;gap:10px;padding:10px 14px;text-decoration:none;display:flex}.bubble-file-icon{opacity:.85;font-size:32px!important}.bubble-file-meta{flex-direction:column;min-width:0;display:flex}.bubble-file-name{white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.bubble-file-size{opacity:.7;font-size:11px}.bubble-location{min-width:180px;color:inherit;align-items:center;gap:10px;padding:10px 14px;text-decoration:none;display:flex}.bubble-location-icon{color:#ff3b30;font-size:32px!important}.bubble-location-meta{flex-direction:column;display:flex}.bubble-location-title{font-family:var(--font-mono,"SF Mono", monospace);font-variant-numeric:tabular-nums;font-size:13px;font-weight:600}.bubble-location-sub{opacity:.7;margin-top:2px;font-size:11px}.profile-page{gap:var(--space-4);flex-direction:column;width:100%;max-width:720px;margin:0 auto;display:flex}.profile-hero{align-items:center;gap:var(--space-4);padding:var(--space-5) var(--space-4);background:var(--surface-raised);border:1px solid var(--surface-sunken);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex}.dark .profile-hero{background:var(--surface);border-color:#ffffff0f}.profile-avatar{width:72px;height:72px;font-family:var(--font-display);color:#fff;background:linear-gradient(135deg, var(--primary), var(--primary-dark,var(--primary)));box-shadow:var(--shadow-md);border-radius:50%;flex-shrink:0;place-items:center;font-size:1.75rem;font-weight:700;display:grid}.profile-hero-info{flex-direction:column;gap:4px;min-width:0;display:flex}.profile-name{font-family:var(--font-display);font-size:var(--text-xl);color:var(--text-primary);letter-spacing:-.01em;font-weight:800;line-height:1.15}.profile-username{font-size:var(--text-sm);color:var(--text-tertiary)}.profile-tenant-badge{border-radius:var(--radius-full,999px);background:var(--primary-subtle);color:var(--primary);font-size:var(--text-xs);letter-spacing:.05em;align-self:flex-start;margin-top:6px;padding:2px 10px;font-weight:700}.profile-card{background:var(--surface-raised);border:1px solid var(--surface-sunken);border-radius:var(--radius-lg);padding:var(--space-4);gap:var(--space-3);box-shadow:var(--shadow-sm);flex-direction:column;display:flex}.dark .profile-card{background:var(--surface);border-color:#ffffff0f}.profile-card-title{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);font-weight:700}.profile-role-list{gap:var(--space-2);flex-wrap:wrap;display:flex}.profile-role-chip{border-radius:var(--radius-full,999px);background:var(--surface-sunken);color:var(--text-secondary);font-size:var(--text-xs);letter-spacing:.03em;padding:6px 12px;font-weight:600}.dark .profile-role-chip{color:var(--text-secondary);background:#ffffff0f}.profile-lang-list{gap:var(--space-2);grid-template-columns:repeat(2,1fr);display:grid}@media (min-width:480px){.profile-lang-list{grid-template-columns:repeat(4,1fr)}}.profile-lang-btn{border-radius:var(--radius-md);border:1px solid var(--surface-sunken);color:var(--text-secondary);font-size:var(--text-sm);cursor:pointer;background:0 0;padding:10px 12px;font-weight:600;transition:all .12s}.profile-lang-btn:hover{border-color:var(--primary);color:var(--primary)}.profile-lang-btn.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.profile-row{align-items:center;gap:var(--space-3);padding:var(--space-2) 0;cursor:pointer;color:var(--text-primary);text-align:left;background:0 0;border:none;width:100%;display:flex}.profile-row-icon{color:var(--text-secondary)}.profile-row-label{font-size:var(--text-sm);flex:1;font-weight:600}.profile-switch{background:var(--surface-sunken);border-radius:999px;flex-shrink:0;width:40px;height:22px;transition:background .16s;position:relative}.profile-switch.on{background:var(--primary)}.profile-switch-thumb{width:18px;height:18px;box-shadow:var(--shadow-sm);background:#fff;border-radius:50%;transition:transform .16s cubic-bezier(.34,1.56,.64,1);position:absolute;top:2px;left:2px}.profile-switch.on .profile-switch-thumb{transform:translate(18px)}.profile-switch.disabled{opacity:.35}.profile-row:disabled{cursor:not-allowed;opacity:.7}.profile-device-token{align-items:center;gap:var(--space-2);border-radius:var(--radius-md);background:var(--status-success-bg,#34c7591a);color:var(--status-success,#34c759);font-size:var(--text-xs);padding:8px 12px;font-weight:600;display:flex}.profile-device-token .material-symbols-outlined{font-size:18px}.profile-sign-out{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3);border-radius:var(--radius-md);border:1px solid var(--status-alert,#ff3b30);color:var(--status-alert,#ff3b30);font-size:var(--text-sm);cursor:pointer;background:0 0;font-weight:700;transition:all .12s;display:flex}.profile-sign-out:hover{background:var(--status-alert-bg,#ff3b301a)}.profile-version{text-align:center;font-size:var(--text-xs);color:var(--text-tertiary);padding:var(--space-2) 0}.att-page{gap:var(--space-4);flex-direction:column;width:100%;max-width:560px;margin:0 auto;display:flex}.att-hero{padding:var(--space-2) 2px;flex-direction:column;gap:4px;display:flex}.att-date{font-size:var(--text-sm);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.att-greeting{font-family:var(--font-display);font-size:var(--text-2xl);color:var(--text-primary);letter-spacing:-.02em;font-weight:800;line-height:1.15}.att-status-card{padding:var(--space-5) var(--space-4);border-radius:var(--radius-lg);align-items:center;gap:var(--space-3);box-shadow:var(--shadow-md);background:var(--surface-raised);border:1px solid var(--surface-sunken);flex-direction:column;transition:all .18s;display:flex;position:relative;overflow:hidden}.dark .att-status-card{background:var(--surface);border-color:#ffffff0f}.att-status-card[data-state=in]{background:linear-gradient(135deg, var(--primary-subtle), var(--surface-raised));border-color:var(--primary)}.att-status-card[data-state=done]{background:linear-gradient(135deg, var(--status-success-bg,#34c7591a), var(--surface-raised));border-color:var(--status-success,#34c759)}.att-status-icon{background:var(--primary);color:#fff;border-radius:50%;place-items:center;width:84px;height:84px;font-size:2.5rem;display:grid;box-shadow:0 6px 20px #00000026}.att-status-icon .material-symbols-outlined{font-size:42px}.att-status-card[data-state=done] .att-status-icon{background:var(--status-success,#34c759)}.att-status-card[data-state=pending] .att-status-icon{background:var(--text-tertiary)}.att-status-label{font-family:var(--font-display);font-size:var(--text-xl);color:var(--text-primary);letter-spacing:-.01em;font-weight:700}.att-status-badge{font-size:var(--text-xs);letter-spacing:.05em;background:var(--status-alert-bg,#ff3b301f);color:var(--status-alert,#ff3b30);border-radius:999px;padding:4px 12px;font-weight:700}.att-status-badge[data-kind=LATE]{background:var(--status-alert-bg,#ff3b301f);color:var(--status-alert,#ff3b30)}.att-status-badge[data-kind=EARLY_LEAVE]{background:var(--status-pending-bg,#ff95001f);color:var(--status-pending,#ff9500)}.att-timeline{background:var(--surface-raised);border:1px solid var(--surface-sunken);border-radius:var(--radius-lg);padding:var(--space-2) var(--space-4);box-shadow:var(--shadow-sm);flex-direction:column;display:flex}.dark .att-timeline{background:var(--surface);border-color:#ffffff0f}.att-row{padding:var(--space-3) 0;border-bottom:1px solid var(--surface-sunken);justify-content:space-between;align-items:center;display:flex}.att-row:last-child{border-bottom:none}.dark .att-row{border-color:#ffffff0f}.att-row-label{font-size:var(--text-sm);color:var(--text-tertiary);font-weight:500}.att-row-value{font-family:var(--font-mono,"SF Mono", Menlo, monospace);font-size:var(--text-base);color:var(--text-primary);font-variant-numeric:tabular-nums;font-weight:700}.att-action-btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-4);border-radius:var(--radius-lg);background:var(--primary);color:#fff;font-family:var(--font-display);font-size:var(--text-lg);letter-spacing:-.01em;cursor:pointer;box-shadow:var(--shadow-md);border:none;font-weight:700;transition:all .18s;display:flex}.att-action-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #0000002e}.att-action-btn:active:not(:disabled){transform:translateY(0)}.att-action-btn:disabled{opacity:.5;cursor:not-allowed}.att-action-btn[data-action=out]{background:var(--status-pending,#ff9500)}.att-action-btn .material-symbols-outlined{font-size:24px}.att-done-note{text-align:center;padding:var(--space-3);font-size:var(--text-sm);color:var(--status-success,#34c759);font-weight:600}.att-empty{margin-top:var(--space-8);align-items:center;gap:var(--space-3);padding:var(--space-6) var(--space-4);text-align:center;flex-direction:column;display:flex}.att-empty .material-symbols-outlined{color:var(--text-tertiary);font-size:64px}.att-empty-title{font-family:var(--font-display);font-size:var(--text-lg);color:var(--text-primary);font-weight:700}.att-empty-body{font-size:var(--text-sm);color:var(--text-tertiary);max-width:320px;line-height:1.5}.reports-page{gap:var(--space-4);flex-direction:column;width:100%;max-width:1200px;margin:0 auto;display:flex}.reports-period{align-items:center;gap:var(--space-2);background:var(--primary-subtle);color:var(--primary);font-family:var(--font-mono,"SF Mono", monospace);font-size:var(--text-sm);letter-spacing:.04em;border-radius:999px;align-self:flex-start;padding:6px 14px;font-weight:700;display:inline-flex}.reports-period .material-symbols-outlined{font-size:18px}.reports-grid{gap:var(--space-3);grid-template-columns:repeat(2,1fr);display:grid}@media (min-width:640px){.reports-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width:1024px){.reports-grid{grid-template-columns:repeat(6,1fr)}}.reports-card{padding:var(--space-4);border-radius:var(--radius-lg);background:var(--surface-raised);border:1px solid var(--surface-sunken);box-shadow:var(--shadow-sm);gap:var(--space-2);flex-direction:column;animation:.4s cubic-bezier(.175,.885,.32,1.275) both card-in;display:flex;position:relative;overflow:hidden}.dark .reports-card{background:var(--surface);border-color:#ffffff0f}@keyframes card-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.reports-card:first-child{animation-delay:0s}.reports-card:nth-child(2){animation-delay:40ms}.reports-card:nth-child(3){animation-delay:80ms}.reports-card:nth-child(4){animation-delay:.12s}.reports-card:nth-child(5){animation-delay:.16s}.reports-card:nth-child(6){animation-delay:.2s}.reports-card:before{content:"";background:var(--primary);border-radius:3px 0 0 3px;width:3px;position:absolute;top:0;bottom:0;left:0}.reports-card[data-tone=primary]:before{background:var(--primary)}.reports-card[data-tone=success]:before{background:var(--status-success,#34c759)}.reports-card[data-tone=warning]:before{background:var(--status-pending,#ff9500)}.reports-card[data-tone=alert]:before{background:var(--status-alert,#ff3b30)}.reports-card[data-tone=secondary]:before{background:var(--text-secondary)}.reports-card-head{align-items:center;gap:var(--space-2);display:flex}.reports-card-icon{border-radius:var(--radius-sm,6px);background:var(--primary-subtle);width:28px;height:28px;color:var(--primary);place-items:center;display:grid}.reports-card[data-tone=success] .reports-card-icon{background:var(--status-success-bg,#34c7591a);color:var(--status-success,#34c759)}.reports-card[data-tone=warning] .reports-card-icon{background:var(--status-pending-bg,#ff95001f);color:var(--status-pending,#ff9500)}.reports-card[data-tone=alert] .reports-card-icon{background:var(--status-alert-bg,#ff3b301f);color:var(--status-alert,#ff3b30)}.reports-card[data-tone=secondary] .reports-card-icon{background:var(--surface-sunken);color:var(--text-secondary)}.reports-card-icon .material-symbols-outlined{font-size:18px}.reports-card-label{font-size:var(--text-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;font-weight:700}.reports-card-value{font-family:var(--font-display);font-size:clamp(var(--text-2xl), 4vw, var(--text-3xl,2rem));color:var(--text-primary);letter-spacing:-.025em;font-variant-numeric:tabular-nums;font-weight:800;line-height:1.05}.reports-card-sub{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:500}.reports-card-change{font-size:var(--text-xs);border-radius:999px;align-self:flex-start;align-items:center;gap:2px;padding:2px 8px;font-weight:700;display:inline-flex}.reports-card-change .material-symbols-outlined{font-size:14px}.reports-card-change.up{background:var(--status-success-bg,#34c7591a);color:var(--status-success,#34c759)}.reports-card-change.down{background:var(--status-alert-bg,#ff3b301f);color:var(--status-alert,#ff3b30)}.reports-po-bar{background:var(--surface-raised);border:1px solid var(--surface-sunken);border-radius:var(--radius-lg);padding:var(--space-4);gap:var(--space-3);box-shadow:var(--shadow-sm);flex-direction:column;display:flex}.dark .reports-po-bar{background:var(--surface);border-color:#ffffff0f}.reports-po-bar-title{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);font-weight:700}.reports-po-chips{gap:var(--space-2);grid-template-columns:repeat(4,1fr);display:grid}.reports-po-chip{padding:var(--space-3) var(--space-2);border-radius:var(--radius-md);text-align:center;background:var(--surface-sunken);flex-direction:column;gap:4px;display:flex}.dark .reports-po-chip{background:#ffffff0a}.reports-po-chip span{font-family:var(--font-display);font-size:var(--text-xl);font-variant-numeric:tabular-nums;color:var(--text-primary);font-weight:800}.reports-po-chip small{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:600}.reports-po-chip[data-kind=draft] span{color:var(--text-secondary)}.reports-po-chip[data-kind=confirmed] span{color:var(--primary)}.reports-po-chip[data-kind=partial] span{color:var(--status-pending,#ff9500)}.reports-po-chip[data-kind=received] span{color:var(--status-success,#34c759)}.reports-empty{align-items:center;gap:var(--space-2);padding:var(--space-6);color:var(--text-tertiary);font-size:var(--text-sm);flex-direction:column;display:flex}.reports-empty .material-symbols-outlined{color:var(--status-alert,#ff3b30);font-size:48px}.fa-page{gap:var(--space-4);flex-direction:column;width:100%;max-width:720px;margin:0 auto;display:flex}.fa-run-picker{gap:var(--space-2);scrollbar-width:none;padding:2px;display:flex;overflow-x:auto}.fa-run-picker::-webkit-scrollbar{display:none}.fa-run-btn{border-radius:var(--radius-md);border:1px solid var(--surface-sunken);background:var(--surface-raised);cursor:pointer;flex-direction:column;flex-shrink:0;align-items:flex-start;gap:2px;padding:8px 14px;transition:all .12s;display:flex}.dark .fa-run-btn{background:var(--surface);border-color:#ffffff0f}.fa-run-btn.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.fa-run-num{font-family:var(--font-mono,"SF Mono", monospace);font-size:var(--text-sm);font-weight:700}.fa-run-date{font-size:var(--text-xs);opacity:.7}.fa-run-head{padding:var(--space-4);border-radius:var(--radius-lg);background:var(--surface-raised);border:1px solid var(--surface-sunken);box-shadow:var(--shadow-sm);gap:var(--space-3);flex-direction:column;display:flex}.dark .fa-run-head{background:var(--surface);border-color:#ffffff0f}.fa-run-num-big{font-family:var(--font-display);font-size:var(--text-2xl);color:var(--text-primary);letter-spacing:-.02em;font-variant-numeric:tabular-nums;font-weight:800}.fa-run-meta{align-items:center;gap:var(--space-2);display:flex}.fa-run-status{font-size:var(--text-xs);letter-spacing:.05em;background:var(--surface-sunken);color:var(--text-secondary);border-radius:999px;padding:3px 10px;font-weight:700}.fa-run-status[data-status=DRAFT]{background:var(--status-pending-bg,#ff95001f);color:var(--status-pending,#ff9500)}.fa-run-status[data-status=IN_PROGRESS]{background:var(--primary-subtle);color:var(--primary)}.fa-run-assignee{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:600}.fa-run-counts{gap:var(--space-2);grid-template-columns:repeat(3,1fr);display:grid}.fa-count-pill{padding:var(--space-3) var(--space-2);border-radius:var(--radius-md);text-align:center;background:var(--surface-sunken);flex-direction:column;gap:4px;display:flex}.dark .fa-count-pill{background:#ffffff0a}.fa-count-pill span{font-family:var(--font-display);font-size:var(--text-2xl);font-variant-numeric:tabular-nums;font-weight:800;line-height:1}.fa-count-pill small{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:600}.fa-count-pill[data-kind=matched] span{color:var(--status-success,#34c759)}.fa-count-pill[data-kind=unmatched] span{color:var(--status-alert,#ff3b30)}.fa-count-pill[data-kind=surplus] span{color:var(--status-pending,#ff9500)}.fa-scan-form{align-items:center;gap:var(--space-2);padding:var(--space-2);border-radius:var(--radius-lg);background:var(--surface-raised);border:2px solid var(--primary);box-shadow:var(--shadow-md);transition:all .18s;display:flex}.dark .fa-scan-form{background:var(--surface)}.fa-scan-form:focus-within{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-subtle)}.fa-scan-icon{color:var(--primary);margin-left:var(--space-2);font-size:28px!important}.fa-scan-input{padding:var(--space-3) 0;font-family:var(--font-mono,"SF Mono", monospace);font-size:var(--text-lg);color:var(--text-primary);letter-spacing:.04em;background:0 0;border:none;outline:none;flex:1;min-width:0;font-weight:700}.fa-scan-input::placeholder{color:var(--text-tertiary);letter-spacing:0;font-weight:400}.fa-scan-btn{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);background:var(--primary);color:#fff;font-family:var(--font-display);font-size:var(--text-sm);cursor:pointer;letter-spacing:.02em;border:none;font-weight:700;transition:all .12s}.fa-scan-btn:hover:not(:disabled){transform:translateY(-1px)}.fa-scan-btn:disabled{opacity:.4;cursor:not-allowed}.fa-camera-btn{border-radius:var(--radius-md);border:1px solid var(--primary);width:44px;height:44px;color:var(--primary);cursor:pointer;background:0 0;flex-shrink:0;place-items:center;transition:all .12s;display:grid}.fa-camera-btn:hover:not(:disabled){background:var(--primary-subtle)}.fa-camera-btn:disabled{opacity:.4;cursor:not-allowed}.fa-camera-btn .material-symbols-outlined{font-size:22px}body.native-scan-active{background:0 0!important}body.native-scan-active .app-layout{visibility:hidden}.fa-history{gap:var(--space-2);flex-direction:column;display:flex}.fa-history-title{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);padding:0 2px;font-weight:700}.fa-history-list{gap:var(--space-2);flex-direction:column;display:flex}.fa-history-row{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);background:var(--surface-raised);border:1px solid var(--surface-sunken);animation:.28s both row-in;display:flex}.dark .fa-history-row{background:var(--surface);border-color:#ffffff0f}@keyframes row-in{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.fa-history-icon .material-symbols-outlined{font-size:28px}.fa-history-row[data-status=COUNTED] .fa-history-icon{color:var(--status-success,#34c759)}.fa-history-row[data-status=SURPLUS] .fa-history-icon{color:var(--status-pending,#ff9500)}.fa-history-row[data-status=DUPLICATE] .fa-history-icon{color:var(--status-alert,#ff3b30)}.fa-history-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.fa-history-num{font-family:var(--font-mono,"SF Mono", monospace);font-size:var(--text-sm);color:var(--text-primary);font-weight:700}.fa-history-name{font-size:var(--text-xs);color:var(--text-tertiary)}.fa-history-meta{flex-direction:column;align-items:flex-end;gap:2px;display:flex}.fa-history-status{font-size:var(--text-xs);letter-spacing:.03em;font-weight:700}.fa-history-row[data-status=COUNTED] .fa-history-status{color:var(--status-success,#34c759)}.fa-history-row[data-status=SURPLUS] .fa-history-status{color:var(--status-pending,#ff9500)}.fa-history-row[data-status=DUPLICATE] .fa-history-status{color:var(--status-alert,#ff3b30)}.fa-history-time{font-size:var(--text-xs);color:var(--text-tertiary);font-variant-numeric:tabular-nums}.fa-empty{margin-top:var(--space-8);align-items:center;gap:var(--space-3);padding:var(--space-6) var(--space-4);text-align:center;flex-direction:column;display:flex}.fa-empty .material-symbols-outlined{color:var(--text-tertiary);font-size:64px}.fa-empty-title{font-family:var(--font-display);font-size:var(--text-lg);color:var(--text-primary);font-weight:700}.fa-empty-body{font-size:var(--text-sm);color:var(--text-tertiary);max-width:320px;line-height:1.5}.fa-complete-btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3);border-radius:var(--radius-md);border:1px solid var(--status-success,#34c759);color:var(--status-success,#34c759);font-size:var(--text-sm);cursor:pointer;background:0 0;font-weight:700;transition:all .12s;display:flex}.fa-complete-btn:hover:not(:disabled){background:var(--status-success-bg,#34c7591a)}.fa-complete-btn:disabled{opacity:.5;cursor:not-allowed}.fa-complete-btn .material-symbols-outlined{font-size:20px}.call-screen{z-index:100;color:#fff;background:linear-gradient(#0b1220 0%,#050a14 100%);flex-direction:column;justify-content:space-between;align-items:center;animation:.26s ease-out both call-in;display:flex;position:fixed;inset:0;overflow:hidden}@keyframes call-in{0%{opacity:0;transform:scale(1.02)}to{opacity:1;transform:scale(1)}}.call-remote-video{object-fit:cover;background:#000;width:100%;height:100%;position:absolute;inset:0}.call-local-video{aspect-ratio:3/4;object-fit:cover;z-index:2;background:#000;border:2px solid #ffffff4d;border-radius:12px;width:110px;position:absolute;top:56px;right:16px;box-shadow:0 8px 24px #00000080}.call-caller{z-index:2;text-align:center;flex-direction:column;align-items:center;gap:14px;margin-top:14vh;padding:0 24px;display:flex}.call-screen[data-kind=video][data-state=connected] .call-caller{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#00000073;border-radius:24px;flex-direction:row;gap:10px;margin-top:24px;padding:8px 16px}.call-screen[data-kind=video][data-state=connected] .call-avatar{width:40px;height:40px;font-size:1rem}.call-screen[data-kind=video][data-state=connected] .call-name{font-size:.95rem}.call-screen[data-kind=video][data-state=connected] .call-status{font-size:.75rem}.call-avatar{background:linear-gradient(135deg, var(--primary,#0071e3), #4d9beb);color:#fff;width:120px;height:120px;font-family:var(--font-display);letter-spacing:.03em;border-radius:50%;place-items:center;font-size:2.5rem;font-weight:700;animation:2.4s ease-in-out infinite call-avatar-pulse;display:grid;box-shadow:0 12px 40px #0006}.call-screen[data-state=connected] .call-avatar{animation:none}@keyframes call-avatar-pulse{0%,to{box-shadow:0 0 #0071e373,0 12px 40px #0006}50%{box-shadow:0 0 0 18px #0071e300,0 12px 40px #0006}}.call-name{font-family:var(--font-display);letter-spacing:-.02em;font-size:1.75rem;font-weight:700}.call-status{color:#ffffffb3;font-variant-numeric:tabular-nums;font-size:.95rem}.call-actions{z-index:2;padding:32px 24px calc(32px + env(safe-area-inset-bottom));background:linear-gradient(#0000 0%,#00000059 100%);justify-content:center;align-items:center;gap:24px;width:100%;display:flex}.call-btn{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff26;border:none;border-radius:50%;place-items:center;width:68px;height:68px;transition:transform .12s,background .16s;display:grid}.call-btn:hover:not(:disabled){transform:scale(1.05)}.call-btn:active:not(:disabled){transform:scale(.95)}.call-btn .material-symbols-outlined{font-size:30px}.call-btn-toggle.active{color:#000;background:#ffffffe6}.call-btn-accept{background:#34c759;box-shadow:0 8px 24px #34c75980}.call-btn-reject,.call-btn-end{background:#ff3b30;box-shadow:0 8px 24px #ff3b3080}.call-btn-accept:hover:not(:disabled){background:#2ba84a}.call-btn-reject:hover:not(:disabled),.call-btn-end:hover:not(:disabled){background:#d70015}:root{--rail-width-full:clamp(240px, 18vw, 312px);--rail-width-compact:72px;--nav-item-height:clamp(44px, 4vw, 52px);--nav-icon-size:clamp(22px, 1.6vw, 26px);--top-bar:clamp(52px, 5vw, 64px);--tenant-w:var(--primary);--tenant-p:var(--status-complete);--tenant-y:var(--secondary);--gradient-rail:linear-gradient(180deg, var(--surface-raised) 0%, var(--canvas) 100%);--gradient-active-wash:linear-gradient(90deg, var(--primary-subtle) 0%, transparent 100%)}.dark{--gradient-rail:linear-gradient(180deg, var(--surface-raised) 0%, var(--surface) 100%)}.rail{-webkit-backdrop-filter:saturate(180%)blur(24px);backdrop-filter:saturate(180%)blur(24px);height:100%;width:var(--rail-width-full);background:#ffffffb8;border-right:.5px solid #0000000f;flex-direction:column;flex-shrink:0;display:flex;position:relative;overflow:hidden}.dark .rail{background:#182028c7;border-right-color:#ffffff0f}.rail:after{content:"";pointer-events:none;background:linear-gradient(180deg, transparent 0%, var(--surface-sunken) 15%, var(--surface-sunken) 85%, transparent 100%);width:1px;position:absolute;top:0;bottom:0;right:0}.dark .rail:after{background:linear-gradient(#0000 0%,#ffffff0f 15% 85%,#0000 100%)}.rail-header{padding:var(--space-5) var(--space-4) var(--space-4);gap:var(--space-4);border-bottom:1px dashed var(--surface-sunken);flex-direction:column;display:flex}.dark .rail-header{border-bottom-color:#ffffff0f}.rail-logo{align-items:center;gap:var(--space-3);display:flex}.rail-logo-mark{border-radius:var(--radius-md);background:var(--gradient-cta);width:36px;height:36px;box-shadow:var(--shadow-sm);flex-shrink:0;place-items:center;display:grid;position:relative;overflow:hidden}.rail-logo-mark:before{content:"";background:#fff3;border-radius:50%;width:60%;height:60%;position:absolute;top:-30%;left:-30%}.rail-logo-mark .material-symbols-outlined{color:#fff;font-variation-settings:"FILL" 1, "wght" 500;z-index:1;font-size:20px;position:relative}.rail-logo-text{flex-direction:column;min-width:0;display:flex}.rail-logo-name{font-family:var(--font-display);font-size:var(--text-lg);color:var(--text-primary);letter-spacing:-.02em;font-weight:800;line-height:1}.rail-logo-name span{color:var(--primary)}.rail-logo-sub{font-size:var(--text-xs);color:var(--text-tertiary);font-family:var(--font-mono);letter-spacing:.08em;margin-top:var(--space-1);text-transform:uppercase}.tenant-card{padding:var(--space-3);border-radius:var(--radius-md);background:var(--surface-raised);border:1px solid var(--surface-sunken);align-items:center;gap:var(--space-3);cursor:pointer;transition:all var(--transition-base);text-align:left;width:100%;display:flex}.dark .tenant-card{background:#ffffff08;border-color:#ffffff14}.tenant-card:hover{background:var(--hover-overlay)}.tenant-card:active{transform:scale(.98)}.tenant-badge{border-radius:var(--radius-sm);width:30px;height:30px;font-family:var(--font-display);font-weight:800;font-size:var(--text-sm);color:#fff;flex-shrink:0;place-items:center;display:grid;box-shadow:inset 0 1px #fff3}.tenant-badge[data-t=W]{background:var(--tenant-w)}.tenant-badge[data-t=P]{background:var(--tenant-p)}.tenant-badge[data-t=Y]{background:var(--tenant-y)}.tenant-info{flex:1;min-width:0}.tenant-name{font-family:var(--font-display);font-size:var(--text-sm);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:700;line-height:1.2;overflow:hidden}.tenant-code{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-tertiary);letter-spacing:.08em;font-variant-numeric:tabular-nums;white-space:nowrap;text-overflow:ellipsis;margin-top:2px;overflow:hidden}.tenant-chevron{color:var(--text-tertiary);font-size:18px}.rail-scroll{padding:var(--space-3) 0;scrollbar-width:thin;scrollbar-color:var(--surface-sunken) transparent;flex-direction:column;flex:1;display:flex;overflow-y:auto}.rail-section-last{margin-top:auto}.rail-scroll::-webkit-scrollbar{width:4px}.rail-scroll::-webkit-scrollbar-thumb{background:var(--surface-sunken);border-radius:2px}.nav-section-label{padding:0 var(--space-5) var(--space-2);font-family:var(--font-display);font-size:var(--text-xs);letter-spacing:.12em;color:var(--text-tertiary);text-transform:uppercase;font-weight:700}.nav-section-label+.nav-section-label,.nav-section-label:not(:first-child){margin-top:var(--space-4)}.nav-item{align-items:center;gap:var(--space-4);height:var(--nav-item-height);padding:0 var(--space-4);margin:2px var(--space-2);border-radius:var(--radius-md);cursor:pointer;color:var(--text-secondary);transition:color var(--transition-fast), background var(--transition-fast);font-family:var(--font-display);font-size:var(--text-base);-webkit-tap-highlight-color:transparent;font-weight:600;text-decoration:none;display:flex;position:relative}.nav-item:hover{background:var(--hover-overlay);color:var(--text-primary)}.nav-item .nav-icon{font-size:var(--nav-icon-size);font-variation-settings:"wght" 400;flex-shrink:0}.nav-item.active{color:var(--primary);box-shadow:none;background:#0071e31a;font-weight:600}.nav-item.active .nav-icon{font-variation-settings:"FILL" 1, "wght" 500}.nav-item-label{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.nav-badge{min-width:20px;height:20px;padding:0 var(--space-2);background:var(--destructive);color:#fff;font-family:var(--font-mono);font-size:var(--text-xs);border-radius:var(--radius-full);font-variant-numeric:tabular-nums;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:inline-flex}.nav-item.active .nav-badge{background:var(--primary)}.nav-lock{color:var(--text-tertiary);opacity:.7;flex-shrink:0;font-size:14px!important}.rail-footer{padding:var(--space-3) var(--space-3) var(--space-4);border-top:1px dashed var(--surface-sunken);gap:var(--space-3);flex-direction:column;display:flex}.dark .rail-footer{border-top-color:#ffffff0f}.user-card{align-items:center;gap:var(--space-3);padding:var(--space-2);border-radius:var(--radius-md);background:var(--surface-raised);border:1px solid var(--surface-sunken);display:flex}.dark .user-card{background:#ffffff08;border-color:#ffffff14}.user-avatar{background:linear-gradient(135deg, var(--secondary), var(--secondary-container));width:32px;height:32px;font-family:var(--font-display);color:#fff;font-weight:800;font-size:var(--text-sm);border-radius:50%;flex-shrink:0;place-items:center;display:grid;box-shadow:inset 0 1px #fff3}.user-info{flex:1;min-width:0}.user-name{font-family:var(--font-display);font-size:var(--text-sm);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-weight:700;overflow:hidden}.user-role{font-size:var(--text-xs);color:var(--text-tertiary);font-family:var(--font-mono);letter-spacing:.05em;white-space:nowrap;text-overflow:ellipsis;margin-top:2px;overflow:hidden}.util-row{gap:var(--space-1);grid-template-columns:repeat(4,1fr);display:grid}.util-btn{border-radius:var(--radius-sm);cursor:pointer;height:36px;color:var(--text-secondary);transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent;background:0 0;border:none;place-items:center;display:grid;position:relative}.util-btn:hover{background:var(--hover-overlay);color:var(--text-primary)}.util-btn:active{transform:scale(.92)}.util-btn .material-symbols-outlined{font-size:18px}.util-btn-dot{background:var(--destructive);width:8px;height:8px;box-shadow:0 0 0 2px var(--surface-raised);border-radius:50%;position:absolute;top:6px;right:8px}.dark .util-btn-dot{box-shadow:0 0 0 2px var(--surface)}.rail.rail-compact{width:var(--rail-width-compact)}.rail-compact .rail-header{padding:var(--space-5) var(--space-3) var(--space-4);align-items:center}.rail-compact .rail-logo{justify-content:center}.rail-compact .rail-logo-text{display:none}.rail-compact .tenant-card{border-radius:var(--radius-md);background:0 0;border:none;justify-content:center;width:40px;height:40px;padding:0}.rail-compact .tenant-card:hover{background:var(--hover-overlay);box-shadow:none;border-color:#0000}.rail-compact .tenant-info,.rail-compact .tenant-chevron,.rail-compact .nav-section-label{display:none}.rail-compact .nav-item{justify-content:center;gap:0;width:44px;margin:3px auto;padding:0}.rail-compact .nav-item-label,.rail-compact .nav-lock{display:none}.rail-compact .nav-badge{min-width:16px;height:16px;padding:0 var(--space-1);box-shadow:0 0 0 2px var(--surface-raised);font-size:9px;position:absolute;top:4px;right:4px}.dark .rail-compact .nav-badge{box-shadow:0 0 0 2px var(--surface)}.rail-compact .rail-footer{padding:var(--space-3) var(--space-3) var(--space-4)}.rail-compact .user-card{background:0 0;border:none;justify-content:center;width:40px;height:40px;padding:0}.rail-compact .user-info{display:none}.rail-compact .util-row{grid-template-columns:1fr;gap:2px}.phone-drawer-scrim{z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0a0f1373;animation:.2s cubic-bezier(.22,1,.36,1) scrim-fade-in;position:fixed;inset:0}@keyframes scrim-fade-in{0%{opacity:0}to{opacity:1}}.phone-drawer{z-index:101;background:var(--gradient-rail);width:280px;box-shadow:var(--shadow-float);animation:drawer-slide-in var(--transition-slow);padding-top:var(--safe-top);padding-bottom:var(--safe-bottom);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0}@keyframes drawer-slide-in{0%{transform:translate(-100%)}to{transform:translate(0)}}.phone-drawer:before{content:"";pointer-events:none;background:linear-gradient(90deg,#0000001f 0%,#0000 100%);width:8px;position:absolute;top:0;bottom:0;right:-8px}.app-layout{height:100dvh;display:flex;position:relative;overflow:hidden}.content-area{background:var(--canvas);flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.top-bar{height:var(--top-bar);align-items:center;gap:var(--space-3);padding:var(--safe-top) var(--space-4) 0;padding-left:calc(var(--safe-left) + var(--space-4));padding-right:calc(var(--safe-right) + var(--space-4));-webkit-backdrop-filter:saturate(180%)blur(24px);backdrop-filter:saturate(180%)blur(24px);z-index:20;box-sizing:content-box;background:#f5f5f7b8;border-bottom:.5px solid #0000000f;flex-shrink:0;display:flex;position:relative}.dark .top-bar{background:#182028c7;border-bottom-color:#ffffff0f}.top-bar-menu{border-radius:var(--radius-md);cursor:pointer;width:36px;height:36px;color:var(--text-secondary);-webkit-tap-highlight-color:transparent;transition:background var(--transition-fast);background:0 0;border:none;place-items:center;display:grid}.top-bar-menu:active{background:var(--hover-overlay)}.top-bar-menu .material-symbols-outlined{font-size:22px}.top-bar-title{font-family:var(--font-display);font-size:var(--text-lg);color:var(--text-primary);letter-spacing:-.01em;white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-weight:700;overflow:hidden}.top-bar-title-sub{font-size:var(--text-xs);color:var(--text-tertiary);font-weight:500;font-family:var(--font-body);margin-left:var(--space-2)}.top-bar-action{border-radius:var(--radius-md);cursor:pointer;width:34px;height:34px;color:var(--text-secondary);-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-shrink:0;place-items:center;display:grid;position:relative}.top-bar-action:active{background:var(--hover-overlay)}.top-bar-action .material-symbols-outlined{font-size:20px}.top-bar-action-dot{background:var(--destructive);border-radius:50%;width:7px;height:7px;position:absolute;top:6px;right:6px}.content-scroll{padding:clamp(var(--space-4), 2vw, var(--space-8));padding-bottom:calc(var(--safe-bottom) + var(--space-4));padding-left:calc(var(--safe-left) + clamp(var(--space-4), 2vw, var(--space-8)));padding-right:calc(var(--safe-right) + clamp(var(--space-4), 2vw, var(--space-8)));flex-direction:column;flex:1;display:flex;overflow-y:auto}.content-scroll:has(>.msg-page){padding:0;overflow:hidden}.content-scroll::-webkit-scrollbar{width:4px}.content-scroll::-webkit-scrollbar-thumb{background:var(--surface-sunken);border-radius:2px}.route-placeholder{gap:clamp(var(--space-3), 1.2vw, var(--space-5));flex:1;grid-template-columns:repeat(auto-fit,minmax(min(260px,100%),1fr));grid-auto-rows:1fr;width:100%;max-width:1400px;min-height:0;margin:0 auto;display:grid}.route-card{padding:clamp(var(--space-4), 1.5vw, var(--space-6));background:var(--surface-raised);border:1px solid var(--surface-sunken);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);gap:var(--space-3);transition:box-shadow var(--transition-base), transform var(--transition-base);flex-direction:column;min-height:180px;display:flex}.dark .route-card{background:var(--surface);border-color:#ffffff0f}.route-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.route-card.route-card-hero{background:var(--gradient-rail);padding:clamp(var(--space-5), 2vw, var(--space-8));grid-column:1/-1;justify-content:center;min-height:220px}.route-card h2{font-family:var(--font-display);font-size:clamp(var(--text-xl), 1.6vw, var(--text-3xl));color:var(--text-primary);letter-spacing:-.02em;font-weight:800;line-height:1.1}.route-card h3{font-family:var(--font-display);font-size:var(--text-base);color:var(--text-primary);letter-spacing:-.01em;font-weight:700}.route-card p{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.6}.route-card code{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--primary);background:var(--primary-subtle);padding:2px var(--space-2);border-radius:var(--radius-sm);font-variant-numeric:tabular-nums}.route-card-icon{border-radius:var(--radius-md);background:var(--primary-subtle);width:40px;height:40px;color:var(--primary);flex-shrink:0;place-items:center;display:grid}.route-card-icon .material-symbols-outlined{font-size:22px}:root{--canvas:#f5f5f7;--surface:#f5f5f7;--surface-raised:#fff;--surface-sunken:#fafafc;--surface-overlay:#ffffffeb;--primary:#0071e3;--primary-hover:#06c;--primary-container:#5ac8fa;--primary-subtle:#0071e31a;--primary-on:#fff;--secondary:#ff9500;--secondary-hover:#e68600;--secondary-container:#ffb74d;--secondary-subtle:#ff95001a;--secondary-on:#fff;--destructive:#ff3b30;--destructive-hover:#d70015;--destructive-subtle:#ff3b301a;--status-complete:#34c759;--status-complete-bg:#34c7591a;--status-success:#34c759;--status-success-bg:#34c7591a;--status-active:#0071e3;--status-active-bg:#0071e31a;--status-pending:#ff9500;--status-pending-bg:#ff95001a;--status-alert:#ff3b30;--status-alert-bg:#ff3b301a;--status-idle:#8e8e93;--status-idle-bg:#8e8e931a;--cat-ink:#ff9500;--cat-screen:#af52de;--cat-film:#34c759;--cat-chemical:#ff3b30;--node-approver:var(--secondary-container);--node-cc:var(--status-active);--node-condition:var(--cat-screen);--text-primary:#1d1d1f;--text-secondary:#3a3a3c;--text-tertiary:#6e6e73;--text-inverse:#f5f5f7;--focus-ring:#0071e366;--hover-overlay:#0000000a;--border:#0000000f;--border-default:#0000000f;--border-strong:#0000001a;--shadow-sm:0 1px 2px #0000000a;--shadow-md:0 2px 8px #0000000f;--shadow-lg:0 8px 24px #00000014;--shadow-float:0 12px 40px #0000001f;--gradient-cta:var(--primary);--gradient-cta-hover:var(--primary-hover);--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--radius-full:9999px;--font-display:"Manrope", system-ui, -apple-system, "Segoe UI", sans-serif;--font-body:"Inter", system-ui, -apple-system, "Segoe UI", sans-serif;--font-tc:"Noto Sans TC", "PingFang TC", "Microsoft JhengHei", sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace;--text-xs:clamp(.6875rem, .65rem + .1vw, .75rem);--text-sm:clamp(.75rem, .7rem + .15vw, .8125rem);--text-base:clamp(.8125rem, .78rem + .12vw, .875rem);--text-lg:clamp(.9375rem, .9rem + .15vw, 1rem);--text-xl:clamp(1.125rem, 1rem + .3vw, 1.25rem);--text-2xl:clamp(1.375rem, 1.2rem + .5vw, 1.625rem);--text-3xl:clamp(1.75rem, 1.5rem + .7vw, 2.125rem);--transition-fast:.12s cubic-bezier(.22, 1, .36, 1);--transition-base:.2s cubic-bezier(.22, 1, .36, 1);--transition-slow:.35s cubic-bezier(.22, 1, .36, 1);--nav-height-t1:52px;--nav-height-t2:44px;--nav-height-t3:38px;--nav-total:calc(var(--nav-height-t1) + var(--nav-height-t2) + var(--nav-height-t3) + 2px);--background:var(--canvas);--foreground:var(--text-primary);--gpl-primary:var(--primary);--gpl-primary-container:var(--primary-container);--gpl-secondary:var(--secondary);--gpl-secondary-container:var(--secondary-container);--gpl-success:var(--status-complete);--gpl-warning:var(--status-pending);--gpl-error:var(--destructive);--bg-primary:var(--canvas);--bg-secondary:var(--surface);--bg-card:var(--surface-raised);--card-bg:var(--surface-raised);--content-bg:var(--canvas);--success:var(--status-complete);--warning:var(--status-pending);--error:var(--destructive);--info:var(--status-active);--color-accent:var(--secondary)}html.dark{--canvas:#000;--surface:#1c1c1e;--surface-raised:#2c2c2e;--surface-sunken:#18181a;--surface-overlay:#1c1c1eeb;--primary:#0a84ff;--primary-hover:#409cff;--primary-container:#64d2ff;--primary-subtle:#0a84ff29;--primary-on:#fff;--secondary:#ff9f0a;--secondary-hover:#ffb340;--secondary-container:#ffd60a;--secondary-subtle:#ff9f0a29;--secondary-on:#000;--destructive:#ff453a;--destructive-hover:#ff6961;--destructive-subtle:#ff453a29;--status-complete:#30d158;--status-complete-bg:#30d15829;--status-success:#30d158;--status-success-bg:#30d15829;--status-active:#0a84ff;--status-active-bg:#0a84ff29;--status-pending:#ff9f0a;--status-pending-bg:#ff9f0a29;--status-alert:#ff453a;--status-alert-bg:#ff453a29;--status-idle:#8e8e93;--status-idle-bg:#8e8e9329;--cat-ink:#ff9f0a;--cat-screen:#bf5af2;--cat-film:#30d158;--cat-chemical:#ff453a;--node-approver:var(--secondary-container);--node-cc:var(--status-active);--node-condition:var(--cat-screen);--text-primary:#f5f5f7;--text-secondary:#aeaeb2;--text-tertiary:#8e8e93;--text-inverse:#1d1d1f;--focus-ring:#0a84ff66;--hover-overlay:#ffffff0f;--border:#ffffff1a;--border-default:#ffffff1a;--border-strong:#ffffff29;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 2px 8px #0006;--shadow-lg:0 8px 24px #00000080;--shadow-float:0 12px 40px #0009;--gradient-cta:var(--primary);--gradient-cta-hover:var(--primary-hover);--background:var(--canvas);--foreground:var(--text-primary);--bg-primary:var(--canvas);--bg-secondary:var(--surface);--bg-card:var(--surface-raised);--card-bg:var(--surface-raised);--content-bg:var(--canvas);--success:var(--status-complete);--warning:var(--status-pending);--error:var(--destructive);--info:var(--status-active)}@theme inline{--color-background: var(--background); --color-foreground: var(--foreground); --font-sans: var(--font-body); --font-mono: var(--font-mono); --font-headline: var(--font-display); --font-label: var(--font-display);}body{font-family:var(--font-body);font-size:var(--text-base);color:var(--text-primary);background:var(--canvas);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5;transition:background .4s,color .4s}html[lang=zh-TW] body,html[lang=zh-TW] *{font-family:var(--font-body), "PingFang TC", "Microsoft JhengHei", sans-serif}html[lang=zh-TW] h1,html[lang=zh-TW] h2,html[lang=zh-TW] h3{font-family:var(--font-display), "PingFang TC", sans-serif}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--surface-sunken);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}:root{--blue:#0071e3;--blue-press:#06c;--blue-soft:#e8f1fe;--blue-tint:#0071e32e;--green:#34c759;--green-soft:#34c7591a;--orange:#ff9500;--orange-press:#e68600;--orange-soft:#ff95001a;--orange-tint:#ff95002e;--red:#ff3b30;--red-press:#d70015;--red-soft:#ff3b301a;--bg-base:#f5f5f7;--card:#fff;--card-2:#fafafc;--line:#0000000f;--line-2:#0000001a;--t-display:#1d1d1f;--t-body:#3a3a3c;--t-muted:#6e6e73;--t-faint:#8e8e93;--hover-tint:#0000000a;--r-card:14px;--r-pill:980px;--r-btn:10px;--r-input:10px}*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-body);font-size:var(--text-base);color:var(--text-primary);background:var(--canvas);min-height:100dvh;line-height:1.5;overflow-x:hidden}:root{--safe-top:env(safe-area-inset-top);--safe-bottom:env(safe-area-inset-bottom);--safe-left:env(safe-area-inset-left);--safe-right:env(safe-area-inset-right)}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer;background:0 0;border:none}a{color:inherit;text-decoration:none}.pull-to-refresh{overflow-anchor:none;touch-action:pan-y;position:relative}.ptr-indicator{color:var(--primary);pointer-events:none;justify-content:center;align-items:center;transition:height .18s;display:flex;position:absolute;top:0;left:0;right:0;overflow:hidden}.ptr-indicator .material-symbols-outlined{font-size:22px;transition:transform .12s linear}.ptr-indicator[data-refreshing] .material-symbols-outlined{animation:.9s linear infinite ptr-spin}@keyframes ptr-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ptr-content{will-change:transform}.offline-banner{z-index:9999;justify-content:center;align-items:center;gap:var(--space-2);background:var(--status-alert,#ff3b30);color:#fff;font-size:var(--text-sm);text-align:center;padding:8px 12px;font-weight:600;animation:.22s ease-out both offline-slide;display:flex;position:fixed;top:0;left:0;right:0;box-shadow:0 2px 8px #00000026}.offline-banner .material-symbols-outlined{font-size:18px}@keyframes offline-slide{0%{transform:translateY(-100%)}to{transform:translateY(0)}}
