@charset "UTF-8";
:root {
  --color__text: #1a1a1a;
  --color__accent: #e85d26;
  --color__bg: #ffffff;
  --color__muted: #666666;
  --color__border: #e8e8e8;
  --font__futura: 'Futura-PT', 'Futura', 'Century Gothic', 'Helvetica', 'Arial', sans-serif;
  --font__inter: 'Inter', 'Helvetica Neue', Helvetica, Arial, sans-serif;
  --font__palatino: 'Palatino', 'Palatino Linotype', 'Book Antiqua', Georgia, serif;
  --font__helvetica: 'Helvetica Neue', Helvetica, Arial, sans-serif;
  --font__mono: 'Courier New', monospace;
  --font-role__body: var(--font__inter);
  --font-role__heading: var(--font__futura);
  --font-role__article: var(--font__palatino);
  --font-role__summary: var(--font__inter);
  --font-role__meta: var(--font__helvetica);
  --font-role__input: var(--font__inter);
  --font-role__button: var(--font__futura);
  --text--xxs: clamp(0.5787rem, calc(0.2894vw + 0.5208rem), 0.6510rem);
  --text--xs: clamp(0.6944rem, calc(0.3472vw + 0.6250rem), 0.7813rem);
  --text--s: clamp(0.8333rem, calc(0.4167vw + 0.7500rem), 0.9375rem);
  --text--m: clamp(1.0000rem, calc(0.5000vw + 0.9000rem), 1.1250rem);
  --text--l: clamp(1.2000rem, calc(0.6000vw + 1.0800rem), 1.3500rem);
  --text--xl: clamp(1.4400rem, calc(0.7200vw + 1.2960rem), 1.6200rem);
  --text--xxl: clamp(1.7280rem, calc(0.8640vw + 1.5552rem), 1.9440rem);
  --heading--1: clamp(2.187500rem, calc(10.303906vw + 0.126719rem), 4.763477rem);
  --heading--2: clamp(1.752600rem, calc(6.130224vw + 0.526556rem), 3.285156rem);
  --heading--3: clamp(1.404164rem, calc(3.445846vw + 0.714994rem), 2.265625rem);
  --heading--4: clamp(1.125000rem, calc(1.750000vw + 0.775000rem), 1.562500rem);
  --heading--5: calc(var(--text--m) + 0.125rem); /* body + 2px optical compensation for Futura vs Inter */
  --space--xxs: clamp(0.5277rem, calc(-0.2591vw + 0.5796rem), 0.4630rem);
  --space--xs: clamp(0.7035rem, calc(-0.0361vw + 0.7107rem), 0.6944rem);
  --space--s: clamp(0.9377rem, calc(0.4157vw + 0.8546rem), 1.0417rem);
  --space--m: clamp(1.2500rem, calc(1.2500vw + 1.0000rem), 1.5625rem);
  --space--l: clamp(1.6663rem, calc(2.7100vw + 1.1242rem), 2.3438rem);
  --space--xl: clamp(2.2211rem, calc(5.1781vw + 1.1855rem), 3.5156rem);
  --space--xxl: clamp(2.9607rem, calc(9.2508vw + 1.1106rem), 5.2734rem);
  --logo__width: 72px;
  --logo__height: 105px;
  --gap__container: var(--space--m);
  --gap__section: var(--space--xl);
  --gap__grid: var(--space--m);
  --gap__article: var(--gap__container);
  --space__gutter: var(--space--m);
  --section__padding-block: var(--space--xxl);
  --hr__height: 6px;
  --hr__color: color-mix(in oklch, oklch(0.8 0 180) 70%, transparent);
  --grid__row--pad-top: var(--space--s);
  --grid__row--nav: 59px;
  --grid__row--hr: var(--hr__height);
  --header__height: calc(var(--grid__row--pad-top) + var(--grid__row--nav) + var(--grid__row--hr));
  --grid__template--rows:
    var(--grid__row--pad-top)
    var(--grid__row--nav)
    var(--grid__row--hr);
  --border__width: 1px;
  --border__width--thick: 1.5px;
  --border__radius--s: 3px;
  --border__radius--m: 4px;
  --duration--fast: 0.15s;
  --duration--normal: 0.2s;
  --easing--default: ease;
  --z__logo: 85;
  --z__cta: 72;
  --z__nav: 71;
  --z__mobile-menu: 30;
  --z__hero: 20;
  --z__hr: 10;
  --z__body: 0;
}

