/* ==========================================================================
   Forgutti — AI Agency Site
   Ported from the Claude Design prototype (Forgutti.dc.html) to a
   framework-free static site. Values transcribed 1:1 from the source.
   ========================================================================== */

:root {
  --accent: #4F8EF7;            /* Theme accent — options: #4F8EF7 / #3DFFD0 / #8B7CF7 */
  --bg: #0A0C12;

  /* Text ramp */
  --t-hi: #F3F5F9;             /* headings */
  --t-base: #EDEFF4;          /* base copy / strong */
  --t-muted: #9AA3B4;         /* section leads */
  --t-body: #8E97A8;          /* card body */
  --t-soft: #828B9C;          /* softer body */
  --t-pill: #C7CDD9;          /* pill text */
  --t-faint: #5C6576;         /* mono captions */

  --font-sans: 'Space Grotesk', system-ui, -apple-system, sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--t-base);
  font-family: var(--font-sans);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

::selection { background: rgba(79, 142, 247, 0.30); color: #fff; }

img, svg, canvas { display: block; }

/* Keyframes ---------------------------------------------------------------- */
@keyframes fgPulse {
  0%, 100% { opacity: .5; transform: scale(1); }
  50%      { opacity: 1;  transform: scale(1.35); }
}
@keyframes fgDrop {
  0%   { transform: translateY(-2px); opacity: 0; }
  25%  { opacity: 1; }
  100% { transform: translateY(24px); opacity: 0; }
}

/* Root wrapper ------------------------------------------------------------- */
.page {
  position: relative;
  min-height: 100vh;
  background: var(--bg);
  color: var(--t-base);
}

/* Helpers ------------------------------------------------------------------ */
.accent { color: var(--accent); }
.accent-soft { color: color-mix(in srgb, var(--accent) 90%, #ffffff); }

.dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent);
}
.dot--pulse {
  box-shadow: 0 0 10px var(--accent);
  animation: fgPulse 2.4s ease-in-out infinite;
}
.dot--dark { background: #0A0C12; box-shadow: none; }

.wrap { max-width: 1100px; margin: 0 auto; width: 100%; }
.wrap--wide { max-width: 1180px; }

/* Scroll progress ---------------------------------------------------------- */
.progress {
  position: fixed; top: 0; left: 0; right: 0;
  height: 2px; z-index: 120; pointer-events: none;
}
.progress__bar {
  display: block; height: 100%; width: 0%;
  background: linear-gradient(90deg, color-mix(in srgb, var(--accent) 45%, transparent), var(--accent));
  box-shadow: 0 0 12px color-mix(in srgb, var(--accent) 70%, transparent);
}

/* Nav ---------------------------------------------------------------------- */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 110;
  display: flex; align-items: center; justify-content: center;
  gap: 16px;
  padding: 15px clamp(18px, 5vw, 40px);
  border-bottom: 1px solid transparent;
  transition: background .3s, border-color .3s, backdrop-filter .3s;
}
.nav.is-scrolled {
  background: rgba(9, 11, 17, 0.72);
  border-bottom-color: rgba(255, 255, 255, 0.07);
  backdrop-filter: saturate(150%) blur(14px);
  -webkit-backdrop-filter: saturate(150%) blur(14px);
}

/* Brand -------------------------------------------------------------------- */
.brand { display: flex; align-items: center; gap: 11px; text-decoration: none; }
.brand__mark {
  display: grid;
  grid-template-columns: repeat(2, 4px);
  grid-template-rows: repeat(2, 4px);
  gap: 3px;
}
.brand__mark span { width: 4px; height: 4px; border-radius: 50%; background: color-mix(in srgb, var(--accent) 50%, transparent); }
.brand__mark span:nth-child(1),
.brand__mark span:nth-child(4) { background: var(--accent); }
.brand__name {
  font-family: var(--font-sans); font-weight: 600;
  font-size: 1.06rem; letter-spacing: -0.01em; color: var(--t-base);
}

/* Buttons ------------------------------------------------------------------ */
.btn {
  display: inline-flex; align-items: center;
  font-family: var(--font-sans); text-decoration: none;
  border: 1px solid transparent; cursor: pointer;
}
.btn--primary { color: #0A0C12; background: var(--accent); transition: transform .25s, box-shadow .25s, filter .25s; }
.btn--primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 34px -10px color-mix(in srgb, var(--accent) 65%, transparent),
              0 0 30px -6px color-mix(in srgb, var(--accent) 60%, transparent);
  filter: brightness(1.06);
}
.btn--primary:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; }

