/*
  forgetranslations.com -- style.css COMPLETE
  Theme: Mediterranean -- deep blue #2B4C7E + terracotta #C45E3E + sand #FAF7F2
  Fonts: Lora (headings) + Nunito Sans (body)
  Nav: ANNOUNCEMENT BAR (top) + sticky main bar with EN/ES language switcher
  Hero: FULL-WIDTH DARK CENTERED with floating script characters
  Services: TRANSLATION PAIR CARDS
  Pricing: HYBRID packages + per-word rates
  Bilingual: EN / ES switcher
  CSS prefix: fgt-
*/

@import url('https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400;0,500;0,600;0,700;1,400;1,600&family=Nunito+Sans:wght@300;400;500;600;700&display=swap');

/* ======================== TOKENS ======================== */
:root {
  --fgt-blue:    #2B4C7E;
  --fgt-blue2:   #1E3557;
  --fgt-blue3:   #3A6199;
  --fgt-bluelt:  rgba(43,76,126,.08);
  --fgt-bluebd:  rgba(43,76,126,.2);
  --fgt-terra:   #C45E3E;
  --fgt-terra2:  #B0522F;
  --fgt-terralt: rgba(196,94,62,.08);
  --fgt-terrabd: rgba(196,94,62,.22);
  --fgt-gold:    #D4A843;
  --fgt-sand:    #FAF7F2;
  --fgt-warm:    #F3EFE8;
  --fgt-parch:   #EDE8DF;
  --fgt-ink:     #1E1B18;
  --fgt-slate:   #4A4640;
  --fgt-muted:   #7A7570;
  --fgt-dim:     #B0ACA8;
  --fgt-edge:    #E8E4DC;
  --fgt-edge2:   #F0EDE8;

  --fgt-max: 1140px;
  --fgt-r:   5px;
  --fgt-r2:  12px;
  --fgt-r3:  24px;

  --fgt-fh: 'Lora', Georgia, serif;
  --fgt-fb: 'Nunito Sans', system-ui, -apple-system, sans-serif;

  --fgt-ease: all 0.22s cubic-bezier(.4,0,.2,1);
  --fgt-sh1:  0 2px 12px rgba(30,27,24,.08);
  --fgt-sh2:  0 8px 40px rgba(30,27,24,.13);
  --fgt-sh3:  0 20px 70px rgba(30,27,24,.18);
}

/* ======================== RESET ======================== */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  background: var(--fgt-sand);
  color: var(--fgt-ink);
  font-family: var(--fgt-fb);
  font-size: 1rem;
  line-height: 1.72;
  overflow-x: hidden;
  padding-top: 100px; /* topbar 36px + mainbar 64px */
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
input, textarea, select { font-family: inherit; font-size: 1rem; }
address { font-style: normal; }

/* ======================== TYPOGRAPHY ======================== */
h1, h2, h3, h4 { font-family: var(--fgt-fh); }
h1 { font-size: clamp(2.5rem, 5.5vw, 6.5rem); line-height: .9; letter-spacing: -.02em; font-weight: 600; }
h2 { font-size: clamp(1.9rem, 3.2vw, 4rem); line-height: .95; letter-spacing: -.015em; font-weight: 600; }
h3 { font-size: 1.05rem; font-weight: 700; font-family: var(--fgt-fb); }
p  { font-size: .9rem; line-height: 1.85; color: var(--fgt-slate); }

/* ======================== LAYOUT ======================== */
.fgt-wrap  { max-width: var(--fgt-max); margin: 0 auto; padding: 0 2.5rem; }
.fgt-slab  { padding: 7rem 0; }
.fgt-slab-sm { padding: 4rem 0; }

/* ======================== TOPBAR ======================== */
.fgt-topbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 960;
  height: 36px; background: var(--fgt-blue2);
  display: flex; align-items: center;
}
.fgt-topbar-inner {
  max-width: var(--fgt-max); margin: 0 auto; padding: 0 2.5rem;
  width: 100%; display: flex; align-items: center; justify-content: space-between;
}
.fgt-topbar-left {
  display: flex; align-items: center; gap: .88rem;
  font-family: var(--fgt-fb); font-size: .62rem; color: rgba(255,255,255,.55);
}
.fgt-topbar-left a { color: rgba(255,255,255,.7); transition: color .15s; }
.fgt-topbar-left a:hover { color: var(--fgt-gold); }
.fgt-topbar-sep { color: rgba(255,255,255,.2); font-size: .55rem; }
.fgt-lang-switch { display: flex; align-items: center; gap: .35rem; }
.fgt-lang-btn {
  font-family: var(--fgt-fb); font-size: .6rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em;
  color: rgba(255,255,255,.4); background: none; border: none; cursor: pointer;
  padding: .2rem .42rem; border-radius: 3px; transition: var(--fgt-ease);
}
.fgt-lang-btn:hover { color: rgba(255,255,255,.8); }
.fgt-lang-btn.fgt-lang-active { color: white; background: rgba(255,255,255,.12); }
.fgt-lang-div { color: rgba(255,255,255,.2); font-size: .6rem; }

/* ======================== MAIN NAV ======================== */
.fgt-mainbar {
  position: fixed; top: 36px; left: 0; right: 0; z-index: 950;
  height: 64px; background: var(--fgt-sand);
  border-bottom: 1px solid var(--fgt-edge);
  transition: box-shadow .3s;
}
.fgt-mainbar.fgt-bar-shadow { box-shadow: var(--fgt-sh2); }
.fgt-mainbar-inner {
  max-width: var(--fgt-max); margin: 0 auto; padding: 0 2.5rem;
  height: 64px; display: flex; align-items: center; gap: 2rem;
}
.fgt-brand {
  font-family: var(--fgt-fh); font-size: 1.08rem; font-weight: 700;
  color: var(--fgt-blue); letter-spacing: -.02em; text-decoration: none; flex-shrink: 0;
}
.fgt-brand em { font-style: italic; color: var(--fgt-terra); }
.fgt-nav-links { display: flex; align-items: center; gap: 0; flex: 1; justify-content: center; }
.fgt-nav-lk {
  font-family: var(--fgt-fb); font-size: .95rem; font-weight: 600;
  color: var(--fgt-slate); padding: .28rem .88rem;
  transition: color .18s; text-decoration: none; white-space: nowrap;
}
.fgt-nav-lk:hover, .fgt-nav-lk.fgt-on { color: var(--fgt-blue); }
.fgt-nav-right { display: flex; align-items: center; gap: .72rem; flex-shrink: 0; }
.fgt-nav-cta {
  font-family: var(--fgt-fb); font-size: .8rem; font-weight: 700;
  color: white; background: var(--fgt-terra);
  padding: .48rem 1.2rem; border-radius: var(--fgt-r);
  transition: background .18s; text-decoration: none; white-space: nowrap;
}
.fgt-nav-cta:hover { background: var(--fgt-terra2); }
.fgt-hamburger {
  display: none; width: 44px; height: 44px;
  flex-direction: column; justify-content: center; align-items: center;
  gap: 5px; cursor: pointer; background: none; border: none;
}
.fgt-hamburger span {
  width: 24px; height: 2px; background: var(--fgt-blue); border-radius: 2px;
  display: block; transition: transform .25s, opacity .2s;
}
.fgt-hamburger.fgt-hx span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.fgt-hamburger.fgt-hx span:nth-child(2) { opacity: 0; }
.fgt-hamburger.fgt-hx span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.fgt-mob-overlay {
  position: fixed; inset: 0; background: var(--fgt-blue2); z-index: 940;
  transform: translateX(100%); transition: transform .32s cubic-bezier(.4,0,.2,1);
  display: flex; flex-direction: column;
}
.fgt-mob-overlay.fgt-mob-open { transform: translateX(0); }
.fgt-mob-hd { height: 100px; display: flex; align-items: flex-end; padding: 0 2rem 1.1rem; border-bottom: 1px solid rgba(255,255,255,.1); }
.fgt-mob-brand { font-family: var(--fgt-fh); font-size: 1.1rem; font-style: italic; color: white; }
.fgt-mob-brand em { font-style: normal; color: var(--fgt-gold); }
.fgt-mob-links { flex: 1; padding: 1.5rem 2rem; display: flex; flex-direction: column; gap: 0; overflow-y: auto; }
.fgt-mob-lk { font-family: var(--fgt-fh); font-size: 2.2rem; font-style: italic; color: rgba(255,255,255,.25); border-bottom: 1px solid rgba(255,255,255,.06); padding: .5rem 0; display: block; transition: color .15s; }
.fgt-mob-lk:hover { color: var(--fgt-gold); }
.fgt-mob-ft { padding: 1.5rem 2rem; border-top: 1px solid rgba(255,255,255,.1); }
.fgt-mob-cta { display: block; text-align: center; background: var(--fgt-terra); color: white; font-family: var(--fgt-fb); font-size: .88rem; font-weight: 700; padding: .82rem; border-radius: var(--fgt-r); }

