:root {
  /* --blue: #5499ed; */
  --blue: #608A8A;/*#49a6ab;*/
  --dark: #3b3837;/*222222;*/
  --cream: #efe9e2;

  --max: 1120px;
  --radius: 18px;

  --ink-on-dark: var(--cream);
  --ink-on-blue: var(--cream);
  --ink-on-cream: var(--dark);

  --gutter: max(20px, calc((100vw - var(--max)) / 2));
  --pad: clamp(24px, 4vw, 56px);
  --panel-y: clamp(278px, 7.5vw, 124px);
  --swoosh-h: clamp(18px, 3vw, 444px);
  --swoosh-ratio: 25.805;
  --swoosh-overlap: 2px;
  --swoosh-mobile-width: 900px;
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
}

body {
  font-family: "Inter", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto;
  line-height: 1.25;
  background: var(--cream);
  color: var(--dark);
}

.legal {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.legal__header {
  max-width: 52rem;
  width: 100%;
  margin: 0 auto;
  padding: clamp(40px, 6vw, 72px) max(20px, 5vw) 22px;
}

.legal__back {
  display: inline-block;
  font-weight: 900;
  margin-bottom: 12px;
}

.legal__header h1 {
  margin: 0 0 8px;
  font-size: clamp(2.2rem, 3.4vw, 3.2rem);
  letter-spacing: -0.02em;
}

.legal__updated {
  margin: 0;
  opacity: 0.7;
  font-weight: 800;
}

.legal__section {
  max-width: 52rem;
  width: 100%;
  margin: 0 auto;
  padding: 0 max(20px, 5vw) 18px;
}

.legal__section h2 {
  margin: 22px 0 10px;
  font-size: 1.25rem;
  letter-spacing: -0.01em;
}

.legal__section p,
.legal__section li {
  font-size: 1.05rem;
  line-height: 1.5;
}

.legal__section ul {
  margin: 0;
  padding-left: 1.05rem;
}

a {
  color: inherit;
  text-decoration: none;
}

a:hover,
a:focus-visible {
  text-decoration: underline;
}

.legal__section a,
.feedback-note a {
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 0.14em;
}

.email-link__link {
  color: inherit;
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 0.14em;
}

.hero {
  padding: clamp(64px, 9vw, 120px) var(--gutter) clamp(48px, 7vw, 88px);
  background: var(--cream);
}

.hero__inner {
  max-width: 56rem;
  margin: 0 auto;
  text-align: center;
}

.hero__wordmark {
  margin: 0 0 22px;
}

.hero__logo {
  width: min(380px, 88vw);
  height: auto;
  display: block;
  margin: 0 auto;
}

.hero__tagline {
  max-width: 44ch;
  font-size: clamp(1.2rem, 2vw, 1.55rem);
  line-height: 1.25;
  margin: 0 auto;
}

.actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 22px;
  justify-content: center;
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 18px;
  border-radius: 12px;
  border: 2px solid transparent;
  font-weight: 600;
  letter-spacing: 0.01em;
  text-decoration: none;
  line-height: 1;
}

.button:hover,
.button:focus-visible {
  text-decoration: none;
  transform: translateY(-1px);
}

.button--blue {
  background: var(--blue);
  border-color: var(--blue);
  color: var(--ink-on-blue);
}

.button--dark {
  background: var(--dark);
  border-color: var(--dark);
  color: var(--ink-on-dark);
}

.button--cream {
  background: var(--cream);
  border-color: var(--cream);
  color: var(--dark);
}

.panel {
  width: 100%;
  position: relative;
  overflow: hidden;
  z-index: 0;
}

.panel__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
  align-items: stretch;
  position: relative;
}

.panel__text {
  position: relative;
  z-index: 3;
  padding-left: var(--gutter);
  padding-right: var(--pad);
  padding-top: var(--panel-y);
  padding-bottom: var(--panel-y);
}

