:root {
  --navy: #0f1e36;
  --coral: #d3524a;
  --gold: #dca842;
  --sage: #3b8b88;
  --paper: #f7f5f0;
  --white: #fff;
  --muted: #aab5c6;
  --line: rgba(15, 30, 54, 0.16);
  --display: "Outfit", "Avenir Next", sans-serif;
  --body: "Plus Jakarta Sans", "Helvetica Neue", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--paper); color: var(--navy); font-family: var(--body); -webkit-font-smoothing: antialiased; }
a { color: inherit; }
h1, h2, h3, p { margin-top: 0; }

.skip-link { position: fixed; z-index: 100; top: .75rem; left: .75rem; padding: .65rem 1rem; background: var(--white); transform: translateY(-150%); }
.skip-link:focus { transform: translateY(0); }

.site-header { position: absolute; z-index: 20; top: 0; left: 0; display: flex; width: 100%; align-items: center; justify-content: space-between; padding: 1.8rem clamp(1.25rem, 4vw, 4.5rem); color: var(--navy); }
.brand { display: inline-flex; align-items: baseline; color: var(--white); font-family: var(--display); font-size: clamp(2.2rem, 3vw, 3rem); font-weight: 600; letter-spacing: -.07em; line-height: 1; text-decoration: none; }
.brand strong { margin-left: .08em; color: var(--gold); font-size: .92em; font-weight: 600; letter-spacing: -.04em; }
.site-nav { display: flex; align-items: center; gap: clamp(1.5rem, 3vw, 3rem); }
.site-nav a { position: relative; color: var(--navy); font-family: var(--display); font-size: .96rem; font-weight: 500; letter-spacing: .12em; text-decoration: none; text-transform: uppercase; }
.site-nav a::after { position: absolute; right: 0; bottom: -.45rem; left: 0; height: 2px; background: var(--coral); content: ""; transform: scaleX(0); transform-origin: right; transition: transform 180ms ease; }
.site-nav a:hover::after, .site-nav a:focus-visible::after { transform: scaleX(1); transform-origin: left; }
.menu-toggle { display: none; }

.hero { position: relative; display: grid; min-height: 100svh; overflow: hidden; grid-template-columns: 58% 42%; background: var(--navy); color: var(--white); }
.hero::before { position: absolute; z-index: 1; top: 0; bottom: 0; left: 58%; width: 1px; background: rgba(255,255,255,.14); content: ""; }
.hero__copy { position: relative; z-index: 2; display: flex; max-width: 68rem; align-items: flex-start; justify-content: center; padding: clamp(9rem, 17vh, 13rem) clamp(1.25rem, 4vw, 4.5rem) 7rem; flex-direction: column; }
.eyebrow, .section-label { display: flex; align-items: center; gap: .9rem; font-family: var(--display); font-size: .69rem; font-weight: 600; letter-spacing: .16em; text-transform: uppercase; }
.eyebrow { margin: 0 0 2rem; color: var(--gold); }
.eyebrow::before { width: 1.7rem; height: 2px; background: currentColor; content: ""; }
h1 { max-width: 12.5ch; margin-bottom: 2.4rem; font-family: var(--display); font-size: clamp(3.55rem, 6.8vw, 7.65rem); font-weight: 600; letter-spacing: -.058em; line-height: .94; }
h1 span { color: var(--coral); }
.hero__intro { max-width: 39rem; margin-bottom: 2.6rem; color: rgba(255,255,255,.78); font-size: clamp(1.25rem, 1.9vw, 1.75rem); line-height: 1.55; }
.hero__visual { position: relative; overflow: hidden; background: var(--paper); }
.hero__visual::after { position: absolute; inset: 0; z-index: 2; background: rgba(247,245,240,.62); content: ""; pointer-events: none; }
.base-pair { position: absolute; border-radius: 50%; opacity: .95; aspect-ratio: 1; }
.base-pair--two { bottom: -20%; left: -34%; width: 70%; background: var(--gold); opacity: .82; }
.base-pair--three { right: -24%; bottom: 11%; width: 38%; background: var(--sage); opacity: .7; }
.dna-mark { position: absolute; z-index: 1; top: 50%; left: 50%; width: min(54%, 23rem); opacity: .32; transform: translate(-50%, -50%); }
.dna-mark__path { stroke: var(--navy); stroke-width: 12; }
.dna-mark__path--alt { stroke: var(--sage); }
.dna-mark__rungs path { stroke: var(--gold); stroke-width: 3; }