/* ======================== HERO: CENTERED DARK ======================== */
.fgt-canvas {
  min-height: calc(88vh - 100px);
  background: var(--fgt-blue2);
  display: flex; align-items: center; justify-content: center;
  text-align: center;
  position: relative; overflow: hidden;
  padding: 5rem 2.5rem;
}
/* Floating script characters in background */
.fgt-canvas-scripts {
  position: absolute; inset: 0; pointer-events: none; overflow: hidden; user-select: none;
}
.fgt-script-ch {
  position: absolute; font-family: var(--fgt-fh); font-size: clamp(4rem, 8vw, 12rem);
  color: rgba(255,255,255,.025); line-height: 1; animation: fgtDrift ease-in-out infinite;
}
.fgt-script-ch:nth-child(1)  { left: 4%;   top: 10%;  animation-duration: 14s; font-size: 9rem; }
.fgt-script-ch:nth-child(2)  { left: 65%;  top: 8%;   animation-duration: 18s; font-size: 7rem; animation-delay: -3s; }
.fgt-script-ch:nth-child(3)  { left: 80%;  top: 50%;  animation-duration: 16s; font-size: 10rem; animation-delay: -6s; }
.fgt-script-ch:nth-child(4)  { left: 2%;   top: 55%;  animation-duration: 20s; font-size: 8rem; animation-delay: -4s; }
.fgt-script-ch:nth-child(5)  { left: 40%;  top: 72%;  animation-duration: 12s; font-size: 6rem; animation-delay: -9s; }
.fgt-script-ch:nth-child(6)  { left: 55%;  top: 30%;  animation-duration: 22s; font-size: 5rem; animation-delay: -11s; }
.fgt-script-ch:nth-child(7)  { left: 25%;  top: 20%;  animation-duration: 15s; font-size: 7rem; animation-delay: -2s; }
@keyframes fgtDrift {
  0%, 100% { transform: translateY(0) rotate(-3deg); opacity: .025; }
  50% { transform: translateY(-18px) rotate(3deg); opacity: .05; }
}
.fgt-canvas-inner { position: relative; z-index: 2; max-width: 860px; }
.fgt-canvas-tag {
  display: inline-flex; align-items: center; gap: .5rem;
  font-family: var(--fgt-fb); font-size: .6rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .22em; color: var(--fgt-gold);
  margin-bottom: 1.5rem;
}
.fgt-canvas-tag::before, .fgt-canvas-tag::after { content: ''; width: 28px; height: 1px; background: var(--fgt-gold); }
.fgt-canvas h1 { color: white; }
.fgt-canvas h1 em { font-style: italic; color: var(--fgt-gold); }
.fgt-canvas-sub {
  color: rgba(255,255,255,.6); max-width: 54ch; margin: 1.2rem auto 2.5rem;
  font-size: .92rem; line-height: 1.9;
}
.fgt-canvas-acts { display: flex; gap: .72rem; justify-content: center; flex-wrap: wrap; }
/* Language pair strip below hero */
.fgt-pair-strip {
  background: var(--fgt-blue); padding: 1.1rem 0; overflow: hidden;
}
.fgt-pair-row { display: flex; width: max-content; animation: fgtPairScroll 32s linear infinite; }
.fgt-pair-item {
  padding: 0 1.5rem; font-family: var(--fgt-fb); font-size: .68rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em; color: rgba(255,255,255,.5);
  white-space: nowrap; display: flex; align-items: center; gap: .72rem;
}
.fgt-pair-item::after { content: ''; width: 1px; height: 12px; background: rgba(255,255,255,.2); }
@keyframes fgtPairScroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ======================== ABOUT / ABOUT SECTION ======================== */
.fgt-narrative-section { background: var(--fgt-sand); }
.fgt-narrative-inner {
  max-width: var(--fgt-max); margin: 0 auto; padding: 0 2.5rem;
  display: grid; grid-template-columns: 1fr 1fr; gap: 6rem; align-items: center;
}
.fgt-narr-tag { display: inline-flex; align-items: center; gap: .45rem; font-family: var(--fgt-fb); font-size: .56rem; font-weight: 700; text-transform: uppercase; letter-spacing: .22em; color: var(--fgt-terra); margin-bottom: .5rem; }
.fgt-narr-tag::before { content: ''; width: 18px; height: 1.5px; background: var(--fgt-terra); }
.fgt-narr-h { color: var(--fgt-ink); margin-bottom: 1.1rem; }
.fgt-narr-text p { margin-bottom: .9rem; }
.fgt-narr-metrics { display: grid; grid-template-columns: repeat(2,1fr); gap: 1px; background: var(--fgt-edge); border: 1px solid var(--fgt-edge); border-radius: var(--fgt-r2); overflow: hidden; margin-top: 2.2rem; }
.fgt-narr-metric { background: var(--fgt-sand); padding: 1.1rem 1.25rem; }
.fgt-narr-metric-n { font-family: var(--fgt-fh); font-size: 2.2rem; font-weight: 600; color: var(--fgt-blue); line-height: 1; letter-spacing: -.02em; }
.fgt-narr-metric-l { font-family: var(--fgt-fb); font-size: .54rem; font-weight: 700; text-transform: uppercase; letter-spacing: .14em; color: var(--fgt-dim); margin-top: .18rem; }
.fgt-narr-img-wrap { border-radius: var(--fgt-r2); overflow: hidden; }
.fgt-narr-img-wrap img { width: 100%; height: 440px; object-fit: cover; display: block; }
.fgt-narr-img-badge { position: absolute; top: 1.5rem; left: 1.5rem; background: var(--fgt-terra); color: white; font-family: var(--fgt-fh); font-size: .78rem; font-style: italic; font-weight: 600; padding: .44rem .88rem; border-radius: var(--fgt-r); }
.fgt-narr-img-stack { position: relative; }

