*{box-sizing:border-box;margin:0;padding:0}body,html{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;background:#f6f7f9;color:#1a1a1a}a{color:inherit;text-decoration:none}.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:16px}.login-card{width:100%;max-width:400px;background:#fff;border-radius:16px;padding:40px 32px;box-shadow:0 20px 60px rgba(0,0,0,.15)}.login-title{font-size:24px;font-weight:700;margin-bottom:4px;color:#1a1a1a}.login-sub{font-size:14px;color:#888;margin-bottom:28px}.login-field{margin-bottom:16px}.login-field label{display:block;font-size:13px;color:#555;margin-bottom:6px;font-weight:500}.login-field input{width:100%;padding:12px 14px;border:1px solid #d8dde5;border-radius:8px;font-size:15px;transition:border .15s;background:#fff;color:#1a1a1a}.login-field input:focus{outline:none;border-color:#667eea}.login-btn{width:100%;padding:12px;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;margin-top:8px;transition:background .15s}.login-btn:hover:not(:disabled){background:#5568d3}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{margin-top:12px;padding:10px 12px;background:#fee;border:1px solid #fcc;border-radius:6px;color:#c33;font-size:13px}.login-hint{margin-top:20px;font-size:12px;color:#999;text-align:center;line-height:1.6}.protected-shell{display:flex;flex-direction:column;height:100vh}.protected-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:#1f2330;color:#fff;border-bottom:1px solid #2c3142;flex-shrink:0}.protected-bar-left{display:flex;align-items:center;gap:12px;font-size:14px}.protected-bar-avatar{width:28px;height:28px;border-radius:50%;background:#667eea;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;color:#fff}.protected-bar-email{font-weight:500}.protected-bar-tag{font-size:11px;padding:2px 8px;background:rgba(102,126,234,.2);border-radius:10px;color:#a5b3f5}.protected-bar-actions{display:flex;gap:8px}.protected-btn{padding:6px 12px;background:hsla(0,0%,100%,.08);color:#fff;border:1px solid hsla(0,0%,100%,.12);border-radius:6px;font-size:13px;cursor:pointer;transition:background .15s}.protected-btn:hover{background:hsla(0,0%,100%,.15)}.protected-btn-logout{background:rgba(220,80,80,.15);border-color:rgba(220,80,80,.3)}.protected-btn-logout:hover{background:rgba(220,80,80,.25)}.protected-iframe{flex:1 1;width:100%;border:none;background:#fff}