.btn--ghost {
  color: var(--t-base); background: rgba(255, 255, 255, 0.02);
  border-color: rgba(255, 255, 255, 0.16);
  transition: transform .25s, box-shadow .25s, border-color .25s, color .25s;
}
.btn--ghost:hover {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--accent) 55%, transparent);
  color: #ffffff;
  box-shadow: 0 0 26px -10px color-mix(in srgb, var(--accent) 50%, transparent);
}
.btn--ghost:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; }

.btn--accent-outline {
  gap: 8px; font-family: var(--font-mono); font-size: 0.82rem;
  color: var(--accent); padding: 10px 16px;
  border: 1px solid color-mix(in srgb, var(--accent) 30%, transparent);
  border-radius: 8px; transition: background .25s, transform .25s;
}
.btn--accent-outline:hover { background: color-mix(in srgb, var(--accent) 10%, transparent); transform: translateY(-2px); }
.btn--accent-outline:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; }

/* Button sizes */
.btn--sm { gap: 8px; font-weight: 600; font-size: 0.9rem; padding: 10px 18px; border-radius: 8px; }
.btn--md { gap: 9px; font-weight: 600; font-size: 1rem; padding: 15px 26px; border-radius: 9px; }
.btn--ghost.btn--md { font-weight: 500; }
.btn--lg { gap: 10px; font-weight: 600; font-size: 1.05rem; padding: 16px 30px; border-radius: 10px; }
.btn--wide { gap: 9px; font-weight: 500; font-size: 0.97rem; padding: 13px 22px; border-radius: 9px; }
.btn__arrow { font-size: 0.9em; }

/* Eyebrow ------------------------------------------------------------------ */
.eyebrow {
  display: flex; align-items: center; gap: 11px;
  font-family: var(--font-mono); font-size: 0.76rem;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--accent); margin-bottom: 22px;
}
.eyebrow--center { justify-content: center; margin-bottom: 24px; }
.eyebrow__line { width: 22px; height: 1px; background: color-mix(in srgb, var(--accent) 55%, transparent); }

/* Section scaffolding ------------------------------------------------------ */
.section {
  position: relative; scroll-margin-top: 90px;
  padding-block: clamp(90px, 12vw, 150px);
  padding-inline: clamp(18px, 5vw, 40px);
}
.section--bordered { border-top: 1px solid rgba(255, 255, 255, 0.05); }
.section__head { max-width: 680px; margin-bottom: clamp(40px, 6vw, 68px); }

.h2 {
  font-family: var(--font-sans); font-weight: 600;
  font-size: clamp(2rem, 5vw, 3.4rem); line-height: 1.02;
  letter-spacing: -0.025em; margin: 0 0 16px; color: var(--t-hi);
}
.h2--about {
  font-weight: 600; font-size: clamp(1.9rem, 4.5vw, 3rem);
  line-height: 1.04; margin: 0 0 20px;
}
.h2--contact {
  font-weight: 700; font-size: clamp(2.2rem, 5.5vw, 3.8rem);
  line-height: 1.0; letter-spacing: -0.03em; margin: 0 0 18px;
}
.lead {
  font-size: clamp(1rem, 1.3vw, 1.12rem); line-height: 1.6;
  color: var(--t-muted); margin: 0;
}
.lead--tight { margin: 0 0 18px; }
.lead--about { font-size: clamp(1rem, 1.3vw, 1.14rem); line-height: 1.65; margin: 0 0 18px; }
.lead--about + .lead--about { margin: 0 0 26px; }

.mono-note { font-family: var(--font-mono); font-size: 0.78rem; letter-spacing: 0.04em; color: var(--t-faint); }

/* Grids -------------------------------------------------------------------- */
.grid { display: grid; gap: clamp(16px, 2vw, 24px); }
.grid--cards { grid-template-columns: repeat(auto-fit, minmax(min(280px, 100%), 1fr)); }
.grid--products { grid-template-columns: repeat(auto-fit, minmax(min(320px, 100%), 1fr)); }