@font-face {
  font-family: "Futura-PT";
  src: url("/assets/fonts/futura-light.woff2") format("woff2");
  font-weight: 300;
  font-style: normal;
  font-display: block;
}
@font-face {
  font-family: "Futura-PT";
  src: url("/assets/fonts/futura-book.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: block;
}
@font-face {
  font-family: "Futura-PT";
  src: url("/assets/fonts/futura-medium.woff2") format("woff2");
  font-weight: 500;
  font-style: normal;
  font-display: block;
}
@font-face {
  font-family: "Futura-PT";
  src: url("/assets/fonts/futura-demi.woff2") format("woff2");
  font-weight: 600;
  font-style: normal;
  font-display: block;
}
@font-face {
  font-family: "Futura-PT";
  src: url("/assets/fonts/futura-heavy.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: block;
}
@font-face {
  font-family: "Palatino";
  src: url("/assets/fonts/palatino-normal.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: block;
}
@font-face {
  font-family: "Palatino";
  src: url("/assets/fonts/palatino-italic.woff2") format("woff2");
  font-weight: 400;
  font-style: italic;
  font-display: block;
}
@font-face {
  font-family: "Palatino";
  src: url("/assets/fonts/palatino-bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: block;
}
@font-face {
  font-family: "Palatino";
  src: url("/assets/fonts/palatino-bold-italic.woff2") format("woff2");
  font-weight: 700;
  font-style: italic;
  font-display: block;
}
@font-face {
  font-family: "Inter";
  src: url("/assets/fonts/inter-regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: block;
}
@font-face {
  font-family: "Inter";
  src: url("/assets/fonts/inter-medium.woff2") format("woff2");
  font-weight: 500;
  font-style: normal;
  font-display: block;
}
@font-face {
  font-family: "Inter";
  src: url("/assets/fonts/inter-semibold.woff2") format("woff2");
  font-weight: 600;
  font-style: normal;
  font-display: block;
}
@font-face {
  font-family: "Inter";
  src: url("/assets/fonts/inter-bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: block;
}
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 100%;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--font-role__body);
  font-size: var(--text--m);
  color: var(--color__text);
  background: var(--color__bg);
  line-height: calc(6px + 2ex);
}

:root {
  --grid__col--content: 750px;
  --grid__col--wide: 100px;
  --grid__col--logo: 68px; /* space after logo right edge */
  --grid__col--body: 72px; /* = logo width; logo left edge aligns to body-start */
  --grid__template--cols:
    [full-start] minmax(var(--space__gutter), 1fr)
    [body-start] var(--grid__col--body)
    [logo-start] var(--grid__col--logo)
    [wide-start] var(--grid__col--wide)
    [content-start] var(--grid__col--content)
    [content-end] var(--grid__col--wide)
    [wide-end] var(--grid__col--logo)
    [logo-end] var(--grid__col--body)
    [body-end] minmax(var(--space__gutter), 1fr)
    [full-end];
}

section,
header,
footer {
  display: grid;
  grid-template-columns: var(--grid__template--cols);
}

section > * {
  grid-column: content-start/content-end;
}

.grid__content {
  grid-column: content-start/content-end;
}

.grid__logo {
  grid-column: logo-start/logo-end;
}

.grid__wide {
  grid-column: wide-start/wide-end;
}

.grid__body {
  grid-column: body-start/body-end;
}

.grid__full {
  grid-column: full-start/full-end;
}

header {
  z-index: var(--z__nav);
  background: rgba(255, 255, 255, 0.92);
  overflow: visible;
  grid-template-rows: var(--grid__template--rows);
}

.header__logo-wrap {
  grid-column: body-start/logo-start;
  grid-row: 2/-1;
  position: relative;
  z-index: var(--z__logo);
}

.header__logo {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  text-decoration: none;
}
.header__logo .logo--sg {
  width: var(--logo__width);
  height: var(--logo__height);
  fill: none;
  stroke: var(--color__accent);
  stroke-width: 90;
}

header hr.header__hr--right {
  grid-column: body-end/full-end;
  grid-row: 3;
  height: var(--grid__row--hr);
  background: var(--hr__color);
  border: none;
  margin: 0;
  z-index: var(--z__hr);
}

header hr.header__hr--left {
  grid-column: full-start/body-start;
  grid-row: 3;
  height: var(--grid__row--hr);
  background: var(--hr__color);
  border: none;
  margin: 0;
  z-index: var(--z__hr);
}

header hr.header__hr {
  grid-column: logo-start/body-end;
  grid-row: 3;
  height: var(--grid__row--hr);
  background: var(--hr__color);
  border: none;
  margin: 0;
  z-index: var(--z__hr);
}

a:has(h1, h2, h3, h4, h5, h6) :is(h1, h2, h3, h4, h5, h6),
header nav li a {
  text-decoration: underline;
  text-decoration-color: transparent;
  text-decoration-thickness: clamp(2px, 0.08em, 6px);
  text-underline-offset: clamp(4px, 0.12em, 9px);
  transition: text-decoration-color 0.25s var(--easing--default);
}

a:has(h1, h2, h3, h4, h5, h6):hover :is(h1, h2, h3, h4, h5, h6),
header nav li a:hover,
header nav li a.nav__link--active {
  text-decoration-color: var(--color__accent);
}

header nav {
  grid-column: body-start/body-end;
  grid-row: 2;
  justify-self: center;
  align-self: center;
  z-index: var(--z__nav);
}
header nav ul {
  list-style: none;
  display: flex;
  align-items: center;
  gap: var(--space--l);
  margin: 0;
  padding: 0;
}
header nav a {
  font-family: var(--font-role__heading);
  font-size: var(--heading--5);
  font-weight: 500;
  letter-spacing: 0;
  color: var(--color__text);
}

.header__cta {
  grid-column: body-start/body-end;
  grid-row: 2;
  justify-self: end;
  align-self: center;
  z-index: var(--z__cta);
  font-family: var(--font-role__heading);
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 0;
  text-transform: capitalize;
  text-decoration: none;
  color: var(--color__text);
  border: 1.5px solid var(--color__text);
  padding: 0.4rem 0.9rem;
  white-space: nowrap;
  transition: all var(--duration--fast) var(--easing--default);
}
.header__cta:hover {
  background: var(--color__text);
  color: var(--color__bg);
}

.nav__toggle {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: var(--space--xs);
}

.nav__toggle-icon {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--color__text);
  position: relative;
  transition: background var(--duration--fast) var(--easing--default);
}
.nav__toggle-icon::before, .nav__toggle-icon::after {
  content: "";
  display: block;
  width: 22px;
  height: 2px;
  background: var(--color__text);
  position: absolute;
  left: 0;
  transition: transform var(--duration--fast) var(--easing--default);
}
.nav__toggle-icon::before {
  top: -7px;
}
.nav__toggle-icon::after {
  top: 7px;
}

article {
  display: flex;
  flex-direction: column;
  gap: var(--gap__article);
}

main { /* sections manage their own vertical rhythm */ }

.page__section {
  padding-block: var(--section__padding-block);
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-role__heading);
  font-weight: 600;
  line-height: calc(6px + 2ex);
  letter-spacing: -0.01em;
}

h1, h2, h3, h4, h5 {
  margin-block-start: 0.5em;
}

h1 {
  font-size: var(--heading--1);
  margin-bottom: var(--space--m);
}

h2 {
  font-size: var(--heading--2);
  margin: var(--space--l) 0 var(--space--m);
}

h3 {
  font-size: var(--heading--3);
  margin: var(--space--l) 0 var(--space--m);
}

h4 {
  font-size: var(--heading--4);
  margin: var(--space--m) 0 var(--space--s);
}

h5 {
  font-size: var(--text--xs);
  margin: var(--space--m) 0 var(--space--s);
}

h6 {
  font-size: var(--text--xs);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color__muted);
  margin: var(--space--m) 0 var(--space--s);
}

body :where(p, h1, h2, h3, h4, h5, h6, ul, ol, li) {
  margin-block: 0;
}

a {
  color: var(--color__accent);
  text-decoration: none;
}

strong {
  font-weight: 700;
}

em {
  font-style: italic;
}

:where(main, footer, article) ul,
:where(main, footer, article) ol {
  margin: 0 0 var(--space--m) 0;
  padding-left: 2.3rem;
}
:where(main, footer, article) ul li,
:where(main, footer, article) ol li {
  margin-bottom: 0.35rem;
}

blockquote {
  border-left: 3px solid var(--color__border);
  margin: var(--space--l) 0;
  padding: 0 0 0 var(--space--l);
  color: var(--color__text);
  font-family: var(--font-role__heading);
  font-size: 24px;
  font-weight: 600;
  font-style: normal;
  line-height: calc(6px + 2ex);
}

blockquote + p > em:only-child {
  display: block;
  font-style: normal;
  color: var(--color__muted);
  margin-block-start: calc(var(--gap__container) * -0.5);
}

code {
  font-family: var(--font__mono);
  font-size: 0.85em;
  background: #f4f4f4;
  padding: 0.15em 0.35em;
  border-radius: var(--border__radius--s);
}

pre {
  background: #f4f4f4;
  padding: var(--space--m) var(--space--l);
  overflow-x: auto;
  margin-bottom: var(--space--m);
  border-radius: var(--border__radius--m);
}
pre code {
  background: none;
  padding: 0;
}

hr {
  border: none;
  border-top: var(--border__width) solid var(--color__border);
  margin: var(--space--xl) 0;
}

.post__date {
  font-family: var(--font-role__meta);
  font-size: var(--text--xxs);
  font-weight: 400;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color__muted);
  margin-bottom: var(--space--xl);
  display: block;
}