/* ======================== SERVICES: TRANSLATION PAIR CARDS ======================== */
.fgt-tongue-section { background: var(--fgt-warm); }
.fgt-tongue-head { max-width: var(--fgt-max); margin: 0 auto; padding: 0 2.5rem; margin-bottom: 3rem; display: flex; align-items: flex-end; justify-content: space-between; }
.fgt-tongue-grid { max-width: var(--fgt-max); margin: 0 auto; padding: 0 2.5rem; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.fgt-tongue-card {
  background: var(--fgt-sand); border: 1px solid var(--fgt-edge);
  border-radius: var(--fgt-r2); overflow: hidden; transition: var(--fgt-ease);
}
.fgt-tongue-card:hover { box-shadow: var(--fgt-sh2); transform: translateY(-3px); border-color: var(--fgt-bluebd); }
.fgt-tongue-img { height: 148px; overflow: hidden; }
.fgt-tongue-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s; }
.fgt-tongue-card:hover .fgt-tongue-img img { transform: scale(1.04); }
.fgt-tongue-body { padding: 1.1rem; }
.fgt-tongue-rate-tag { display: inline-block; font-family: var(--fgt-fb); font-size: .54rem; font-weight: 700; text-transform: uppercase; letter-spacing: .12em; color: var(--fgt-blue); background: var(--fgt-bluelt); border: 1px solid var(--fgt-bluebd); padding: .18rem .58rem; border-radius: 20px; margin-bottom: .5rem; }
.fgt-tongue-nm { font-family: var(--fgt-fb); font-size: .9rem; font-weight: 700; color: var(--fgt-ink); margin-bottom: .28rem; }
.fgt-tongue-desc { font-size: .78rem; color: var(--fgt-muted); line-height: 1.72; margin-bottom: .75rem; }
.fgt-tongue-lk { font-family: var(--fgt-fb); font-size: .72rem; font-weight: 700; color: var(--fgt-terra); display: inline-flex; align-items: center; gap: .3rem; transition: gap .18s; }
.fgt-tongue-card:hover .fgt-tongue-lk { gap: .5rem; }

/* ======================== STATS BAND ======================== */
.fgt-signal-band { background: var(--fgt-blue); }
.fgt-signal-inner { max-width: var(--fgt-max); margin: 0 auto; padding: 3.5rem 2.5rem; display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-left: 1px solid rgba(255,255,255,.08); }
.fgt-signal-cell { padding: 1.5rem 2rem; border-right: 1px solid rgba(255,255,255,.08); text-align: center; }
.fgt-signal-n { font-family: var(--fgt-fh); font-size: 3rem; font-weight: 600; font-style: italic; color: var(--fgt-gold); line-height: 1; letter-spacing: -.02em; }
.fgt-signal-l { font-family: var(--fgt-fb); font-size: .54rem; font-weight: 700; text-transform: uppercase; letter-spacing: .16em; color: rgba(255,255,255,.4); margin-top: .25rem; }

/* ======================== CASE STUDIES ======================== */
.fgt-reel-section { background: var(--fgt-sand); }
.fgt-reel-head { text-align: center; margin-bottom: 4rem; }
.fgt-reel-list { display: flex; flex-direction: column; gap: 0; }
.fgt-reel-row { display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid var(--fgt-edge); overflow: hidden; }
.fgt-reel-row:last-child { border-bottom: 1px solid var(--fgt-edge); }
.fgt-reel-img { overflow: hidden; height: 340px; }
.fgt-reel-img img { width: 100%; height: 100%; object-fit: cover; filter: brightness(.65) saturate(.8); transition: filter .4s, transform .4s; }
.fgt-reel-row:hover .fgt-reel-img img { filter: brightness(.8) saturate(1); transform: scale(1.03); }
.fgt-reel-content { padding: 3.5rem; display: flex; flex-direction: column; justify-content: center; }
.fgt-reel-tags { display: flex; gap: .38rem; flex-wrap: wrap; margin-bottom: .88rem; }
.fgt-reel-tag { font-family: var(--fgt-fb); font-size: .54rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--fgt-blue); border: 1px solid var(--fgt-bluebd); padding: .16rem .56rem; border-radius: 20px; }
.fgt-reel-nm { font-family: var(--fgt-fh); font-size: clamp(1.4rem, 2.2vw, 2.2rem); font-weight: 600; color: var(--fgt-ink); margin-bottom: .2rem; line-height: 1.1; }
.fgt-reel-type { font-family: var(--fgt-fb); font-size: .7rem; color: var(--fgt-muted); margin-bottom: .88rem; }
.fgt-reel-intro { font-size: .86rem; color: var(--fgt-slate); line-height: 1.82; margin-bottom: 1.5rem; }
.fgt-reel-result { display: flex; align-items: flex-end; gap: .5rem; }
.fgt-reel-rn { font-family: var(--fgt-fh); font-size: 3rem; font-weight: 600; font-style: italic; color: var(--fgt-terra); line-height: 1; letter-spacing: -.03em; }
.fgt-reel-rs { font-family: var(--fgt-fb); font-size: .72rem; color: var(--fgt-muted); max-width: 24ch; line-height: 1.55; }

/* ======================== TESTIMONIALS ======================== */
.fgt-proof-section { background: var(--fgt-warm); }
.fgt-proof-head { text-align: center; margin-bottom: 3.5rem; }
.fgt-proof-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.1rem; }
.fgt-proof-card { background: var(--fgt-sand); border: 1px solid var(--fgt-edge); border-radius: var(--fgt-r2); padding: 2rem; transition: var(--fgt-ease); }
.fgt-proof-card:hover { border-color: var(--fgt-terrabd); box-shadow: var(--fgt-sh1); }
.fgt-proof-stars { display: flex; gap: .18rem; color: var(--fgt-gold); margin-bottom: .88rem; }
.fgt-proof-flag { font-size: 1.5rem; margin-bottom: .88rem; display: block; }
.fgt-proof-q { font-family: var(--fgt-fh); font-size: .94rem; font-style: italic; color: var(--fgt-ink); line-height: 1.55; margin-bottom: 1rem; }
.fgt-proof-who { font-family: var(--fgt-fb); font-size: .8rem; font-weight: 700; color: var(--fgt-terra); }
.fgt-proof-co  { font-family: var(--fgt-fb); font-size: .68rem; color: var(--fgt-dim); }

