body{color:#0f172a;background:#f8fafc;margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}.shell{flex-direction:column;min-height:100vh;display:flex}.topbar{border-bottom:1px solid #d9dde3;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.header-right{align-items:center;gap:10px;display:flex}.badge{color:#334155;background:#e2e8f0;border-radius:999px;padding:4px 8px;font-size:12px}.small{color:#334155;font-size:12px}.nav{-webkit-overflow-scrolling:touch;scrollbar-width:thin;border-bottom:1px solid #e5e7eb;flex-wrap:nowrap;align-items:center;gap:8px;padding:12px 20px;display:flex;overflow-x:auto}.nav-link{color:#0f172a;white-space:nowrap;background:#f1f5f9;border-radius:8px;flex-shrink:0;padding:8px 12px;text-decoration:none}.nav-loading{flex-shrink:0;padding:8px 4px;font-size:13px}.nav-link.active{color:#1d4ed8;background:#dbeafe}.status{color:#334155;margin:10px 20px 0}.status.error{color:#b91c1c}.content{padding:20px}.billing{background:#f1f5f9;border:1px solid #dbe3ee;border-radius:8px;align-items:center;gap:10px;margin:0 20px;padding:10px 12px;display:flex}.page{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px}.error-text{color:#b91c1c}.ops-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:12px;margin-top:12px;display:grid}.ops-card{background:#f8fafc;border:1px solid #e5e7eb;border-radius:10px;padding:10px}.ops-card h3{margin-top:0}.ops-card pre{white-space:pre-wrap;margin:0;font-size:12px}.checkout-actions{gap:8px;margin-top:8px;display:flex}.checkout-actions button{cursor:pointer;background:#fff;border:1px solid #cbd5e1;border-radius:6px;padding:6px 10px}.api-base{margin-left:auto}.legacy-open{margin-top:12px}.legacy-link{color:#0f172a;background:#fff;border:1px solid #94a3b8;border-radius:8px;padding:8px 14px;font-weight:600;text-decoration:none;display:inline-block}.legacy-link:hover{background:#f1f5f9}.legacy-link--button{font:inherit;cursor:pointer}.legacy-link--button:disabled{opacity:.65;cursor:not-allowed}.legacy-handoff-error{color:#b91c1c;font-size:14px}.post-signout-legacy-hint{color:#334155;background:#f8fafc;border:1px solid #cbd5e1;border-radius:8px;margin:0 0 14px;padding:10px 12px;font-size:14px;line-height:1.45}.header-link{font-size:13px}.muted{color:#64748b}.auth-page .auth-form{flex-direction:column;gap:12px;max-width:440px;display:flex}.auth-page{max-width:560px;margin:18px auto 0;box-shadow:0 2px 14px #1d4ed814}.auth-page .field{flex-direction:column;gap:4px;font-size:14px;display:flex}.auth-page .field span{color:#334155;font-weight:600}.auth-page input[type=email],.auth-page input[type=password],.auth-page input[type=text]{border:1px solid #cbd5e1;border-radius:8px;padding:8px 10px}.auth-actions{margin-bottom:12px}.btn-primary{color:#fff;cursor:pointer;background:#1d4ed8;border:none;border-radius:8px;padding:10px 14px;font-weight:600}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-ghost{cursor:pointer;background:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:10px 14px;font-weight:600}.btn-ghost:disabled{opacity:.6;cursor:not-allowed}.link-button{color:#1d4ed8;font:inherit;cursor:pointer;background:0 0;border:none;margin-left:6px;padding:0;text-decoration:underline}.divider{text-align:center;color:#64748b;margin:16px 0;font-size:13px}.checkbox{align-items:flex-start;gap:8px;font-size:14px;display:flex}.auth-hint{margin:10px 20px}.dashboard-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-top:16px;display:grid}.dashboard-card{color:inherit;background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;padding:14px 16px;text-decoration:none;transition:background .15s,border-color .15s;display:block}.dashboard-card:hover{background:#eff6ff;border-color:#bfdbfe}.dashboard-card h3{margin:0 0 6px;font-size:1.05rem}.dashboard-card--locked{opacity:.65;cursor:not-allowed;background:#f1f5f9}.subscription-banners{flex-direction:column;gap:8px;margin:10px 20px 0;display:flex}.banner{border-radius:8px;padding:10px 14px;font-size:14px;line-height:1.45}.banner--info{color:#0c4a6e;background:#e0f2fe;border:1px solid #7dd3fc}.banner--warn{color:#78350f;background:#fef3c7;border:1px solid #fcd34d}.billing-setup{margin:12px 0;font-size:13px}.billing-setup pre{max-height:180px;margin:8px 0 0;font-size:11px;overflow:auto}.billing-multi{background:#fafafa;border:1px dashed #cbd5e1;border-radius:10px;margin:16px 0;padding:12px 14px}.billing-multi h3{margin-top:0}.interval-toggle{gap:16px;margin:10px 0;font-size:14px;display:flex}.billing-multi-submit{margin-top:8px}.billing-portal-row{flex-wrap:wrap;align-items:center;gap:10px;margin:12px 0;display:flex}.catalog-select{margin-bottom:8px;font-size:13px;display:block}.shell-footer{justify-content:center;gap:20px;padding:18px 10px 28px;font-size:14px;display:flex}@media (width<=600px){.topbar{flex-wrap:wrap;gap:10px}.header-right{flex-wrap:wrap;justify-content:flex-end}}.shell--auth-gateway{background:#eef3fb linear-gradient(#e8f1ff 0%,#f6f8fc 48%,#eef3fb 100%)}.content--auth-gateway{flex-direction:column;flex:1;align-items:center;padding-top:32px;display:flex}.shell-footer--gateway{background:0 0;padding-top:8px}.auth-gateway-brand{justify-content:center;margin-bottom:6px;display:flex}.hub-brand-lockup{color:inherit;align-items:center;gap:12px;text-decoration:none;display:inline-flex}.hub-brand-lockup:hover .hub-brand-name{color:#1e40af}.hub-brand-text{text-align:left;flex-direction:column;line-height:1.2;display:flex}.hub-brand-name{letter-spacing:-.03em;color:#1d4ed8;font-size:21px;font-weight:700}.hub-brand-tagline{text-transform:uppercase;letter-spacing:.06em;color:#64748b;font-size:11px;font-weight:600}.auth-page-gateway{background:#fffffffa;border:1px solid #cfe0fb;border-radius:16px;width:min(460px,100%);padding:26px 24px 30px;box-shadow:0 1px 2px #0f172a0d,0 16px 40px #1d6fe61a}.auth-page-gateway h2{text-align:center;letter-spacing:-.02em;color:#0f172a;margin-top:4px;margin-bottom:8px;font-size:1.35rem}.datafrunk-workspace-list h2{margin-top:0}.datafrunk-workspace-table-wrap{border:1px solid #e5e7eb;border-radius:8px;margin-top:12px;overflow-x:auto}.datafrunk-workspace-table{border-collapse:collapse;width:100%;font-size:13px}.datafrunk-workspace-table th,.datafrunk-workspace-table td{text-align:left;border-bottom:1px solid #f1f5f9;padding:8px 12px}.datafrunk-workspace-table th{color:#334155;background:#f8fafc;font-weight:600}.datafrunk-workspace-table tbody tr:last-child td{border-bottom:none}