.post-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.post-list__item {
  padding: var(--space--l) 0;
  border-bottom: var(--border__width) solid var(--color__border);
}
.post-list__item:first-child {
  border-top: var(--border__width) solid var(--color__border);
}

.post-list__link {
  color: var(--color__text);
}
.post-list__link h3 {
  margin: 0;
}

.post-list__date {
  display: block;
  font-family: var(--font-role__meta);
  font-size: var(--text--xxs);
  font-weight: 400;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color__muted);
  margin-bottom: var(--space--s);
}

.post-list__excerpt {
  font-family: var(--font-role__summary);
  color: var(--color__muted);
  margin-bottom: 0;
}

footer {
  border-top: var(--border__width) solid var(--color__border);
  margin-top: var(--space--xxl);
  padding-top: var(--space--xl);
  padding-bottom: var(--space--xl);
}

.footer__inner {
  grid-column: body-start/body-end;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space--m);
}

.footer__copy {
  font-family: var(--font-role__meta);
  font-size: var(--text--xxs);
  font-weight: 400;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color__muted);
  margin: 0;
}

.footer__nav {
  display: flex;
  gap: var(--space--l);
}
.footer__nav a {
  font-family: var(--font-role__meta);
  font-size: var(--text--xxs);
  font-weight: 400;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color__muted);
  transition: color var(--duration--fast) var(--easing--default);
}
.footer__nav a:hover {
  color: var(--color__accent);
}