/* ======================== PRICING: HYBRID CARDS ======================== */
.fgt-ledger-section { background: var(--fgt-blue2); }
.fgt-ledger-head { text-align: center; margin-bottom: 4rem; }
.fgt-ledger-head h2 { color: var(--fgt-sand); }
.fgt-ledger-sub { color: rgba(250,247,242,.5); font-size: .88rem; max-width: 52ch; margin: .6rem auto 0; }
.fgt-ledger-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.1rem; }
.fgt-ledger-card { border-radius: var(--fgt-r2); overflow: hidden; border: 1px solid rgba(255,255,255,.1); background: rgba(255,255,255,.04); transition: var(--fgt-ease); }
.fgt-ledger-card:hover { transform: translateY(-4px); border-color: rgba(255,255,255,.2); }
.fgt-ledger-card.fgt-ledger-feat { border-color: var(--fgt-terra); box-shadow: 0 0 0 1px var(--fgt-terra); background: rgba(196,94,62,.08); }
.fgt-ledger-top { padding: 2rem; }
.fgt-ledger-nm { font-family: var(--fgt-fb); font-size: .52rem; font-weight: 700; text-transform: uppercase; letter-spacing: .18em; color: rgba(250,247,242,.4); margin-bottom: .3rem; }
.fgt-ledger-feat .fgt-ledger-nm { color: var(--fgt-terra); }
.fgt-ledger-pill { display: inline-block; background: var(--fgt-terra); color: white; font-family: var(--fgt-fb); font-size: .52rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; padding: .18rem .65rem; border-radius: 20px; margin-bottom: .5rem; }
.fgt-ledger-pr { font-family: var(--fgt-fh); font-size: 3.5rem; font-style: italic; font-weight: 600; color: var(--fgt-sand); line-height: 1; letter-spacing: -.02em; }
.fgt-ledger-feat .fgt-ledger-pr { color: var(--fgt-gold); }
.fgt-ledger-pr-sym { font-size: 1.4rem; font-style: normal; vertical-align: super; font-weight: 600; }
.fgt-ledger-per { font-family: var(--fgt-fb); font-size: .6rem; color: rgba(250,247,242,.35); margin-top: .2rem; }
.fgt-ledger-sub-p { font-family: var(--fgt-fb); font-size: .76rem; color: rgba(250,247,242,.55); margin-top: .5rem; line-height: 1.55; }
.fgt-ledger-body { padding: .5rem 2rem 2rem; }
.fgt-ledger-incs { display: flex; flex-direction: column; gap: .42rem; margin-bottom: 1.5rem; }
.fgt-ledger-inc { display: flex; align-items: flex-start; gap: .5rem; font-family: var(--fgt-fb); font-size: .8rem; color: rgba(250,247,242,.65); }
.fgt-ledger-inc svg { color: var(--fgt-gold); flex-shrink: 0; margin-top: .14rem; }
.fgt-ledger-feat .fgt-ledger-inc { color: rgba(250,247,242,.85); }
/* Per-word rates table */
.fgt-rates-panel { max-width: var(--fgt-max); margin: 3.5rem auto 0; padding: 0 2.5rem; }
.fgt-rates-h { font-family: var(--fgt-fb); font-size: .56rem; font-weight: 700; text-transform: uppercase; letter-spacing: .2em; color: rgba(250,247,242,.35); margin-bottom: 1rem; text-align: center; }
.fgt-rates-row { display: grid; grid-template-columns: 1fr auto auto; gap: 1.5rem; padding: .88rem 1.25rem; border-bottom: 1px solid rgba(255,255,255,.07); align-items: center; }
.fgt-rates-nm { font-family: var(--fgt-fb); font-size: .84rem; color: rgba(250,247,242,.7); }
.fgt-rates-pw { font-family: var(--fgt-fh); font-size: .96rem; font-style: italic; color: var(--fgt-gold); }
.fgt-rates-unit { font-family: var(--fgt-fb); font-size: .6rem; color: rgba(250,247,242,.3); text-transform: uppercase; letter-spacing: .08em; }

/* ======================== PROCESS ======================== */
.fgt-milestone-section { background: var(--fgt-sand); }
.fgt-milestone-head { text-align: center; margin-bottom: 4rem; }
.fgt-milestone-row { display: grid; grid-template-columns: repeat(5, 1fr); gap: 0; position: relative; }
.fgt-milestone-row::before { content: ''; position: absolute; top: 28px; left: 10%; right: 10%; height: 1px; background: linear-gradient(90deg, var(--fgt-terra), var(--fgt-blue)); pointer-events: none; }
.fgt-milestone-step { padding: 0 1.25rem 2rem; text-align: center; position: relative; }
.fgt-milestone-num { width: 56px; height: 56px; border-radius: 50%; background: var(--fgt-sand); border: 2px solid var(--fgt-edge); font-family: var(--fgt-fh); font-size: .9rem; font-style: italic; font-weight: 600; color: var(--fgt-terra); display: flex; align-items: center; justify-content: center; margin: 0 auto 1.1rem; position: relative; z-index: 1; transition: var(--fgt-ease); }
.fgt-milestone-step:hover .fgt-milestone-num { background: var(--fgt-blue); border-color: var(--fgt-blue); color: white; }
.fgt-milestone-h { font-family: var(--fgt-fb); font-size: .84rem; font-weight: 700; color: var(--fgt-ink); margin-bottom: .35rem; }
.fgt-milestone-p { font-size: .72rem; color: var(--fgt-muted); line-height: 1.7; }
.fgt-milestone-dur { font-family: var(--fgt-fb); font-size: .54rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: var(--fgt-blue); margin-top: .42rem; }

/* ======================== FAQ ======================== */
.fgt-vault-section { background: var(--fgt-warm); }
.fgt-vault-inner { max-width: var(--fgt-max); margin: 0 auto; padding: 0 2.5rem; display: grid; grid-template-columns: 1fr 1.6fr; gap: 6rem; align-items: start; }
.fgt-vault-left { position: sticky; top: 110px; }
.fgt-vault-tag { display: inline-flex; align-items: center; gap: .42rem; font-family: var(--fgt-fb); font-size: .56rem; font-weight: 700; text-transform: uppercase; letter-spacing: .22em; color: var(--fgt-terra); margin-bottom: .5rem; }
.fgt-vault-tag::before { content: ''; width: 18px; height: 1.5px; background: var(--fgt-terra); }
.fgt-vault-h { color: var(--fgt-ink); margin-bottom: .8rem; }
.fgt-vault-p { color: var(--fgt-muted); margin-bottom: 2rem; font-size: .88rem; }
.fgt-vault-list { display: flex; flex-direction: column; }
.fgt-qa { border-bottom: 1px solid var(--fgt-edge); }
.fgt-qa-btn { width: 100%; text-align: left; padding: 1.1rem 0; display: flex; align-items: center; justify-content: space-between; gap: 1rem; cursor: pointer; background: none; }
.fgt-qa-q { font-family: var(--fgt-fb); font-size: .9rem; font-weight: 600; color: var(--fgt-ink); }
.fgt-qa-ic { width: 26px; height: 26px; border-radius: 50%; border: 1.5px solid var(--fgt-edge); display: flex; align-items: center; justify-content: center; color: var(--fgt-terra); flex-shrink: 0; transition: var(--fgt-ease); }
.fgt-qa.fgt-qa-open .fgt-qa-ic { background: var(--fgt-terra); border-color: var(--fgt-terra); color: white; transform: rotate(45deg); }
.fgt-qa-body { max-height: 0; overflow: hidden; transition: max-height .3s ease; }
.fgt-qa.fgt-qa-open .fgt-qa-body { max-height: 300px; }
.fgt-qa-ans { padding: 0 0 1.1rem; font-size: .86rem; color: var(--fgt-slate); line-height: 1.82; }

