/* =========================================================
   Train with Wendi — landing page styles
   Palette: black → white gradient, baby-blue tertiary accent
   Type: Cabinet Grotesk (display) + Satoshi (body)
   ========================================================= */

:root{
  --ink:        #0b0b0c;   /* off-black, never #000 */
  --ink-soft:   #1b1c1f;
  --paper:      #f7f8fa;   /* off-white */
  --paper-pure: #ffffff;
  --line:       #e5e7eb;
  --muted:      #6b7077;

  --blue:       #8fc9ee;   /* baby blue accent */
  --blue-deep:  #5aa9da;   /* for text contrast on light */
  --blue-soft:  #e7f3fc;

  --radius:     22px;
  --radius-lg:  30px;
  --maxw:       1240px;

  --ease:       cubic-bezier(0.16, 1, 0.3, 1);
  --shadow:     0 24px 60px -30px rgba(11,11,12,.28);
  --shadow-sm:  0 10px 30px -16px rgba(11,11,12,.25);
}

*{ box-sizing:border-box; margin:0; padding:0; }

html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }

body{
  font-family:'Satoshi', system-ui, sans-serif;
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

img{ display:block; max-width:100%; }

h1,h2,h3,h4{
  font-family:'Cabinet Grotesk', system-ui, sans-serif;
  letter-spacing:-.02em;
  line-height:1.02;
  font-weight:800;
}

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 clamp(20px, 5vw, 56px); }

.accent{ color:var(--blue-deep); }
.hide-sm{ display:inline; }

/* ---------- grain ---------- */
.grain{
  position:fixed; inset:0; z-index:120; pointer-events:none;
  opacity:.04; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.55em;
  font-family:'Satoshi',sans-serif; font-weight:700; font-size:.95rem;
  padding:.8em 1.35em; border-radius:999px; text-decoration:none;
  border:1px solid transparent; cursor:pointer;
  transition:transform .25s var(--ease), background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease), box-shadow .25s var(--ease);
  white-space:nowrap;
}
.btn i{ font-size:1.15em; }
.btn:active{ transform:translateY(1px) scale(.98); }