.hero__label {
  font-family: var(--font-role__meta);
  font-size: var(--text--xxs);
  font-weight: 400;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color__muted);
  margin-bottom: var(--space--l);
}

.hero__headline {
  font-size: clamp(2rem, 5vw, var(--heading--1));
  color: var(--color__text);
  max-width: 16ch;
}

.hero__sub {
  font-family: var(--font-role__article);
  font-size: var(--text--m);
  line-height: 1.65;
  color: var(--color__muted);
  max-width: 44ch;
  margin-bottom: var(--space--xl);
}

.signup {
  display: flex;
  gap: var(--space--s);
  flex-wrap: wrap;
  margin-bottom: var(--space--m);
  container-type: inline-size;
  container-name: signup;
}

.signup__input {
  font-family: var(--font-role__input);
  font-size: var(--text--m);
  padding: 0.75rem var(--space--m);
  border: var(--border__width--thick) solid var(--color__border);
  background: var(--color__bg);
  color: var(--color__text);
  flex: 1 1 auto;
  min-width: 0;
  outline: none;
  transition: border-color var(--duration--fast) var(--easing--default);
}
.signup__input:focus {
  border-color: var(--color__accent);
}

.signup__button {
  font-family: var(--font-role__button);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: var(--color__accent);
  color: #fff;
  border: none;
  padding: 0.75rem var(--space--l);
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  transition: opacity var(--duration--fast) var(--easing--default);
}
.signup__button:hover {
  opacity: 0.85;
}

@container signup (max-width: 420px) {
  .signup__input,
  .signup__button {
    flex: 1 1 100%;
    width: 100%;
  }
}
.signup__note {
  font-family: var(--font-role__meta);
  font-size: var(--text--xxs);
  font-weight: 400;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color__muted);
  letter-spacing: 0.06em;
  margin-bottom: 0;
}

