    :root{
      --ink:#0f172a;
      --muted:#64748b;
      --line:#e5e7eb;
      --panel:#ffffff;
      --bg:#f8fafc;
      --brand:#0ea5b7;
      --brand-dark:#0b8593;
    }
    *{ box-sizing:border-box; }
    body{
      margin:0;
      font-family: system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
      background:var(--bg);
      color:var(--ink);
    }
    .page{
      max-width: 960px;
      margin: 0 auto;
      padding: 16px 16px 40px;
    }
    header.recs-header{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:16px;
      margin-bottom:20px;
    }
    .brand{
      display:flex;
      align-items:center;
      gap:10px;
    }
    .brand img{
      height:40px;
    }
    .brand-title{
      font-weight:800;
      font-size:18px;
      letter-spacing:.03em;
    }
    .badge-perfil{
      padding:4px 10px;
      border-radius:999px;
      border:1px solid var(--line);
      background:#ecfeff;
      color:#0b4960;
      font-size:12px;
      font-weight:600;
    }
    .pill-proto{
      padding:6px 12px;
      border-radius:999px;
      background:#0ea5b7;
      color:#f0f9ff;
      font-weight:700;
      font-size:12px;
      box-shadow:0 1px 2px rgba(15,23,42,.25);
    }

    .card{
      background:var(--panel);
      border-radius:14px;
      border:1px solid var(--line);
      padding:16px 18px;
      margin-bottom:14px;
      box-shadow:0 1px 0 rgba(15,23,42,.03);
    }
    h1,h2,h3{
      margin:0 0 8px;
    }
    p{ margin:0 0 8px; color:var(--muted); }
    .muted{ color:var(--muted); }

    .steps-list{
      margin:8px 0 0;
      padding-left:20px;
    }
    .steps-list li{
      margin-bottom:4px;
    }

    .alert-box{
      margin-top:10px;
      padding:10px 12px;
      border-radius:10px;
      border:1px solid #fed7aa;
      background:#fff7ed;
      color:#7c2d12;
      font-size:13px;
    }

    .services-grid{
      display:grid;
      grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
      gap:10px;
      margin-top:8px;
    }
    .service-card{
      border-radius:12px;
      border:1px solid var(--line);
      padding:12px 12px 10px;
      background:#f9fafb;
      display:flex;
      flex-direction:column;
      gap:4px;
    }
    .service-card h3{
      font-size:14px;
      margin:0 0 4px;
    }
    .service-tags{
      display:flex;
      flex-wrap:wrap;
      gap:4px;
      margin-top:4px;
    }
    .service-tag{
      font-size:11px;
      padding:2px 8px;
      border-radius:999px;
      border:1px solid #d4d4d8;
      background:#f4f4f5;
    }
    .service-cta{
      margin-top:6px;
      font-size:13px;
      font-weight:600;
      color:#2563eb;
      text-decoration:none;
      align-self:flex-start;
    }

    .status{
      font-size:14px;
      display:flex;
      align-items:center;
      gap:8px;
    }
    .spinner{
      width:16px;
      height:16px;
      border-radius:999px;
      border:2px solid #e5e7eb;
      border-top-color:#0ea5b7;
      animation:spin 0.7s linear infinite;
    }
    @keyframes spin{
      to{ transform:rotate(360deg); }
    }

    .error-box{
      border-radius:10px;
      padding:10px 12px;
      border:1px solid #fecaca;
      background:#fef2f2;
      color:#7f1d1d;
      font-size:13px;
      margin-top:6px;
    }

    .back-link{
      display:inline-flex;
      align-items:center;
      gap:6px;
      font-size:13px;
      margin-top:8px;
      text-decoration:none;
      color:#2563eb;
    }
    .greeting {
  font-size: 14px;
  color: #475569;
  margin: 0 0 12px 0;
}

.persona-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 12px;
  margin-top: 16px;
}

.persona-card {
  border-radius: 12px;
  border: 1px solid #e2e8f0;
  background: #f8fafc;
  padding: 12px 14px;
  font-size: 13px;
}

.persona-card h3 {
  margin: 0 0 6px 0;
  font-size: 14px;
}

.persona-card ul {
  margin: 0;
  padding-left: 18px;
}
