/* Marketing site — page-scoped styles. Lingua DS tokens.
   All class names prefixed lg- for safety. */

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body { background: var(--color-bg-cream); color: var(--color-fg-ink); font: var(--type-body); }

/* ---------- Nav ---------- */
.lg-nav {
  position: sticky; top: 0; z-index: 100;
  display: flex; align-items: center; gap: 24px;
  padding: 14px 32px;
  background: rgba(246, 241, 234, 0.82);
  backdrop-filter: blur(14px) saturate(1.2);
  -webkit-backdrop-filter: blur(14px) saturate(1.2);
  border-bottom: 1px solid var(--color-border);
}
.lg-nav__brand { border: none; display: inline-flex; align-items: center; }
.lg-nav__links { display: flex; gap: 28px; align-items: center; }
.lg-nav__link { color: var(--color-fg-ink-2); border: none; transition: color .18s; }
.lg-nav__link:hover { color: var(--color-brand-blue); }
.lg-nav__caret { font-size: 10px; opacity: .6; margin-left: 2px; }
.lg-nav__spacer { flex: 1; }
.lg-nav__login { font: 500 14px var(--font-sans); color: var(--color-fg-ink); border: none; }
.lg-nav__cta { background: var(--color-bg-ink); color: #fff; padding: 10px 18px; border-radius: 999px; font: 500 13px var(--font-sans); border: none; transition: background .18s, transform .18s; }
.lg-nav__cta:hover { background: var(--color-bg-ink-2); color: #fff; transform: translateY(-1px); }
.lg-nav__cta-label { display: inline-flex; }
.lg-nav__cta-char { display: inline-block; will-change: transform; }
.lg-nav__cta-label.is-riding .lg-nav__cta-char { animation: lg-coaster 620ms cubic-bezier(.5,-0.4,.35,1.5) both; }
@keyframes lg-coaster {
  0%   { transform: translateY(0)    rotate(0); }
  35%  { transform: translateY(-9px) rotate(-8deg); }
  60%  { transform: translateY(3px)  rotate(4deg); }
  80%  { transform: translateY(-2px) rotate(-2deg); }
  100% { transform: translateY(0)    rotate(0); }
}

/* ---------- Buttons ---------- */
.lg-btn { display: inline-flex; align-items: center; gap: 8px; padding: 13px 22px; border-radius: 999px; font: 500 15px/1 var(--font-sans); border: 1px solid transparent; cursor: pointer; transition: all .18s cubic-bezier(.22,1,.36,1); }
.lg-btn--primary { background: var(--color-bg-ink); color: #fff; }
.lg-btn--primary:hover { background: var(--color-bg-ink-2); color: #fff; transform: translateY(-1px); }
.lg-btn--blue { background: var(--color-brand-blue); color: #fff; box-shadow: var(--shadow-pop); }
.lg-btn--blue:hover { background: var(--color-brand-blue-deep); color: #fff; transform: translateY(-1px); }
.lg-btn--blue.is-on { background: var(--color-brand-blue-deep); }
.lg-btn--ghost { background: #fff; color: var(--color-fg-ink); border-color: var(--color-border); }
.lg-btn--ghost:hover { background: var(--color-bg-cream-2); color: var(--color-fg-ink); }
.lg-btn--cream { background: var(--color-bg-cream); color: var(--color-fg-ink); }
.lg-btn--cream:hover { background: var(--color-bg-cream-2); color: var(--color-fg-ink); }

/* ---------- Eyebrow / section title ---------- */
.lg-eyebrow { font: var(--type-eyebrow); letter-spacing: var(--letter-eyebrow); text-transform: uppercase; color: var(--color-fg-muted); text-align: center; }
.lg-section__title { font: var(--type-h1); letter-spacing: var(--tracking-tight); text-align: center; max-width: 820px; margin: 14px auto 12px; color: var(--color-fg-ink); }
.lg-section__sub { font: var(--type-lead); color: var(--color-fg-ink-2); text-align: center; max-width: 620px; margin: 0 auto 40px; }

/* ---------- Hero ---------- */
.lg-hero { text-align: center; padding: 96px 24px 64px; max-width: 1200px; margin: 0 auto; }
.lg-hero__title { font: var(--type-display-1); letter-spacing: var(--tracking-tight); margin: 14px 0 18px; color: var(--color-fg-ink); min-height: 1.05em; }
.lg-hero__typed { display: inline; }
.lg-hero__tail { display: inline; animation: lg-tail-pop .35s cubic-bezier(.22,1,.36,1); }
.lg-hero__caret {
  display: inline-block;
  width: 4px; height: 0.85em;
  background: var(--color-brand-blue);
  margin-left: 2px;
  vertical-align: -0.08em;
  animation: lg-title-caret 1s steps(2) infinite;
  border-radius: 1px;
}
@keyframes lg-title-caret { 50% { opacity: 0; } }
@keyframes lg-tail-pop {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.lg-hero__sub { font: var(--type-lead); color: var(--color-fg-ink-2); max-width: 600px; margin: 0 auto 24px; white-space: pre-line; }
.lg-hero__platforms { display: flex; gap: 18px; align-items: center; justify-content: center; font: 500 13px var(--font-sans); color: var(--color-fg-muted); margin: 0 auto 24px; }
.lg-hero__platforms span { display: inline-flex; align-items: center; gap: 6px; }
.lg-hero__platforms img { vertical-align: middle; opacity: .8; }
.lg-hero__ctas { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.lg-hero__fine { font: var(--type-caption); color: var(--color-fg-muted); margin-top: 16px; }
.lg-hero__frame { position: relative; max-width: 920px; margin: 64px auto 0; transform: rotate(-1.2deg); }
.lg-hero__frame img { width: 100%; height: auto; border-radius: 32px; box-shadow: var(--shadow-lg); }
.lg-hero__listen { position: absolute; left: 50%; bottom: -22px; transform: translateX(-50%); display: inline-flex; align-items: center; gap: 12px; background: var(--color-bg-ink); color: #fff; padding: 12px 22px; border-radius: 999px; box-shadow: var(--shadow-lg); font: 500 14px var(--font-sans); }

/* ---------- Hero animation: curved Wispr-style text-along-path ---------- */
.lg-hero-anim {
  position: relative;
  max-width: 1200px;
  margin: 56px auto 0;
  height: 460px;
  pointer-events: none;
}

.lg-hero-anim__svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  overflow: visible;
}

.lg-hero-anim__text {
  font-family: var(--font-serif, 'Instrument Serif', 'Georgia', serif);
  font-size: 28px;
  font-style: italic;
  letter-spacing: -0.005em;
  font-weight: 400;
}

@keyframes lg-anim-flow {
  /* Move the textPath along the curve. textPath supports startOffset
     animation via attribute; we use offset-distance via CSS variable on
     the wrapper instead — but textPath itself can be animated through the
     -webkit attribute. Simplest cross-browser: animate the SVG transform. */
  from { transform: translateX(0); }
  to   { transform: translateX(-1200px); }
}

/* Central waveform pill — sits over the path mid-way */
.lg-hero-anim__pill {
  position: absolute;
  left: 50%;
  top: 42%;
  transform: translate(-50%, -50%);
  background: #fff;
  border: 1.5px solid var(--color-fg-ink);
  border-radius: 999px;
  padding: 16px 32px;
  box-shadow: 0 8px 24px rgba(15,23,42,0.08);
  z-index: 2;
  transition: box-shadow .3s, border-color .3s;
}
.lg-hero-anim__pill.is-paused {
  border-color: var(--color-border, #d8d2c5);
  box-shadow: 0 4px 12px rgba(15,23,42,0.05);
}

.lg-hero-anim__wave {
  display: flex;
  align-items: center;
  gap: 3px;
  height: 28px;
  width: 90px;
  justify-content: center;
}

.lg-hero-anim__wave span {
  display: block;
  width: 3px;
  background: var(--color-fg-ink);
  border-radius: 2px;
  height: 6px;
  animation: lg-hero-wave 1.1s ease-in-out infinite;
  transition: height .3s ease, opacity .3s ease;
}
.lg-hero-anim__pill.is-paused .lg-hero-anim__wave span {
  animation-play-state: paused;
  height: 4px !important;
  opacity: 0.35 !important;
}

@keyframes lg-hero-wave {
  0%, 100% { height: 4px;  opacity: 0.35; }
  20%      { height: 22px; opacity: 1; }
  50%      { height: 8px;  opacity: 0.7; }
  80%      { height: 18px; opacity: 1; }
}

/* Transcription card — "what gets written" */
.lg-hero-anim__transcript {
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  width: min(560px, 90%);
  background: #fff;
  border: 1px solid var(--color-border, #e3dccb);
  border-radius: 16px;
  padding: 14px 18px 16px;
  box-shadow: 0 12px 32px rgba(15,23,42,0.10);
  z-index: 3;
  text-align: left;
  pointer-events: auto;
}
.lg-hero-anim__transcript-head {
  display: flex; align-items: center; gap: 8px;
  font: 500 11px/1 var(--font-sans);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-fg-muted, #8a8473);
  margin-bottom: 8px;
}
.lg-hero-anim__dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--color-brand-blue, #3b82f6);
  box-shadow: 0 0 0 0 rgba(59,130,246,0.55);
  animation: lg-hero-dot 1.6s ease-out infinite;
}
@keyframes lg-hero-dot {
  0%   { box-shadow: 0 0 0 0   rgba(59,130,246,0.55); }
  70%  { box-shadow: 0 0 0 8px rgba(59,130,246,0); }
  100% { box-shadow: 0 0 0 0   rgba(59,130,246,0); }
}
.lg-hero-anim__transcript-body {
  font: 400 16px/1.45 var(--font-sans);
  color: var(--color-fg-ink);
  min-height: 84px;
  position: relative;
  padding-right: 64px; /* room for persona avatar in bottom-right */
}
.lg-hero-anim__persona {
  position: absolute;
  right: 14px;
  bottom: 14px;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  overflow: hidden;
  box-shadow:
    0 0 0 2px #fff,
    0 0 0 3px rgba(15,23,42,0.06),
    0 6px 14px rgba(15,23,42,0.10);
  animation: lg-hero-persona-pum .55s cubic-bezier(.22,1.4,.36,1);
  z-index: 4;
}
.lg-hero-anim__persona::after {
  /* tiny status dot — same blue as the recording dot */
  content: '';
  position: absolute;
  right: 1px;
  bottom: 1px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--color-brand-blue, #3b82f6);
  box-shadow: 0 0 0 2px #fff;
}
@keyframes lg-hero-persona-pum {
  0%   { opacity: 0; transform: translateY(8px) scale(0.7);  filter: blur(3px); }
  55%  { opacity: 1; transform: translateY(0)   scale(1.06); filter: blur(0); }
  100% { opacity: 1; transform: translateY(0)   scale(1); }
}
.lg-hero-anim__line {
  margin: 0 0 4px;
  transition: opacity .5s, transform .5s;
}
.lg-hero-anim__line--age0 {
  /* Newest line — pum into existence */
  animation: lg-hero-pum .42s cubic-bezier(.22,1.4,.36,1);
  opacity: 1;
  color: var(--color-fg-ink);
}
.lg-hero-anim__line--age1 { opacity: 0.55; }
.lg-hero-anim__line--age2 { opacity: 0.28; }
@keyframes lg-hero-pum {
  0%   { opacity: 0; transform: translateY(6px) scale(0.985); filter: blur(2px); }
  60%  { opacity: 1; filter: blur(0); }
  100% { opacity: 1; transform: translateY(0) scale(1); }
}
.lg-hero-anim__cursor {
  display: inline-block;
  width: 2px; height: 1.05em;
  background: var(--color-brand-blue, #3b82f6);
  vertical-align: -0.15em;
  margin-left: 2px;
  animation: lg-hero-cursor 1s steps(2) infinite;
}
@keyframes lg-hero-cursor { 50% { opacity: 0; } }

@media (max-width: 720px) {
  .lg-hero-anim { height: 360px; margin-top: 32px; }
  .lg-hero-anim__text { font-size: 18px; }
  .lg-hero-anim__pill { padding: 12px 22px; top: 38%; }
  .lg-hero-anim__wave { width: 64px; height: 22px; }
  .lg-hero-anim__transcript-body { font-size: 14px; min-height: 72px; padding-right: 52px; }
  .lg-hero-anim__persona { width: 44px; height: 44px; right: 10px; bottom: 10px; }
  .lg-hero-anim__persona::after { width: 10px; height: 10px; }
}

/* ---------- App grid ---------- */
.lg-apps { padding: 96px 24px; max-width: 1100px; margin: 0 auto; text-align: center; }
.lg-apps__grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 14px; max-width: 880px; margin: 0 auto; }
.lg-apps__cell { aspect-ratio: 1; background: #fff; border: 1px solid var(--color-border); border-radius: 16px; display: flex; align-items: center; justify-content: center; transition: all .2s; }
.lg-apps__cell:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.lg-apps__cell img { width: 56%; height: 56%; object-fit: contain; }

/* ---------- "Any app you use" — small grid cell that mirrors the others ---------- */
.lg-apps__cell--any {
  flex-direction: column;
  gap: 2px;
  text-align: center;
  background: var(--color-bg-cream);
  padding: 8px;
}
.lg-apps__cell--any:hover { background: #fff; }
.lg-apps__any-eb {
  font: 600 12px/1.1 var(--font-sans);
  color: var(--color-brand-blue-deep);
  letter-spacing: -0.01em;
}
.lg-apps__any-sub {
  font: 400 10px/1.2 var(--font-sans);
  color: var(--color-fg-ink-2);
  letter-spacing: -0.005em;
}

/* ---------- App-aware tone (under app grid) ---------- */
.lg-tone {
  margin: 96px auto 0;
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 64px;
  align-items: center;
  max-width: 1100px;
}
.lg-tone__intro { text-align: left; }
.lg-tone__intro .lg-eyebrow { text-align: left; }
.lg-tone__h {
  font: var(--type-h2, 600 36px/1.1 var(--font-sans));
  letter-spacing: var(--tracking-tight);
  margin: 12px 0 14px;
  color: var(--color-fg-ink);
}
.lg-tone__b {
  font: var(--type-lead);
  color: var(--color-fg-ink-2);
  max-width: 460px;
  margin: 0;
}
.lg-tone__card {
  background: #fff;
  border: 1px solid var(--color-border, #e7dfd0);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.04);
}
.lg-tone__head {
  padding: 12px 18px;
  font: 500 13px var(--font-sans);
  color: #5b6675;
  border-bottom: 1px solid #f0eadf;
}
.lg-tone__said {
  color: var(--color-fg-ink);
  font-weight: 500;
  font-style: italic;
  letter-spacing: -0.011em;
  margin-left: 4px;
}
.lg-tone__row {
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: 14px;
  padding: 14px 18px;
  align-items: flex-start;
  border-top: 1px solid #f5efe3;
}
.lg-tone__row:first-of-type { border-top: none; }
.lg-tone__app {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font: 500 13.5px var(--font-sans);
  color: var(--color-fg-ink);
  letter-spacing: -0.005em;
}
.lg-tone__badge {
  width: 20px; height: 20px; border-radius: 5px; flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center;
  font: 600 11px var(--font-sans); color: #fff;
}
.lg-tone__badge--logo { background: #fff; padding: 1px; }
.lg-tone__badge--logo img { width: 100%; height: 100%; object-fit: contain; display: block; }
.lg-tone__out {
  font: 400 14px/1.45 var(--font-sans);
  color: var(--color-fg-ink);
  letter-spacing: -0.008em;
}
.lg-tone__pill {
  display: inline-block;
  font: 500 10px/1 var(--font-sans);
  color: #266d92;
  background: #d6e8f2;
  padding: 4px 8px;
  border-radius: 999px;
  letter-spacing: 0.02em;
  margin-left: 6px;
  vertical-align: 2px;
}

/* ---------- Value cards ---------- */
.lg-values { padding: 96px 24px; max-width: 1200px; margin: 0 auto; }
.lg-values__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.lg-value { background: #fff; border-radius: 24px; padding: 32px; border: 1px solid var(--color-border); box-shadow: var(--shadow-card-cream); transition: all .2s; }
.lg-value:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.lg-value__icon { width: 28px; height: 28px; display: block; margin-bottom: 18px; }
.lg-value__eb { font: var(--type-eyebrow); letter-spacing: var(--letter-eyebrow); text-transform: uppercase; color: var(--color-fg-muted); margin-bottom: 8px; }
.lg-value__t { font: var(--type-h3); letter-spacing: var(--tracking-snug); margin: 0 0 12px; }
.lg-value__b { font: var(--type-body); color: var(--color-fg-ink-2); margin: 0; }

/* ---------- Persona tabs ---------- */
.lg-personas { padding: 96px 24px; max-width: 1200px; margin: 0 auto; text-align: center; }
.lg-personas__tabs { display: inline-flex; flex-wrap: wrap; gap: 8px; margin: 8px auto 32px; padding: 6px; background: #fff; border: 1px solid var(--color-border); border-radius: 999px; }
.lg-personas__tab { padding: 10px 18px; border-radius: 999px; font: 500 14px var(--font-sans); border: none; background: transparent; cursor: pointer; color: var(--color-fg-muted); transition: all .2s; }
.lg-personas__tab:hover { color: var(--color-fg-ink); }
.lg-personas__tab.is-active { background: var(--color-bg-ink); color: #fff; }
.lg-personas__panel { display: grid; grid-template-columns: 1fr 1.2fr; gap: 32px; align-items: center; text-align: left; background: var(--color-bg-cream-2); border-radius: 32px; padding: 48px; }
.lg-personas__h { font: var(--type-h2); letter-spacing: var(--tracking-tight); margin: 0 0 16px; }
.lg-personas__b { font: var(--type-lead); color: var(--color-fg-ink-2); margin: 0 0 24px; }
.lg-personas__ctas { display: flex; gap: 10px; }
.lg-personas__art img { width: 100%; height: auto; border-radius: 20px; box-shadow: var(--shadow-md); }

/* ---------- Love letters ---------- */
.lg-letters { padding: 96px 24px; max-width: 1200px; margin: 0 auto; text-align: center; }
.lg-letters__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; text-align: left; }
.lg-letter { background: #fff; border-radius: 24px; padding: 28px; border: 1px solid var(--color-border); box-shadow: var(--shadow-card-cream); }
.lg-letter__q { font: 500 18px/1.45 var(--font-sans); letter-spacing: -.01em; color: var(--color-fg-ink); margin: 0 0 24px; text-wrap: pretty; }
.lg-letter__who { display: flex; gap: 12px; align-items: center; }
.lg-letter__who img { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; }
.lg-letter__name { font: 500 14px var(--font-sans); }
.lg-letter__role { font: 400 12px var(--font-sans); color: var(--color-fg-muted); }

/* ---------- CTA band ---------- */
.lg-cta-band { background: var(--color-bg-ink); color: var(--color-fg-on-dark); text-align: center; padding: 96px 24px; }
.lg-cta-band__t { font: var(--type-display-2); letter-spacing: var(--tracking-tight); color: #fff; margin: 0 0 16px; }
.lg-cta-band__b { font: var(--type-lead); color: var(--color-fg-on-dark-2); max-width: 600px; margin: 0 auto 28px; }
.lg-cta-band__ctas { display: inline-flex; gap: 12px; }
.lg-cta-band__fine { font: var(--type-caption); color: var(--color-fg-on-dark-2); margin-top: 24px; }

/* ---------- Footer ---------- */
.lg-footer { padding: 64px 32px 32px; background: var(--color-bg-cream); border-top: 1px solid var(--color-border); }
.lg-footer__cols { display: grid; grid-template-columns: repeat(4, 1fr); gap: 32px; max-width: 1200px; margin: 0 auto 48px; }
.lg-footer__h { font: 500 13px var(--font-sans); color: var(--color-fg-ink); margin: 0 0 14px; letter-spacing: .02em; }
.lg-footer__cols a { display: block; font: 400 14px/1.9 var(--font-sans); color: var(--color-fg-muted); border: none; }
.lg-footer__cols a:hover { color: var(--color-brand-blue); }
.lg-footer__bottom { display: flex; align-items: center; gap: 18px; max-width: 1200px; margin: 0 auto; padding-top: 24px; border-top: 1px solid var(--color-border); flex-wrap: wrap; }
.lg-footer__copy { font: var(--type-caption); color: var(--color-fg-muted); }
.lg-footer__legal { margin-left: auto; display: flex; gap: 14px; }
.lg-footer__legal a { font: var(--type-caption); color: var(--color-fg-muted); border: none; }
.lg-footer__legal a:hover { color: var(--color-brand-blue); }

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
  .lg-hero__title { font: 600 56px/1 var(--font-sans); letter-spacing: -.025em; }
  .lg-values__grid, .lg-letters__grid { grid-template-columns: 1fr; }
  .lg-personas__panel { grid-template-columns: 1fr; padding: 28px; }
  .lg-apps__grid { grid-template-columns: repeat(5, 1fr); max-width: 100%; }
  .lg-tone { grid-template-columns: 1fr; gap: 32px; }
  .lg-footer__cols { grid-template-columns: repeat(2, 1fr); }
  /* Tighter nav at narrow widths so the menu trio still fits. */
  .lg-nav { padding: 14px 24px; gap: 14px; }
  .lg-nav__links { gap: 14px; }
  .lg-nav__login, .lg-nav__contact { display: none; }
}
@media (max-width: 640px) {
  .lg-nav__links { display: none; }
}


/* ---------- Contact modal (shared — used by Footer + about.html) ---------- */
.lg-roles-modal {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(14, 17, 22, 0.55);
  backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  animation: lg-modal-fade .18s ease-out both;
}
@keyframes lg-modal-fade { from { opacity: 0; } to { opacity: 1; } }
.lg-roles-modal__card {
  position: relative;
  background: #fff;
  border-radius: 18px;
  width: min(520px, 100%);
  max-height: calc(100vh - 48px);
  overflow: auto;
  padding: 32px 32px 28px;
  box-shadow: 0 24px 80px rgba(14,17,22,.28);
  animation: lg-modal-rise .22s cubic-bezier(.2,.7,.2,1) both;
}
@keyframes lg-modal-rise { from { transform: translateY(12px); opacity: 0; } to { transform: none; opacity: 1; } }
.lg-roles-modal__x {
  position: absolute; top: 14px; right: 14px;
  width: 32px; height: 32px; border-radius: 50%;
  border: none; background: transparent;
  font-size: 22px; line-height: 1; cursor: pointer;
  color: var(--color-fg-ink-2);
  display: flex; align-items: center; justify-content: center;
}
.lg-roles-modal__x:hover { background: rgba(14,17,22,.06); color: var(--color-fg-ink); }
.lg-roles-modal__h { font: var(--type-h3); letter-spacing: var(--tracking-tight); margin: 0 0 8px; }
.lg-roles-modal__sub { font: 400 14px/1.5 var(--font-sans); color: var(--color-fg-ink-2); margin: 0 0 22px; }
.lg-roles-modal__sub strong { color: var(--color-fg-ink); font-weight: 500; }
.lg-roles-modal__form { display: flex; flex-direction: column; gap: 14px; }
.lg-roles-modal__field { display: flex; flex-direction: column; gap: 6px; }
.lg-roles-modal__field span { font: 500 12px/1 var(--font-sans); color: var(--color-fg-ink-2); letter-spacing: .02em; text-transform: uppercase; }
.lg-roles-modal__field input,
.lg-roles-modal__field textarea {
  font: 400 15px/1.45 var(--font-sans);
  color: var(--color-fg-ink);
  background: var(--color-bg-cream-2, #f1ebe1);
  border: 1px solid rgba(14,17,22,.10);
  border-radius: 10px;
  padding: 11px 13px;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
  resize: vertical;
  font-family: inherit;
}
.lg-roles-modal__field input:focus,
.lg-roles-modal__field textarea:focus {
  border-color: var(--color-brand-blue);
  box-shadow: 0 0 0 3px color-mix(in oklch, var(--color-brand-blue) 18%, transparent);
}
.lg-roles-modal__actions { display: flex; gap: 10px; justify-content: flex-end; margin-top: 6px; }
.lg-roles-modal__actions .lg-btn { border-bottom: none; }


/* ---------- Smooth in-page scrolling + nav anchor offsets ---------- */
html { scroll-behavior: smooth; }
#home, #apps, #values, #for-you, #love { scroll-margin-top: 88px; }

/* ---------- Nav "On this page" dropdown ---------- */
.lg-nav__menu { position: relative; display: inline-flex; align-items: center; }
.lg-nav__link, .lg-nav__menu-trigger {
  font: 500 13px/1 var(--font-sans);
  letter-spacing: -0.005em;
}
.lg-nav__menu-trigger {
  background: transparent;
  border: none;
  color: var(--color-fg-ink-2);
  cursor: pointer;
  padding: 0;
  display: inline-flex; align-items: center; gap: 4px;
  transition: color .18s;
}
.lg-nav__menu-trigger:hover { color: var(--color-brand-blue); }
.lg-nav__menu-trigger.is-open .lg-nav__caret {
  transform: rotate(180deg);
}
.lg-nav__caret { transition: transform .15s; display: inline-block; }
.lg-nav__menu-pop {
  position: absolute;
  top: calc(100% + 12px);
  left: 50%;
  transform: translateX(-50%);
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: 14px;
  padding: 6px;
  min-width: 220px;
  box-shadow: 0 18px 48px rgba(14,17,22,.14);
  z-index: 60;
  display: flex; flex-direction: column;
  animation: lg-nav-pop-in .16s cubic-bezier(.22,1,.36,1) both;
}
@keyframes lg-nav-pop-in {
  from { opacity: 0; transform: translate(-50%, -4px); }
  to   { opacity: 1; transform: translate(-50%, 0); }
}
.lg-nav__menu-item {
  display: block;
  padding: 9px 12px;
  border-radius: 8px;
  font: 500 14px/1.2 var(--font-sans);
  color: var(--color-fg-ink);
  text-decoration: none;
  border: none;
  transition: background .12s, color .12s;
}
.lg-nav__menu-item:hover {
  background: var(--color-bg-cream);
  color: var(--color-brand-blue-deep);
}


/* ---------- LangToggle (ES / EN pill) ---------- */
.lg-langtoggle {
  display: inline-flex;
  align-items: center;
  background: rgba(14,17,22,0.06);
  border-radius: 999px;
  padding: 3px;
  margin-right: 6px;
  flex-shrink: 0;
}
.lg-langtoggle__btn {
  font: 600 11px/1 var(--font-sans);
  letter-spacing: 0.04em;
  padding: 6px 10px;
  border-radius: 999px;
  border: none;
  background: transparent;
  color: var(--color-fg-ink-2);
  cursor: pointer;
  transition: background .14s, color .14s;
}
.lg-langtoggle__btn:hover { color: var(--color-fg-ink); }
.lg-langtoggle__btn.is-on {
  background: #fff;
  color: var(--color-brand-blue-deep);
  box-shadow: 0 1px 2px rgba(14,17,22,0.08);
}
@media (max-width: 760px) {
  .lg-langtoggle { margin-right: 0; }
}