.posts-recent {
  padding-top: var(--space--xxl);
  padding-bottom: var(--space--xxl);
}

.posts-recent__label {
  font-family: var(--font-role__meta);
  font-size: var(--text--xxs);
  font-weight: 400;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color__muted);
  margin-bottom: var(--space--xl);
}

.posts-recent__list {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space--xl);
}

.posts-recent__item {
  border-top: var(--border__width) solid var(--color__border);
  padding: var(--space--m) 0;
}
.posts-recent__item:last-child {
  border-bottom: var(--border__width) solid var(--color__border);
}

.posts-recent__link {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--space--m);
  text-decoration: none;
  color: var(--color__text);
}
.posts-recent__link:hover .posts-recent__title {
  color: var(--color__accent);
}

.posts-recent__title {
  font-family: var(--font-role__heading);
  font-size: var(--text--s);
  font-weight: 500;
  transition: color var(--duration--fast) var(--easing--default);
}

.posts-recent__date {
  font-family: var(--font-role__meta);
  font-size: var(--text--xxs);
  font-weight: 400;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color__muted);
  letter-spacing: 0.06em;
  white-space: nowrap;
  flex-shrink: 0;
}

.posts-recent__all {
  font-family: var(--font-role__heading);
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 0;
  text-transform: capitalize;
  text-decoration: none;
  color: var(--color__accent);
}
.posts-recent__all:hover {
  text-decoration: underline;
}

@media (max-width: 680px) {
  :root {
    --grid__template--cols:
      [full-start] var(--space__gutter)
      [body-start] var(--logo__width)
      [logo-start wide-start content-start] 1fr
      [content-end wide-end logo-end body-end] var(--space__gutter)
      [full-end];
  }
  .grid__content,
  .grid__wide,
  .grid__body {
    grid-column: body-start/body-end;
  }
}
@media (max-width: 680px) {
  html {
    font-size: 16px;
  }
  header nav ul {
    display: none;
  }
  .header__cta {
    display: none;
  }
  .nav__toggle {
    display: block;
  }
  header nav {
    justify-self: end;
    padding: 0;
  }
  .footer__inner {
    flex-direction: column;
    align-items: flex-start;
  }
}
body.nav-open .nav__toggle-icon {
  background: transparent;
}
body.nav-open .nav__toggle-icon::before {
  top: 0;
  transform: rotate(45deg);
}
body.nav-open .nav__toggle-icon::after {
  top: 0;
  transform: rotate(-45deg);
}

.nav__overlay {
  display: none;
  position: fixed;
  top: var(--header__height);
  left: 0;
  right: 0;
  bottom: 0;
  background: var(--color__bg);
  z-index: 999;
  flex-direction: column;
  padding: var(--space--xl) var(--space--l);
  overflow-y: auto;
}

.nav__overlay-links {
  list-style: none;
  padding: 0;
  margin: 0;
  flex: 1;
}

.nav__overlay-link {
  display: block;
  font-family: var(--font-role__heading);
  font-size: 1.1rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color__text);
  text-decoration: none;
  padding: var(--space--m) 0;
  border-bottom: var(--border__width) solid var(--color__border);
  transition: color var(--duration--fast) var(--easing--default);
}
.nav__overlay-link:hover {
  color: var(--color__accent);
}

.nav__overlay-links li:last-child .nav__overlay-link {
  border-bottom: none;
}

.nav__overlay-cta {
  display: block;
  font-family: var(--font-role__button);
  font-size: 0.85rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: center;
  text-decoration: none;
  background: var(--color__text);
  color: var(--color__bg);
  padding: var(--space--m) var(--space--l);
  margin-top: var(--space--xl);
  margin-bottom: env(safe-area-inset-bottom);
  transition: opacity var(--duration--fast) var(--easing--default);
}
.nav__overlay-cta:hover {
  opacity: 0.85;
}

body.nav-open .nav__overlay {
  display: flex;
}

.callout {
  display: flex;
  gap: var(--space--m);
  background: #f8f8f8;
  border-left: 3px solid var(--color__accent);
  border-radius: var(--border__radius--m);
  padding: var(--space--m) var(--space--l);
  margin-bottom: var(--space--m);
}
.callout__icon {
  font-size: 1.2rem;
  line-height: 1.15;
  flex-shrink: 0;
}
.callout__body p {
  margin-bottom: 0;
}

