.install-banner{z-index:9998;background:#fff;border-top:1px solid #e8e8e8;justify-content:space-between;align-items:center;gap:12px;padding:14px 20px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 12px #0000001a}*,:before,:after{box-sizing:border-box}html,body{-webkit-font-smoothing:antialiased;color:#242424;-webkit-tap-highlight-color:transparent;background:#f5f5f5;height:100%;margin:0;padding:0;font-family:Segoe UI Variable,Segoe UI,system-ui,-apple-system,sans-serif}#app{height:100%;min-height:100dvh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:silver;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#909090}fluent-button[appearance=accent]{--accent-fill-rest:#3d9970;--accent-fill-hover:#2e7a58;--accent-fill-active:#256147}fluent-text-field::part(root){width:100%}.page-card{background:#fff;border:1px solid #e8e8e8;border-radius:10px;padding:20px 24px;box-shadow:0 1px 4px #0000000f}.page-content{max-width:720px;min-height:100%;padding:24px 28px}.page-title{color:#242424;margin:0 0 4px;font-size:20px;font-weight:600}.page-subtitle{color:#767676;margin:0 0 24px;font-size:13px}.form-field{flex-direction:column;gap:4px;margin-bottom:16px;display:flex}.form-field label{color:#242424;font-size:13px;font-weight:600}.badge{border-radius:12px;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-success{color:#107c10;background:#dff6dd}.badge-danger{color:#c4314b;background:#fde7e9}.badge-warning{color:#7d5a00;background:#fff4ce}.badge-info{color:#0078d4;background:#deecf9}.badge-neutral{color:#616161;background:#f0f0f0}#toast-container{z-index:9999;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}#toast-container>*{pointer-events:auto}.toast{background:#fff;border:1px solid #e0e0e0;border-radius:8px;align-items:center;gap:10px;min-width:240px;max-width:360px;padding:12px 16px;font-size:13px;animation:.25s slideIn;display:flex;box-shadow:0 4px 16px #0000001f}.toast.success{border-left:3px solid #107c10}.toast.error{border-left:3px solid #c4314b}.toast.warning{border-left:3px solid #c68a00}.toast.info{border-left:3px solid #0078d4}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.qr-code{aspect-ratio:1;border-radius:10px;width:min(300px,80vw);height:auto}.qr-container{flex-direction:column;align-items:center;gap:20px;display:flex}.login-page{background:#f5f5f5;min-height:100dvh;display:flex}.brand-panel{background:linear-gradient(160deg,#1a6644 0%,#3d9970 60%,#56a882 100%);flex-direction:column;flex-shrink:0;justify-content:flex-end;align-items:flex-start;width:420px;padding:48px;display:flex}.brand-logo{background:#fff;border-radius:16px;width:260px;max-width:100%;height:auto;margin-bottom:28px;padding:24px 28px;display:block;box-shadow:0 8px 24px #00000024}.brand-title{color:#fffffff2;margin-bottom:8px;font-size:20px;font-weight:600}.brand-sub{color:#ffffffb3;font-size:13px;line-height:1.5}.brand-dots{gap:6px;margin-top:32px;display:flex}.brand-dot{background:#fff6;border-radius:50%;width:6px;height:6px}.brand-dot.active{background:#fff;border-radius:3px;width:20px}.form-panel{flex:1;justify-content:center;align-items:center;padding:40px 24px;display:flex}.form-box{width:100%;max-width:380px}.form-title{color:#242424;margin:0 0 6px;font-size:24px;font-weight:600}.form-sub{color:#767676;margin:0 0 28px;font-size:13px}.alert-error{color:#c4314b;background:#fde7e9;border-left:3px solid #c4314b;border-radius:6px;margin-bottom:16px;padding:10px 14px;font-size:13px}.alert-success{color:#107c10;background:#dff6dd;border-left:3px solid #107c10;border-radius:6px;margin-bottom:16px;padding:10px 14px;font-size:13px}.extra-links{text-align:center;margin-top:20px}.extra-links a{color:#3d9970;font-size:13px;text-decoration:none}.extra-links a:hover{text-decoration:underline}.brand-header{text-align:center;background:linear-gradient(135deg,#1a6644 0%,#3d9970 100%);padding:28px 20px 20px;display:none}.brand-header-logo{background:#fff;border-radius:14px;width:200px;max-width:82%;height:auto;padding:16px 22px;display:inline-block;box-shadow:0 6px 18px #00000029}.brand-header-sub{color:#ffffffb3;letter-spacing:.5px;margin-top:4px;font-size:11px}.home-greeting{align-items:center;gap:14px;margin-bottom:24px;display:flex}.home-avatar{color:#fff;background:linear-gradient(135deg,#1a6644,#3d9970);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:18px;font-weight:700;display:flex}.home-greeting-text{color:#242424;font-size:20px;font-weight:600}.home-greeting-sub{color:#767676;margin-top:2px;font-size:12px}.menu-list{flex-direction:column;gap:10px;display:flex}.menu-item{cursor:pointer;color:inherit;-webkit-tap-highlight-color:transparent;background:#fff;border:1px solid #e8e8e8;border-radius:10px;align-items:center;gap:14px;padding:16px 20px;text-decoration:none;transition:box-shadow .15s,transform .1s;display:flex;box-shadow:0 1px 3px #0000000a}.menu-item:active{transform:scale(.985)}.menu-item:hover{box-shadow:0 2px 8px #00000014}.menu-item-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:22px;display:flex}.menu-item-icon.green{background:#e8f5ee}.menu-item-icon.amber{background:#fff8e8}.menu-item-icon.red{background:#fdecea}.menu-item-label{font-size:15px;font-weight:600}.menu-item-arrow{color:silver;margin-left:auto;font-size:16px}.install-banner{padding:14px 20px;padding-bottom:max(14px, env(safe-area-inset-bottom,14px));z-index:9998;background:#fff;border-top:1px solid #e8e8e8;justify-content:space-between;align-items:center;gap:12px;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -2px 12px #0000001a}.install-banner-text{color:#242424;font-size:14px;font-weight:600}.install-banner-actions{flex-shrink:0;gap:8px;display:flex}.logout-icon{background:#fdecea;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:16px;font-size:28px;display:flex}@media (width<=768px){.page-content{padding:18px 14px}.page-card{border-radius:10px;padding:18px 16px}.page-title{font-size:18px}.page-subtitle{margin-bottom:20px;font-size:13px}.brand-panel{display:none!important}.brand-header{display:block}.login-page{flex-direction:column}.form-panel{flex:1;align-items:flex-start;padding:28px 18px}.form-title{font-size:21px}.form-sub{margin-bottom:24px}.app-subtitle,.quick-actions{display:none}.qr-code{width:min(240px,75vw)}#toast-container{padding-bottom:env(safe-area-inset-bottom,12px);bottom:12px;left:12px;right:12px}.toast{min-width:0;max-width:100%}.install-banner{text-align:center;padding:14px 16px;padding-bottom:max(14px, env(safe-area-inset-bottom,14px));flex-direction:column;gap:10px}}