/* Hero --------------------------------------------------------------------- */
.hero {
  position: relative; min-height: 100svh;
  display: flex; align-items: center; overflow: hidden;
  padding: 120px clamp(18px, 5vw, 40px) 96px;
}
.hero__canvas { position: absolute; inset: 0; width: 100%; height: 100%; display: block; z-index: 0; }
.hero__glow {
  position: absolute; inset: 0; z-index: 1;
  background: radial-gradient(120% 80% at 50% 0%, color-mix(in srgb, var(--accent) 10%, transparent) 0%, transparent 42%);
}
.hero__vignette {
  position: absolute; inset: 0; z-index: 1;
  background: radial-gradient(100% 72% at 50% 44%, transparent 0%, rgba(10, 12, 18, 0.35) 55%, #0A0C12 100%);
}
.hero__inner { position: relative; z-index: 2; max-width: 1000px; margin: 0 auto; width: 100%; text-align: center; }

.hero__badge {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--font-mono); font-size: 0.74rem;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: color-mix(in srgb, var(--accent) 90%, #ffffff);
  padding: 7px 15px;
  border: 1px solid color-mix(in srgb, var(--accent) 28%, transparent);
  border-radius: 100px;
  background: color-mix(in srgb, var(--accent) 7%, transparent);
  margin-bottom: 30px;
}

.hero__title {
  font-family: var(--font-sans); font-weight: 700;
  font-size: clamp(2.9rem, 8.5vw, 6.6rem); line-height: 0.96;
  letter-spacing: -0.035em; margin: 0 0 26px; color: var(--t-hi);
}
.hero__lead {
  max-width: 630px; margin: 0 auto 38px;
  font-size: clamp(1.02rem, 1.4vw, 1.2rem); line-height: 1.6; color: var(--t-muted);
}
.hero__actions { display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; }
.hero__now { margin-top: 34px; }
.now-link {
  text-decoration: none; font-family: var(--font-mono);
  font-size: 0.8rem; letter-spacing: 0.04em; color: var(--t-faint);
  display: inline-flex; align-items: center; gap: 9px;
  transition: color .2s;
}
.now-link:hover { color: var(--t-muted); }
.now-link .dot { width: 7px; height: 7px; }

.scroll-cue {
  position: absolute; bottom: 26px; left: 50%; transform: translateX(-50%); z-index: 2;
  display: flex; flex-direction: column; align-items: center; gap: 11px; text-decoration: none;
}
.scroll-cue__label {
  font-family: var(--font-mono); font-size: 0.6rem;
  letter-spacing: 0.32em; text-transform: uppercase; color: var(--t-faint);
}
.scroll-cue__rail { position: relative; width: 1px; height: 40px; background: rgba(255, 255, 255, 0.12); overflow: hidden; }
.scroll-cue__drop { position: absolute; top: 0; left: 0; width: 1px; height: 12px; background: var(--accent); animation: fgDrop 2.2s ease-in-out infinite; }

/* Services ----------------------------------------------------------------- */
.svc-card {
  position: relative; padding: 30px;
  border: 1px solid rgba(255, 255, 255, 0.08); border-radius: 14px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.025), rgba(255, 255, 255, 0.008));
  transition: transform .3s, border-color .3s, box-shadow .3s;
}
.svc-card:hover {
  transform: translateY(-6px);
  border-color: color-mix(in srgb, var(--accent) 38%, transparent);
  box-shadow: 0 24px 50px -24px rgba(0, 0, 0, 0.6),
              0 0 36px -18px color-mix(in srgb, var(--accent) 55%, transparent);
}
.svc-card__icon {
  display: flex; align-items: center; justify-content: center;
  width: 52px; height: 52px; border-radius: 12px;
  border: 1px solid color-mix(in srgb, var(--accent) 22%, transparent);
  background: color-mix(in srgb, var(--accent) 8%, transparent);
  margin-bottom: 22px;
}
.svc-card__title {
  font-family: var(--font-sans); font-weight: 600; font-size: 1.28rem;
  letter-spacing: -0.01em; margin: 0 0 12px; color: var(--t-base);
}
.svc-card__body { font-size: 0.98rem; line-height: 1.62; color: var(--t-body); margin: 0; }