.toggle {
  border-bottom: var(--border__width) solid var(--color__border);
  margin-bottom: var(--space--s);
}
.toggle__summary {
  font-family: var(--font-role__heading);
  font-size: var(--text--m);
  font-weight: 500;
  cursor: pointer;
  padding: var(--space--m) 0;
  list-style: none;
  display: flex;
  align-items: center;
  gap: var(--space--s);
  transition: color var(--duration--fast) var(--easing--default);
}
.toggle__summary:hover {
  color: var(--color__accent);
}
.toggle__summary::before {
  content: "▶";
  font-size: 0.6em;
  transition: transform var(--duration--fast) var(--easing--default);
}
.toggle[open] .toggle__summary::before {
  transform: rotate(90deg);
}
.toggle__body {
  padding: 0 0 var(--space--m) var(--space--xl);
  color: var(--color__muted);
}

.todo-list {
  list-style: none;
  margin: 0 0 var(--space--m);
  padding: 0;
}
.todo-list__item {
  display: flex;
  align-items: baseline;
  gap: var(--space--s);
  padding: var(--space__2xs) 0;
}
.todo-list__item input[type=checkbox] {
  flex-shrink: 0;
  accent-color: var(--color__accent);
  width: 1em;
  height: 1em;
  cursor: default;
}
.todo-list__item--done span {
  color: var(--color__muted);
  text-decoration: line-through;
}

figure {
  margin: var(--space--l) 0;
  display: block;
}
figure img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--border__radius--m);
}
figure figcaption {
  font-family: var(--font-role__heading);
  font-size: var(--text--xxs);
  letter-spacing: 0.06em;
  color: var(--color__muted);
  margin-top: var(--space--s);
  text-align: center;
}
figure--video video {
  width: 100%;
  border-radius: var(--border__radius--m);
}

.bookmark {
  display: block;
  border: var(--border__width) solid var(--color__border);
  border-radius: var(--border__radius--m);
  padding: var(--space--m) var(--space--l);
  margin-bottom: var(--space--m);
  text-decoration: none;
  color: var(--color__text);
  transition: all var(--duration--fast) var(--easing--default);
}
.bookmark:hover {
  border-color: var(--color__accent);
  text-decoration: none;
}
.bookmark__url {
  font-family: var(--font-role__heading);
  font-size: var(--text--xs);
  letter-spacing: 0.06em;
  color: var(--color__muted);
  display: block;
  word-break: break-all;
}
.bookmark__caption {
  font-size: var(--text--m);
  font-weight: 500;
  margin-top: var(--space__2xs);
  display: block;
}

table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: var(--space--l);
  font-size: var(--text--s);
}
table th, table td {
  border: var(--border__width) solid var(--color__border);
  padding: var(--space--s) var(--space--m);
  text-align: left;
}
table th {
  font-family: var(--font-role__heading);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  font-size: var(--text--xxs);
  background: #f8f8f8;
}
table tr:nth-child(even) td {
  background: #fafafa;
}

.columns {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--space--l);
  margin-bottom: var(--space--l);
}
.columns__item {
  min-width: 0;
}

.color--gray {
  color: #787774;
}
.color--brown {
  color: #9F6B53;
}
.color--orange {
  color: #D9730D;
}
.color--yellow {
  color: #CB912F;
}
.color--green {
  color: #448361;
}
.color--blue {
  color: #337EA9;
}
.color--purple {
  color: #9065B0;
}
.color--pink {
  color: #C14C8A;
}
.color--red {
  color: #D44C47;
}
.color--gray_background {
  background: #F1F1EF;
  padding: 0.1em 0.3em;
}
.color--brown_background {
  background: #F4EEEE;
  padding: 0.1em 0.3em;
}
.color--orange_background {
  background: #FBECDD;
  padding: 0.1em 0.3em;
}
.color--yellow_background {
  background: #FBF3DB;
  padding: 0.1em 0.3em;
}
.color--green_background {
  background: #EDF3EC;
  padding: 0.1em 0.3em;
}
.color--blue_background {
  background: #E7F3F8;
  padding: 0.1em 0.3em;
}
.color--purple_background {
  background: #F6F3F9;
  padding: 0.1em 0.3em;
}
.color--pink_background {
  background: #FAF1F5;
  padding: 0.1em 0.3em;
}
.color--red_background {
  background: #FDEBEC;
  padding: 0.1em 0.3em;
}