.panel__text h2 {
  font-size: clamp(2.2rem, 3.4vw, 3.3rem);
  line-height: 1.02;
  letter-spacing: -0.02em;
  margin: 0 0 14px;
}

.panel__text p {
  font-size: clamp(1.1rem, 1.6vw, 1.35rem);
  line-height: 1.35;
  margin: 0 0 14px;
  max-width: 48ch;
}

.panel__media {
  position: relative;
  z-index: 1;
  height: 100%;
  min-height: 500px;
}

.panel__img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
}

.panel__media--parallax {
  overflow: hidden;
  --parallax-bleed: clamp(44px, 7vw, 80px);
}

.panel__img--parallax {
  position: absolute;
  inset: 50% 0 auto;
  height: calc(100% + (var(--parallax-bleed) * 2));
  border-radius: 0;
  transform: translate3d(0, calc(-50% + var(--parallax-shift, 0px)), 0) scale(1.1);
  will-change: transform;
}

.panel--blue {
  background: var(--blue);
  color: var(--ink-on-blue);
  --swoosh-top-color: var(--cream);
  --swoosh-bottom-color: var(--dark);
}

#about.panel--blue {
  --swoosh-top-color: var(--dark);
  --swoosh-bottom-color: var(--cream);
}

.panel--blue .button--cream {
  border-color: rgba(246, 241, 230, 0.85);
}

.panel--blue .panel__img {
  border-radius: var(--radius) 0 0 var(--radius);
}

.panel--blue .panel__media--parallax {
  border-radius: var(--radius) 0 0 var(--radius);
}

.panel--dark {
  background: var(--dark);
  color: var(--ink-on-dark);
  --swoosh-top-color: var(--blue);
  --swoosh-bottom-color: var(--cream);
}

.panel--dark .panel__img {
  border-radius: 0 var(--radius) var(--radius) 0;
}

.panel--dark .panel__media--parallax {
  border-radius: 0 var(--radius) var(--radius) 0;
}

.panel--dark .button--cream {
  border-color: rgba(246, 241, 230, 0.85);
}

.panel--cream {
  background: var(--cream);
  color: var(--ink-on-cream);
  --swoosh-top-color: var(--dark);
  --swoosh-bottom-color: var(--dark);
}

.panel--cream .panel__img {
  border-radius: var(--radius) 0 0 var(--radius);
}

.panel--cream .panel__media--parallax {
  border-radius: var(--radius) 0 0 var(--radius);
}

.panel--flip .panel__grid {
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
}

.panel--flip .panel__text {
  padding-left: var(--pad);
  padding-right: var(--gutter);
}

#about {
  --panel-y: clamp(104px, 7vw, 144px);
}

#about .panel__media {
  min-height: 540px;
}

.final-cta {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  overflow: hidden;
  background: var(--cream);
  color: var(--dark);
  --swoosh-top-color: var(--blue);
  --swoosh-bottom-color: var(--dark);
  --swoosh-bleed: var(--gutter);
  padding: clamp(72px, 8vw, 110px) var(--gutter);
}

.final-cta__inner {
  max-width: 56rem;
  position: relative;
  z-index: 1;
  width: 100%;
}

.final-cta h2 {
  margin: 0 0 10px;
  font-size: clamp(2.5rem, 4vw, 3.6rem);
  line-height: 1.02;
  letter-spacing: -0.02em;
  text-align: center;
}

.final-cta p {
  margin: 0;
  font-size: 1.25rem;
  line-height: 1.3;
}

.tiers {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  width: min(100%, 42rem);
  margin: 22px auto 0;
}

.tier {
  position: relative;
  border-radius: var(--radius);
  padding: 22px 20px 20px;
  background: var(--cream);
  color: var(--dark);
  border: 0;
  display: flex;
  flex-direction: column;
}

.tier__name {
  margin: 0 0 12px;
  font-size: 1.15rem;
  letter-spacing: -0.02em;
  text-align: center;
}

