/* Guest / public marketing & auth surfaces */

body.guest-public .guest-auth-wrap {
  width: 100%;
}

nav.guest-topnav.navbar {
  background: rgba(15, 31, 56, 0.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  box-shadow: 0 8px 32px rgba(8, 16, 32, 0.12);
}

nav.guest-topnav .nav-link {
  color: rgba(255, 255, 255, 0.82) !important;
  font-weight: 500;
  font-size: 0.92rem;
  padding-inline: 0.75rem;
  border-radius: 999px;
  transition: background 0.15s ease, color 0.15s ease;
}

nav.guest-topnav .nav-link:hover {
  background: rgba(255, 255, 255, 0.1);
  color: #fff !important;
}

/* Landing hero mesh */
.hero-mesh {
  position: relative;
  overflow: hidden;
  background: linear-gradient(
    132deg,
    #0c182d 0%,
    #122a46 42%,
    #134956 72%,
    #1b5f6a 100%
  );
}

.hero-mesh::before {
  content: "";
  position: absolute;
  inset: -40% -10% auto -10%;
  height: 80%;
  background: radial-gradient(
    ellipse at 60% 0%,
    rgba(27, 163, 169, 0.28),
    transparent 55%
  );
  pointer-events: none;
}

.hero-mesh::after {
  content: "";
  position: absolute;
  inset: auto -20% -50% -20%;
  height: 70%;
  background: radial-gradient(
    ellipse at 20% 100%,
    rgba(63, 99, 196, 0.25),
    transparent 50%
  );
  pointer-events: none;
}

.hero-mesh .container {
  position: relative;
  z-index: 1;
}

.guest-trust-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.38rem 0.95rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.14);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: rgba(212, 230, 255, 0.95);
}

.guest-display {
  letter-spacing: -0.035em;
  line-height: 1.08;
}

.guest-hero-copy {
  color: rgba(255, 255, 255, 0.76);
  font-size: 1.125rem;
  line-height: 1.58;
}

.guest-highlight-card {
  border-radius: 18px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  background: rgba(255, 255, 255, 0.04);
  backdrop-filter: blur(12px);
  box-shadow: 0 28px 60px rgba(0, 0, 0, 0.2);
}

.guest-mini-stat {
  border-radius: 14px;
  padding: 1rem 1.15rem;
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.guest-float-icon {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  font-size: 1.35rem;
  flex-shrink: 0;
  background: linear-gradient(145deg, rgba(27, 163, 169, 0.35), rgba(47, 109, 220, 0.18));
  color: rgba(255, 255, 255, 0.95);
  border: 1px solid rgba(255, 255, 255, 0.12);
}

.guest-role-card {
  border-radius: 16px;
  border: 1px solid rgba(21, 42, 70, 0.08);
  height: 100%;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  background: #fff;
}

.guest-role-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 22px 48px rgba(15, 31, 56, 0.1);
}

.guest-steps {
  background: linear-gradient(180deg, #f8fafc 0%, #eef2f6 100%);
  border-top: 1px solid rgba(15, 31, 56, 0.06);
  border-bottom: 1px solid rgba(15, 31, 56, 0.06);
}

.guest-step-num {
  width: 2rem;
  height: 2rem;
  border-radius: 10px;
  display: grid;
  place-items: center;
  font-weight: 700;
  font-size: 0.92rem;
  background: linear-gradient(135deg, var(--ri-teal), #2f6bdc);
  color: #fff;
}

.guest-cta-band {
  background: linear-gradient(90deg, #0f1f38 0%, #17395c 50%, #1a5560 100%);
  color: #fff;
}

/* Auth shell */
body.guest-public .guest-auth-wrap {
  min-height: calc(100vh - 180px);
  display: flex;
  align-items: center;
}

.guest-auth-card {
  border-radius: 18px;
  border: 1px solid rgba(21, 42, 70, 0.08);
  background: #fff;
  box-shadow: 0 24px 56px rgba(15, 31, 56, 0.1);
}

.guest-auth-eyebrow {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ri-muted);
}

.guest-auth-title {
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--ri-navy);
}

.guest-login-pick-grid .guest-pick-panel {
  border-radius: 16px;
  border: 1px solid rgba(21, 42, 70, 0.07);
  background: #fff;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
  box-shadow: 0 14px 40px rgba(15, 31, 56, 0.05);
}

.guest-login-pick-grid .guest-pick-panel:hover {
  transform: translateY(-2px);
  box-shadow: 0 20px 48px rgba(15, 31, 56, 0.1);
}

  background: #f8fafc !important;
  border-top: 1px solid rgba(15, 31, 56, 0.08);
}