/* Stack -------------------------------------------------------------------- */
.stack {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(300px, 100%), 1fr));
  gap: clamp(36px, 5vw, 64px); align-items: start;
}
.stack__groups { display: flex; flex-direction: column; }
.stack-group { padding: 18px 0; border-top: 1px solid rgba(255, 255, 255, 0.07); }
.stack-group--first { padding: 0 0 18px; border-top: none; }
.stack-group__head { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.stack-group__label { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--accent); }
.stack-group__rule { flex: 1; height: 1px; background: rgba(255, 255, 255, 0.06); }

.pills { display: flex; flex-wrap: wrap; gap: 9px; }
.pill {
  display: inline-flex; align-items: center;
  font-family: var(--font-mono); font-size: 0.8rem; color: var(--t-pill);
  padding: 8px 13px; border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 100px; background: rgba(255, 255, 255, 0.02);
  transition: transform .2s, border-color .2s, box-shadow .2s, color .2s;
}
.pill:hover {
  transform: translateY(-2px); color: #ffffff;
  border-color: color-mix(in srgb, var(--accent) 45%, transparent);
  box-shadow: 0 0 20px -8px color-mix(in srgb, var(--accent) 55%, transparent);
}

/* Products ----------------------------------------------------------------- */
.product-card {
  position: relative; overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.1); border-radius: 16px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.03), rgba(255, 255, 255, 0.012));
  transition: transform .3s, border-color .3s, box-shadow .3s;
}
.product-card:hover {
  transform: translateY(-6px);
  border-color: color-mix(in srgb, var(--accent) 40%, transparent);
  box-shadow: 0 30px 60px -28px rgba(0, 0, 0, 0.7),
              0 0 50px -22px color-mix(in srgb, var(--accent) 50%, transparent);
}
.product-card__banner { position: relative; height: 172px; overflow: hidden; border-bottom: 1px solid rgba(255, 255, 255, 0.07); }
.product-card__hatch {
  position: absolute; inset: -20px;
  background: repeating-linear-gradient(135deg, color-mix(in srgb, var(--accent) 18%, transparent) 0 2px, transparent 2px 12px);
  filter: blur(7px); opacity: 0.7;
}
.product-card__radial { position: absolute; inset: 0; background: radial-gradient(120% 100% at 30% 20%, color-mix(in srgb, var(--accent) 20%, transparent), transparent 60%); }
.product-card__blur { position: absolute; inset: 0; backdrop-filter: blur(2px); -webkit-backdrop-filter: blur(2px); }
.product-card__body { padding: 28px; }
.product-card__title { font-family: var(--font-sans); font-weight: 600; font-size: 1.5rem; letter-spacing: -0.015em; margin: 0 0 12px; color: var(--t-hi); }
.product-card__text { font-size: 0.99rem; line-height: 1.62; color: var(--t-muted); margin: 0 0 22px; }
.product-card__status { font-family: var(--font-mono); font-size: 0.76rem; letter-spacing: 0.06em; color: var(--t-faint); }

.tag {
  position: absolute; top: 16px; left: 16px;
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 0.66rem;
  letter-spacing: 0.18em; text-transform: uppercase;
}
.tag--accent {
  color: #0A0C12; background: var(--accent);
  padding: 7px 12px; border-radius: 100px;
  box-shadow: 0 0 24px -4px color-mix(in srgb, var(--accent) 70%, transparent);
}
.tag .dot { width: 6px; height: 6px; animation-duration: 2.2s; }

.pipeline-card {
  position: relative; display: flex; flex-direction: column;
  justify-content: center; align-items: flex-start; min-height: 100%;
  padding: 32px; border: 1px dashed rgba(255, 255, 255, 0.16);
  border-radius: 16px; background: rgba(255, 255, 255, 0.008);
  transition: border-color .3s, background .3s, transform .3s;
}
.pipeline-card:hover {
  transform: translateY(-6px);
  border-color: color-mix(in srgb, var(--accent) 40%, transparent);
  background: color-mix(in srgb, var(--accent) 4%, transparent);
}
.pipeline-card__plus {
  display: flex; align-items: center; justify-content: center;
  width: 46px; height: 46px; border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  color: var(--t-muted); font-size: 1.4rem; line-height: 1; margin-bottom: 22px;
}
.pipeline-card__title { font-family: var(--font-sans); font-weight: 600; font-size: 1.3rem; margin: 0 0 10px; color: var(--t-pill); }
.pipeline-card__text { font-size: 0.97rem; line-height: 1.6; color: var(--t-soft); margin: 0 0 24px; max-width: 340px; }