.statement { display: grid; padding: clamp(6rem, 11vw, 11rem) clamp(1.25rem, 6vw, 7rem); grid-template-columns: 1fr 3fr; gap: 3rem; }
.section-label { align-items: flex-start; color: var(--navy); }
.section-label span { color: var(--coral); }
.section-label p { margin: 0; }
.statement__body { max-width: 72rem; }
.statement h2 { max-width: 12ch; margin-bottom: 2.5rem; font-family: var(--display); font-size: clamp(3.25rem, 7vw, 7.2rem); font-weight: 600; letter-spacing: -.065em; line-height: .94; }
.statement__body > p { max-width: 42rem; margin-left: auto; color: #53647a; font-size: clamp(1.05rem, 1.65vw, 1.35rem); line-height: 1.75; }
.principles { display: grid; margin-top: 5rem; border-top: 1px solid var(--line); grid-template-columns: 1fr 1fr; }
.principles article { display: flex; min-height: 12rem; border-right: 1px solid var(--line); align-items: flex-start; padding: 2rem; gap: 1rem; }
.principles article:last-child { border-right: 0; }
.principles__symbol { font-size: 1.8rem; line-height: 1; }
.principles__symbol--coral { color: var(--coral); }
.principles__symbol--gold { color: var(--gold); }
.principles h3 { margin-bottom: .6rem; font-family: var(--display); font-size: 1.25rem; }
.principles p { margin: 0; color: #637289; font-size: .85rem; line-height: 1.65; }

.founders { display: grid; padding: clamp(6rem, 10vw, 10rem) clamp(1.25rem, 6vw, 7rem); border-top: 1px solid var(--line); background: var(--white); grid-template-columns: 1fr 3fr; gap: 3rem; }
.founders__body { max-width: 72rem; }
.founders__heading { display: grid; align-items: end; grid-template-columns: minmax(0, 1.6fr) minmax(18rem, .9fr); gap: 3rem; }
.founders h2 { max-width: 12ch; margin: 0; font-family: var(--display); font-size: clamp(3rem, 6vw, 6.6rem); font-weight: 600; letter-spacing: -.065em; line-height: .94; }
.founders__heading p { margin: 0; color: #53647a; font-size: clamp(1rem, 1.35vw, 1.18rem); line-height: 1.75; }
.founder-grid { display: grid; margin-top: 5rem; gap: 1.5rem; }
.founder-card { display: grid; border: 1px solid var(--line); border-radius: .5rem; overflow: hidden; background: var(--paper); grid-template-columns: minmax(16rem, .8fr) minmax(0, 1.8fr); }
.founder-card__photo { position: relative; display: grid; min-height: 31rem; place-items: center; overflow: hidden; background: linear-gradient(135deg, rgba(15,30,54,.96), rgba(59,139,136,.84)); color: var(--white); }
.founder-card__photo::before { position: absolute; top: 12%; left: 50%; width: 72%; border: 1px solid rgba(255,255,255,.22); border-radius: 50%; content: ""; aspect-ratio: 1; transform: translateX(-50%); }
.founder-card__photo::after { position: absolute; right: -18%; bottom: -20%; width: 62%; border-radius: 50%; background: rgba(220, 168, 66, .7); content: ""; aspect-ratio: 1; }
.founder-card__photo span { position: relative; z-index: 1; display: grid; width: clamp(7rem, 13vw, 10rem); border: 1px solid rgba(255,255,255,.35); border-radius: 50%; place-items: center; color: rgba(255,255,255,.88); font-family: var(--display); font-size: clamp(2.3rem, 4vw, 3.8rem); font-weight: 600; letter-spacing: 0; aspect-ratio: 1; }
.founder-card__photo img { position: absolute; inset: 0; z-index: 3; width: 100%; height: 100%; object-fit: cover; }
.founder-card__photo:has(img)::before, .founder-card__photo:has(img)::after, .founder-card__photo:has(img) span { display: none; }
.founder-card__content { padding: clamp(2rem, 4vw, 3.6rem); }
.founder-card__role { margin-bottom: 1rem; color: var(--coral); font-family: var(--display); font-size: .68rem; font-weight: 700; letter-spacing: .14em; line-height: 1.55; text-transform: uppercase; }
.founder-card h3 { margin: 0 0 1.7rem; font-family: var(--display); font-size: clamp(2.35rem, 4vw, 4.4rem); font-weight: 600; letter-spacing: -.055em; line-height: .95; }
.founder-card__content p:not(.founder-card__role) { max-width: 43rem; margin-bottom: 1rem; color: #53647a; font-size: .94rem; line-height: 1.75; }
.founder-card__content p:last-child { margin-bottom: 0; }

.capabilities { padding: clamp(6rem, 9vw, 9rem) clamp(1.25rem, 6vw, 7rem); background: var(--navy); color: var(--white); }
.section-label--light { color: var(--muted); }
.section-label--light span { color: var(--gold); }
.capabilities__heading { display: grid; margin: 5rem 0 7rem; align-items: end; grid-template-columns: 2fr 1fr; gap: 3rem; }
.capabilities__heading h2 { max-width: 12ch; margin: 0; font-family: var(--display); font-size: clamp(3rem, 6.4vw, 7rem); font-weight: 600; letter-spacing: -.065em; line-height: .94; }
.capabilities__heading p { max-width: 25rem; margin: 0; color: var(--muted); font-size: .95rem; line-height: 1.7; }
.approach-link { display: inline-flex; border: 1px solid rgba(255,255,255,.34); border-radius: 999px; align-items: center; margin-top: 1.6rem; padding: .85rem 1.15rem; gap: .65rem; background: transparent; color: var(--white); font-family: var(--display); font-size: .72rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; cursor: pointer; transition: background-color 180ms ease, border-color 180ms ease, color 180ms ease; }
.approach-link span { color: var(--gold); transition: transform 180ms ease; }
.approach-link:hover, .approach-link:focus-visible { border-color: var(--gold); background: var(--paper); color: var(--navy); }
.approach-link:hover span, .approach-link:focus-visible span { transform: translate(.2rem,-.2rem); }
.capability-list { display: grid; margin: 0; border-top: 1px solid rgba(255,255,255,.2); padding: 0; grid-template-columns: repeat(4, 1fr); list-style: none; }
.capability-list li { position: relative; min-height: 24rem; border-right: 1px solid rgba(255,255,255,.2); padding: 1.35rem; transition: background-color 220ms ease, color 220ms ease; }
.capability-list li:last-child { border-right: 0; }
.capability-list li::after { position: absolute; right: 1.35rem; bottom: 1.35rem; width: .7rem; height: .7rem; border-radius: 50%; background: var(--coral); content: ""; }
.capability-list li:nth-child(2)::after { background: var(--gold); }
.capability-list li:nth-child(3)::after { background: var(--sage); }
.capability-list li:hover { background: var(--paper); color: var(--navy); }
.capability-list li > span { color: var(--gold); font-family: var(--display); font-size: .62rem; font-weight: 600; }
.capability-list h3 { margin: 7rem 0 1.5rem; font-family: var(--display); font-size: clamp(2.4rem, 4vw, 4rem); font-weight: 600; letter-spacing: -.05em; }
.capability-list p { max-width: 15rem; color: var(--muted); font-size: .85rem; line-height: 1.65; }
.capability-list li:hover p { color: #637289; }

.contact { position: relative; overflow: hidden; padding: clamp(6rem, 10vw, 10rem) clamp(1.25rem, 6vw, 7rem) 2rem; background: var(--paper); color: var(--navy); }
.contact::after { position: absolute; z-index: 0; right: -12vw; bottom: -24vw; width: 38vw; min-width: 18rem; border-radius: 50%; background: var(--gold); content: ""; aspect-ratio: 1; }
.contact > * { position: relative; z-index: 1; }
.contact .eyebrow { color: var(--coral); }
.contact h2 { max-width: 10ch; margin: 0 0 4rem; font-family: var(--display); font-size: clamp(4rem, 9.5vw, 10rem); font-weight: 600; letter-spacing: -.075em; line-height: .88; }
.contact__link { display: flex; width: 100%; border: 0; border-top: 2px solid var(--navy); border-bottom: 2px solid var(--navy); align-items: center; justify-content: space-between; padding: 1.6rem 0; background: transparent; color: inherit; font-family: var(--display); font-size: clamp(1.3rem, 3vw, 3rem); font-weight: 600; letter-spacing: -.03em; text-align: left; text-decoration: none; cursor: pointer; }
.contact__link span { color: var(--coral); transition: transform 180ms ease; }
.contact__link:hover span, .contact__link:focus-visible span { transform: translate(.35rem,-.35rem); }
.footer { display: grid; margin-top: 8rem; align-items: end; grid-template-columns: 1fr 1fr 1fr; font-family: var(--display); font-size: .62rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; }
.footer p { margin: 0; }
.footer p:nth-child(2) { text-align: center; }
.footer p:last-child { text-align: right; }
.brand--footer { color: var(--navy); font-size: 1.3rem; text-transform: none; }

.approach-modal { width: min(96vw, 76rem); max-height: 92svh; border: 0; padding: 0; background: transparent; color: var(--navy); }
.approach-modal::backdrop { background: rgba(15, 30, 54, .72); backdrop-filter: blur(8px); }
.approach-modal__panel { position: relative; overflow: auto; max-height: 92svh; border-radius: .5rem; background: var(--paper); box-shadow: 0 2rem 5rem rgba(15, 30, 54, .35); }
.approach-modal__panel::before { position: absolute; z-index: 0; top: -10rem; right: -9rem; width: 22rem; border-radius: 50%; background: rgba(59, 139, 136, .22); content: ""; aspect-ratio: 1; pointer-events: none; }
.approach-modal__panel > * { position: relative; z-index: 1; }
.approach-modal__close { position: sticky; z-index: 4; top: 1rem; left: calc(100% - 4.2rem); display: grid; width: 2.8rem; height: 2.8rem; border: 1px solid var(--line); border-radius: 50%; place-items: center; margin: 1rem 1rem -3.8rem auto; background: var(--white); color: var(--navy); font-size: 1.45rem; line-height: 1; cursor: pointer; }
.approach-modal__hero { padding: clamp(4rem, 8vw, 7rem) clamp(1.35rem, 6vw, 6rem) clamp(2.5rem, 5vw, 4rem); background: var(--navy); color: var(--white); }
.approach-modal__hero h2 { max-width: 12ch; margin: 0 0 2rem; font-family: var(--display); font-size: clamp(3.15rem, 7.4vw, 7rem); font-weight: 600; letter-spacing: -.065em; line-height: .92; }
.approach-modal__hero p:last-child { max-width: 45rem; margin: 0; color: rgba(255,255,255,.78); font-size: clamp(1rem, 1.45vw, 1.32rem); line-height: 1.7; }
.approach-modal__intro { padding: clamp(2.5rem, 5vw, 4.5rem) clamp(1.35rem, 6vw, 6rem); border-bottom: 1px solid var(--line); }
.approach-modal__intro p { max-width: 58rem; margin: 0; color: #53647a; font-size: clamp(1.05rem, 1.7vw, 1.45rem); line-height: 1.75; }
.work-process { display: grid; padding: clamp(2.5rem, 5vw, 4.5rem) clamp(1.35rem, 6vw, 6rem); border-bottom: 1px solid var(--line); align-items: start; grid-template-columns: 1fr 1.4fr; gap: 3rem; }
.work-process__number, .approach-steps span { color: var(--coral); font-family: var(--display); font-size: .68rem; font-weight: 700; letter-spacing: .16em; }
.work-process h3 { max-width: 10ch; margin: 1rem 0 0; font-family: var(--display); font-size: clamp(2.4rem, 4.8vw, 5rem); font-weight: 600; letter-spacing: -.06em; line-height: .94; }
.work-process p { max-width: 38rem; margin: 0; color: #53647a; font-size: 1rem; line-height: 1.75; }
.approach-steps { display: grid; margin: 0; padding: 0 clamp(1.35rem, 6vw, 6rem); grid-template-columns: repeat(4, 1fr); list-style: none; }
.approach-steps li { min-height: 23rem; border-right: 1px solid var(--line); padding: 2rem 1.4rem 2.4rem 0; }
.approach-steps li + li { padding-left: 1.4rem; }
.approach-steps li:last-child { border-right: 0; }
.approach-steps h3 { margin: 4.5rem 0 1rem; font-family: var(--display); font-size: clamp(1.75rem, 2.5vw, 2.55rem); font-weight: 600; letter-spacing: -.045em; line-height: 1; }
.approach-steps p { margin: 0; color: #637289; font-size: .87rem; line-height: 1.65; }
.approach-modal__actions { display: flex; justify-content: space-between; padding: 2rem clamp(1.35rem, 6vw, 6rem) clamp(2.5rem, 5vw, 4rem); gap: 1rem; }
.approach-modal__primary, .approach-modal__secondary { display: inline-flex; border-radius: 999px; align-items: center; justify-content: center; min-height: 3.1rem; padding: .95rem 1.35rem; gap: .55rem; font-family: var(--display); font-size: .76rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; cursor: pointer; }
.approach-modal__primary { border: 0; background: var(--navy); color: var(--white); }
.approach-modal__primary span { color: var(--gold); transition: transform 180ms ease; }
.approach-modal__primary:hover, .approach-modal__primary:focus-visible { background: var(--coral); }
.approach-modal__primary:hover span, .approach-modal__primary:focus-visible span { transform: translate(.2rem,-.2rem); }
.approach-modal__secondary { border: 1px solid var(--line); background: var(--white); color: var(--navy); }

.contact-modal { width: min(92vw, 58rem); border: 0; padding: 0; background: transparent; color: var(--navy); }
.contact-modal::backdrop { background: rgba(15, 30, 54, .72); backdrop-filter: blur(8px); }
.contact-modal__panel { position: relative; overflow: hidden; border-radius: .5rem; padding: clamp(2rem, 5vw, 4rem); background: var(--paper); box-shadow: 0 2rem 5rem rgba(15, 30, 54, .35); }
.contact-modal__panel::after { position: absolute; right: -8rem; bottom: -10rem; width: 18rem; border-radius: 50%; background: rgba(220, 168, 66, .45); content: ""; aspect-ratio: 1; pointer-events: none; }
.contact-modal__panel > * { position: relative; z-index: 1; }
.contact-modal__close { position: absolute; z-index: 2; top: 1.2rem; right: 1.2rem; display: grid; width: 2.6rem; height: 2.6rem; border: 1px solid var(--line); border-radius: 50%; place-items: center; background: var(--white); color: var(--navy); font-size: 1.45rem; line-height: 1; cursor: pointer; }
.contact-modal h2 { max-width: 11ch; margin: 0 0 2rem; font-family: var(--display); font-size: clamp(2.8rem, 6vw, 5.8rem); font-weight: 600; letter-spacing: -.065em; line-height: .92; }
.contact-form { display: grid; gap: 1.25rem; }
.contact-form__grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; }
.contact-form label { display: grid; gap: .5rem; color: #53647a; font-size: .72rem; font-weight: 600; letter-spacing: .1em; text-transform: uppercase; }
.contact-form input, .contact-form textarea { width: 100%; border: 1px solid var(--line); border-radius: .35rem; padding: .9rem 1rem; background: var(--white); color: var(--navy); font: 500 1rem/1.4 var(--body); }
.contact-form textarea { resize: vertical; }
.contact-form input:focus, .contact-form textarea:focus { border-color: var(--coral); outline: 2px solid rgba(211, 82, 74, .2); outline-offset: 2px; }
.contact-form__submit { justify-self: start; border: 0; border-radius: 999px; padding: .95rem 1.4rem; background: var(--navy); color: var(--white); font-family: var(--display); font-size: .8rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; cursor: pointer; }
.contact-form__submit:hover, .contact-form__submit:focus-visible { background: var(--coral); }
.contact-form__note { margin: 0; color: #637289; font-size: .82rem; line-height: 1.6; }

:focus-visible { outline: 2px solid currentColor; outline-offset: 5px; }
@media (prefers-reduced-motion: no-preference) {
  .dna-mark { animation: breathe 9s ease-in-out infinite; }
  @keyframes breathe { 50% { transform: translate(-50%,-50%) scale(1.025); } }
}

@media (max-width: 900px) {
  .site-header { position: fixed; background: var(--navy); }
  .menu-toggle { z-index: 2; display: flex; border: 0; align-items: center; padding: 0; gap: .7rem; background: transparent; color: var(--white); font: inherit; cursor: pointer; }
  .menu-toggle__label { font-family: var(--display); font-size: .65rem; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; }
  .menu-toggle__icon, .menu-toggle__icon::before { display: block; width: 1.25rem; height: 2px; background: var(--gold); content: ""; transition: transform 180ms ease; }
  .menu-toggle__icon::before { transform: translateY(.38rem); }
  .menu-toggle[aria-expanded="true"] .menu-toggle__icon { transform: rotate(45deg); }
  .menu-toggle[aria-expanded="true"] .menu-toggle__icon::before { transform: rotate(-90deg); }
  .site-nav { position: fixed; top: 0; right: 0; left: 0; display: grid; min-height: 100svh; align-content: center; padding: 5rem 1.25rem; gap: 2rem; background: var(--navy); opacity: 0; pointer-events: none; transform: translateY(-1rem); transition: opacity 180ms ease, transform 180ms ease; }
  .site-nav.is-open { opacity: 1; pointer-events: auto; transform: translateY(0); }
  .site-nav a { font-size: clamp(2.5rem, 13vw, 5rem); letter-spacing: -.05em; text-transform: none; }
  .hero { min-height: auto; padding-top: 5rem; grid-template-columns: 1fr; }
  .hero::before { display: none; }
  .hero__copy { min-height: calc(100svh - 5rem); padding-top: 5rem; padding-bottom: 5rem; }
  h1 { font-size: clamp(3.65rem, 14vw, 6.4rem); }
  .hero__visual { min-height: 72svh; }
  .statement, .founders, .capabilities__heading { grid-template-columns: 1fr; }
  .statement { gap: 4rem; }
  .statement__body > p { margin-left: 0; }
  .founders { gap: 4rem; }
  .founders__heading, .founder-card { grid-template-columns: 1fr; }
  .founder-card__photo { min-height: 24rem; }
  .capabilities__heading { margin: 4rem 0; }
  .work-process, .approach-steps { grid-template-columns: 1fr; }
  .work-process { gap: 2rem; }
  .approach-steps li, .approach-steps li + li { min-height: auto; border-right: 0; border-bottom: 1px solid var(--line); padding: 2rem 0; }
  .approach-steps h3 { margin-top: 2rem; }
  .capability-list { grid-template-columns: repeat(2, 1fr); }
  .capability-list li:nth-child(2) { border-right: 0; }
  .capability-list li:nth-child(-n+2) { border-bottom: 1px solid rgba(255,255,255,.2); }
  .contact-form__grid { grid-template-columns: 1fr; }
}

@media (max-width: 600px) {
  .hero__copy { min-height: 43rem; }
  .hero__visual { min-height: 38rem; }
  .statement { padding-top: 6rem; padding-bottom: 6rem; }
  .statement h2 { font-size: clamp(3.25rem, 15vw, 5rem); }
  .founders { padding-top: 6rem; padding-bottom: 6rem; }
  .founders h2 { font-size: clamp(3.15rem, 14vw, 4.85rem); }
  .founders__heading { gap: 2rem; }
  .founder-grid { margin-top: 3rem; }
  .founder-card__photo { min-height: 20rem; }
  .founder-card__content { padding: 1.55rem; }
  .principles, .capability-list { grid-template-columns: 1fr; }
  .approach-modal { width: 100vw; max-height: 100svh; }
  .approach-modal__panel { max-height: 100svh; border-radius: 0; }
  .approach-modal__actions { flex-direction: column-reverse; }
  .approach-modal__primary, .approach-modal__secondary { width: 100%; }
  .principles article { border-right: 0; border-bottom: 1px solid var(--line); }
  .capability-list li, .capability-list li:nth-child(2) { min-height: 18rem; border-right: 0; border-bottom: 1px solid rgba(255,255,255,.2); }
  .capability-list h3 { margin-top: 4rem; }
  .footer { align-items: start; gap: 2rem; grid-template-columns: 1fr; }
  .footer p:nth-child(2), .footer p:last-child { text-align: left; }
}
