/*
 * This is a manifest file that'll be compiled into application.css.
 *
 * With Propshaft, assets are served efficiently without preprocessing steps. You can still include
 * application-wide styles in this file, but keep in mind that CSS precedence will follow the standard
 * cascading order, meaning styles declared later in the document or manifest will override earlier ones,
 * depending on specificity.
 *
 * Consider organizing styles into separate files for maintainability.
 */

:root {
  --font-brand-sans: "Lexend", ui-sans-serif, system-ui, -apple-system,
    "Segoe UI", sans-serif;
  --font-brand-display: var(--font-brand-sans);
  --tracking-brand-display: -0.03em;
}

.markdown > * + * {
  margin-top: 0.75rem;
}

.markdown table {
  width: 100%;
  border-collapse: collapse;
}

.markdown th,
.markdown td {
  border: 1px solid #e2e8f0;
  padding: 0.5rem 0.75rem;
  text-align: left;
  vertical-align: top;
}

.markdown th {
  background: #f8fafc;
  font-weight: 600;
}

.markdown ul,
.markdown ol {
  padding-left: 1.25rem;
}

.markdown blockquote {
  border-left: 4px solid #e2e8f0;
  padding-left: 0.75rem;
  color: #475569;
}

.markdown code {
  background: #f1f5f9;
  border-radius: 0.25rem;
  padding: 0.1rem 0.25rem;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas,
    "Liberation Mono", "Courier New", monospace;
}

.markdown pre {
  background: #0f172a;
  border-radius: 0.5rem;
  color: #f8fafc;
  overflow-x: auto;
  padding: 0.75rem;
}

body {
  font-family: var(--font-brand-sans);
}

.marketing-display {
  font-family: var(--font-brand-display);
  letter-spacing: var(--tracking-brand-display);
}

.mock-agent-stage {
  background-image:
    radial-gradient(
      circle at 18% 14%,
      rgba(196, 181, 253, 0.22),
      transparent 42%
    ),
    radial-gradient(
      circle at 78% 78%,
      rgba(129, 140, 248, 0.2),
      transparent 38%
    );
}

.mock-agent-line {
  opacity: 0;
  transform: translateY(8px);
  animation: mockAgentReveal 0.6s ease-out forwards;
  animation-delay: var(--line-delay, 0s);
}

.mock-typing-dot {
  width: 0.375rem;
  height: 0.375rem;
  border-radius: 999px;
  background-color: rgba(255, 255, 255, 0.9);
  opacity: 0.3;
  animation: mockTyping 1s infinite;
  animation-delay: var(--dot-delay, 0s);
}

