/* Helppiu SaaS Landing — estilos públicos */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin:0; padding:0; font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif; color:#1d2433; background:#fff; line-height:1.5; }
a { color: #1a3a5c; text-decoration: none; }
a:hover { color: #00a09d; }
img { max-width:100%; }

.saas-container { max-width: 1180px; margin: 0 auto; padding: 0 24px; }

/* Header */
.saas-header { position: sticky; top:0; background:rgba(255,255,255,0.92); backdrop-filter: blur(10px); border-bottom:1px solid #eef0f4; z-index:100; }
.saas-header-inner { display:flex; align-items:center; justify-content:space-between; padding:14px 24px; }
.saas-logo { font-size:22px; font-weight:800; color:#1a3a5c; }
.saas-logo span { color:#00a09d; }
.saas-logo-link { display:inline-flex; align-items:center; gap:10px; }
.saas-logo-prefix { font-family:'Poppins', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif; font-size:16px; font-weight:700; color:#1a3a5c; letter-spacing:0.5px; text-transform:uppercase; }
.saas-logo-img { max-height:38px; width:auto; display:block; }
.saas-footer-brand { display:inline-flex; align-items:center; gap:10px; margin-bottom:14px; }
.saas-footer-prefix { font-family:'Poppins', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif; font-size:15px; font-weight:700; color:#ffffff; letter-spacing:0.5px; text-transform:uppercase; }
.saas-footer-logo { max-height:40px; width:auto; display:block; filter: brightness(0) invert(1); opacity:0.92; }

/* SVG outline icons */
.saas-svg { width:22px; height:22px; stroke:currentColor; fill:none; vertical-align:middle; }
.saas-trust .saas-svg { width:16px; height:16px; margin-right:6px; color:#00a09d; }
.saas-feature-icon { width:48px; height:48px; border-radius:12px; background:linear-gradient(135deg,#e3f9f8,#f0f7ff); display:inline-flex; align-items:center; justify-content:center; color:#00a09d; margin-bottom:16px; }
.saas-feature-icon .saas-svg { width:26px; height:26px; }
.saas-step-num .saas-svg { width:24px; height:24px; color:#fff; stroke:#fff; }
.saas-nav { display:flex; align-items:center; gap:22px; }
.saas-nav a { font-weight:500; color:#3a4554; }
.saas-nav a:hover { color:#1a3a5c; }

/* Botones */
.saas-btn { display:inline-block; padding:10px 18px; border-radius:8px; font-weight:600; border:none; cursor:pointer; transition: all .15s ease; font-size:14px; text-align:center; text-decoration:none; }
.saas-btn-primary { background:linear-gradient(135deg,#1a3a5c 0%,#00a09d 100%); color:#ffffff !important; box-shadow: 0 6px 20px rgba(26,58,92,0.25); }
.saas-btn-primary:hover, .saas-btn-primary:focus, .saas-btn-primary:visited { color:#ffffff !important; text-decoration:none; }
.saas-btn-primary:hover { transform: translateY(-1px); box-shadow: 0 10px 28px rgba(26,58,92,0.32); }
.saas-btn-ghost { background:transparent; color:#1a3a5c; border:1.5px solid #1a3a5c; }
.saas-btn-ghost:hover { background:#1a3a5c; color:#fff; }
.saas-btn-lg { padding:14px 26px; font-size:16px; }

/* Hero */
.saas-hero { padding: 80px 0 60px; background: radial-gradient(ellipse at top left, #f0f7ff 0%, #fff 60%); }
.saas-hero-grid { display:grid; grid-template-columns: 1fr 1fr; gap:60px; align-items:center; }
.saas-badge { display:inline-block; background:#e3f9f8; color:#00a09d; padding:6px 14px; border-radius:20px; font-size:12px; font-weight:600; margin-bottom:18px; }
.saas-hero h1 { font-size: 52px; line-height:1.1; margin: 0 0 20px; font-weight:800; color:#1a3a5c; }
.saas-hero h1 .grad { background: linear-gradient(135deg,#1a3a5c,#00a09d); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }
.saas-lead { font-size:18px; color:#5a6675; margin: 0 0 28px; max-width:520px; }
.saas-cta-row { display:flex; gap:14px; margin-bottom:24px; flex-wrap:wrap; }
.saas-trust { display:flex; gap:18px; flex-wrap:wrap; font-size:13px; color:#5a6675; }

/* Flow animado: propuesta → NDA → contrato → orden */
.saas-hero-card { position:relative; }
.saas-flow { background:#fff; border:1px solid #eef0f4; border-radius:16px; padding:22px; box-shadow:0 30px 70px rgba(20,30,50,0.14); }
.saas-flow-track { display:flex; flex-direction:column; gap:12px; position:relative; }
.saas-flow-track::before { content:""; position:absolute; left:27px; top:32px; bottom:32px; width:2px; background:linear-gradient(180deg,#e5e9ef 0%, #e5e9ef 100%); z-index:0; }
.saas-flow-step { display:flex; align-items:center; gap:14px; padding:14px 16px; background:#fff; border:1.5px solid #eef0f4; border-radius:12px; position:relative; z-index:1; opacity:0; transform: translateX(-14px); transition: all 0.5s cubic-bezier(.2,.7,.3,1); }
.saas-flow-step.is-active { opacity:1; transform: translateX(0); border-color:#00a09d; box-shadow: 0 10px 24px rgba(0,160,157,0.12); }
.saas-flow-icon { width:32px; height:32px; border-radius:50%; background:linear-gradient(135deg,#1a3a5c,#00a09d); color:#fff; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.saas-flow-icon .saas-svg { width:18px; height:18px; stroke:#fff; }
.saas-flow-body { flex:1; min-width:0; }
.saas-flow-body h5 { margin:0 0 2px; font-size:14px; color:#1a3a5c; font-weight:700; }
.saas-flow-meta { font-size:12px; color:#6c7686; }
.saas-flow-check { width:26px; height:26px; border-radius:50%; background:#e5e9ef; color:#fff; display:flex; align-items:center; justify-content:center; flex-shrink:0; transition: all .4s ease; transform: scale(0.5); opacity:0; }
.saas-flow-check .saas-svg { width:18px; height:18px; stroke:#fff; }
.saas-flow-step.is-done .saas-flow-check { background:#10b981; transform: scale(1); opacity:1; }
.saas-flow-progress { height:3px; background:#eef0f4; border-radius:2px; overflow:hidden; margin-top:6px; display:none; }
.saas-flow-step.is-progress .saas-flow-progress { display:block; }
.saas-flow-bar { height:100%; width:0%; background:linear-gradient(90deg,#1a3a5c,#00a09d); animation: barFill 1.2s ease forwards; }
@keyframes barFill { to { width:100%; } }
.saas-mock { background:#fff; border-radius:14px; box-shadow: 0 30px 70px rgba(20,30,50,0.18); transform: rotate(-1.5deg); overflow:hidden; border:1px solid #eef0f4; }
.saas-mock-bar { display:flex; gap:6px; padding:10px 14px; background:#f7f8fa; border-bottom:1px solid #eef0f4; }
.saas-mock-bar span { width:11px; height:11px; border-radius:50%; background:#d8dde5; }
.saas-mock-bar span:nth-child(1){ background:#ff6058; }
.saas-mock-bar span:nth-child(2){ background:#ffbd2e; }
.saas-mock-bar span:nth-child(3){ background:#28c941; }
.saas-mock-body { display:grid; grid-template-columns: repeat(3, 1fr); gap:14px; padding:18px; background:#fafbfc; }
.saas-mock-col h5 { margin: 0 0 10px; font-size:11px; text-transform:uppercase; letter-spacing:0.5px; color:#6c7686; }
.saas-mock-card { background:#fff; border:1px solid #e5e9ef; padding:10px 12px; border-radius:8px; font-size:13px; margin-bottom:8px; }
.saas-mock-card.saas-win { border-color:#28c941; color:#0f7a2c; font-weight:600; }
.saas-mock-card.saas-pulse { border-color:#00a09d; background:linear-gradient(120deg,#e3f9f8,#fff,#e3f9f8); background-size: 200% 100%; animation: pulse 2.4s ease infinite; color:#006d6a; font-weight:600; }
@keyframes pulse { 0%{background-position: 200% 0;} 100%{background-position: -200% 0;} }

/* Section general */
.saas-section { padding: 80px 0; }
.saas-section-alt { background:#f7f9fc; }
.saas-section-head { text-align:center; max-width:680px; margin: 0 auto 50px; }
.saas-section-head h2 { font-size:36px; color:#1a3a5c; margin:0 0 12px; font-weight:800; }
.saas-section-head p { color:#5a6675; font-size:17px; margin:0; }

/* Features */
.saas-feature-grid { display:grid; grid-template-columns: repeat(4, 1fr); gap:24px; }
.saas-feature { background:#fff; border:1px solid #eef0f4; border-radius:12px; padding:28px 22px; transition: all .2s; }
.saas-feature:hover { transform: translateY(-4px); box-shadow: 0 18px 40px rgba(20,30,50,0.08); border-color:#00a09d; }
.saas-feature h3 { margin:0 0 8px; color:#1a3a5c; font-size:18px; }
.saas-feature p { margin:0; color:#5a6675; font-size:14px; }

/* Steps */
.saas-steps { display:grid; grid-template-columns: repeat(4, 1fr); gap:24px; }
.saas-step { text-align:center; padding:24px 16px; }
.saas-step-num { display:inline-flex; align-items:center; justify-content:center; width:54px; height:54px; border-radius:50%; background:linear-gradient(135deg,#1a3a5c,#00a09d); color:#fff; margin-bottom:14px; }
.saas-step h4 { margin:0 0 8px; color:#1a3a5c; }
.saas-step p { margin:0; color:#5a6675; }

/* Pricing */
.saas-pricing-grid { display:grid; grid-template-columns: repeat(3, 1fr); gap:24px; align-items:stretch; }
.saas-plan { background:#fff; border:1.5px solid #eef0f4; border-radius:14px; padding:30px 24px; display:flex; flex-direction:column; position:relative; transition: all .2s; }
.saas-plan:hover { transform: translateY(-4px); box-shadow: 0 18px 40px rgba(20,30,50,0.10); }
.saas-plan-highlight { border-color:#00a09d; box-shadow: 0 14px 40px rgba(0,160,157,0.18); }
.saas-plan-badge { position:absolute; top:-14px; left:50%; transform:translateX(-50%); background:#00a09d; color:#fff; padding:6px 14px; border-radius:20px; font-size:12px; font-weight:600; }
.saas-plan h3 { color:#1a3a5c; margin: 0 0 12px; font-size:22px; }
.saas-plan-price { margin: 0 0 4px; }
.saas-plan-price .amount { font-size:42px; font-weight:800; color:#1a3a5c; }
.saas-plan-price .suffix { color:#5a6675; font-size:13px; }
.saas-plan-cop { font-size:13px; color:#00a09d; margin-bottom:18px; font-weight:600; }
.saas-plan ul { padding-left:22px; margin: 8px 0 24px; color:#3a4554; font-size:14px; line-height:1.7; }
.saas-plan ul li strong { color:#1a3a5c; }
.saas-plan-cta { margin-top:auto; }
.saas-pricing-note { text-align:center; color:#8a93a3; font-size:13px; margin-top:30px; }

/* FAQ */
.saas-faq-container { max-width:760px; }
.saas-faq-container details { background:#fff; padding:18px 22px; margin-bottom:12px; border-radius:10px; border:1px solid #eef0f4; }
.saas-faq-container summary { cursor:pointer; font-weight:600; color:#1a3a5c; }
.saas-faq-container p { margin: 10px 0 0; color:#5a6675; }

/* CTA final */
.saas-cta-final { background: linear-gradient(135deg,#1a3a5c 0%,#00a09d 100%); color:#fff; padding: 80px 0; text-align:center; }
.saas-cta-final h2 { font-size:38px; margin:0 0 14px; }
.saas-cta-final p { font-size:18px; opacity:0.95; mfff; color:#1a3a5c !important; box-shadow:none; }
.saas-cta-final .saas-btn-primary:hover { color:#00a09d !important; background:#fffffflor:#1a3a5c; box-shadow:none; }
.saas-cta-final .saas-btn-primary:hover { color:#00a09d; }

/* Footer */
.saas-footer { background:#0f1e30; color:#a9b6c8; padding: 50px 0 26px; }
.saas-footer h4 { color:#fff; margin: 0 0 14px; font-size:15px; }
.saas-footer a { color:#a9b6c8; display:block; margin-bottom:7px; font-size:14px; }
.saas-footer a:hover { color:#00a09d; }
.saas-footer-grid { display:grid; grid-template-columns: 2fr 1fr 1fr; gap:40px; padding-bottom:30px; border-bottom:1px solid #1f3149; }
.saas-footer-copy { padding-top:22px; font-size:12px; text-align:center; color:#6c7d92; }

/* Signup */
.saas-signup-main { padding: 60px 0; background:#f7f9fc; min-height:80vh; }
.saas-consent { display:flex; align-items:flex-start; gap:10px; margin: 18px 0 6px; font-size:13px; color:#5a6675; line-height:1.5; cursor:pointer; }
.saas-consent input[type="checkbox"] { width:18px; height:18px; margin-top:2px; flex-shrink:0; accent-color:#00a09d; }
.saas-consent a { color:#00a09d; text-decoration:underline; }

/* Legal pages */
.saas-legal { padding: 60px 0; background:#fff; }
.saas-legal-container { max-width: 820px; }
.saas-legal h1 { font-size:32px; color:#1a3a5c; margin: 0 0 6px; }
.saas-legal-meta { color:#8a93a3; font-size:13px; margin-bottom:30px; }
.saas-legal h2 { font-size:20px; color:#1a3a5c; margin: 32px 0 10px; padding-bottom:6px; border-bottom:1px solid #eef0f4; }
.saas-legal p, .saas-legal li { color:#3a4554; font-size:15px; line-height:1.7; }
.saas-legal ul { padding-left:22px; }
.saas-legal a { color:#00a09d; }
.saas-signup-grid { display:grid; grid-template-columns: 2fr 1fr; gap: 40px; align-items:start; }
.saas-signup-form { background:#fff; padding:40px; border-radius:14px; box-shadow:0 10px 30px rgba(20,30,50,0.06); }
.saas-signup-form h1 { margin: 0 0 8px; color:#1a3a5c; font-size:28px; }
.saas-signup-form h3 { color:#1a3a5c; margin-top:24px; border-bottom: 1px solid #eef0f4; padding-bottom:6px; }
.saas-form label { display:block; margin: 14px 0 6px; font-size:13px; color:#3a4554; font-weight:500; }
.saas-form input, .saas-form select { width:100%; padding:11px 14px; border:1.5px solid #d8dde5; border-radius:8px; font-size:15px; transition: border .15s; }
.saas-form input:focus, .saas-form select:focus { border-color:#00a09d; outline:none; }
.saas-signup-summary { display:flex; justify-content:space-between; align-items:center; background:#f0fcfc; border:1.5px solid #00a09d; border-radius:10px; padding:16px; margin: 24px 0 18px; }
.saas-signup-total { text-align:right; }
.saas-signup-total span { display:block; }
.saas-signup-total #total_usd { font-size:20px; font-weight:700; color:#1a3a5c; }
.saas-signup-cop { color:#00a09d; font-weight:600; font-size:14px; }
.saas-form-submit { width:100%; margin-top:10px; }
.saas-form-note { text-align:center; color:#8a93a3; font-size:13px; margin-top:14px; }
.saas-signup-side { background:#fff; padding:28px; border-radius:14px; border:1.5px solid #00a09d; }
.saas-signup-side h3 { color:#1a3a5c; margin-top:0; }
.saas-link { color:#00a09d; }

/* Onboarding */
.saas-onboarding { padding: 60px 0; background:#f7f9fc; min-height:80vh; }
.saas-onboarding h1 { color:#1a3a5c; }
.saas-onboard-steps { display:grid; grid-template-columns: repeat(3, 1fr); gap:24px; margin-top:30px; }
.saas-onboard-card { background:#fff; border-radius:14px; padding:30px 24px; box-shadow:0 6px 18px rgba(20,30,50,0.06); position:relative; }
.saas-onboard-num { position:absolute; top:-16px; left:24px; background:linear-gradient(135deg,#1a3a5c,#00a09d); color:#fff; width:36px; height:36px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:18px; }
.saas-onboard-card h3 { margin: 6px 0 14px; color:#1a3a5c; }
.saas-help { color:#5a6675; font-size:13px; margin-bottom:14px; }

/* Alerts */
.saas-alert { padding: 20px 24px; border-radius:10px; margin:20px 0; }
.saas-alert-error { background:#ffe6e6; color:#a82222; border:1px solid #ffb3b3; }
.saas-alert h3 { margin: 0 0 10px; }

/* Return */
.saas-return { padding: 60px 0; text-align:center; }
.saas-return-card { max-width:520px; margin:0 auto; background:#fff; padding:50px 30px; border-radius:14px; box-shadow:0 10px 30px rgba(20,30,50,0.08); }
.saas-return-spinner { width:48px; height:48px; border:4px solid #eef0f4; border-top-color:#00a09d; border-radius:50%; margin: 0 auto 22px; animation: spin 0.9s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* Responsive */
@media (max-width: 880px) {
    .saas-hero { padding: 50px 0 40px; }
    .saas-hero-grid { grid-template-columns: 1fr; gap:30px; }
    .saas-hero h1 { font-size: 36px; }
    .saas-feature-grid, .saas-pricing-grid, .saas-onboard-steps, .saas-steps { grid-template-columns: 1fr; }
    .saas-nav { display:none; }
    .saas-signup-grid { grid-template-columns: 1fr; }
    .saas-footer-grid { grid-template-columns: 1fr; gap:24px; }
}

/* WhatsApp floating button */
.saas-wa-fab {
    position: fixed;
    bottom: 22px;
    right: 22px;
    background: #25D366;
    color: #fff !important;
    border-radius: 999px;
    padding: 14px 18px 14px 16px;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-weight: 600;
    font-size: 14px;
    box-shadow: 0 12px 28px rgba(37, 211, 102, 0.45), 0 4px 10px rgba(0,0,0,0.18);
    z-index: 9999;
    text-decoration: none;
    transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
    animation: wa-pulse 2.4s ease-in-out infinite;
}
.saas-wa-fab:hover { transform: translateY(-2px) scale(1.03); background:#1ebe5d; color:#fff !important; text-decoration:none; box-shadow: 0 16px 36px rgba(37,211,102,0.55); }
.saas-wa-icon { width:26px; height:26px; flex-shrink:0; color:#fff; }
.saas-wa-label { white-space: nowrap; }
@keyframes wa-pulse {
    0%, 100% { box-shadow: 0 12px 28px rgba(37, 211, 102, 0.45), 0 0 0 0 rgba(37, 211, 102, 0.55); }
    50% { box-shadow: 0 12px 28px rgba(37, 211, 102, 0.55), 0 0 0 18px rgba(37, 211, 102, 0); }
}
@media (max-width: 640px) {
    .saas-wa-fab { padding: 12px; bottom: 16px; right: 16px; }
    .saas-wa-label { display: none; }
}

/* ═══════════════════════════════════════════════════
   ONBOARDING WIZARD V2
   ═══════════════════════════════════════════════════ */
.saas-onboarding-v2 { padding: 40px 0 80px; background: linear-gradient(180deg, #f7f9fc 0%, #ffffff 100%); min-height: 90vh; }
.ob-head { display:flex; justify-content:space-between; align-items:flex-start; gap:30px; margin-bottom:36px; flex-wrap:wrap; }
.ob-greeting { color:#00a09d; font-size:14px; font-weight:600; }
.ob-head h1 { color:#1a3a5c; font-size:32px; margin:8px 0 6px; font-weight:800; }
.ob-sub { color:#5a6675; margin:0; font-size:15px; }

.ob-trial-card { background: linear-gradient(135deg, #1a3a5c 0%, #00a09d 100%); color:#fff; padding:20px 26px; border-radius:14px; min-width:240px; box-shadow:0 14px 34px rgba(26,58,92,0.22); }
.ob-trial-title { font-size:12px; text-transform:uppercase; letter-spacing:0.8px; opacity:0.85; }
.ob-trial-days { font-size:42px; font-weight:800; line-height:1; margin-top:6px; }
.ob-trial-sub { font-size:13px; opacity:0.9; margin-bottom:10px; }
.ob-trial-plan { font-size:13px; padding-top:10px; border-top:1px solid rgba(255,255,255,0.25); }

/* Steps progress */
.ob-steps { display:flex; gap:0; margin-bottom:30px; background:#fff; border-radius:12px; padding:14px 8px; box-shadow:0 4px 14px rgba(20,30,50,0.05); overflow:hidden; }
.ob-step { flex:1; display:flex; align-items:center; gap:10px; padding:8px 12px; color:#8a93a3; font-size:13px; font-weight:500; position:relative; }
.ob-step:not(:last-child)::after { content:""; position:absolute; right:-8px; top:50%; width:16px; height:2px; background:#eef0f4; }
.ob-step-num { display:inline-flex; align-items:center; justify-content:center; width:28px; height:28px; border-radius:50%; background:#eef0f4; color:#8a93a3; font-weight:700; font-size:13px; flex-shrink:0; }
.ob-step.is-active { color:#1a3a5c; }
.ob-step.is-active .ob-step-num { background:linear-gradient(135deg,#1a3a5c,#00a09d); color:#fff; }
.ob-step.is-done { color:#00a09d; }
.ob-step.is-done .ob-step-num { background:#00a09d; color:#fff; }
.ob-step.is-done .ob-step-num::after { content:"✓"; }
.ob-step.is-done .ob-step-num span { display:none; }

/* Card del paso */
.ob-card { background:#fff; border-radius:14px; padding:40px; box-shadow:0 10px 30px rgba(20,30,50,0.06); }
.ob-card h2 { color:#1a3a5c; margin:0 0 8px; font-size:24px; }
.ob-help { color:#5a6675; margin:0 0 24px; font-size:14px; }
.ob-form label { display:block; margin: 12px 0 6px; font-size:13px; color:#3a4554; font-weight:500; }
.ob-form input, .ob-form select, .ob-form textarea { width:100%; padding:11px 14px; border:1.5px solid #d8dde5; border-radius:8px; font-size:15px; transition: border .15s; font-family: inherit; }
.ob-form input:focus, .ob-form select:focus, .ob-form textarea:focus { border-color:#00a09d; outline:none; }
.ob-form textarea { resize: vertical; min-height: 70px; }
.ob-grid-2 { display:grid; grid-template-columns: 1fr 1fr; gap:14px; }
.ob-upload { margin-top:18px; padding:18px; background:#f7f9fc; border-radius:10px; border:1.5px dashed #d8dde5; }
.ob-upload label { margin-top:0; font-weight:600; color:#1a3a5c; }
.ob-upload small { display:block; margin-top:6px; color:#8a93a3; font-size:12px; }
.ob-actions { display:flex; justify-content:space-between; align-items:center; margin-top:30px; padding-top:24px; border-top:1px solid #eef0f4; }
.ob-divider { text-align:center; margin: 30px 0 14px; position:relative; }
.ob-divider::before { content:""; position:absolute; left:0; right:0; top:50%; height:1px; background:#eef0f4; z-index:0; }
.ob-divider span { background:#fff; padding:0 16px; position:relative; z-index:1; color:#8a93a3; font-size:13px; font-weight:600; }

/* Pipeline cards */
.ob-pipelines { display:grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap:14px; margin-top:10px; }
.ob-pipeline-card { display:block; cursor:pointer; background:#fff; border:2px solid #eef0f4; border-radius:12px; padding:18px; transition: all .15s; position:relative; }
.ob-pipeline-card:hover { border-color:#00a09d; }
.ob-pipeline-card input { position:absolute; opacity:0; }
.ob-pipeline-card input:checked + .ob-pipeline-body { color:#1a3a5c; }
.ob-pipeline-card:has(input:checked) { border-color:#00a09d; background: linear-gradient(135deg, #f0fcfc, #fff); box-shadow:0 8px 22px rgba(0,160,157,0.12); }
.ob-pipeline-body h4 { margin:0 0 8px; color:#1a3a5c; font-size:16px; }
.ob-pipeline-body p { margin:0; color:#5a6675; font-size:13px; line-height:1.5; }

/* Invite row */
.ob-invite-row { margin-bottom:10px; }

/* Done */
.ob-done { text-align:center; padding: 14px 0 24px; }
.ob-check { width:64px; height:64px; border-radius:50%; background:linear-gradient(135deg,#10b981,#00a09d); color:#fff; font-size:32px; line-height:64px; margin:0 auto 14px; }
.ob-done h2 { margin:0 0 6px; }

.ob-guide-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap:16px; margin-top:14px; }
.ob-guide { background:#f7f9fc; border-radius:12px; padding:22px; position:relative; }
.ob-guide-num { width:32px; height:32px; border-radius:50%; background:linear-gradient(135deg,#1a3a5c,#00a09d); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700; margin-bottom:10px; }
.ob-guide h4 { margin:0 0 8px; color:#1a3a5c; font-size:15px; }
.ob-guide p { margin:0; color:#5a6675; font-size:13px; line-height:1.5; }
.ob-guide a { color:#00a09d; }

.ob-skip { text-align:center; margin-top:24px; }
.ob-skip a { color:#8a93a3; font-size:13px; }
.ob-skip a:hover { color:#00a09d; }

/* ═══════════════════════════════════════════════════
   PORTAL SAAS (Mi cuenta)
   ═══════════════════════════════════════════════════ */
.saas-portal { max-width: 1180px !important; }
.saas-portal-grid { display:grid; grid-template-columns: 260px 1fr; gap:30px; align-items:flex-start; }
.saas-portal-aside { position:sticky; top:80px; display:flex; flex-direction:column; gap:18px; }
.saas-portal-card { background:#fff; border-radius:12px; padding:22px; box-shadow:0 4px 14px rgba(20,30,50,0.05); margin-bottom:20px; }
.saas-portal-card h3 { color:#1a3a5c; margin:0 0 14px; font-size:17px; font-weight:700; }
.saas-portal-card h3:not(:first-child) { margin-top:24px; }

.saas-portal-userbox { display:flex; align-items:center; gap:12px; }
.saas-portal-avatar { width:46px; height:46px; border-radius:50%; background:linear-gradient(135deg,#1a3a5c,#00a09d); color:#fff; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:18px; flex-shrink:0; }
.saas-portal-username { font-weight:700; color:#1a3a5c; font-size:14px; }
.saas-portal-company { color:#8a93a3; font-size:12px; }

.saas-portal-nav { background:#fff; border-radius:12px; padding:8px; box-shadow:0 4px 14px rgba(20,30,50,0.05); display:flex; flex-direction:column; gap:2px; }
.saas-portal-navlink { display:block; padding:11px 14px; color:#3a4554; font-size:14px; font-weight:500; border-radius:8px; }
.saas-portal-navlink:hover { background:#f7f9fc; color:#1a3a5c; text-decoration:none; }
.saas-portal-navlink.is-active { background: linear-gradient(135deg, #f0fcfc, #f0f7ff); color:#1a3a5c; font-weight:700; }
.saas-portal-navlink-cta { background:linear-gradient(135deg,#1a3a5c,#00a09d); color:#fff !important; margin-top:8px; }
.saas-portal-navlink-cta:hover { color:#fff !important; opacity:.95; }
.saas-portal-navlink-muted { color:#8a93a3; font-size:13px; }

.saas-portal-trialbox { padding:18px; }
.saas-portal-trial-state { display:inline-block; padding:3px 10px; border-radius:14px; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.5px; }
.saas-portal-trial-state.state-trial { background:#fff4e0; color:#b8860b; }
.saas-portal-trial-state.state-active { background:#d1f7e6; color:#0f7a4a; }
.saas-portal-trial-state.state-past_due, .saas-portal-trial-state.state-pending_payment { background:#fff0f0; color:#a82222; }
.saas-portal-trial-state.state-suspended, .saas-portal-trial-state.state-cancelled { background:#eef0f4; color:#5a6675; }
.saas-portal-trial-plan { margin-top:10px; color:#3a4554; font-size:13px; }
.saas-portal-trial-days { font-size:24px; font-weight:800; color:#1a3a5c; margin-top:8px; }
.saas-portal-trial-days small { font-size:12px; color:#5a6675; font-weight:500; }
.saas-portal-trial-users { color:#5a6675; font-size:12px; margin-top:4px; }
.saas-portal-trial-link { display:block; margin-top:10px; color:#00a09d; font-size:13px; font-weight:600; }

/* Main */
.saas-portal-main { min-width:0; }
.saas-portal-hero { margin-bottom:24px; }
.saas-portal-hero h2 { color:#1a3a5c; margin:0 0 6px; font-size:26px; font-weight:800; }
.saas-portal-sub { color:#5a6675; margin:0; font-size:14px; }

/* Stats */
.saas-portal-stats { display:grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap:16px; margin-bottom:20px; }
.saas-portal-stat { background:#fff; border-radius:12px; padding:20px; box-shadow:0 4px 14px rgba(20,30,50,0.05); border-left:4px solid #00a09d; }
.saas-portal-stat-label { color:#8a93a3; font-size:12px; text-transform:uppercase; letter-spacing:0.5px; font-weight:600; }
.saas-portal-stat-value { font-size:22px; font-weight:800; color:#1a3a5c; margin:6px 0; }
.saas-portal-stat-link { font-size:13px; color:#00a09d; font-weight:600; }

/* Quick tiles */
.saas-portal-quick { display:grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap:14px; }
.saas-portal-quicktile { display:block; padding:18px; background:#f7f9fc; border-radius:10px; transition: all .15s; }
.saas-portal-quicktile:hover { background:linear-gradient(135deg, #f0fcfc, #f0f7ff); transform:translateY(-2px); text-decoration:none; }
.saas-portal-quicktile strong { display:block; color:#1a3a5c; font-size:15px; margin-bottom:4px; }
.saas-portal-quicktile span { color:#5a6675; font-size:13px; }

/* Subscription card */
.saas-portal-subgrid { display:grid; grid-template-columns: 2fr 1fr; gap:20px; align-items:flex-end; }
.saas-portal-subactions { text-align:right; }

/* Badges */
.saas-portal-badge { display:inline-block; padding:3px 10px; border-radius:14px; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:0.4px; }
.saas-portal-badge.state-active, .saas-portal-badge.state-paid { background:#d1f7e6; color:#0f7a4a; }
.saas-portal-badge.state-trial { background:#fff4e0; color:#b8860b; }
.saas-portal-badge.state-pending, .saas-portal-badge.state-pending_payment, .saas-portal-badge.state-past_due { background:#fff0e0; color:#a06000; }
.saas-portal-badge.state-failed, .saas-portal-badge.state-expired, .saas-portal-badge.state-suspended, .saas-portal-badge.state-cancelled { background:#fff0f0; color:#a82222; }

/* Tablas */
.saas-portal-table { width:100%; border-collapse: collapse; }
.saas-portal-table th { text-align:left; padding:12px 10px; font-size:12px; text-transform:uppercase; letter-spacing:0.5px; color:#8a93a3; border-bottom:2px solid #eef0f4; }
.saas-portal-table td { padding:14px 10px; border-bottom:1px solid #eef0f4; font-size:14px; color:#3a4554; }
.saas-portal-table tr:hover td { background:#fafbfc; }

/* Forms */
.saas-portal-form-inline { display:flex; gap:10px; align-items:center; flex-wrap:wrap; }
.saas-portal-form-inline input, .saas-portal-form-inline select { padding:10px 14px; border:1.5px solid #d8dde5; border-radius:8px; font-size:14px; flex:1; min-width:160px; }
.saas-portal-form-inline input:focus, .saas-portal-form-inline select:focus { border-color:#00a09d; outline:none; }
.saas-portal-formstack { display:flex; flex-direction:column; gap:0; }
.saas-portal-formactions { text-align:right; padding:14px 0; }

/* Inputs dentro de cards del portal */
.saas-portal-card label { display:block; margin: 10px 0 6px; font-size:13px; color:#3a4554; font-weight:600; }
.saas-portal-card input[type="text"],
.saas-portal-card input[type="email"],
.saas-portal-card input[type="password"],
.saas-portal-card input[type="number"],
.saas-portal-card input[type="tel"],
.saas-portal-card input[type="url"],
.saas-portal-card select,
.saas-portal-card textarea {
    width:100%; padding:11px 14px; border:1.5px solid #d8dde5; border-radius:8px;
    font-size:14px; transition: border .15s, box-shadow .15s; font-family: inherit;
    background:#fff; color:#1a3a5c; box-sizing:border-box;
}
.saas-portal-card input:focus,
.saas-portal-card select:focus,
.saas-portal-card textarea:focus {
    border-color:#00a09d; outline:none; box-shadow:0 0 0 3px rgba(0,160,157,0.12);
}
.saas-portal-card input:disabled,
.saas-portal-card select:disabled,
.saas-portal-card textarea:disabled {
    background:#f5f7fa; color:#6b7280; cursor:not-allowed;
}
.saas-portal-card textarea { resize: vertical; min-height: 90px; }
.saas-portal-card small { display:block; margin-top:4px; color:#6b7280; font-size:12px; }
.saas-portal-card .ob-grid-full { grid-column: 1 / -1; }
.saas-portal-card table { border-collapse: collapse; width: 100%; }
.saas-portal-card table th, .saas-portal-card table td { padding: 8px 10px; border-bottom: 1px solid #eef0f4; vertical-align: top; }
.saas-portal-card table tbody tr:hover td { background:#f9fafc; }
.saas-portal-card table a { color:#00a09d; text-decoration:none; }
.saas-portal-card table a:hover { text-decoration: underline; }

/* Botones */
.saas-btn-sm { padding:6px 12px; font-size:13px; }
.saas-btn-danger { background:#fff; color:#c0392b; border:1.5px solid #c0392b; }
.saas-btn-danger:hover { background:#c0392b; color:#fff; }

.saas-portal-danger { border-left:4px solid #c0392b; }

/* Help */
.saas-portal-help-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap:18px; }
.saas-portal-help { padding:24px; }
.saas-portal-help h3 { font-size:16px; margin:0 0 12px; }
.saas-portal-help p, .saas-portal-help li { color:#3a4554; font-size:14px; line-height:1.6; }
.saas-portal-help ul, .saas-portal-help ol { padding-left:20px; margin:8px 0; }
.saas-portal-help a { color:#00a09d; font-weight:600; }

.saas-alert-ok { background:#d1f7e6; color:#0f7a4a; border:1px solid #88e3b6; padding:14px 18px; border-radius:8px; margin-bottom:14px; }

@media (max-width: 880px) {
    .saas-portal-grid { grid-template-columns: 1fr; }
    .saas-portal-aside { position:static; }
    .saas-portal-subgrid { grid-template-columns:1fr; }
    .saas-portal-subactions { text-align:left; }
    .ob-head { flex-direction:column; }
    .ob-trial-card { width:100%; }
    .ob-grid-2 { grid-template-columns:1fr; }
    .ob-steps { overflow-x:auto; }
}