/* ======================== CTA DISPATCH ======================== */
.fgt-dispatch { background: var(--fgt-blue2); padding: 8rem 0; position: relative; overflow: hidden; }
.fgt-dispatch-glow { position: absolute; inset: 0; background: radial-gradient(ellipse 60% 70% at 50% 50%, rgba(212,168,67,.08) 0%, transparent 65%); pointer-events: none; }
.fgt-dispatch-inner { max-width: var(--fgt-max); margin: 0 auto; padding: 0 2.5rem; display: grid; grid-template-columns: 1fr 380px; gap: 5rem; align-items: center; position: relative; z-index: 1; }
.fgt-dispatch-h { font-family: var(--fgt-fh); font-size: clamp(2.2rem, 4.5vw, 5rem); font-style: italic; font-weight: 600; color: var(--fgt-sand); line-height: .92; margin-bottom: .7rem; }
.fgt-dispatch-h em { font-style: normal; color: var(--fgt-gold); }
.fgt-dispatch-p { color: rgba(250,247,242,.55); max-width: 46ch; margin-bottom: 2rem; font-size: .9rem; }
.fgt-dispatch-acts { display: flex; gap: .72rem; flex-wrap: wrap; }
.fgt-quote-form { background: var(--fgt-sand); border-radius: var(--fgt-r2); padding: 2rem; }
.fgt-quote-h { font-family: var(--fgt-fh); font-size: 1.2rem; font-weight: 600; color: var(--fgt-ink); margin-bottom: .2rem; }
.fgt-quote-sub { font-family: var(--fgt-fb); font-size: .72rem; color: var(--fgt-dim); margin-bottom: 1rem; }
.fgt-qf-in { width: 100%; background: var(--fgt-warm); border: 1.5px solid var(--fgt-edge); border-radius: var(--fgt-r); padding: .6rem .88rem; color: var(--fgt-ink); font-size: .86rem; margin-bottom: .5rem; font-family: var(--fgt-fb); transition: border-color .18s; }
.fgt-qf-in:focus { outline: none; border-color: var(--fgt-bluebd); background: var(--fgt-sand); }
.fgt-qf-in::placeholder { color: var(--fgt-dim); }
.fgt-qf-btn { width: 100%; background: var(--fgt-terra); color: white; font-family: var(--fgt-fb); font-size: .8rem; font-weight: 700; padding: .68rem; border-radius: var(--fgt-r); border: none; cursor: pointer; transition: background .18s; }
.fgt-qf-btn:hover { background: var(--fgt-terra2); }
.fgt-quote-done { display: none; text-align: center; padding: 1.5rem; }

/* ======================== BUTTONS ======================== */
.fgt-btn-terra { display: inline-flex; align-items: center; gap: .42rem; font-family: var(--fgt-fb); font-size: .8rem; font-weight: 700; color: white; background: var(--fgt-terra); padding: .7rem 1.75rem; border-radius: var(--fgt-r); transition: background .18s; text-decoration: none; border: none; cursor: pointer; white-space: nowrap; }
.fgt-btn-terra:hover { background: var(--fgt-terra2); }
.fgt-btn-blue { display: inline-flex; align-items: center; gap: .42rem; font-family: var(--fgt-fb); font-size: .8rem; font-weight: 700; color: white; background: var(--fgt-blue); padding: .7rem 1.75rem; border-radius: var(--fgt-r); transition: background .18s; text-decoration: none; border: none; cursor: pointer; white-space: nowrap; }
.fgt-btn-blue:hover { background: var(--fgt-blue2); }
.fgt-btn-outline-w { display: inline-flex; align-items: center; gap: .42rem; font-family: var(--fgt-fb); font-size: .8rem; font-weight: 700; color: white; background: transparent; padding: .68rem 1.72rem; border-radius: var(--fgt-r); border: 1.5px solid rgba(255,255,255,.28); transition: var(--fgt-ease); text-decoration: none; white-space: nowrap; }
.fgt-btn-outline-w:hover { border-color: rgba(255,255,255,.6); }
.fgt-btn-outline { display: inline-flex; align-items: center; gap: .42rem; font-family: var(--fgt-fb); font-size: .8rem; font-weight: 700; color: var(--fgt-ink); background: transparent; padding: .68rem 1.72rem; border-radius: var(--fgt-r); border: 1.5px solid var(--fgt-edge); transition: var(--fgt-ease); text-decoration: none; white-space: nowrap; }
.fgt-btn-outline:hover { border-color: var(--fgt-ink); }

/* ======================== INNER PAGE CROWN ======================== */
.fgt-crown { background: var(--fgt-blue2); padding: 7rem 0 5rem; text-align: center; position: relative; overflow: hidden; }
.fgt-crown::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 50% 60% at 50% 0%, rgba(212,168,67,.1) 0%, transparent 60%); pointer-events: none; }
.fgt-crown-tag { display: inline-flex; align-items: center; gap: .5rem; font-family: var(--fgt-fb); font-size: .56rem; font-weight: 700; text-transform: uppercase; letter-spacing: .24em; color: var(--fgt-gold); margin-bottom: .6rem; position: relative; }
.fgt-crown-tag::before { content: ''; width: 20px; height: 1.5px; background: var(--fgt-gold); }
.fgt-crown h1 { color: var(--fgt-sand); max-width: 26ch; margin: 0 auto .5rem; position: relative; font-size: clamp(2.2rem, 5vw, 5.5rem); }
.fgt-crown-sub { font-family: var(--fgt-fb); font-size: .9rem; color: rgba(250,247,242,.5); max-width: 54ch; margin: 0 auto; line-height: 1.88; position: relative; }

/* ======================== SERVICE PAGE ======================== */
.fgt-svc-layout { max-width: var(--fgt-max); margin: 0 auto; padding: 5rem 2.5rem; display: grid; grid-template-columns: 1fr 272px; gap: 4.5rem; align-items: start; }
.fgt-svc-body h2 { font-family: var(--fgt-fh); font-size: 1.4rem; font-weight: 600; color: var(--fgt-blue); margin: 2.5rem 0 .6rem; }
.fgt-svc-body p { margin-bottom: .9rem; }
.fgt-svc-incs { display: flex; flex-direction: column; gap: .42rem; margin-bottom: 1.75rem; }
.fgt-svc-inc { display: flex; align-items: flex-start; gap: .5rem; font-family: var(--fgt-fb); font-size: .84rem; color: var(--fgt-slate); }
.fgt-svc-inc svg { color: var(--fgt-blue); flex-shrink: 0; margin-top: .14rem; }
.fgt-svc-del-note { background: var(--fgt-bluelt); border-left: 3px solid var(--fgt-blue); padding: .75rem 1rem; border-radius: 0 var(--fgt-r) var(--fgt-r) 0; }
.fgt-svc-del-note p { font-size: .84rem; margin: 0; color: var(--fgt-ink); }
.fgt-svc-aside { position: sticky; top: 110px; }
.fgt-svc-box { background: var(--fgt-blue2); border-radius: var(--fgt-r2); overflow: hidden; }
.fgt-svc-box-img img { width: 100%; height: 120px; object-fit: cover; display: block; filter: brightness(.4) saturate(.6); }
.fgt-svc-box-body { padding: 1.4rem; }
.fgt-svc-box-nm { font-family: var(--fgt-fb); font-size: .68rem; font-weight: 700; color: rgba(250,247,242,.45); text-transform: uppercase; letter-spacing: .1em; margin-bottom: .25rem; }
.fgt-svc-box-rate { font-family: var(--fgt-fh); font-size: .88rem; font-style: italic; color: var(--fgt-gold); margin-bottom: .22rem; }
.fgt-svc-box-min { font-family: var(--fgt-fb); font-size: .6rem; color: rgba(250,247,242,.3); text-transform: uppercase; letter-spacing: .08em; margin-bottom: .88rem; }
.fgt-svc-box-acts { display: flex; flex-direction: column; gap: .38rem; }
.fgt-svc-box-acts a { justify-content: center; font-size: .78rem; }