@keyframes mockAgentReveal {
  from {
    opacity: 0;
    transform: translateY(8px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes mockTyping {
  0%,
  80%,
  100% {
    opacity: 0.3;
    transform: translateY(0);
  }

  40% {
    opacity: 1;
    transform: translateY(-2px);
  }
}

.hero-typewriter-frame {
  display: block;
}

.hero-typewriter-text {
  display: block;
  white-space: normal;
  word-break: break-word;
}

.hero-typewriter-text .Typewriter__wrapper,
.hero-typewriter-text .Typewriter__cursor {
  display: inline-block;
  transition: opacity 320ms ease, transform 320ms ease;
}

.hero-typewriter-text .Typewriter__cursor {
  margin-left: 0.14em;
  font-size: 0.74em;
  line-height: 1;
  transform: translateY(-0.06em);
}

.hero-typewriter-exit {
  opacity: 0;
  transform: translateY(0.42em);
}

@media (prefers-reduced-motion: reduce) {
  .mock-agent-line {
    animation: none;
    opacity: 1;
    transform: none;
  }

  .mock-typing-dot {
    animation: none;
    opacity: 1;
  }

  .hero-typewriter-text .Typewriter__wrapper,
  .hero-typewriter-text .Typewriter__cursor {
    transition: none;
  }
}

/* ============================================================
   LANDING PAGE — MODERN MINIMAL DESIGN SYSTEM
   Based on the indigo/violet palette from the hero.
   ============================================================ */

/* ── Sticky nav colour transitions ──
   When the header scrolls over light content the surface goes white/95.
   These rules swap the violet-on-dark palette to indigo-on-white. */

.nav-is-scrolled .landing-nav-brand {
  color: #312e81; /* indigo-900 */
}

.nav-is-scrolled .landing-nav-link {
  color: #4338ca; /* indigo-700 */
}

.nav-is-scrolled .landing-nav-link:hover {
  color: #1e1b4b; /* indigo-950 */
}

.nav-is-scrolled .landing-nav-sign-in {
  background-color: transparent;
  border-color: #c4b5fd; /* violet-300 */
  color: #4338ca; /* indigo-700 */
}

.nav-is-scrolled .landing-nav-sign-in:hover {
  background-color: #f5f3ff; /* violet-50 */
}

.nav-is-scrolled .marketing-nav-primary {
  background-color: #4338ca; /* indigo-700 */
  color: #ffffff;
}

.nav-is-scrolled .marketing-nav-primary:hover {
  background-color: #3730a3; /* indigo-800 */
}

.marketing-nav-secondary,
.marketing-nav-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 9999px;
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  line-height: 1.25rem;
  transition:
    background-color 150ms ease,
    border-color 150ms ease,
    color 150ms ease;
}

.marketing-nav-secondary {
  border: 1px solid rgba(255, 255, 255, 0.15);
  color: rgba(255, 255, 255, 0.85);
  font-weight: 500;
}

.marketing-nav-secondary:hover {
  border-color: rgba(255, 255, 255, 0.3);
  color: #ffffff;
}

.marketing-nav-primary {
  background-color: #ffffff;
  color: #1e1b4b; /* indigo-950 */
  font-weight: 600;
}

.marketing-nav-primary:hover {
  background-color: #ede9fe; /* violet-100 */
}

/* ============================================================
   LANDING PAGE — FIGMA HOMEPAGE
   Scoped styles for the Roava marketing landing page rebuild.
   ============================================================ */

.landing-figma-page {
  --landing-font-display: "Urbanist", ui-sans-serif, system-ui, sans-serif;
  --landing-font-body: "Urbanist", ui-sans-serif, system-ui, sans-serif;
  --landing-font-ui: "Inter", ui-sans-serif, system-ui, sans-serif;
}

.landing-figma-page h1,
.landing-figma-page h2,
.landing-figma-page h3,
.landing-figma-page h4,
.landing-figma-page h5,
.landing-figma-page h6 {
  font-family: var(--landing-font-display);
}

.landing-figma-page p,
.landing-figma-page li,
.landing-figma-page a,
.landing-figma-page button,
.landing-figma-page input {
  font-family: var(--landing-font-body);
}

.landing-figma-search-field {
  position: relative;
}

.landing-figma-search-input {
  width: 100%;
  height: 6.1875rem;
  border-radius: 1.5rem;
  border: 1px solid #ebebeb;
  background: #f7f7f7;
  padding: 1.4rem 4.5rem 1.3rem 1.4rem;
  color: #111111;
  font-family: var(--landing-font-ui);
  font-size: 1rem;
  line-height: 1.2;
  letter-spacing: 0.01em;
}

.landing-figma-search-input:focus {
  outline: none;
  border-color: #d8d8d8;
  box-shadow: 0 0 0 4px rgba(0, 0, 0, 0.04);
}

.landing-figma-search-overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 1.4rem 4.5rem 1.3rem 1.4rem;
  transition: opacity 180ms ease;
}

.landing-figma-search-primary,
.landing-figma-search-secondary {
  margin: 0;
  text-align: center;
  font-family: var(--landing-font-ui);
  font-size: 1rem;
  line-height: 1.2;
  letter-spacing: 0.01em;
}

.landing-figma-search-primary {
  color: #747474;
}

.landing-figma-search-secondary {
  margin-top: 0.55rem;
  color: #d2d2d2;
}

.landing-figma-search-input:not(:placeholder-shown) + .landing-figma-search-overlay,
.landing-figma-search-field:focus-within .landing-figma-search-overlay {
  opacity: 0;
}

.landing-figma-search-submit {
  position: absolute;
  right: 0.5rem;
  bottom: 0.625rem;
  display: inline-flex;
  width: 2.5rem;
  height: 2.5rem;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 999px;
  background: #d9d9d9;
  color: #4b5563;
  font-size: 1rem;
  line-height: 1;
  cursor: pointer;
  transition:
    transform 150ms ease,
    background-color 150ms ease,
    color 150ms ease;
}

.landing-figma-search-submit:hover {
  background: #111111;
  color: #ffffff;
  transform: translateY(-1px);
}

.landing-figma-workflow-track {
  position: relative;
  width: min(100%, 75.4375rem);
  height: 21.875rem;
}

.landing-figma-workflow-arc {
  position: absolute;
  left: 0.478%;
  top: 0.571%;
  width: 97.704%;
  height: 87.714%;
}

.landing-figma-workflow-node {
  position: absolute;
  display: flex;
  width: 3.0625rem;
  height: 3.0625rem;
  align-items: center;
  justify-content: center;
  border: 1px solid #b5b5b5;
  border-radius: 999px;
  background: #ffffff;
}

.landing-figma-workflow-edge {
  position: absolute;
  width: 1.5rem;
  height: 1.5rem;
}

.landing-figma-workflow-edge-left {
  left: 0;
  top: 92.57%;
}

.landing-figma-workflow-edge-right {
  right: 0;
  top: 92.57%;
}

.landing-figma-final-fade {
  position: absolute;
  left: 50%;
  top: 50%;
  width: min(67rem, 100%);
  height: 25.5625rem;
  transform: translate(-50%, -50%);
  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0) 0%,
    rgb(255, 255, 255) 31%,
    rgb(255, 255, 255) 70%,
    rgba(255, 255, 255, 0) 98%
  );
  pointer-events: none;
}