/* About -------------------------------------------------------------------- */
.about {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(300px, 100%), 1fr));
  gap: clamp(36px, 5vw, 64px); align-items: center;
}
.about__card {
  position: relative; aspect-ratio: 1 / 1; max-width: 380px; width: 100%;
  border: 1px solid rgba(255, 255, 255, 0.09); border-radius: 18px; overflow: hidden;
  background: linear-gradient(160deg, #0E121A, #0A0C12);
}
.about__glow { position: absolute; inset: 0; background: radial-gradient(80% 70% at 50% 38%, color-mix(in srgb, var(--accent) 16%, transparent), transparent 60%); }
.about__grid {
  position: absolute; inset: 0;
  background: repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.03) 0 1px, transparent 1px 40px),
              repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.03) 0 1px, transparent 1px 40px);
}
.about__ring {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -56%);
  width: 118px; height: 118px;
  border: 1px solid color-mix(in srgb, var(--accent) 45%, transparent); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 0 50px -10px color-mix(in srgb, var(--accent) 45%, transparent);
}
.about__initial { font-family: var(--font-sans); font-weight: 700; font-size: 2.6rem; color: var(--accent); }
.about__spark { position: absolute; border-radius: 50%; }
.about__spark--1 { top: 26%; left: 24%; width: 6px; height: 6px; background: var(--accent); box-shadow: 0 0 10px var(--accent); }
.about__spark--2 { top: 70%; left: 74%; width: 5px; height: 5px; background: color-mix(in srgb, var(--accent) 70%, transparent); }
.about__spark--3 { top: 74%; left: 30%; width: 4px; height: 4px; background: color-mix(in srgb, var(--accent) 60%, transparent); }
.about__caption {
  position: absolute; left: 0; right: 0; bottom: 0; padding: 15px 18px;
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.12em; color: var(--t-faint);
  border-top: 1px solid rgba(255, 255, 255, 0.06); background: rgba(10, 12, 18, 0.45);
}
.about__sign { font-family: var(--font-mono); font-size: 0.84rem; letter-spacing: 0.06em; color: color-mix(in srgb, var(--accent) 88%, #ffffff); }

/* Writing ------------------------------------------------------------------ */
.post-card {
  display: flex; flex-direction: column; text-decoration: none;
  border: 1px solid rgba(255, 255, 255, 0.08); border-radius: 14px; overflow: hidden;
  background: rgba(255, 255, 255, 0.015);
  transition: transform .3s, border-color .3s, box-shadow .3s;
}
.post-card:hover {
  transform: translateY(-6px);
  border-color: color-mix(in srgb, var(--accent) 35%, transparent);
  box-shadow: 0 24px 50px -26px rgba(0, 0, 0, 0.65),
              0 0 34px -18px color-mix(in srgb, var(--accent) 45%, transparent);
}
.post-card:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; }
.post-card__thumb { position: relative; aspect-ratio: 16 / 9; overflow: hidden; border-bottom: 1px solid rgba(255, 255, 255, 0.07); background: #0C0F16; }
.post-card__hatch { position: absolute; inset: 0; background: repeating-linear-gradient(135deg, color-mix(in srgb, var(--accent) 10%, transparent) 0 1px, transparent 1px 9px); }
.post-card__radial { position: absolute; inset: 0; }
.post-card__radial--a { background: radial-gradient(90% 80% at 25% 20%, color-mix(in srgb, var(--accent) 14%, transparent), transparent 65%); }
.post-card__radial--b { background: radial-gradient(90% 80% at 75% 25%, color-mix(in srgb, var(--accent) 14%, transparent), transparent 65%); }
.post-card__radial--c { background: radial-gradient(90% 80% at 50% 80%, color-mix(in srgb, var(--accent) 14%, transparent), transparent 65%); }
.post-card__file { position: absolute; bottom: 14px; left: 14px; font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.08em; color: var(--t-body); }
.post-card__kind {
  position: absolute; top: 14px; right: 14px;
  font-family: var(--font-mono); font-size: 0.62rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--accent); border: 1px solid color-mix(in srgb, var(--accent) 30%, transparent);
  padding: 4px 9px; border-radius: 100px; background: color-mix(in srgb, var(--accent) 8%, transparent);
}
.post-card__body { padding: 22px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.post-card__meta { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.06em; color: var(--t-faint); }
.post-card__title { font-family: var(--font-sans); font-weight: 600; font-size: 1.16rem; line-height: 1.25; letter-spacing: -0.01em; margin: 0; color: var(--t-base); }
.post-card__cta { margin-top: auto; font-family: var(--font-mono); font-size: 0.74rem; color: var(--accent); display: inline-flex; align-items: center; gap: 7px; }

.writing__more { margin-top: clamp(32px, 4vw, 48px); }

/* Contact ------------------------------------------------------------------ */
.contact {
  position: relative; max-width: 1080px; overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--accent) 22%, transparent); border-radius: 22px;
  background: linear-gradient(160deg, #0E1320, #0A0C12);
  padding: clamp(44px, 7vw, 86px) clamp(24px, 5vw, 64px); text-align: center;
}
.contact__glow { position: absolute; inset: 0; background: radial-gradient(90% 120% at 50% 0%, color-mix(in srgb, var(--accent) 16%, transparent), transparent 55%); }
.contact__inner { position: relative; z-index: 1; max-width: 640px; margin: 0 auto; }
.contact__lead { margin: 0 auto 36px; max-width: 520px; }
.contact__email { margin-top: 22px; font-family: var(--font-mono); font-size: 0.84rem; letter-spacing: 0.04em; color: var(--t-soft); }
.contact__community { margin-top: 30px; padding-top: 26px; border-top: 1px solid rgba(255, 255, 255, 0.08); display: flex; flex-direction: column; align-items: center; gap: 14px; }
.contact__community-label { font-family: var(--font-mono); font-size: 0.74rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--t-faint); }
.contact__community .btn--wide { border-radius: 10px; gap: 10px; }