/* ======================== SERVICES LIST ======================== */
.fgt-svclist { border: 1px solid var(--fgt-edge); border-radius: var(--fgt-r2); overflow: hidden; }
.fgt-svclist-row { display: grid; grid-template-columns: 1fr auto auto; gap: 2rem; padding: 1.4rem 1.75rem; border-bottom: 1px solid var(--fgt-edge); align-items: center; background: var(--fgt-sand); transition: background .15s; }
.fgt-svclist-row:last-child { border-bottom: none; }
.fgt-svclist-row:hover { background: var(--fgt-warm); }
.fgt-svclist-nm { font-family: var(--fgt-fb); font-size: .92rem; font-weight: 700; color: var(--fgt-ink); margin-bottom: .18rem; }
.fgt-svclist-desc { font-size: .78rem; color: var(--fgt-muted); }
.fgt-svclist-rate { font-family: var(--fgt-fh); font-size: 1.2rem; font-style: italic; font-weight: 600; color: var(--fgt-terra); white-space: nowrap; }
.fgt-svclist-per { font-family: var(--fgt-fb); font-size: .52rem; color: var(--fgt-dim); text-align: right; text-transform: uppercase; letter-spacing: .08em; }

/* ======================== BUILDER (SCROLL) ======================== */
.fgt-scroll-layout { max-width: var(--fgt-max); margin: 0 auto; padding: 5rem 2.5rem; display: grid; grid-template-columns: 1fr 280px; gap: 4rem; align-items: start; }
.fgt-scroll-lbl { display: block; font-family: var(--fgt-fb); font-size: .54rem; font-weight: 700; text-transform: uppercase; letter-spacing: .22em; color: var(--fgt-terra); margin-bottom: .82rem; }
.fgt-scroll-step { margin-bottom: 2.5rem; }
.fgt-scroll-items { display: flex; flex-direction: column; gap: .42rem; }
.fgt-scroll-item { background: var(--fgt-sand); border: 1.5px solid var(--fgt-edge); border-radius: var(--fgt-r); padding: .84rem 1rem; display: flex; align-items: center; gap: .72rem; cursor: pointer; transition: var(--fgt-ease); user-select: none; }
.fgt-scroll-item:hover { border-color: var(--fgt-bluebd); }
.fgt-scroll-item.fgt-item-sel { border-color: var(--fgt-blue); background: var(--fgt-bluelt); }
.fgt-scroll-item-pr { font-family: var(--fgt-fb); font-size: .66rem; font-weight: 700; color: var(--fgt-blue); flex-shrink: 0; min-width: 5rem; }
.fgt-scroll-item-nm { font-family: var(--fgt-fb); font-size: .84rem; color: var(--fgt-slate); flex: 1; }
.fgt-scroll-item.fgt-item-sel .fgt-scroll-item-nm { color: var(--fgt-ink); font-weight: 700; }
.fgt-scroll-chk { width: 18px; height: 18px; border: 1.5px solid var(--fgt-dim); border-radius: 3px; flex-shrink: 0; transition: var(--fgt-ease); }
.fgt-scroll-item.fgt-item-sel .fgt-scroll-chk { background: var(--fgt-blue); border-color: var(--fgt-blue); }
.fgt-scroll-addons { display: grid; grid-template-columns: 1fr 1fr; gap: .42rem; }
.fgt-adn-tile { background: var(--fgt-sand); border: 1.5px solid var(--fgt-edge); border-radius: var(--fgt-r); padding: .72rem .88rem; cursor: pointer; transition: var(--fgt-ease); user-select: none; }
.fgt-adn-tile:hover { border-color: var(--fgt-terrabd); }
.fgt-adn-tile.fgt-adn-sel { border-color: var(--fgt-terra); background: var(--fgt-terralt); }
.fgt-adn-tile-nm { font-family: var(--fgt-fb); font-size: .8rem; font-weight: 600; color: var(--fgt-slate); margin-bottom: .14rem; }
.fgt-adn-tile.fgt-adn-sel .fgt-adn-tile-nm { color: var(--fgt-ink); }
.fgt-adn-tile-pr { font-size: .64rem; color: var(--fgt-dim); }
.fgt-adn-tile.fgt-adn-sel .fgt-adn-tile-pr { color: var(--fgt-terra); }
.fgt-hrs-box { background: var(--fgt-sand); border: 1.5px solid var(--fgt-edge); border-radius: var(--fgt-r); padding: 1.1rem; }
.fgt-hrs-top { display: flex; justify-content: space-between; align-items: center; margin-bottom: .5rem; }
.fgt-hrs-lbl { font-family: var(--fgt-fb); font-size: .84rem; color: var(--fgt-slate); }
.fgt-hrs-val { font-family: var(--fgt-fh); font-size: 2rem; font-style: italic; font-weight: 600; color: var(--fgt-terra); line-height: 1; }
.fgt-hrs-slide { -webkit-appearance: none; width: 100%; height: 3px; background: var(--fgt-edge); border-radius: 2px; cursor: pointer; }
.fgt-hrs-slide::-webkit-slider-thumb { -webkit-appearance: none; width: 20px; height: 20px; border-radius: 50%; background: var(--fgt-terra); cursor: pointer; box-shadow: var(--fgt-sh1); }
.fgt-hrs-labels { display: flex; justify-content: space-between; font-size: .58rem; color: var(--fgt-dim); margin-top: .35rem; font-family: var(--fgt-fb); }

/* LEDGER (receipt) sidebar */
.fgt-cart { background: var(--fgt-blue2); border-radius: var(--fgt-r2); overflow: hidden; position: sticky; top: 110px; }
.fgt-cart-hd { background: var(--fgt-terra); padding: .88rem 1.25rem; }
.fgt-cart-hl { font-family: var(--fgt-fb); font-size: .52rem; font-weight: 700; text-transform: uppercase; letter-spacing: .16em; color: rgba(255,255,255,.8); }
.fgt-cart-body { padding: .88rem 1.25rem; min-height: 60px; }
.fgt-cart-empty { font-family: var(--fgt-fb); font-size: .74rem; color: rgba(250,247,242,.35); font-style: italic; }
.fgt-cart-line { display: flex; justify-content: space-between; gap: .5rem; font-family: var(--fgt-fb); font-size: .76rem; margin-bottom: .42rem; }
.fgt-cart-lnm { color: rgba(250,247,242,.55); }
.fgt-cart-lpr { font-weight: 700; color: var(--fgt-sand); }
.fgt-cart-foot { border-top: 1px solid rgba(255,255,255,.08); padding: .88rem 1.25rem; }
.fgt-cart-tot { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: .88rem; }
.fgt-cart-tot-l { font-family: var(--fgt-fb); font-size: .52rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: rgba(250,247,242,.4); }
.fgt-cart-tot-v { font-family: var(--fgt-fh); font-size: 2.8rem; font-style: italic; font-weight: 600; color: var(--fgt-gold); line-height: 1; letter-spacing: -.02em; }
.fgt-cart-go { display: block; width: 100%; text-align: center; background: var(--fgt-terra); color: white; font-family: var(--fgt-fb); font-size: .78rem; font-weight: 700; padding: .72rem; border-radius: var(--fgt-r); border: none; cursor: pointer; transition: background .18s; }
.fgt-cart-go:hover:not(:disabled) { background: var(--fgt-terra2); }
.fgt-cart-go:disabled { opacity: .25; cursor: not-allowed; }

