/* LOPTI · Hub (entrance chooser) — minimal stylesheet */

:root {
  --teal: #0A9396;
  --teal-600: #097D80;
  --teal-700: #06676A;
  --teal-100: #D6EFEF;
  --teal-050: #EBF7F7;
  --navy: #1B2A4A;
  --navy-700: #15223C;
  --orange: #E76F51;
  --orange-600: #CF5A3E;
  --orange-050: #FFF1EB;
  --paper: #F6F7F8;
  --line: #DEE2E6;
  --ink-300: #8B8B8B;
  --ink-500: #4A4A4A;
  --ink-900: #14181C;
  --sans: "Inter", system-ui, -apple-system, sans-serif;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--sans);
  color: var(--ink-900);
  background: linear-gradient(180deg, var(--paper) 0%, #ffffff 60%);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
}

.skip-link { position: absolute; left: -9999px; top: 8px; background: var(--navy); color: #fff; padding: 8px 16px; border-radius: 6px; z-index: 2000; }
.skip-link:focus { left: 8px; }

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

/* NAV */
.hub-nav { padding: 22px 0; border-bottom: 1px solid var(--line); background: #fff; }
.hub-nav .hub-container { display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.hub-nav .brand { display: inline-flex; align-items: center; gap: 10px; text-decoration: none; color: var(--navy); }
.hub-nav .wordmark { font-weight: 800; letter-spacing: 0.06em; color: var(--navy); }
.hub-mini-links { display: flex; gap: 18px; }
.hub-mini-links a { color: var(--ink-500); text-decoration: none; font-weight: 500; font-size: 0.95rem; }
.hub-mini-links a:hover { color: var(--teal); }

/* HERO */
.hub-hero { padding: 72px 0 32px; text-align: center; }
.hub-eyebrow {
  display: inline-block; padding: 6px 14px;
  background: var(--teal-050); color: var(--teal-700);
  border-radius: 100px; font-size: 0.78rem; font-weight: 600;
  letter-spacing: 0.04em; text-transform: uppercase;
}
.hub-hero h1 {
  margin-top: 18px;
  font-size: clamp(2rem, 4.4vw, 3.5rem);
  font-weight: 800; line-height: 1.05;
  color: var(--navy); letter-spacing: -0.02em;
}
.hub-lead { margin-top: 14px; font-size: 1.125rem; color: var(--ink-500); max-width: 620px; margin-left: auto; margin-right: auto; }

/* CHOICE */
.hub-choice { padding: 36px 0 80px; }
.hub-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
@media (max-width: 880px) { .hub-grid { grid-template-columns: 1fr; } }

.hub-card {
  display: grid; grid-template-rows: auto 1fr;
  gap: 18px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 36px 32px;
  text-decoration: none;
  color: inherit;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
  position: relative;
  overflow: hidden;
}
.hub-card:hover { transform: translateY(-4px); box-shadow: 0 18px 40px rgba(27, 42, 74, 0.10); border-color: transparent; }
.hub-card::after {
  content: "";
  position: absolute; inset: -1px;
  border-radius: 19px;
  background: linear-gradient(135deg, currentColor, transparent 60%);
  opacity: 0; transition: opacity 0.18s ease;
  z-index: 0; pointer-events: none;
}
.hub-card:hover::after { opacity: 0.06; }

.hub-card-corp { color: var(--teal); }
.hub-card-home { color: var(--orange); }

.hub-card-icon { color: inherit; }

.hub-card-body { display: flex; flex-direction: column; gap: 12px; position: relative; z-index: 1; }
.hub-card-tag {
  display: inline-block; width: max-content;
  padding: 4px 12px; font-size: 0.78rem;
  border-radius: 100px;
  background: currentColor; color: #fff;
}
.hub-card-corp .hub-card-tag { color: #fff; background: var(--teal); }
.hub-card-home .hub-card-tag { color: #fff; background: var(--orange); }

.hub-card h2 { font-size: 1.65rem; color: var(--navy); font-weight: 700; letter-spacing: -0.01em; }
.hub-card p { color: var(--ink-500); }

.hub-card-checklist { list-style: none; display: grid; gap: 8px; margin-top: 4px; }
.hub-card-checklist li {
  position: relative; padding-left: 26px;
  font-size: 0.95rem; color: var(--ink-500);
}
.hub-card-checklist li::before {
  content: ""; position: absolute; left: 0; top: 8px;
  width: 16px; height: 8px;
  border-left: 2px solid currentColor; border-bottom: 2px solid currentColor;
  transform: rotate(-45deg);
}

.hub-card-cta {
  margin-top: 12px; font-weight: 600;
  font-size: 0.98rem; color: currentColor;
}

.hub-card-preferred { box-shadow: 0 8px 24px rgba(10, 147, 150, 0.12); border-color: currentColor; }

.hub-help { text-align: center; margin-top: 32px; color: var(--ink-500); font-size: 0.95rem; }
.hub-help a { color: var(--teal); font-weight: 600; }

/* TRUST */
.hub-trust { padding: 32px 0 64px; border-top: 1px solid var(--line); background: var(--paper); }
.hub-trust-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; text-align: center; }
@media (max-width: 760px) { .hub-trust-grid { grid-template-columns: repeat(2, 1fr); } }
.hub-trust-grid > div { display: flex; flex-direction: column; gap: 4px; }
.hub-trust-grid strong { font-size: 1.6rem; color: var(--navy); font-weight: 800; }
.hub-trust-grid span { color: var(--ink-500); font-size: 0.92rem; }

/* FOOTER */
.hub-footer { padding: 28px 0 36px; text-align: center; color: var(--ink-300); font-size: 0.88rem; }
.hub-footer .hub-footer-links { margin-top: 8px; }
.hub-footer a { color: var(--ink-500); text-decoration: none; }
.hub-footer a:hover { color: var(--teal); }

/* ============================================================
 * Mobile fine-tuning (≤620px)
 * ============================================================ */
@media (max-width: 620px) {
  .hub-container { padding: 0 18px; }
  .hub-nav { padding: 16px 0; }
  .hub-mini-links { gap: 12px; font-size: 0.85rem; }
  .hub-hero { padding: 48px 0 24px; }
  .hub-hero h1 { font-size: clamp(1.7rem, 6vw, 2.4rem); }
  .hub-lead { font-size: 1rem; }

  .hub-choice { padding: 24px 0 56px; }
  .hub-card { padding: 24px 20px; border-radius: 14px; }
  .hub-card h2 { font-size: 1.35rem; }
  .hub-card-checklist li { font-size: 0.9rem; padding-left: 22px; }
  .hub-card-icon svg { width: 48px; height: 48px; }
  .hub-help { font-size: 0.9rem; padding: 0 8px; }

  .hub-trust { padding: 24px 0 48px; }
  .hub-trust-grid strong { font-size: 1.3rem; }
  .hub-trust-grid span { font-size: 0.82rem; }
}

@media (max-width: 380px) {
  .hub-trust-grid { grid-template-columns: 1fr 1fr; gap: 16px; }
  .hub-mini-links a:first-child { display: none; }
  .hub-eyebrow { font-size: 0.75rem; padding: 5px 10px; }
}

/* Hub CTA: garante altura confortável */
.hub-card-cta { 
  display: inline-flex; 
  align-items: center; 
  min-height: 40px; 
  padding: 8px 0;
}
body, html { overflow-x: hidden; }