/* Footer ------------------------------------------------------------------- */
.footer { border-top: 1px solid rgba(255, 255, 255, 0.07); padding: clamp(48px, 7vw, 72px) clamp(18px, 5vw, 40px) 40px; }
.footer__top {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(min(220px, 100%), 1fr));
  gap: 36px; padding-bottom: 40px; border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}
.footer__brandcol { max-width: 320px; }
.footer__tagline { margin: 16px 0 0; font-size: 0.92rem; line-height: 1.6; color: var(--t-soft); }
.footer__heading { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--t-faint); margin-bottom: 18px; }
.footer__links { display: flex; flex-direction: column; gap: 11px; }
.footer-link { font-family: var(--font-sans); font-size: 0.92rem; color: var(--t-muted); text-decoration: none; transition: color .2s; width: fit-content; }
.footer-link:hover { color: var(--accent); }
.footer__socials { display: flex; flex-direction: column; gap: 11px; align-items: flex-start; }
.footer-social {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 0.78rem; color: var(--t-muted); text-decoration: none;
  padding: 9px 14px; border: 1px solid rgba(255, 255, 255, 0.1); border-radius: 8px;
  transition: color .25s, border-color .25s, transform .25s;
}
.footer-social:hover { color: #ffffff; border-color: color-mix(in srgb, var(--accent) 45%, transparent); transform: translateY(-2px); }
.footer-social:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; }
.footer__bottom {
  display: flex; flex-wrap: wrap; gap: 14px; justify-content: space-between; align-items: center;
  padding-top: 24px; font-family: var(--font-mono); font-size: 0.74rem; color: var(--t-faint);
}
.footer__toplink { color: var(--t-faint); text-decoration: none; transition: color .2s; }
.footer__toplink:hover { color: var(--accent); }

/* Reveal-on-scroll --------------------------------------------------------- */
[data-reveal] { will-change: opacity, transform; }
.is-revealed { opacity: 1 !important; transform: none !important; }

/* Reduced motion ----------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  [data-anim] { animation: none !important; }
  [data-reveal] { opacity: 1 !important; transform: none !important; transition: none !important; }
}