/* ======================== CHECKOUT ======================== */
.fgt-bill-wrap { max-width: 900px; margin: 0 auto; padding: 5rem 2.5rem; display: grid; grid-template-columns: 1fr 272px; gap: 4rem; align-items: start; }
.fgt-fg { margin-bottom: .72rem; }
.fgt-fg2 { display: grid; grid-template-columns: 1fr 1fr; gap: .72rem; }
.fgt-fl { display: block; font-family: var(--fgt-fb); font-size: .54rem; font-weight: 700; text-transform: uppercase; letter-spacing: .12em; color: var(--fgt-dim); margin-bottom: .3rem; }
.fgt-fi { width: 100%; background: var(--fgt-warm); border: 1.5px solid var(--fgt-edge); border-radius: var(--fgt-r); padding: .62rem .88rem; color: var(--fgt-ink); font-size: .88rem; transition: border-color .18s; }
.fgt-fi:focus { outline: none; border-color: var(--fgt-bluebd); background: var(--fgt-sand); }
.fgt-fi::placeholder { color: var(--fgt-dim); }
.fgt-agree { display: flex; align-items: flex-start; gap: .5rem; font-family: var(--fgt-fb); font-size: .8rem; color: var(--fgt-slate); line-height: 1.6; margin: 1rem 0; }
.fgt-agree input { margin-top: .12rem; accent-color: var(--fgt-terra); }
.fgt-agree a { color: var(--fgt-terra); }
.fgt-bill-side { background: var(--fgt-blue2); border-radius: var(--fgt-r2); overflow: hidden; position: sticky; top: 110px; }
.fgt-bill-side-hd { background: var(--fgt-terra); padding: .78rem 1.1rem; }
.fgt-bill-side-hl { font-family: var(--fgt-fb); font-size: .52rem; font-weight: 700; text-transform: uppercase; letter-spacing: .14em; color: rgba(255,255,255,.8); }
.fgt-bill-body { padding: .88rem 1.1rem; }
.fgt-bill-line { display: flex; justify-content: space-between; gap: 1rem; font-family: var(--fgt-fb); font-size: .76rem; margin-bottom: .4rem; }
.fgt-bill-lnm { color: rgba(250,247,242,.5); }
.fgt-bill-lpr { font-weight: 700; color: var(--fgt-sand); }
.fgt-bill-div { border: none; border-top: 1px solid rgba(255,255,255,.08); margin: .6rem 0; }
.fgt-bill-tot { display: flex; justify-content: space-between; align-items: flex-end; }
.fgt-bill-tot-l { font-family: var(--fgt-fb); font-size: .52rem; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; color: rgba(250,247,242,.35); }
.fgt-bill-tot-v { font-family: var(--fgt-fh); font-size: 2.4rem; font-style: italic; font-weight: 600; color: var(--fgt-gold); line-height: 1; }

/* ======================== LEGAL ======================== */
.fgt-statute { max-width: 820px; margin: 0 auto; padding: 5rem 2.5rem; }
.fgt-statute h2 { font-family: var(--fgt-fh); font-size: 1.4rem; font-weight: 600; color: var(--fgt-blue); margin: 2.8rem 0 .6rem; }
.fgt-statute h3 { font-family: var(--fgt-fb); font-size: .96rem; font-weight: 700; color: var(--fgt-ink); margin: 1.4rem 0 .3rem; }
.fgt-statute p { margin-bottom: .9rem; font-size: .88rem; }
.fgt-statute ul { padding-left: 1.2rem; margin: .4rem 0 .9rem; display: flex; flex-direction: column; gap: .32rem; }
.fgt-statute li { font-size: .88rem; list-style: disc; color: var(--fgt-slate); line-height: 1.72; }
.fgt-statute a { color: var(--fgt-terra); }
.fgt-statute table { width: 100%; border-collapse: collapse; font-size: .82rem; margin: .88rem 0 1.1rem; }
.fgt-statute th { background: var(--fgt-blue2); color: white; padding: .5rem .9rem; text-align: left; font-size: .6rem; text-transform: uppercase; letter-spacing: .06em; font-weight: 700; font-family: var(--fgt-fb); }
.fgt-statute td { padding: .5rem .9rem; border: 1px solid var(--fgt-edge); color: var(--fgt-slate); }
.fgt-statute address { font-style: normal; background: var(--fgt-bluelt); border-left: 3px solid var(--fgt-blue); padding: .88rem 1.2rem; font-size: .86rem; line-height: 1.9; color: var(--fgt-slate); margin: .9rem 0; border-radius: 0 var(--fgt-r) var(--fgt-r) 0; }
.fgt-statute-eff { display: inline-block; font-family: var(--fgt-fb); font-size: .72rem; color: var(--fgt-dim); background: var(--fgt-warm); border: 1px solid var(--fgt-edge); padding: .3rem .78rem; border-radius: 20px; margin-bottom: 1.5rem; }

/* ======================== RESULT PAGES ======================== */
.fgt-result-pg { min-height: 75vh; display: flex; align-items: center; justify-content: center; text-align: center; padding: 5rem 2.5rem; background: var(--fgt-blue2); }
.fgt-result-box { max-width: 500px; }

/* ======================== COOKIE + CHAT ======================== */
.fgt-cookie-tray { position: fixed; bottom: 0; left: 0; right: 0; background: var(--fgt-blue2); border-top: 3px solid var(--fgt-terra); z-index: 9999; padding: .9rem 2rem; display: none; gap: 1rem; align-items: center; justify-content: space-between; flex-wrap: wrap; }
.fgt-cookie-tray p { font-family: var(--fgt-fb); font-size: .76rem; color: rgba(255,255,255,.6); margin: 0; }
.fgt-cookie-tray a { color: var(--fgt-gold); }
.fgt-ck-acts { display: flex; gap: .42rem; flex-shrink: 0; }
.fgt-ck-ok  { background: var(--fgt-terra); color: white; font-family: var(--fgt-fb); font-size: .74rem; font-weight: 700; padding: .38rem 1rem; border: none; border-radius: var(--fgt-r); cursor: pointer; }
.fgt-ck-no  { background: transparent; color: rgba(255,255,255,.45); font-family: var(--fgt-fb); font-size: .74rem; padding: .38rem 1rem; border: 1px solid rgba(255,255,255,.15); border-radius: var(--fgt-r); cursor: pointer; }
.fgt-chat-btn { position: fixed; bottom: 4.5rem; right: 1.5rem; z-index: 9990; width: 50px; height: 50px; background: var(--fgt-blue); color: white; border-radius: 50%; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 20px rgba(43,76,126,.4); cursor: pointer; border: none; transition: var(--fgt-ease); }
.fgt-chat-btn:hover { background: var(--fgt-terra); transform: scale(1.06); }
.fgt-chatpop { position: fixed; bottom: 7.5rem; right: 1.5rem; z-index: 9989; width: 280px; background: var(--fgt-sand); border: 1px solid var(--fgt-edge); border-radius: var(--fgt-r2); box-shadow: var(--fgt-sh3); opacity: 0; pointer-events: none; transform: translateY(10px) scale(.97); transition: opacity .2s, transform .22s; overflow: hidden; }
.fgt-chatpop.fgt-chat-open { opacity: 1; pointer-events: auto; transform: translateY(0) scale(1); }
.fgt-chatpop-hd { background: var(--fgt-blue2); padding: .9rem 1.1rem; display: flex; align-items: center; justify-content: space-between; }
.fgt-chatpop-title { font-family: var(--fgt-fh); font-size: 1rem; font-style: italic; font-weight: 600; color: white; }
.fgt-chatpop-sub { font-family: var(--fgt-fb); font-size: .58rem; color: rgba(255,255,255,.5); }
.fgt-chatpop-x { color: rgba(255,255,255,.4); background: none; border: none; cursor: pointer; }
.fgt-chatpop-bd { padding: .88rem; }
.fgt-chat-done { display: none; text-align: center; padding: 1rem; font-family: var(--fgt-fb); font-size: .78rem; color: var(--fgt-blue); font-weight: 700; }
.fgt-chat-in { width: 100%; background: var(--fgt-warm); border: 1px solid var(--fgt-edge); border-radius: var(--fgt-r); padding: .44rem .72rem; font-size: .78rem; color: var(--fgt-ink); margin-bottom: .42rem; font-family: var(--fgt-fb); resize: none; }
.fgt-chat-in:focus { outline: none; border-color: var(--fgt-bluebd); }
.fgt-chat-in::placeholder { color: var(--fgt-dim); }
.fgt-chat-send { width: 100%; background: var(--fgt-terra); color: white; font-family: var(--fgt-fb); font-size: .76rem; font-weight: 700; padding: .46rem; border-radius: var(--fgt-r); border: none; cursor: pointer; }