.landing-figma-floating-card {
  position: absolute;
  max-width: 21.6875rem;
  border: 1px solid #f3f3f3;
  border-radius: 0.5rem;
  background: #ffffff;
  box-shadow: 0 14px 22px rgba(0, 0, 0, 0.12);
  padding: 0.8rem 1.35rem;
  color: #020202;
  font-size: 0.875rem;
  font-weight: 500;
  line-height: 1rem;
  opacity: 0.3;
}

@media (max-width: 640px) {
  .landing-figma-search-input {
    height: 6.5rem;
    padding-right: 4rem;
  }

  .landing-figma-search-primary,
  .landing-figma-search-secondary {
    font-size: 0.92rem;
  }
}

/* Eyebrow / label typography */
.coord-label {
  font-family: var(--font-brand-sans);
  font-size: 0.675rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

/* Typing dots — light (indigo) variant for white-background sections.
   Use a solid colour so the animation's own opacity: 0.3→1 does the fading
   instead of stacking with a semi-transparent fill. */
.mock-typing-dot-indigo {
  background-color: rgb(99, 102, 241); /* indigo-500 */
}

@media (prefers-reduced-motion: reduce) {
  .mock-typing-dot-indigo {
    animation: none;
    opacity: 0.6;
  }
}

/* ============================================================
   MARKETING SURFACES
   ============================================================ */

.marketing-page-shell {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(
      120% 70% at 0% 0%,
      rgba(196, 181, 253, 0.16),
      transparent 62%
    ),
    radial-gradient(
      80% 80% at 100% 20%,
      rgba(99, 102, 241, 0.14),
      transparent 58%
    ),
    linear-gradient(180deg, #ffffff 0%, #f8f7ff 48%, #ffffff 100%);
}

.marketing-rise {
  opacity: 0;
  transform: translateY(14px);
  animation: marketingRise 0.75s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

.marketing-rise:nth-child(2) {
  animation-delay: 0.08s;
}

.marketing-rise:nth-child(3) {
  animation-delay: 0.16s;
}

.marketing-rise:nth-child(4) {
  animation-delay: 0.24s;
}

@keyframes marketingRise {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.landing-advisor-strip {
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(99, 102, 241, 0.14);
  background:
    linear-gradient(
      135deg,
      rgba(238, 242, 255, 0.98),
      rgba(245, 243, 255, 0.92) 52%,
      rgba(255, 255, 255, 0.98)
    );
  box-shadow: 0 26px 60px rgba(76, 29, 149, 0.08);
}

.landing-advisor-strip::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(
      circle at 85% 20%,
      rgba(129, 140, 248, 0.15),
      transparent 22%
    );
}

.marketing-hero-shell,
.advisor-page-hero {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(
      120% 110% at 100% 0%,
      rgba(79, 70, 229, 0.22),
      transparent 60%
    ),
    radial-gradient(
      100% 90% at 0% 100%,
      rgba(217, 70, 239, 0.12),
      transparent 54%
    ),
    linear-gradient(145deg, #181341 0%, #211b57 52%, #0f172a 100%);
}

.marketing-grid,
.advisor-grid {
  position: relative;
}

.marketing-grid::before,
.advisor-grid::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.08) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: linear-gradient(180deg, rgba(0, 0, 0, 0.85), transparent 90%);
}

.marketing-glass-card,
.advisor-signal-card {
  border: 1px solid rgba(255, 255, 255, 0.12);
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.14),
      rgba(255, 255, 255, 0.06)
    );
  backdrop-filter: blur(10px);
}

.marketing-elevated-panel,
.advisor-form-panel {
  border: 1px solid rgba(79, 70, 229, 0.16);
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98),
      rgba(244, 244, 255, 0.96)
    );
  box-shadow: 0 30px 70px rgba(30, 41, 59, 0.12);
}

@media (prefers-reduced-motion: reduce) {
  .marketing-rise {
    animation: none;
    opacity: 1;
    transform: none;
  }
}

/* ── Itinerary carousel ── */

@keyframes landingCarousel {
  to { transform: translateX(-50%); }
}

.landing-carousel-track {
  animation: landingCarousel 55s linear infinite;
  will-change: transform;
}

.landing-carousel-track:hover {
  animation-play-state: paused;
}

@media (prefers-reduced-motion: reduce) {
  .landing-carousel-track {
    animation: none;
    overflow-x: auto;
    scrollbar-width: none;
  }

  .landing-carousel-track::-webkit-scrollbar {
    display: none;
  }
}
