:root{color-scheme:light;font-family:PingFang SC,Microsoft YaHei,Inter,system-ui,-apple-system,sans-serif;background:#f0f4fa;color:#1e2635}*{box-sizing:border-box;margin:0;padding:0}body{min-height:100vh;background:radial-gradient(1200px 500px at 10% -10%,rgba(86,140,255,.15),transparent),radial-gradient(1000px 420px at 100% 0%,rgba(20,184,166,.1),transparent),#f0f4fa}.portal-page{min-height:100vh;display:flex;flex-direction:column}.portal-header{background:linear-gradient(135deg,#0d2b5e,#1a4fa0 40%,#2b7cd8);color:#fff;padding:0 32px;display:flex;align-items:center;justify-content:space-between;height:64px;box-shadow:0 2px 12px #00000026;position:relative;z-index:10}.portal-header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent)}.portal-logo{display:flex;align-items:center;gap:14px}.portal-logo-icon{width:38px;height:38px;background:#ffffff26;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:800;border:1px solid rgba(255,255,255,.2)}.portal-logo h1{font-size:20px;font-weight:700;letter-spacing:1px}.portal-logo p{font-size:12px;opacity:.75;margin-top:2px}.portal-user-area{display:flex;align-items:center;gap:12px}.portal-user-info{text-align:right}.portal-user-info .name{font-size:14px;font-weight:600}.portal-user-info .role{font-size:12px;opacity:.7}.portal-logout-btn{padding:7px 16px;border-radius:8px;background:#ffffff1f;color:#fff;border:1px solid rgba(255,255,255,.2);cursor:pointer;font-size:13px;font-weight:600;transition:background .2s}.portal-logout-btn:hover{background:#ffffff38}.portal-body{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;gap:48px}.portal-welcome{text-align:center}.portal-welcome h2{font-size:28px;color:#0d2b5e;margin-bottom:10px}.portal-welcome p{font-size:15px;color:#5b6e92;line-height:1.7}.system-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:32px;max-width:860px;width:100%}.system-card{background:#fffffff2;border:1px solid #dce7fb;border-radius:20px;padding:36px 28px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 8px 32px #2753a90f}.system-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;border-radius:20px 20px 0 0}.system-card.device-card:before{background:linear-gradient(90deg,#2563eb,#06b6d4)}.system-card.claw-card:before{background:linear-gradient(90deg,#f59e0b,#ef4444)}.system-card:hover{transform:translateY(-6px);box-shadow:0 20px 48px #2753a924;border-color:#b6cff9}.system-card-icon{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:28px;margin-bottom:20px}.device-card .system-card-icon{background:linear-gradient(135deg,#eff6ff,#dbeafe)}.claw-card .system-card-icon{background:linear-gradient(135deg,#fffbeb,#fef3c7)}.system-card h3{font-size:22px;color:#0d2b5e;margin-bottom:10px}.system-card .desc{font-size:14px;color:#5b6e92;line-height:1.7;margin-bottom:18px}.system-card .enter-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 24px;border-radius:10px;font-size:14px;font-weight:600;border:none;cursor:pointer;transition:all .2s}.device-card .enter-btn{background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff}.device-card .enter-btn:hover{background:linear-gradient(135deg,#1d4ed8,#2563eb)}.claw-card .enter-btn{background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff}.claw-card .enter-btn:hover{background:linear-gradient(135deg,#d97706,#f59e0b)}.system-card .arrow{font-size:16px;transition:transform .2s}.system-card:hover .arrow{transform:translate(4px)}.system-card .features{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}.system-card .feature-tag{padding:4px 12px;border-radius:20px;font-size:12px;background:#f4f8ff;color:#4b6baf;border:1px solid #e4ecfc}.claw-card .feature-tag{background:#fffbeb;color:#92400e;border-color:#fef3c7}.iframe-view{display:flex;flex-direction:column;height:100vh}.iframe-toolbar{background:#fff;border-bottom:1px solid #e5eaf2;padding:0 24px;display:flex;align-items:center;height:50px;gap:16px;flex-shrink:0}.iframe-back-btn{padding:6px 14px;border-radius:8px;background:#f4f8ff;color:#2458bb;border:1px solid #cedaf2;cursor:pointer;font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px;transition:all .2s}.iframe-back-btn:hover{background:#edf4ff;border-color:#abc5f3}.iframe-title{font-size:15px;font-weight:600;color:#1e2635}.iframe-hint{font-size:12px;color:#7e8fb0}.iframe-container{flex:1;position:relative;background:#f0f4fa}.iframe-container iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.login-page{min-height:100vh;display:grid;place-items:center;padding:24px}.login-card{width:min(460px,100%);background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;border:1px solid #dce7fb;box-shadow:0 16px 48px #2753a91f;padding:40px 32px}.login-card .login-logo{text-align:center;margin-bottom:28px}.login-card .login-logo-icon{width:56px;height:56px;background:linear-gradient(135deg,#0d2b5e,#2b7cd8);border-radius:16px;display:inline-flex;align-items:center;justify-content:center;font-size:26px;color:#fff;font-weight:800;margin-bottom:16px}.login-card .login-logo h1{font-size:26px;color:#0d2b5e;letter-spacing:1px}.login-card .login-logo p{font-size:14px;color:#5b6e92;margin-top:8px}.login-form{display:grid;gap:14px}.login-form input,.login-form select{border-radius:10px;border:1px solid #cedaf2;padding:12px 14px;font-size:14px;background:#fff;outline:none;transition:border-color .2s}.login-form input:focus,.login-form select:focus{border-color:#4f8fff;box-shadow:0 0 0 3px #4f8fff1f}.login-form .system-select{display:grid;grid-template-columns:1fr 1fr;gap:10px}.login-form .system-option{padding:14px;border:2px solid #e5eaf2;border-radius:12px;text-align:center;cursor:pointer;transition:all .2s;background:#fafbff}.login-form .system-option:hover{border-color:#b6cff9;background:#f4f8ff}.login-form .system-option.active{border-color:#2563eb;background:#eff6ff;box-shadow:0 0 0 3px #2563eb1a}.login-form .system-option .opt-icon{font-size:24px;margin-bottom:6px}.login-form .system-option .opt-name{font-size:14px;font-weight:600;color:#1e2635}.login-submit-btn{padding:12px;border-radius:10px;border:none;background:linear-gradient(135deg,#0d2b5e,#2563eb);color:#fff;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s}.login-submit-btn:hover{background:linear-gradient(135deg,#1a3f7a,#1d4ed8)}.login-submit-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{border-radius:10px;background:#fff2f2;border:1px solid #ffcaca;color:#be2f39;padding:10px 14px;font-size:13px}.login-card .login-hint{margin-top:16px;font-size:12px;color:#7e8fb0;text-align:center;line-height:1.8}.login-card .login-hint strong{color:#5b6e92}.toast-container{position:fixed;top:80px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px}.toast{padding:12px 20px;border-radius:10px;font-size:14px;box-shadow:0 8px 24px #0000001f;animation:toast-in .3s ease;max-width:360px}.toast.error{background:#fff2f2;border:1px solid #ffcaca;color:#be2f39}.toast.success{background:#f0fff5;border:1px solid #b8e8c9;color:#119a4a}@keyframes toast-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;flex-direction:column;gap:16px}.loading-spinner{width:36px;height:36px;border:3px solid #e5eaf2;border-top-color:#2563eb;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{font-size:14px;color:#5b6e92}.backend-status{display:flex;align-items:center;gap:6px;font-size:12px;color:#7e8fb0}.status-dot{width:8px;height:8px;border-radius:50%}.status-dot.online{background:#10b981;box-shadow:0 0 6px #10b98166}.status-dot.offline{background:#ef4444;box-shadow:0 0 6px #ef444466}.status-dot.checking{background:#f59e0b;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.iframe-refresh-btn{margin-left:auto;padding:5px 12px;border-radius:6px;background:#f4f8ff;color:#2458bb;border:1px solid #cedaf2;cursor:pointer;font-size:12px;font-weight:600;transition:all .2s}.iframe-refresh-btn:hover{background:#edf4ff;border-color:#abc5f3}.iframe-error-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:16px;background:#f0f4fa}.iframe-error-icon{width:56px;height:56px;border-radius:50%;background:#fff2f2;border:2px solid #ffcaca;color:#ef4444;font-size:28px;font-weight:700;display:flex;align-items:center;justify-content:center}.iframe-error-text{font-size:14px;color:#5b6e92;max-width:400px;text-align:center;line-height:1.7}.iframe-retry-btn{padding:8px 24px;border-radius:8px;background:linear-gradient(135deg,#0d2b5e,#2563eb);color:#fff;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.iframe-retry-btn:hover{background:linear-gradient(135deg,#1a3f7a,#1d4ed8)}button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid #4f8fff;outline-offset:2px}@media (max-width: 700px){.system-cards{grid-template-columns:1fr;gap:20px}.portal-header{padding:0 16px}.portal-welcome h2{font-size:22px}.system-card{padding:24px 20px}.login-card{padding:28px 20px}}