.tier__list {
  margin: 0;
  padding-left: 1.05rem;
  font-size: 1.05rem;
  line-height: 1.45;
}

.tier__actions {
  margin-top: auto;
  padding-top: 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.tier__version {
  margin: 0;
  font-size: 1rem;
  line-height: 1.3;
  font-weight: 400;
}

.feedback-note {

  text-align: center;
  margin-top: 20px;
  width: 100%;
  max-width: 36rem;
  margin-left: auto;
  margin-right: auto;
  border-radius: var(--radius);
  background: rgba(239, 233, 226, 0.13);
  border: 1px solid rgba(239, 233, 226, 0.3);
  padding: 18px 20px;
}

.feedback-note h3 {
  margin: 0 0 10px;
  font-size: 1.25rem;
  letter-spacing: -0.01em;
}

.feedback-note p {
  font-size: 1.05rem;
}

.feedback-note p + p {
  margin-top: 10px;
}

.footer {
  padding: 28px var(--gutter);
  background: var(--dark);
  color: rgba(246, 241, 230, 0.82);
  font-weight: 300;
  font-size: 0.95rem;
  text-align: center;
}

.footer p {
  margin: 0;
}

.footer__links {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px 14px;
  margin-top: 12px;
  font-weight: 400;
}

.footer__links a,
.footer__links a:hover,
.footer__links a:focus-visible {
  color: rgba(246, 241, 230, 0.92);
  font-size: 0.85rem;
  text-decoration: none;
}

.swoosh-defs {
  position: absolute;
  width: 0;
  height: 0;
  overflow: hidden;
}

.swoosh {
  position: absolute;
  left: 50%;
  z-index: 2;
  pointer-events: none;
  width: calc(100% + (var(--swoosh-bleed, 0px) * 2) + (var(--swoosh-overlap) * 2));
  height: calc(var(--swoosh-h) + var(--swoosh-overlap));
  display: block;
  margin-left: 0;
  transform: translateX(-50%);
  shape-rendering: geometricPrecision;
}

.swoosh--top {
  top: calc(var(--swoosh-overlap) * -1);
  transform: translateX(-50%) scaleY(-1);
  color: var(--swoosh-top-color, var(--cream));
}

.swoosh--bottom {
  bottom: calc(var(--swoosh-overlap) * -1);
  color: var(--swoosh-bottom-color, var(--dark));
}

#workflow {
  --panel-y: 210px;
}

#philosophy {
  --panel-y: 210px;
}

#philosophy .panel__media {
  display: flex;
  align-items: center;
  justify-content: center;
}

#philosophy .panel__img {
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  border-radius: var(--radius);
}

@media (min-width: 901px) {
  #philosophy .panel__media {
    padding: clamp(100px, 4vw, 320px);
  }
}

@media (max-width: 900px) {
  .tiers {
    grid-template-columns: 1fr;
  }

  .panel__grid,
  .panel--flip .panel__grid {
    grid-template-columns: 1fr;
  }

  .panel__text,
  .panel--flip .panel__text {
    padding-left: max(20px, 5vw);
    padding-right: max(20px, 5vw);
    padding-top: 54px;
    padding-bottom: 22px;
  }

  .panel__media {
    min-height: 340px;
  }

  .panel__media--parallax {
    --parallax-bleed: 40px;
  }

  .panel--blue .panel__img,
  .panel--dark .panel__img,
  .panel--cream .panel__img {
    border-radius: 0;
  }

  .panel--blue .panel__media--parallax,
  .panel--dark .panel__media--parallax,
  .panel--cream .panel__media--parallax {
    border-radius: 0;
  }

  .swoosh {
    width: calc(var(--swoosh-mobile-width) + (var(--swoosh-bleed, 0px) * 2) + (var(--swoosh-overlap) * 2));
    height: calc((var(--swoosh-mobile-width) / var(--swoosh-ratio)) + var(--swoosh-overlap));
  }
}