.btn--solid{ background:var(--ink); color:#fff; }
.btn--solid:hover{ background:var(--ink-soft); box-shadow:var(--shadow-sm); transform:translateY(-2px); }

.btn--ghost{ background:transparent; color:var(--ink); border-color:var(--line); }
.btn--ghost:hover{ border-color:var(--ink); transform:translateY(-1px); }

.btn--line{ background:rgba(255,255,255,.06); color:#fff; border-color:rgba(255,255,255,.5); backdrop-filter:blur(6px); }
.btn--line:hover{ background:rgba(255,255,255,.16); border-color:#fff; transform:translateY(-2px); }

.btn--lg{ padding:1.02em 1.7em; font-size:1.02rem; }

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  transition:background .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease);
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(247,248,250,.72);
  backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid var(--line);
  box-shadow:0 1px 0 rgba(255,255,255,.6) inset;
}
.nav__inner{
  max-width:var(--maxw); margin:0 auto;
  padding:14px clamp(20px,5vw,56px);
  display:flex; align-items:center; justify-content:space-between; gap:24px;
}
.nav__brand{ display:flex; align-items:center; gap:12px; text-decoration:none; }
.nav__logo{ height:46px; width:auto; }
.nav__brandname{
  font-family:'Cabinet Grotesk', sans-serif; font-weight:700; font-size:1.18rem;
  letter-spacing:-.02em; color:#fff; text-shadow:0 1px 14px rgba(0,0,0,.4);
  transition:color .35s var(--ease), text-shadow .35s var(--ease); white-space:nowrap;
}
.nav.scrolled .nav__brandname{ color:var(--ink); text-shadow:none; }
.nav__links{ display:flex; gap:30px; margin-left:auto; }
.nav__links a{
  position:relative; text-decoration:none; color:#fff;
  font-weight:500; font-size:.96rem; transition:color .25s var(--ease), opacity .25s;
  text-shadow:0 1px 12px rgba(0,0,0,.35);
}
.nav__links a::after{
  content:''; position:absolute; left:0; bottom:-6px; height:2px; width:0;
  background:var(--blue); transition:width .3s var(--ease);
}
.nav__links a:hover::after{ width:100%; }
.nav.scrolled .nav__links a{ color:var(--ink); text-shadow:none; }
.nav.scrolled .nav__links a:hover{ color:var(--blue-deep); }

.nav__cta{ display:flex; gap:12px; align-items:center; }
.nav.scrolled .nav__cta .btn--ghost{ color:var(--ink); }
.nav:not(.scrolled) .nav__cta .btn--ghost{ color:#fff; border-color:rgba(255,255,255,.45); }

.nav__burger{
  display:none; flex-direction:column; gap:5px; background:none; border:0;
  cursor:pointer; padding:8px; z-index:110;
}
.nav__burger span{ width:24px; height:2px; background:#fff; border-radius:2px; transition:.3s var(--ease); }
.nav.scrolled .nav__burger span{ background:var(--ink); }
.nav__burger.open span{ background:var(--ink); }
.nav__burger.open span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav__burger.open span:nth-child(2){ opacity:0; }
.nav__burger.open span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* mobile sheet */
.sheet{
  position:fixed; inset:0; z-index:105;
  background:var(--paper); padding:96px 28px 28px;
  display:flex; flex-direction:column; gap:6px;
  transform:translateY(-100%); opacity:0; pointer-events:none;
  transition:transform .45s var(--ease), opacity .35s var(--ease);
}
.sheet.open{ transform:translateY(0); opacity:1; pointer-events:auto; }
.sheet a{ text-decoration:none; color:var(--ink); font-family:'Cabinet Grotesk'; font-weight:700; font-size:1.6rem; padding:12px 0; border-bottom:1px solid var(--line); }
.sheet__call{ font-size:1.1rem !important; color:var(--blue-deep) !important; }
.sheet__book{ margin-top:18px; justify-content:center; font-size:1.05rem !important; }

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative; min-height:100dvh;
  display:flex; flex-direction:column; justify-content:flex-end;
  padding:0 0 clamp(40px,7vw,80px);
  overflow:hidden; isolation:isolate;
  background:var(--ink);
}
.hero__stage{ position:absolute; inset:0; z-index:-2; }
.hero__slide{
  position:absolute; inset:0; opacity:0;
  background-size:cover; background-position:center;
  transition:opacity 1.4s var(--ease);
  transform:scale(1.06);
}
.hero__slide.is-active{ opacity:1; animation:kenburns 8s ease-out forwards; }
@keyframes kenburns{ from{ transform:scale(1.04); } to{ transform:scale(1.13); } }

.hero__scrim{
  position:absolute; inset:0; z-index:-1;
  /* Dark linear gradient and backdrop-filter blur to enhance text contrast */
  background:linear-gradient(180deg,
    rgba(11,11,12,.50) 0%,
    rgba(11,11,12,.30) 30%,
    rgba(11,11,12,.60) 70%,
    rgba(11,11,12,.92) 100%);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
}

.hero__content{ max-width:var(--maxw); width:100%; margin:0 auto; padding:0 clamp(20px,5vw,56px); color:#fff; }

.hero__eyebrow{
  display:inline-flex; align-items:center; gap:9px;
  font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; font-weight:700;
  color:rgba(255,255,255,.85);
  padding:8px 15px; border:1px solid rgba(255,255,255,.22); border-radius:999px;
  background:rgba(255,255,255,.06); backdrop-filter:blur(8px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.12);
}
.hero__eyebrow .dot{ width:8px; height:8px; border-radius:50%; background:var(--blue); box-shadow:0 0 0 0 rgba(143,201,238,.7); animation:pulse 2.4s infinite; }
@keyframes pulse{ 0%{ box-shadow:0 0 0 0 rgba(143,201,238,.6);} 70%{ box-shadow:0 0 0 10px rgba(143,201,238,0);} 100%{ box-shadow:0 0 0 0 rgba(143,201,238,0);} }

.hero__title{
  font-size:clamp(2.6rem, 7vw, 5.6rem);
  margin:22px 0 0; max-width:16ch;
  text-shadow:0 4px 40px rgba(0,0,0,.4);
}
.hero__sub{
  font-size:clamp(1.05rem,1.6vw,1.3rem); color:rgba(255,255,255,.82);
  max-width:48ch; margin-top:22px; line-height:1.55;
}
.hero__actions{ display:flex; flex-wrap:wrap; gap:14px; margin-top:34px; }
.hero__badges{
  display:flex; align-items:center; gap:14px; flex-wrap:wrap;
  margin-top:30px; color:rgba(255,255,255,.7); font-size:.92rem;
}
.hero__badges span{ display:inline-flex; align-items:center; gap:7px; }
.hero__badges i{ color:var(--blue); font-size:1.1em; }
.hero__badges .sep{ opacity:.4; }

.hero__dots{ position:absolute; right:clamp(20px,5vw,56px); bottom:clamp(40px,7vw,80px); display:flex; flex-direction:column; gap:11px; z-index:5; }
.hero__dots button{
  width:10px; height:10px; border-radius:50%; border:0; cursor:pointer;
  background:rgba(255,255,255,.35); transition:.35s var(--ease); padding:0;
}
.hero__dots button.active{ background:var(--blue); height:26px; border-radius:6px; }

.hero__scroll{
  position:absolute; left:50%; bottom:22px; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:4px;
  color:rgba(255,255,255,.6); text-decoration:none; font-size:.7rem; letter-spacing:.2em; text-transform:uppercase;
}
.hero__scroll i{ animation:bob 1.8s var(--ease) infinite; font-size:1.1rem; }
@keyframes bob{ 0%,100%{ transform:translateY(0);} 50%{ transform:translateY(6px);} }

/* =========================================================
   MARQUEE
   ========================================================= */
.marquee{ background:var(--ink); color:#fff; overflow:hidden; padding:20px 0; border-bottom:1px solid rgba(255,255,255,.08); }
.marquee__track{ display:flex; align-items:center; gap:28px; white-space:nowrap; width:max-content; animation:scroll 32s linear infinite; }
.marquee__track span{ font-family:'Cabinet Grotesk'; font-weight:700; font-size:1.35rem; letter-spacing:-.01em; }
.marquee .m-dot{ color:var(--blue); }
@keyframes scroll{ from{ transform:translateX(0);} to{ transform:translateX(-50%);} }

/* =========================================================
   ABOUT
   ========================================================= */
.about{ padding:clamp(70px,9vw,130px) 0; }
.about__grid{ display:grid; grid-template-columns:0.85fr 1.15fr; gap:clamp(36px,6vw,84px); align-items:center; }
.about__media{ position:relative; }
.about__media img{ width:100%; border-radius:var(--radius-lg); object-fit:cover; aspect-ratio:9/11; box-shadow:var(--shadow); }
.about__stat{
  position:absolute; bottom:-22px; left:-22px;
  background:var(--paper-pure); border:1px solid var(--line); border-radius:18px;
  padding:16px 22px; box-shadow:var(--shadow-sm); max-width:200px;
}
.about__stat strong{ font-family:'Cabinet Grotesk'; font-size:2.2rem; display:block; line-height:1; }
.about__stat span{ font-size:.82rem; color:var(--muted); }

.kicker{ font-size:.8rem; letter-spacing:.18em; text-transform:uppercase; font-weight:700; color:var(--blue-deep); margin-bottom:14px; }
.kicker--light{ color:var(--blue); }
.about__copy h2, .sec-head h2, .area__copy h2{ font-size:clamp(2rem,3.6vw,3.2rem); }
.lead{ font-size:1.18rem; color:var(--ink-soft); margin-top:18px; max-width:60ch; }
.about__copy p:not(.lead):not(.kicker){ color:var(--muted); margin-top:16px; max-width:58ch; }

.about__pills{ display:flex; flex-wrap:wrap; gap:10px; margin-top:28px; }
.pill{ display:inline-flex; align-items:center; gap:7px; font-size:.9rem; font-weight:500; padding:8px 14px; border:1px solid var(--line); border-radius:999px; background:var(--paper-pure); }
.pill i{ color:var(--blue-deep); font-size:1.1em; }

/* =========================================================
   SERVICES / BENTO
   ========================================================= */
.services{ padding:clamp(60px,8vw,110px) 0; }
.sec-head{ margin-bottom:clamp(36px,5vw,60px); }
.sec-head h2{ font-size:clamp(2rem,4vw,3.4rem); }

.bento{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.card{
  position:relative;
  background: linear-gradient(145deg, var(--paper-pure) 0%, #f2f7fc 100%);
  border:1px solid rgba(143, 201, 238, 0.25);
  border-radius:var(--radius); padding:30px;
  transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease);
  overflow:hidden; will-change:transform;
  isolation: isolate;
}
.card::before{
  content:''; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  background:radial-gradient(420px circle at var(--mx,50%) var(--my,0%), rgba(143,201,238,.24), transparent 55%);
  opacity:0; transition:opacity .4s var(--ease);
  z-index: -1;
}
.card::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: radial-gradient(rgba(143, 201, 238, 0.12) 1.2px, transparent 1.2px);
  background-size: 16px 16px;
  opacity: 0.25;
  z-index: -2;
  transition: opacity 0.4s var(--ease);
}
.card:hover{
  transform:translateY(-5px);
  box-shadow: 0 30px 60px -15px rgba(143,201,238,.3);
  border-color: var(--blue);
}
.card:hover::before{ opacity:1; }
.card:hover::after{ opacity:0.5; }

.card__icon{
  width:50px; height:50px; border-radius:14px; display:grid; place-items:center;
  background: linear-gradient(135deg, rgba(143,201,238,0.2) 0%, rgba(143,201,238,0.05) 100%);
  border: 1px solid rgba(143, 201, 238, 0.35);
  color:var(--blue-deep); font-size:1.5rem; margin-bottom:18px;
  transition: transform 0.3s var(--ease), background 0.3s var(--ease), color 0.3s var(--ease), box-shadow 0.3s var(--ease);
}
.card:hover .card__icon {
  transform: scale(1.1) translateY(-2px);
  background: var(--blue);
  color: var(--ink);
  box-shadow: 0 8px 20px rgba(143,201,238,0.45);
  border-color: var(--blue);
}

.card h3{ font-size:1.32rem; margin-bottom:8px; }
.card p{ color:var(--muted); font-size:.98rem; }
.card__link{ display:inline-flex; align-items:center; gap:6px; margin-top:16px; color:var(--ink); font-weight:700; text-decoration:none; font-size:.95rem; }
.card__link i{ transition:transform .3s var(--ease); }
.card__link:hover i{ transform:translate(3px,-3px); }

/* feature + wide spans */
.card--feature{
  grid-row:span 2;
  background: linear-gradient(145deg, #0b0b0c 0%, #17181c 100%);
  color:#fff;
  border-color: rgba(255, 255, 255, 0.08);
  display:flex; flex-direction:column; justify-content:flex-end; gap:6px;
}
.card--feature::after {
  background-image: radial-gradient(rgba(255, 255, 255, 0.06) 1.2px, transparent 1.2px);
}
.card--feature:hover {
  border-color: var(--blue-deep);
  box-shadow: 0 30px 60px -15px rgba(11,11,12,.6), 0 0 30px 0 rgba(143,201,238,.12);
}
.card--feature .card__icon{
  background: linear-gradient(135deg, rgba(255,255,255,0.1) 0%, rgba(255,255,255,0.02) 100%);
  border: 1px solid rgba(255, 255, 255, 0.15);
  color: var(--blue);
}
.card--feature:hover .card__icon {
  background: var(--blue);
  color: var(--ink);
  border-color: var(--blue);
}
.card--feature h3{ font-size:1.7rem; }
.card--feature p{ color:rgba(255,255,255,.72); }
.card--feature .card__link{ color:#fff; }
.card--wide{ grid-column:span 2; }

/* =========================================================
   PROCESS
   ========================================================= */
.process{ background:var(--ink); color:#fff; padding:clamp(70px,9vw,120px) 0; }
.process .sec-head h2{ color:#fff; }
.steps{ list-style:none; display:grid; grid-template-columns:repeat(4,1fr); gap:0; }
.step{ position:relative; padding:30px 28px 30px 0; border-top:1px solid rgba(255,255,255,.16); }
.step + .step{ padding-left:28px; border-left:1px solid rgba(255,255,255,.12); }
.step__num{ font-family:'Cabinet Grotesk'; font-size:1rem; font-weight:700; color:var(--blue); letter-spacing:.05em; }
.step h3{ font-size:1.45rem; margin:14px 0 8px; color:#fff; }
.step p{ color:rgba(255,255,255,.66); font-size:.96rem; }

/* =========================================================
   SERVICE AREA
   ========================================================= */
.area{ padding:clamp(70px,9vw,120px) 0; }
.area__grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(36px,6vw,80px); align-items:center; }
.area__list{ list-style:none; display:grid; grid-template-columns:1fr 1fr; gap:12px 24px; margin-top:28px; }
.area__list li{ display:flex; align-items:center; gap:10px; font-weight:500; }
.area__list i{ color:var(--blue-deep); }
.area__map{
  position:relative; aspect-ratio:5/4; border-radius:var(--radius-lg);
  border:1px solid var(--line); overflow:hidden;
  box-shadow:var(--shadow);
}

/* =========================================================
   REVIEWS
   ========================================================= */
.reviews{ padding:clamp(60px,8vw,110px) 0; }
.reviews__head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; flex-wrap:wrap; margin-bottom:0; }

.google-badge{
  display:inline-flex; align-items:center; gap:14px; text-decoration:none;
  background:var(--paper-pure); border:1px solid var(--line); border-radius:18px;
  padding:14px 20px; box-shadow:var(--shadow-sm);
  transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.google-badge:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.google-badge__g{ display:grid; place-items:center; font-size:1.9rem; color:#4285f4; line-height:1; }
.google-badge__txt{ display:flex; flex-direction:column; line-height:1.25; }
.google-badge__rating{ font-family:'Cabinet Grotesk'; font-weight:800; font-size:1.25rem; display:flex; align-items:center; gap:8px; color:var(--ink); }
.google-badge__rating .stars{ font-size:.95rem; }
.google-badge__label{ font-size:.82rem; color:var(--muted); font-weight:500; }

.reviews__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:clamp(36px,5vw,56px); }
.quote{
  background:var(--paper-pure); border:1px solid var(--line); border-radius:var(--radius);
  padding:30px; display:flex; flex-direction:column; gap:16px;
  transition:transform .4s var(--ease), box-shadow .4s var(--ease);
}
.quote:hover{ transform:translateY(-4px); box-shadow:var(--shadow-sm); }
.stars{ color:var(--blue-deep); letter-spacing:2px; font-size:1rem; }
.quote blockquote{ font-family:'Cabinet Grotesk'; font-weight:500; font-size:1.08rem; line-height:1.42; letter-spacing:-.01em; }
.quote figcaption{ display:flex; flex-direction:column; margin-top:auto; }
.quote figcaption strong{ font-weight:700; }
.quote figcaption span{ color:var(--muted); font-size:.86rem; }

/* second card offset for asymmetry */
.reviews__grid .quote:nth-child(2){ transform:translateY(22px); }
.reviews__grid .quote:nth-child(2):hover{ transform:translateY(18px); }

/* =========================================================
   CTA
   ========================================================= */
.cta{
  background:linear-gradient(180deg, var(--paper) 0%, var(--paper) 38%, var(--ink) 38%, var(--ink) 100%);
  padding:0 0 clamp(70px,9vw,120px);
}
.cta__inner{
  display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,70px);
  background:var(--ink); color:#fff; border-radius:var(--radius-lg);
  padding:clamp(36px,5vw,64px); box-shadow:var(--shadow);
  border:1px solid rgba(255,255,255,.08);
}
.cta__copy h2{ font-size:clamp(2rem,3.6vw,3rem); color:#fff; }
.cta__copy .lead{ color:rgba(255,255,255,.74); }
.cta__contacts{ display:flex; flex-direction:column; gap:12px; margin-top:30px; }
.cta__contacts a{ display:inline-flex; align-items:center; gap:11px; color:#fff; text-decoration:none; font-weight:500; font-size:1.05rem; transition:color .25s; width:fit-content; }
.cta__contacts a i{ color:var(--blue); font-size:1.3em; }
.cta__contacts a:hover{ color:var(--blue); }

/* form */
.form{ display:flex; flex-direction:column; gap:16px; }
.field{ display:flex; flex-direction:column; gap:7px; }
.field label{ font-size:.86rem; font-weight:700; color:rgba(255,255,255,.85); }
.field input, .field textarea{
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.16); border-radius:14px;
  padding:13px 16px; color:#fff; font-family:'Satoshi'; font-size:1rem; resize:vertical;
  transition:border-color .25s var(--ease), background .25s var(--ease);
}
.field input::placeholder, .field textarea::placeholder{ color:rgba(255,255,255,.4); }
.field input:focus, .field textarea:focus{ outline:none; border-color:var(--blue); background:rgba(143,201,238,.08); }
.err{ color:#ff9d9d; font-size:.8rem; display:none; }
.field.invalid input{ border-color:#ff7a7a; }
.field.invalid .err{ display:block; }
.form__submit{ justify-content:center; margin-top:6px; }
.form__done{ display:flex; align-items:center; gap:8px; color:var(--blue); font-weight:700; margin-top:4px; }
.form__done i{ font-size:1.3em; }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{ background:var(--ink); color:#fff; padding:clamp(50px,6vw,80px) 0 30px; border-top:1px solid rgba(255,255,255,.08); }
.footer__grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; }
.footer__logo{ height:92px; width:auto; margin-bottom:18px; }
.footer__brand p{ color:rgba(255,255,255,.6); max-width:34ch; font-size:.95rem; }
.footer__col h4{ font-family:'Cabinet Grotesk'; font-size:.82rem; letter-spacing:.16em; text-transform:uppercase; color:var(--blue); margin-bottom:16px; }
.footer__col a, .footer__col span{ display:flex; align-items:center; gap:8px; color:rgba(255,255,255,.78); text-decoration:none; margin-bottom:11px; font-size:.96rem; transition:color .25s; }
.footer__col a:hover{ color:var(--blue); }
.footer__bar{
  max-width:var(--maxw); margin:48px auto 0; padding:24px clamp(20px,5vw,56px) 0;
  border-top:1px solid rgba(255,255,255,.1);
  display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap;
  color:rgba(255,255,255,.5); font-size:.86rem;
}

/* =========================================================
   REVEAL ANIMATION
   ========================================================= */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; } .reveal.d3{ transition-delay:.24s; }

@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1000px){
  .about__grid{ grid-template-columns:1fr; }
  .about__media{ max-width:440px; }
  .area__grid{ grid-template-columns:1fr; }
  .cta__inner{ grid-template-columns:1fr; }
  .footer__grid{ grid-template-columns:1fr 1fr; }
  .steps{ grid-template-columns:1fr 1fr; }
  .step + .step{ border-left:0; padding-left:0; }
  .step:nth-child(odd){ padding-left:0; }
  .step:nth-child(even){ padding-left:28px; border-left:1px solid rgba(255,255,255,.12); }
}

@media (max-width:760px){
  .nav__links, .nav__cta{ display:none; }
  .nav__burger{ display:flex; }
  .hide-sm{ display:none; }

  .bento{ grid-template-columns:1fr; }
  .card--feature{ grid-row:auto; }
  .card--wide{ grid-column:auto; }

  .reviews__grid{ grid-template-columns:1fr; }
  .reviews__grid .quote:nth-child(2){ transform:none; }
  .reviews__grid .quote:nth-child(2):hover{ transform:translateY(-4px); }

  .hero{ justify-content:flex-end; padding-bottom:120px; }
  .hero__dots{ flex-direction:row; right:auto; left:clamp(20px,5vw,56px); bottom:80px; }
  .hero__dots button.active{ height:10px; width:26px; border-radius:6px; }
  .hero__scroll{ display:none; }

  .area__list{ grid-template-columns:1fr; }
  .footer__grid{ grid-template-columns:1fr; gap:30px; }
  .footer__bar{ flex-direction:column; }
}

@media (max-width:420px){
  .steps{ grid-template-columns:1fr; }
  .step:nth-child(even){ padding-left:0; border-left:0; }
}