.container {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: var(--gap__container);
}

section {
  padding-block: var(--section__padding-block);
}

section.alt {
  background: #f8f8f8;
}

section.hero {
  border-bottom: var(--border__width) solid var(--color__border);
}

main > section.hero:first-child,
main > section.alt:first-child {
  margin-top: calc(var(--header__height) * -1);
  padding-top: calc(var(--header__height) + var(--space--xxl));
}

.contact-form {
  display: flex;
  flex-direction: column;
  gap: var(--space--m);
}

.contact-form__field {
  display: flex;
  flex-direction: column;
  gap: var(--space--xs);
}

.contact-form__label {
  font-family: var(--font-role__heading);
  font-size: var(--heading--5);
  font-weight: 500;
  color: var(--color__text);
}

.contact-form__optional {
  font-weight: 400;
  color: var(--color__muted);
}

.contact-form__input,
.contact-form__textarea {
  font-family: var(--font-role__input);
  font-size: var(--text--m);
  padding: 0.5em 0.75em;
  border: var(--border__width) solid var(--color__border);
  border-radius: var(--border__radius--s);
  color: var(--color__text);
  background: var(--color__bg);
  width: 100%;
}
.contact-form__input:focus,
.contact-form__textarea:focus {
  outline: 2px solid var(--color__accent);
  outline-offset: 2px;
  border-color: var(--color__accent);
}

.contact-form__textarea {
  resize: vertical;
  min-height: 8em;
  line-height: var(--text--m);
}

.contact-form__button {
  font-family: var(--font-role__button);
  font-size: var(--text--m);
  font-weight: 600;
  padding: 0.5em 1.5em;
  background: var(--color__accent);
  color: #fff;
  border: none;
  border-radius: var(--border__radius--s);
  cursor: pointer;
  align-self: flex-start;
  transition: opacity var(--duration--fast) var(--easing--default);
}
.contact-form__button:hover {
  opacity: 0.85;
}
.contact-form__button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.contact-form__feedback {
  font-size: var(--text--s);
  color: var(--color__muted);
}

.signup {
  display: flex;
  flex-direction: column;
  gap: var(--space--s);
}

.signup__row {
  display: flex;
  gap: var(--space--xs);
  flex-wrap: wrap;
}

.signup__input {
  flex: 1 1 240px;
  font-family: var(--font-role__input);
  font-size: var(--text--m);
  padding: 0.5em 0.75em;
  border: var(--border__width) solid var(--color__border);
  border-radius: var(--border__radius--s);
  color: var(--color__text);
  background: var(--color__bg);
}
.signup__input:focus {
  outline: 2px solid var(--color__accent);
  outline-offset: 2px;
  border-color: var(--color__accent);
}

.signup__button {
  font-family: var(--font-role__button);
  font-size: var(--text--m);
  font-weight: 600;
  padding: 0.5em 1.25em;
  background: var(--color__accent);
  color: #fff;
  border: none;
  border-radius: var(--border__radius--s);
  cursor: pointer;
  white-space: nowrap;
  transition: opacity var(--duration--fast) var(--easing--default);
}
.signup__button:hover {
  opacity: 0.85;
}
.signup__button:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.signup__feedback {
  font-size: var(--text--s);
  color: var(--color__muted);
}

.btn {
  display: inline-flex;
  justify-content: center;
  font-family: var(--font-role__button);
  font-size: var(--text--m);
  font-weight: 500;
  text-decoration: none;
  color: var(--color__text);
  background: transparent;
  padding: 0.5em 0.75em;
  border: var(--border__width--thick) solid var(--color__text);
  border-radius: 100px;
  transition: background 0.2s ease-in-out, color 0.2s ease-in-out, opacity 0.2s ease-in-out;
}
.btn:hover {
  background: var(--color__text);
  color: var(--color__bg);
}

.figure--video,
.figure--embed {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.figure--video iframe,
.figure--video video,
.figure--embed iframe,
.figure--embed video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.grid-test {
  row-gap: var(--space--s);
}

.grid-test__zone {
  background: #f0f0f0;
  border-left: 3px solid var(--color__accent);
  padding: var(--space--s) var(--space--m);
  font-family: var(--font-role__meta);
  font-size: var(--text--xs);
  letter-spacing: 0.06em;
}