/* ======================== ANIMATIONS ======================== */
.fgt-rise { opacity: 0; transform: translateY(16px); transition: opacity .5s ease, transform .5s ease; }
.fgt-rise.fgt-vis { opacity: 1; transform: translateY(0); }
.fgt-rise-l { opacity: 0; transform: translateX(-18px); transition: opacity .52s ease, transform .52s ease; }
.fgt-rise-l.fgt-vis { opacity: 1; transform: translateX(0); }
.fgt-rise-r { opacity: 0; transform: translateX(18px); transition: opacity .52s ease, transform .52s ease; }
.fgt-rise-r.fgt-vis { opacity: 1; transform: translateX(0); }

/* ======================== FOOTER ======================== */
.fgt-foundation { background: var(--fgt-ink); }
.fgt-foundation-top { max-width: var(--fgt-max); margin: 0 auto; padding: 5.5rem 2.5rem 2.5rem; display: grid; grid-template-columns: 1.8fr 1fr 1fr 1.2fr; gap: 3rem; }
.fgt-foundation-brand { font-family: var(--fgt-fh); font-size: 1.2rem; font-style: italic; font-weight: 600; color: white; letter-spacing: -.01em; margin-bottom: .3rem; }
.fgt-foundation-brand em { font-style: normal; color: var(--fgt-terra); }
.fgt-foundation-tag { font-family: var(--fgt-fb); font-size: .72rem; color: rgba(255,255,255,.38); max-width: 26ch; line-height: 1.72; margin-bottom: 1.35rem; }
.fgt-foundation-soc { display: flex; gap: .42rem; }
.fgt-foundation-soc a { width: 34px; height: 34px; border: 1px solid rgba(255,255,255,.1); border-radius: var(--fgt-r); display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,.38); transition: var(--fgt-ease); }
.fgt-foundation-soc a:hover { border-color: var(--fgt-terra); color: var(--fgt-terra); }
.fgt-foundation-col-h { font-family: var(--fgt-fb); font-size: .5rem; font-weight: 700; letter-spacing: .22em; text-transform: uppercase; color: rgba(255,255,255,.28); margin-bottom: .88rem; }
.fgt-foundation-lks { display: flex; flex-direction: column; gap: .44rem; }
.fgt-foundation-lks a { font-family: var(--fgt-fb); font-size: .76rem; color: rgba(255,255,255,.42); transition: color .16s; }
.fgt-foundation-lks a:hover { color: var(--fgt-gold); }
.fgt-foundation-ct { display: flex; flex-direction: column; gap: .55rem; }
.fgt-foundation-ct a { font-family: var(--fgt-fb); font-size: .74rem; color: rgba(255,255,255,.42); display: flex; align-items: flex-start; gap: .42rem; transition: color .16s; line-height: 1.55; }
.fgt-foundation-ct a:hover { color: var(--fgt-gold); }
.fgt-foundation-ct svg { flex-shrink: 0; color: var(--fgt-terra); opacity: .7; margin-top: .04rem; }
.fgt-foundation-btm { border-top: 1px solid rgba(255,255,255,.06); max-width: var(--fgt-max); margin: 0 auto; padding: 1.5rem 2.5rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.fgt-foundation-copy { font-family: var(--fgt-fb); font-size: .6rem; color: rgba(255,255,255,.25); }
.fgt-foundation-legal { display: flex; gap: 1.35rem; }
.fgt-foundation-legal a { font-family: var(--fgt-fb); font-size: .6rem; color: rgba(255,255,255,.32); transition: color .16s; }
.fgt-foundation-legal a:hover { color: var(--fgt-gold); }

/* ======================== RESPONSIVE ======================== */
@media (max-width: 1024px) {
  .fgt-nav-links { display: none; }
  .fgt-hamburger { display: flex; }
  .fgt-tongue-grid { grid-template-columns: 1fr 1fr; }
  .fgt-signal-inner { grid-template-columns: 1fr 1fr; }
  .fgt-reel-row { grid-template-columns: 1fr; }
  .fgt-reel-img { height: 260px; }
  .fgt-proof-grid { grid-template-columns: 1fr; }
  .fgt-ledger-grid { grid-template-columns: 1fr; max-width: 420px; margin: 0 auto; }
  .fgt-milestone-row { grid-template-columns: 1fr 1fr 1fr; }
  .fgt-milestone-row::before { display: none; }
  .fgt-vault-inner { grid-template-columns: 1fr; gap: 2.5rem; }
  .fgt-vault-left { position: static; }
  .fgt-dispatch-inner { grid-template-columns: 1fr; gap: 3rem; }
  .fgt-narrative-inner { grid-template-columns: 1fr; gap: 3rem; }
  .fgt-svc-layout, .fgt-scroll-layout, .fgt-bill-wrap { grid-template-columns: 1fr; }
  .fgt-foundation-top { grid-template-columns: 1fr 1fr; gap: 2rem; }
}
@media (max-width: 640px) {
  body { padding-top: 100px; }
  .fgt-wrap { padding: 0 1.25rem; }
  .fgt-slab { padding: 4.5rem 0; }
  .fgt-topbar-left > span:last-child { display: none; }
  .fgt-tongue-grid { grid-template-columns: 1fr; }
  .fgt-signal-inner { grid-template-columns: 1fr 1fr; }
  .fgt-milestone-row { grid-template-columns: 1fr 1fr; }
  .fgt-fg2 { grid-template-columns: 1fr; }
  .fgt-scroll-addons { grid-template-columns: 1fr; }
  .fgt-foundation-top { grid-template-columns: 1fr; }
  .fgt-foundation-legal { flex-wrap: wrap; gap: .75rem; }
  .fgt-cookie-tray { flex-direction: column; align-items: flex-start; }
}
