/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */
@layer properties;
@layer theme, base, components, utilities;
@layer theme {
  :root, :host {
    --font-sans: 'Zen Kaku Gothic New', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', 'Yu Gothic', YuGothic, Meiryo, ui-sans-serif, system-ui, sans-serif;
    --font-serif: ui-serif, Georgia, Cambria, "Times New Roman", Times, serif;
    --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono",
      "Courier New", monospace;
    --color-red-50: oklch(97.1% 0.013 17.38);
    --color-red-200: oklch(88.5% 0.062 18.334);
    --color-red-500: oklch(63.7% 0.237 25.331);
    --color-red-600: oklch(57.7% 0.245 27.325);
    --color-red-700: oklch(50.5% 0.213 27.518);
    --color-orange-600: #c4521a;
    --color-green-500: oklch(72.3% 0.219 149.579);
    --color-gray-50: oklch(98.5% 0.002 247.839);
    --color-gray-100: oklch(96.7% 0.003 264.542);
    --color-gray-200: oklch(92.8% 0.006 264.531);
    --color-gray-400: oklch(70.7% 0.022 261.325);
    --color-gray-500: oklch(55.1% 0.027 264.364);
    --color-gray-600: oklch(44.6% 0.03 256.802);
    --color-gray-700: oklch(37.3% 0.034 259.733);
    --color-gray-900: oklch(21% 0.034 264.665);
    --color-black: #000;
    --color-white: #fff;
    --spacing: 0.25rem;
    --container-md: 28rem;
    --container-xl: 36rem;
    --container-2xl: 42rem;
    --container-3xl: 48rem;
    --container-4xl: 56rem;
    --container-5xl: 64rem;
    --container-7xl: 80rem;
    --text-xs: 0.75rem;
    --text-xs--line-height: calc(1 / 0.75);
    --text-sm: 0.875rem;
    --text-sm--line-height: calc(1.25 / 0.875);
    --text-base: 1rem;
    --text-base--line-height: calc(1.5 / 1);
    --text-lg: 1.125rem;
    --text-lg--line-height: calc(1.75 / 1.125);
    --text-xl: 1.25rem;
    --text-xl--line-height: calc(1.75 / 1.25);
    --text-2xl: 1.5rem;
    --text-2xl--line-height: calc(2 / 1.5);
    --text-3xl: 1.875rem;
    --text-3xl--line-height: calc(2.25 / 1.875);
    --text-4xl: 2.25rem;
    --text-4xl--line-height: calc(2.5 / 2.25);
    --text-6xl: 3.75rem;
    --text-6xl--line-height: 1;
    --text-7xl: 4.5rem;
    --text-7xl--line-height: 1;
    --text-9xl: 8rem;
    --text-9xl--line-height: 1;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --leading-tight: 1.25;
    --leading-snug: 1.375;
    --leading-relaxed: 1.625;
    --leading-loose: 2;
    --radius-sm: 0.25rem;
    --radius-lg: 0.5rem;
    --radius-xl: 0.75rem;
    --radius-2xl: 1rem;
    --ease-in: cubic-bezier(0.4, 0, 1, 1);
    --ease-out: cubic-bezier(0, 0, 0.2, 1);
    --animate-spin: spin 1s linear infinite;
    --blur-sm: 8px;
    --default-transition-duration: 150ms;
    --default-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    --default-font-family: var(--font-sans);
    --default-mono-font-family: var(--font-mono);
    --color-primary: #E8621A;
    --color-navy: #233654;
    --color-orange: #E8621A;
    --color-cream: #F7F4EF;
    --color-ink: #1A1A1A;
    --color-muted: #3a3a3a;
    --color-border: #DDD9D2;
  }
}
@layer base {
  *, ::after, ::before, ::backdrop, ::file-selector-button {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    border: 0 solid;
  }
  html, :host {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    font-family: var(--default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
    font-feature-settings: var(--default-font-feature-settings, normal);
    font-variation-settings: var(--default-font-variation-settings, normal);
    -webkit-tap-highlight-color: transparent;
  }
  hr {
    height: 0;
    color: inherit;
    border-top-width: 1px;
  }
  abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
  }
  h1, h2, h3, h4, h5, h6 {
    font-size: inherit;
    font-weight: inherit;
  }
  a {
    color: inherit;
    -webkit-text-decoration: inherit;
    text-decoration: inherit;
  }
  b, strong {
    font-weight: bolder;
  }
  code, kbd, samp, pre {
    font-family: var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);
    font-feature-settings: var(--default-mono-font-feature-settings, normal);
    font-variation-settings: var(--default-mono-font-variation-settings, normal);
    font-size: 1em;
  }
  small {
    font-size: 80%;
  }
  sub, sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
  }
  sub {
    bottom: -0.25em;
  }
  sup {
    top: -0.5em;
  }
  table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse;
  }
  :-moz-focusring {
    outline: auto;
  }
  progress {
    vertical-align: baseline;
  }
  summary {
    display: list-item;
  }
  ol, ul, menu {
    list-style: none;
  }
  img, svg, video, canvas, audio, iframe, embed, object {
    display: block;
    vertical-align: middle;
  }
  img, video {
    max-width: 100%;
    height: auto;
  }
  button, input, select, optgroup, textarea, ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    border-radius: 0;
    background-color: transparent;
    opacity: 1;
  }
  :where(select:is([multiple], [size])) optgroup {
    font-weight: bolder;
  }
  :where(select:is([multiple], [size])) optgroup option {
    padding-inline-start: 20px;
  }
  ::file-selector-button {
    margin-inline-end: 4px;
  }
  ::placeholder {
    opacity: 1;
  }
  @supports (not (-webkit-appearance: -apple-pay-button))  or (contain-intrinsic-size: 1px) {
    ::placeholder {
      color: currentcolor;
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, currentcolor 50%, transparent);
      }
    }
  }
  textarea {
    resize: vertical;
  }
  ::-webkit-search-decoration {
    -webkit-appearance: none;
  }
  ::-webkit-date-and-time-value {
    min-height: 1lh;
    text-align: inherit;
  }
  ::-webkit-datetime-edit {
    display: inline-flex;
  }
  ::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
  }
  ::-webkit-datetime-edit, ::-webkit-datetime-edit-year-field, ::-webkit-datetime-edit-month-field, ::-webkit-datetime-edit-day-field, ::-webkit-datetime-edit-hour-field, ::-webkit-datetime-edit-minute-field, ::-webkit-datetime-edit-second-field, ::-webkit-datetime-edit-millisecond-field, ::-webkit-datetime-edit-meridiem-field {
    padding-block: 0;
  }
  ::-webkit-calendar-picker-indicator {
    line-height: 1;
  }
  :-moz-ui-invalid {
    box-shadow: none;
  }
  button, input:where([type="button"], [type="reset"], [type="submit"]), ::file-selector-button {
    appearance: button;
  }
  ::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
    height: auto;
  }
  [hidden]:where(:not([hidden="until-found"])) {
    display: none !important;
  }
}
@layer utilities {
  .pointer-events-none {
    pointer-events: none;
  }
  .absolute {
    position: absolute;
  }
  .fixed {
    position: fixed;
  }
  .relative {
    position: relative;
  }
  .inset-0 {
    inset: calc(var(--spacing) * 0);
  }
  .start {
    inset-inline-start: var(--spacing);
  }
  .-top-4 {
    top: calc(var(--spacing) * -4);
  }
  .top-0 {
    top: calc(var(--spacing) * 0);
  }
  .top-1 {
    top: calc(var(--spacing) * 1);
  }
  .top-2\.5 {
    top: calc(var(--spacing) * 2.5);
  }
  .top-4 {
    top: calc(var(--spacing) * 4);
  }
  .top-24 {
    top: calc(var(--spacing) * 24);
  }
  .top-full {
    top: 100%;
  }
  .-right-4 {
    right: calc(var(--spacing) * -4);
  }
  .right-0 {
    right: calc(var(--spacing) * 0);
  }
  .right-1 {
    right: calc(var(--spacing) * 1);
  }
  .right-2\.5 {
    right: calc(var(--spacing) * 2.5);
  }
  .right-4 {
    right: calc(var(--spacing) * 4);
  }
  .right-8 {
    right: calc(var(--spacing) * 8);
  }
  .-bottom-2 {
    bottom: calc(var(--spacing) * -2);
  }
  .bottom-8 {
    bottom: calc(var(--spacing) * 8);
  }
  .-left-4 {
    left: calc(var(--spacing) * -4);
  }
  .left-0 {
    left: calc(var(--spacing) * 0);
  }
  .left-1\/2 {
    left: calc(1 / 2 * 100%);
  }
  .z-10 {
    z-index: 10;
  }
  .z-50 {
    z-index: 50;
  }
  .z-\[1\] {
    z-index: 1;
  }
  .z-\[2\] {
    z-index: 2;
  }
  .z-\[9999\] {
    z-index: 9999;
  }
  .col-span-2 {
    grid-column: span 2 / span 2;
  }
  .container {
    width: 100%;
    @media (width >= 40rem) {
      max-width: 40rem;
    }
    @media (width >= 48rem) {
      max-width: 48rem;
    }
    @media (width >= 64rem) {
      max-width: 64rem;
    }
    @media (width >= 80rem) {
      max-width: 80rem;
    }
    @media (width >= 96rem) {
      max-width: 96rem;
    }
  }
  .m-0 {
    margin: calc(var(--spacing) * 0);
  }
  .-mx-6 {
    margin-inline: calc(var(--spacing) * -6);
  }
  .mx-0 {
    margin-inline: calc(var(--spacing) * 0);
  }
  .mx-auto {
    margin-inline: auto;
  }
  .-mt-10 {
    margin-top: calc(var(--spacing) * -10);
  }
  .mt-0\.5 {
    margin-top: calc(var(--spacing) * 0.5);
  }
  .mt-1 {
    margin-top: calc(var(--spacing) * 1);
  }
  .mt-1\.5 {
    margin-top: calc(var(--spacing) * 1.5);
  }
  .mt-2 {
    margin-top: calc(var(--spacing) * 2);
  }
  .mt-3 {
    margin-top: calc(var(--spacing) * 3);
  }
  .mt-4 {
    margin-top: calc(var(--spacing) * 4);
  }
  .mt-5 {
    margin-top: calc(var(--spacing) * 5);
  }
  .mt-6 {
    margin-top: calc(var(--spacing) * 6);
  }
  .mt-7 {
    margin-top: calc(var(--spacing) * 7);
  }
  .mt-8 {
    margin-top: calc(var(--spacing) * 8);
  }
  .mt-10 {
    margin-top: calc(var(--spacing) * 10);
  }
  .mt-12 {
    margin-top: calc(var(--spacing) * 12);
  }
  .mt-16 {
    margin-top: calc(var(--spacing) * 16);
  }
  .mr-2 {
    margin-right: calc(var(--spacing) * 2);
  }
  .mr-3 {
    margin-right: calc(var(--spacing) * 3);
  }
  .-mb-10 {
    margin-bottom: calc(var(--spacing) * -10);
  }
  .mb-0 {
    margin-bottom: calc(var(--spacing) * 0);
  }
  .mb-0\.5 {
    margin-bottom: calc(var(--spacing) * 0.5);
  }
  .mb-1\.5 {
    margin-bottom: calc(var(--spacing) * 1.5);
  }
  .mb-2 {
    margin-bottom: calc(var(--spacing) * 2);
  }
  .mb-3 {
    margin-bottom: calc(var(--spacing) * 3);
  }
  .mb-4 {
    margin-bottom: calc(var(--spacing) * 4);
  }
  .mb-5 {
    margin-bottom: calc(var(--spacing) * 5);
  }
  .mb-6 {
    margin-bottom: calc(var(--spacing) * 6);
  }
  .mb-8 {
    margin-bottom: calc(var(--spacing) * 8);
  }
  .mb-10 {
    margin-bottom: calc(var(--spacing) * 10);
  }
  .mb-12 {
    margin-bottom: calc(var(--spacing) * 12);
  }
  .mb-14 {
    margin-bottom: calc(var(--spacing) * 14);
  }
  .line-clamp-1 {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
  }
  .line-clamp-2 {
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
  }
  .block {
    display: block;
  }
  .contents {
    display: contents;
  }
  .flex {
    display: flex;
  }
  .grid {
    display: grid;
  }
  .hidden {
    display: none;
  }
  .inline-block {
    display: inline-block;
  }
  .inline-flex {
    display: inline-flex;
  }
  .table {
    display: table;
  }
  .aspect-\[3\/1\] {
    aspect-ratio: 3/1;
  }
  .aspect-\[3\/2\] {
    aspect-ratio: 3/2;
  }
  .aspect-\[4\/3\] {
    aspect-ratio: 4/3;
  }
  .aspect-\[16\/9\] {
    aspect-ratio: 16/9;
  }
  .aspect-square {
    aspect-ratio: 1 / 1;
  }
  .h-2\.5 {
    height: calc(var(--spacing) * 2.5);
  }
  .h-3 {
    height: calc(var(--spacing) * 3);
  }
  .h-4 {
    height: calc(var(--spacing) * 4);
  }
  .h-5 {
    height: calc(var(--spacing) * 5);
  }
  .h-6 {
    height: calc(var(--spacing) * 6);
  }
  .h-7 {
    height: calc(var(--spacing) * 7);
  }
  .h-8 {
    height: calc(var(--spacing) * 8);
  }
  .h-9 {
    height: calc(var(--spacing) * 9);
  }
  .h-10 {
    height: calc(var(--spacing) * 10);
  }
  .h-12 {
    height: calc(var(--spacing) * 12);
  }
  .h-14 {
    height: calc(var(--spacing) * 14);
  }
  .h-16 {
    height: calc(var(--spacing) * 16);
  }
  .h-24 {
    height: calc(var(--spacing) * 24);
  }
  .h-48 {
    height: calc(var(--spacing) * 48);
  }
  .h-52 {
    height: calc(var(--spacing) * 52);
  }
  .h-72 {
    height: calc(var(--spacing) * 72);
  }
  .h-80 {
    height: calc(var(--spacing) * 80);
  }
  .h-\[54px\] {
    height: 54px;
  }
  .h-\[calc\(2\.5rem\+2\.25rem\)\] {
    height: calc(2.5rem + 2.25rem);
  }
  .h-full {
    height: 100%;
  }
  .h-px {
    height: 1px;
  }
  .max-h-\[7rem\] {
    max-height: 7rem;
  }
  .max-h-\[92vh\] {
    max-height: 92vh;
  }
  .min-h-0 {
    min-height: calc(var(--spacing) * 0);
  }
  .min-h-\[2rem\] {
    min-height: 2rem;
  }
  .min-h-screen {
    min-height: 100vh;
  }
  .w-2\.5 {
    width: calc(var(--spacing) * 2.5);
  }
  .w-3 {
    width: calc(var(--spacing) * 3);
  }
  .w-4 {
    width: calc(var(--spacing) * 4);
  }
  .w-5 {
    width: calc(var(--spacing) * 5);
  }
  .w-6 {
    width: calc(var(--spacing) * 6);
  }
  .w-7 {
    width: calc(var(--spacing) * 7);
  }
  .w-8 {
    width: calc(var(--spacing) * 8);
  }
  .w-10 {
    width: calc(var(--spacing) * 10);
  }
  .w-14 {
    width: calc(var(--spacing) * 14);
  }
  .w-16 {
    width: calc(var(--spacing) * 16);
  }
  .w-\[72px\] {
    width: 72px;
  }
  .w-auto {
    width: auto;
  }
  .w-full {
    width: 100%;
  }
  .w-px {
    width: 1px;
  }
  .max-w-2xl {
    max-width: var(--container-2xl);
  }
  .max-w-3xl {
    max-width: var(--container-3xl);
  }
  .max-w-4xl {
    max-width: var(--container-4xl);
  }
  .max-w-5xl {
    max-width: var(--container-5xl);
  }
  .max-w-7xl {
    max-width: var(--container-7xl);
  }
  .max-w-\[240px\] {
    max-width: 240px;
  }
  .max-w-\[1440px\] {
    max-width: 1440px;
  }
  .max-w-\[min\(100\%\,100rem\)\] {
    max-width: min(100%, 100rem);
  }
  .max-w-full {
    max-width: 100%;
  }
  .max-w-md {
    max-width: var(--container-md);
  }
  .max-w-none {
    max-width: none;
  }
  .max-w-xl {
    max-width: var(--container-xl);
  }
  .min-w-0 {
    min-width: calc(var(--spacing) * 0);
  }
  .min-w-28 {
    min-width: calc(var(--spacing) * 28);
  }
  .min-w-\[11rem\] {
    min-width: 11rem;
  }
  .flex-1 {
    flex: 1;
  }
  .flex-shrink-0 {
    flex-shrink: 0;
  }
  .shrink-0 {
    flex-shrink: 0;
  }
  .-translate-x-1\/2 {
    --tw-translate-x: calc(calc(1 / 2 * 100%) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .translate-x-full {
    --tw-translate-x: 100%;
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .-translate-y-1 {
    --tw-translate-y: calc(var(--spacing) * -1);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .translate-y-0 {
    --tw-translate-y: calc(var(--spacing) * 0);
    translate: var(--tw-translate-x) var(--tw-translate-y);
  }
  .-rotate-6 {
    rotate: calc(6deg * -1);
  }
  .rotate-12 {
    rotate: 12deg;
  }
  .rotate-180 {
    rotate: 180deg;
  }
  .transform {
    transform: var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,);
  }
  .animate-spin {
    animation: var(--animate-spin);
  }
  .cursor-default {
    cursor: default;
  }
  .cursor-pointer {
    cursor: pointer;
  }
  .scroll-mt-28 {
    scroll-margin-top: calc(var(--spacing) * 28);
  }
  .grid-cols-1 {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }
  .grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .flex-col {
    flex-direction: column;
  }
  .flex-wrap {
    flex-wrap: wrap;
  }
  .place-items-center {
    place-items: center;
  }
  .items-center {
    align-items: center;
  }
  .items-start {
    align-items: flex-start;
  }
  .justify-between {
    justify-content: space-between;
  }
  .justify-center {
    justify-content: center;
  }
  .justify-end {
    justify-content: flex-end;
  }
  .justify-start {
    justify-content: flex-start;
  }
  .gap-1 {
    gap: calc(var(--spacing) * 1);
  }
  .gap-1\.5 {
    gap: calc(var(--spacing) * 1.5);
  }
  .gap-2 {
    gap: calc(var(--spacing) * 2);
  }
  .gap-3 {
    gap: calc(var(--spacing) * 3);
  }
  .gap-4 {
    gap: calc(var(--spacing) * 4);
  }
  .gap-5 {
    gap: calc(var(--spacing) * 5);
  }
  .gap-6 {
    gap: calc(var(--spacing) * 6);
  }
  .gap-8 {
    gap: calc(var(--spacing) * 8);
  }
  .gap-10 {
    gap: calc(var(--spacing) * 10);
  }
  .gap-px {
    gap: 1px;
  }
  .space-y-1 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 1) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 1) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-2 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-4 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .space-y-6 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .gap-x-3 {
    column-gap: calc(var(--spacing) * 3);
  }
  .gap-x-4 {
    column-gap: calc(var(--spacing) * 4);
  }
  .gap-x-5 {
    column-gap: calc(var(--spacing) * 5);
  }
  .gap-x-6 {
    column-gap: calc(var(--spacing) * 6);
  }
  .gap-x-10 {
    column-gap: calc(var(--spacing) * 10);
  }
  .space-x-3 {
    :where(& > :not(:last-child)) {
      --tw-space-x-reverse: 0;
      margin-inline-start: calc(calc(var(--spacing) * 3) * var(--tw-space-x-reverse));
      margin-inline-end: calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-x-reverse)));
    }
  }
  .gap-y-0\.5 {
    row-gap: calc(var(--spacing) * 0.5);
  }
  .gap-y-1 {
    row-gap: calc(var(--spacing) * 1);
  }
  .gap-y-1\.5 {
    row-gap: calc(var(--spacing) * 1.5);
  }
  .gap-y-5 {
    row-gap: calc(var(--spacing) * 5);
  }
  .gap-y-7 {
    row-gap: calc(var(--spacing) * 7);
  }
  .gap-y-8 {
    row-gap: calc(var(--spacing) * 8);
  }
  .divide-y {
    :where(& > :not(:last-child)) {
      --tw-divide-y-reverse: 0;
      border-bottom-style: var(--tw-border-style);
      border-top-style: var(--tw-border-style);
      border-top-width: calc(1px * var(--tw-divide-y-reverse));
      border-bottom-width: calc(1px * calc(1 - var(--tw-divide-y-reverse)));
    }
  }
  .divide-\[\#DDD9D2\] {
    :where(& > :not(:last-child)) {
      border-color: #DDD9D2;
    }
  }
  .divide-\[var\(--color-border\)\] {
    :where(& > :not(:last-child)) {
      border-color: var(--color-border);
    }
  }
  .self-start {
    align-self: flex-start;
  }
  .self-stretch {
    align-self: stretch;
  }
  .overflow-hidden {
    overflow: hidden;
  }
  .overflow-y-auto {
    overflow-y: auto;
  }
  .rounded {
    border-radius: 0.25rem;
  }
  .rounded-2xl {
    border-radius: var(--radius-2xl);
  }
  .rounded-full {
    border-radius: calc(infinity * 1px);
  }
  .rounded-lg {
    border-radius: var(--radius-lg);
  }
  .rounded-sm {
    border-radius: var(--radius-sm);
  }
  .rounded-xl {
    border-radius: var(--radius-xl);
  }
  .border {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }
  .border-2 {
    border-style: var(--tw-border-style);
    border-width: 2px;
  }
  .border-t {
    border-top-style: var(--tw-border-style);
    border-top-width: 1px;
  }
  .border-b {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 1px;
  }
  .border-b-2 {
    border-bottom-style: var(--tw-border-style);
    border-bottom-width: 2px;
  }
  .border-\[\#DDD9D2\] {
    border-color: #DDD9D2;
  }
  .border-\[\#DDD9D2\]\/70 {
    border-color: color-mix(in oklab, #DDD9D2 70%, transparent);
  }
  .border-\[\#E8621A\] {
    border-color: #E8621A;
  }
  .border-\[\#E8621A\]\/60 {
    border-color: color-mix(in oklab, #E8621A 60%, transparent);
  }
  .border-\[var\(--color-border\)\] {
    border-color: var(--color-border);
  }
  .border-black\/10 {
    border-color: color-mix(in srgb, #000 10%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      border-color: color-mix(in oklab, var(--color-black) 10%, transparent);
    }
  }
  .border-gray-200 {
    border-color: var(--color-gray-200);
  }
  .border-ink {
    border-color: var(--color-ink);
  }
  .border-navy {
    border-color: var(--color-navy);
  }
  .border-primary {
    border-color: var(--color-primary);
  }
  .border-red-200 {
    border-color: var(--color-red-200);
  }
  .border-transparent {
    border-color: transparent;
  }
  .border-t-\[\#1A1A1A\] {
    border-top-color: #1A1A1A;
  }
  .bg-\[\#DDD9D2\] {
    background-color: #DDD9D2;
  }
  .bg-\[\#E2DDD2\] {
    background-color: #E2DDD2;
  }
  .bg-\[\#E8621A\] {
    background-color: #E8621A;
  }
  .bg-\[\#E8621A\]\/5 {
    background-color: color-mix(in oklab, #E8621A 5%, transparent);
  }
  .bg-\[\#E8621A\]\/10 {
    background-color: color-mix(in oklab, #E8621A 10%, transparent);
  }
  .bg-\[\#F8F5F0\] {
    background-color: #F8F5F0;
  }
  .bg-black\/25 {
    background-color: color-mix(in srgb, #000 25%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-black) 25%, transparent);
    }
  }
  .bg-cream {
    background-color: var(--color-cream);
  }
  .bg-gray-50 {
    background-color: var(--color-gray-50);
  }
  .bg-gray-100 {
    background-color: var(--color-gray-100);
  }
  .bg-gray-900\/55 {
    background-color: color-mix(in srgb, oklch(21% 0.034 264.665) 55%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-gray-900) 55%, transparent);
    }
  }
  .bg-green-500 {
    background-color: var(--color-green-500);
  }
  .bg-ink {
    background-color: var(--color-ink);
  }
  .bg-ink\/5 {
    background-color: color-mix(in srgb, #1A1A1A 5%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      background-color: color-mix(in oklab, var(--color-ink) 5%, transparent);
    }
  }
  .bg-navy {
    background-color: var(--color-navy);
  }
  .bg-orange {
    background-color: var(--color-orange);
  }
  .bg-primary {
    background-color: var(--color-primary);
  }
  .bg-red-50 {
    background-color: var(--color-red-50);
  }
  .bg-red-500 {
    background-color: var(--color-red-500);
  }
  .bg-red-600 {
    background-color: var(--color-red-600);
  }
  .bg-white {
    background-color: var(--color-white);
  }
  .bg-gradient-to-br {
    --tw-gradient-position: to bottom right in oklab;
    background-image: linear-gradient(var(--tw-gradient-stops));
  }
  .from-primary\/20 {
    --tw-gradient-from: color-mix(in srgb, #E8621A 20%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      --tw-gradient-from: color-mix(in oklab, var(--color-primary) 20%, transparent);
    }
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .to-orange\/10 {
    --tw-gradient-to: color-mix(in srgb, #E8621A 10%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      --tw-gradient-to: color-mix(in oklab, var(--color-orange) 10%, transparent);
    }
    --tw-gradient-stops: var(--tw-gradient-via-stops, var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position));
  }
  .object-contain {
    object-fit: contain;
  }
  .object-cover {
    object-fit: cover;
  }
  .object-\[left_68\%\] {
    object-position: left 68%;
  }
  .p-2 {
    padding: calc(var(--spacing) * 2);
  }
  .p-3\.5 {
    padding: calc(var(--spacing) * 3.5);
  }
  .p-4 {
    padding: calc(var(--spacing) * 4);
  }
  .p-6 {
    padding: calc(var(--spacing) * 6);
  }
  .p-8 {
    padding: calc(var(--spacing) * 8);
  }
  .px-0 {
    padding-inline: calc(var(--spacing) * 0);
  }
  .px-2 {
    padding-inline: calc(var(--spacing) * 2);
  }
  .px-3 {
    padding-inline: calc(var(--spacing) * 3);
  }
  .px-4 {
    padding-inline: calc(var(--spacing) * 4);
  }
  .px-5 {
    padding-inline: calc(var(--spacing) * 5);
  }
  .px-6 {
    padding-inline: calc(var(--spacing) * 6);
  }
  .px-8 {
    padding-inline: calc(var(--spacing) * 8);
  }
  .py-0\.5 {
    padding-block: calc(var(--spacing) * 0.5);
  }
  .py-1 {
    padding-block: calc(var(--spacing) * 1);
  }
  .py-1\.5 {
    padding-block: calc(var(--spacing) * 1.5);
  }
  .py-2 {
    padding-block: calc(var(--spacing) * 2);
  }
  .py-2\.5 {
    padding-block: calc(var(--spacing) * 2.5);
  }
  .py-3 {
    padding-block: calc(var(--spacing) * 3);
  }
  .py-4 {
    padding-block: calc(var(--spacing) * 4);
  }
  .py-5 {
    padding-block: calc(var(--spacing) * 5);
  }
  .py-6 {
    padding-block: calc(var(--spacing) * 6);
  }
  .py-8 {
    padding-block: calc(var(--spacing) * 8);
  }
  .py-10 {
    padding-block: calc(var(--spacing) * 10);
  }
  .py-14 {
    padding-block: calc(var(--spacing) * 14);
  }
  .py-16 {
    padding-block: calc(var(--spacing) * 16);
  }
  .py-20 {
    padding-block: calc(var(--spacing) * 20);
  }
  .pt-0 {
    padding-top: calc(var(--spacing) * 0);
  }
  .pt-2 {
    padding-top: calc(var(--spacing) * 2);
  }
  .pt-3 {
    padding-top: calc(var(--spacing) * 3);
  }
  .pt-4 {
    padding-top: calc(var(--spacing) * 4);
  }
  .pt-6 {
    padding-top: calc(var(--spacing) * 6);
  }
  .pt-8 {
    padding-top: calc(var(--spacing) * 8);
  }
  .pt-10 {
    padding-top: calc(var(--spacing) * 10);
  }
  .pt-12 {
    padding-top: calc(var(--spacing) * 12);
  }
  .pt-16 {
    padding-top: calc(var(--spacing) * 16);
  }
  .pt-20 {
    padding-top: calc(var(--spacing) * 20);
  }
  .pt-32 {
    padding-top: calc(var(--spacing) * 32);
  }
  .pt-\[calc\(var\(--site-header-height\)\+1\.25rem\)\] {
    padding-top: calc(var(--site-header-height) + 1.25rem);
  }
  .pb-0 {
    padding-bottom: calc(var(--spacing) * 0);
  }
  .pb-0\.5 {
    padding-bottom: calc(var(--spacing) * 0.5);
  }
  .pb-2 {
    padding-bottom: calc(var(--spacing) * 2);
  }
  .pb-5 {
    padding-bottom: calc(var(--spacing) * 5);
  }
  .pb-6 {
    padding-bottom: calc(var(--spacing) * 6);
  }
  .pb-9 {
    padding-bottom: calc(var(--spacing) * 9);
  }
  .pb-10 {
    padding-bottom: calc(var(--spacing) * 10);
  }
  .pb-14 {
    padding-bottom: calc(var(--spacing) * 14);
  }
  .pb-16 {
    padding-bottom: calc(var(--spacing) * 16);
  }
  .pb-20 {
    padding-bottom: calc(var(--spacing) * 20);
  }
  .pb-24 {
    padding-bottom: calc(var(--spacing) * 24);
  }
  .pb-28 {
    padding-bottom: calc(var(--spacing) * 28);
  }
  .pb-32 {
    padding-bottom: calc(var(--spacing) * 32);
  }
  .text-center {
    text-align: center;
  }
  .text-left {
    text-align: left;
  }
  .font-serif {
    font-family: var(--font-serif);
  }
  .text-2xl {
    font-size: var(--text-2xl);
    line-height: var(--tw-leading, var(--text-2xl--line-height));
  }
  .text-3xl {
    font-size: var(--text-3xl);
    line-height: var(--tw-leading, var(--text-3xl--line-height));
  }
  .text-6xl {
    font-size: var(--text-6xl);
    line-height: var(--tw-leading, var(--text-6xl--line-height));
  }
  .text-9xl {
    font-size: var(--text-9xl);
    line-height: var(--tw-leading, var(--text-9xl--line-height));
  }
  .text-base {
    font-size: var(--text-base);
    line-height: var(--tw-leading, var(--text-base--line-height));
  }
  .text-lg {
    font-size: var(--text-lg);
    line-height: var(--tw-leading, var(--text-lg--line-height));
  }
  .text-sm {
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
  }
  .text-xl {
    font-size: var(--text-xl);
    line-height: var(--tw-leading, var(--text-xl--line-height));
  }
  .text-xs {
    font-size: var(--text-xs);
    line-height: var(--tw-leading, var(--text-xs--line-height));
  }
  .text-\[0\.55rem\] {
    font-size: 0.55rem;
  }
  .leading-loose {
    --tw-leading: var(--leading-loose);
    line-height: var(--leading-loose);
  }
  .leading-none {
    --tw-leading: 1;
    line-height: 1;
  }
  .leading-relaxed {
    --tw-leading: var(--leading-relaxed);
    line-height: var(--leading-relaxed);
  }
  .leading-snug {
    --tw-leading: var(--leading-snug);
    line-height: var(--leading-snug);
  }
  .leading-tight {
    --tw-leading: var(--leading-tight);
    line-height: var(--leading-tight);
  }
  .font-bold {
    --tw-font-weight: var(--font-weight-bold);
    font-weight: var(--font-weight-bold);
  }
  .font-medium {
    --tw-font-weight: var(--font-weight-medium);
    font-weight: var(--font-weight-medium);
  }
  .font-semibold {
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
  }
  .text-balance {
    text-wrap: balance;
  }
  .break-all {
    word-break: break-all;
  }
  .whitespace-nowrap {
    white-space: nowrap;
  }
  .whitespace-pre-line {
    white-space: pre-line;
  }
  .whitespace-pre-wrap {
    white-space: pre-wrap;
  }
  .text-\[\#1a1a1a\] {
    color: #1a1a1a;
  }
  .text-\[\#555\] {
    color: #555;
  }
  .text-\[\#777\] {
    color: #777;
  }
  .text-\[\#999\] {
    color: #999;
  }
  .text-\[\#DDD9D2\] {
    color: #DDD9D2;
  }
  .text-\[\#E8621A\] {
    color: #E8621A;
  }
  .text-\[\#E8621A\]\/70 {
    color: color-mix(in oklab, #E8621A 70%, transparent);
  }
  .text-gray-400 {
    color: var(--color-gray-400);
  }
  .text-gray-500 {
    color: var(--color-gray-500);
  }
  .text-gray-600 {
    color: var(--color-gray-600);
  }
  .text-gray-700 {
    color: var(--color-gray-700);
  }
  .text-gray-900 {
    color: var(--color-gray-900);
  }
  .text-ink {
    color: var(--color-ink);
  }
  .text-muted {
    color: var(--color-muted);
  }
  .text-navy {
    color: var(--color-navy);
  }
  .text-primary {
    color: var(--color-primary);
  }
  .text-red-500 {
    color: var(--color-red-500);
  }
  .text-red-700 {
    color: var(--color-red-700);
  }
  .text-white {
    color: var(--color-white);
  }
  .uppercase {
    text-transform: uppercase;
  }
  .not-italic {
    font-style: normal;
  }
  .tabular-nums {
    --tw-numeric-spacing: tabular-nums;
    font-variant-numeric: var(--tw-ordinal,) var(--tw-slashed-zero,) var(--tw-numeric-figure,) var(--tw-numeric-spacing,) var(--tw-numeric-fraction,);
  }
  .underline {
    text-decoration-line: underline;
  }
  .underline-offset-2 {
    text-underline-offset: 2px;
  }
  .accent-\[\#1A1A1A\] {
    accent-color: #1A1A1A;
  }
  .opacity-0 {
    opacity: 0%;
  }
  .opacity-60 {
    opacity: 60%;
  }
  .opacity-80 {
    opacity: 80%;
  }
  .opacity-95 {
    opacity: 95%;
  }
  .opacity-100 {
    opacity: 100%;
  }
  .shadow-2xl {
    --tw-shadow: 0 25px 50px -12px var(--tw-shadow-color, rgb(0 0 0 / 0.25));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-\[\.\.\.\] {
    --tw-shadow: ...;
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-\[0_12px_40px_rgba\(26\,26\,26\,0\.06\)\] {
    --tw-shadow: 0 12px 40px var(--tw-shadow-color, rgba(26,26,26,0.06));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-\[0_12px_40px_rgba\(26\,26\,26\,0\.10\)\] {
    --tw-shadow: 0 12px 40px var(--tw-shadow-color, rgba(26,26,26,0.10));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-lg {
    --tw-shadow: 0 10px 15px -3px var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 4px 6px -4px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .shadow-sm {
    --tw-shadow: 0 1px 3px 0 var(--tw-shadow-color, rgb(0 0 0 / 0.1)), 0 1px 2px -1px var(--tw-shadow-color, rgb(0 0 0 / 0.1));
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .backdrop-blur-\[1px\] {
    --tw-backdrop-blur: blur(1px);
    -webkit-backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);
    backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);
  }
  .backdrop-blur-sm {
    --tw-backdrop-blur: blur(var(--blur-sm));
    -webkit-backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);
    backdrop-filter: var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);
  }
  .transition {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to, opacity, box-shadow, transform, translate, scale, rotate, filter, -webkit-backdrop-filter, backdrop-filter, display, content-visibility, overlay, pointer-events;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-all {
    transition-property: all;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-colors {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-opacity {
    transition-property: opacity;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .transition-transform {
    transition-property: transform, translate, scale, rotate;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .duration-100 {
    --tw-duration: 100ms;
    transition-duration: 100ms;
  }
  .duration-150 {
    --tw-duration: 150ms;
    transition-duration: 150ms;
  }
  .duration-300 {
    --tw-duration: 300ms;
    transition-duration: 300ms;
  }
  .duration-\[640ms\] {
    --tw-duration: 640ms;
    transition-duration: 640ms;
  }
  .ease-\[cubic-bezier\(0\.22\,1\,0\.36\,1\)\] {
    --tw-ease: cubic-bezier(0.22,1,0.36,1);
    transition-timing-function: cubic-bezier(0.22,1,0.36,1);
  }
  .ease-in {
    --tw-ease: var(--ease-in);
    transition-timing-function: var(--ease-in);
  }
  .ease-out {
    --tw-ease: var(--ease-out);
    transition-timing-function: var(--ease-out);
  }
  .group-hover\:scale-\[1\.02\] {
    &:is(:where(.group):hover *) {
      @media (hover: hover) {
        scale: 1.02;
      }
    }
  }
  .file\:mr-4 {
    &::file-selector-button {
      margin-right: calc(var(--spacing) * 4);
    }
  }
  .file\:border-0 {
    &::file-selector-button {
      border-style: var(--tw-border-style);
      border-width: 0px;
    }
  }
  .file\:bg-primary {
    &::file-selector-button {
      background-color: var(--color-primary);
    }
  }
  .file\:px-4 {
    &::file-selector-button {
      padding-inline: calc(var(--spacing) * 4);
    }
  }
  .file\:py-2 {
    &::file-selector-button {
      padding-block: calc(var(--spacing) * 2);
    }
  }
  .file\:text-sm {
    &::file-selector-button {
      font-size: var(--text-sm);
      line-height: var(--tw-leading, var(--text-sm--line-height));
    }
  }
  .file\:font-medium {
    &::file-selector-button {
      --tw-font-weight: var(--font-weight-medium);
      font-weight: var(--font-weight-medium);
    }
  }
  .file\:text-white {
    &::file-selector-button {
      color: var(--color-white);
    }
  }
  .hover\:border-ink {
    &:hover {
      @media (hover: hover) {
        border-color: var(--color-ink);
      }
    }
  }
  .hover\:bg-cream {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-cream);
      }
    }
  }
  .hover\:bg-cream\/60 {
    &:hover {
      @media (hover: hover) {
        background-color: color-mix(in srgb, #F7F4EF 60%, transparent);
        @supports (color: color-mix(in lab, red, red)) {
          background-color: color-mix(in oklab, var(--color-cream) 60%, transparent);
        }
      }
    }
  }
  .hover\:bg-ink {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-ink);
      }
    }
  }
  .hover\:bg-navy {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-navy);
      }
    }
  }
  .hover\:bg-navy\/90 {
    &:hover {
      @media (hover: hover) {
        background-color: color-mix(in srgb, #233654 90%, transparent);
        @supports (color: color-mix(in lab, red, red)) {
          background-color: color-mix(in oklab, var(--color-navy) 90%, transparent);
        }
      }
    }
  }
  .hover\:bg-orange-600 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-orange-600);
      }
    }
  }
  .hover\:bg-red-700 {
    &:hover {
      @media (hover: hover) {
        background-color: var(--color-red-700);
      }
    }
  }
  .hover\:text-\[\#1a1a1a\] {
    &:hover {
      @media (hover: hover) {
        color: #1a1a1a;
      }
    }
  }
  .hover\:text-\[\#E8621A\] {
    &:hover {
      @media (hover: hover) {
        color: #E8621A;
      }
    }
  }
  .hover\:text-\[\#e8621a\] {
    &:hover {
      @media (hover: hover) {
        color: #e8621a;
      }
    }
  }
  .hover\:text-gray-600 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-gray-600);
      }
    }
  }
  .hover\:text-ink {
    &:hover {
      @media (hover: hover) {
        color: var(--color-ink);
      }
    }
  }
  .hover\:text-primary {
    &:hover {
      @media (hover: hover) {
        color: var(--color-primary);
      }
    }
  }
  .hover\:text-red-600 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-red-600);
      }
    }
  }
  .hover\:text-white {
    &:hover {
      @media (hover: hover) {
        color: var(--color-white);
      }
    }
  }
  .hover\:underline {
    &:hover {
      @media (hover: hover) {
        text-decoration-line: underline;
      }
    }
  }
  .hover\:file\:bg-orange-600 {
    &:hover {
      @media (hover: hover) {
        &::file-selector-button {
          background-color: var(--color-orange-600);
        }
      }
    }
  }
  .focus\:border-ink {
    &:focus {
      border-color: var(--color-ink);
    }
  }
  .focus\:outline-none {
    &:focus {
      --tw-outline-style: none;
      outline-style: none;
    }
  }
  .disabled\:cursor-not-allowed {
    &:disabled {
      cursor: not-allowed;
    }
  }
  .disabled\:opacity-60 {
    &:disabled {
      opacity: 60%;
    }
  }
  .max-lg\:order-1 {
    @media (width < 64rem) {
      order: 1;
    }
  }
  .max-lg\:order-2 {
    @media (width < 64rem) {
      order: 2;
    }
  }
  .max-lg\:mt-8 {
    @media (width < 64rem) {
      margin-top: calc(var(--spacing) * 8);
    }
  }
  .max-lg\:mb-6 {
    @media (width < 64rem) {
      margin-bottom: calc(var(--spacing) * 6);
    }
  }
  .max-lg\:contents {
    @media (width < 64rem) {
      display: contents;
    }
  }
  .max-lg\:flex {
    @media (width < 64rem) {
      display: flex;
    }
  }
  .max-lg\:flex-col {
    @media (width < 64rem) {
      flex-direction: column;
    }
  }
  .max-lg\:border-0 {
    @media (width < 64rem) {
      border-style: var(--tw-border-style);
      border-width: 0px;
    }
  }
  .max-lg\:pb-0 {
    @media (width < 64rem) {
      padding-bottom: calc(var(--spacing) * 0);
    }
  }
  .max-md\:order-1 {
    @media (width < 48rem) {
      order: 1;
    }
  }
  .max-md\:order-2 {
    @media (width < 48rem) {
      order: 2;
    }
  }
  .max-md\:mt-3 {
    @media (width < 48rem) {
      margin-top: calc(var(--spacing) * 3);
    }
  }
  .max-md\:flex {
    @media (width < 48rem) {
      display: flex;
    }
  }
  .max-md\:flex-col {
    @media (width < 48rem) {
      flex-direction: column;
    }
  }
  .max-md\:pt-0 {
    @media (width < 48rem) {
      padding-top: calc(var(--spacing) * 0);
    }
  }
  .max-md\:pt-8 {
    @media (width < 48rem) {
      padding-top: calc(var(--spacing) * 8);
    }
  }
  .max-md\:pb-8 {
    @media (width < 48rem) {
      padding-bottom: calc(var(--spacing) * 8);
    }
  }
  .max-md\:text-sm {
    @media (width < 48rem) {
      font-size: var(--text-sm);
      line-height: var(--tw-leading, var(--text-sm--line-height));
    }
  }
  .max-md\:first\:pt-4 {
    @media (width < 48rem) {
      &:first-child {
        padding-top: calc(var(--spacing) * 4);
      }
    }
  }
  .sm\:top-3 {
    @media (width >= 40rem) {
      top: calc(var(--spacing) * 3);
    }
  }
  .sm\:right-3 {
    @media (width >= 40rem) {
      right: calc(var(--spacing) * 3);
    }
  }
  .sm\:mb-2 {
    @media (width >= 40rem) {
      margin-bottom: calc(var(--spacing) * 2);
    }
  }
  .sm\:hidden {
    @media (width >= 40rem) {
      display: none;
    }
  }
  .sm\:w-44 {
    @media (width >= 40rem) {
      width: calc(var(--spacing) * 44);
    }
  }
  .sm\:min-w-\[12rem\] {
    @media (width >= 40rem) {
      min-width: 12rem;
    }
  }
  .sm\:flex-1 {
    @media (width >= 40rem) {
      flex: 1;
    }
  }
  .sm\:grid-cols-2 {
    @media (width >= 40rem) {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }
  .sm\:grid-cols-3 {
    @media (width >= 40rem) {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }
  .sm\:grid-cols-\[9rem_1fr\] {
    @media (width >= 40rem) {
      grid-template-columns: 9rem 1fr;
    }
  }
  .sm\:flex-row {
    @media (width >= 40rem) {
      flex-direction: row;
    }
  }
  .sm\:gap-2 {
    @media (width >= 40rem) {
      gap: calc(var(--spacing) * 2);
    }
  }
  .sm\:gap-3 {
    @media (width >= 40rem) {
      gap: calc(var(--spacing) * 3);
    }
  }
  .sm\:gap-4 {
    @media (width >= 40rem) {
      gap: calc(var(--spacing) * 4);
    }
  }
  .sm\:gap-5 {
    @media (width >= 40rem) {
      gap: calc(var(--spacing) * 5);
    }
  }
  .sm\:space-y-6 {
    @media (width >= 40rem) {
      :where(& > :not(:last-child)) {
        --tw-space-y-reverse: 0;
        margin-block-start: calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));
        margin-block-end: calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)));
      }
    }
  }
  .sm\:p-5 {
    @media (width >= 40rem) {
      padding: calc(var(--spacing) * 5);
    }
  }
  .sm\:px-4 {
    @media (width >= 40rem) {
      padding-inline: calc(var(--spacing) * 4);
    }
  }
  .sm\:px-6 {
    @media (width >= 40rem) {
      padding-inline: calc(var(--spacing) * 6);
    }
  }
  .sm\:px-8 {
    @media (width >= 40rem) {
      padding-inline: calc(var(--spacing) * 8);
    }
  }
  .sm\:py-3 {
    @media (width >= 40rem) {
      padding-block: calc(var(--spacing) * 3);
    }
  }
  .sm\:pr-8 {
    @media (width >= 40rem) {
      padding-right: calc(var(--spacing) * 8);
    }
  }
  .sm\:text-2xl {
    @media (width >= 40rem) {
      font-size: var(--text-2xl);
      line-height: var(--tw-leading, var(--text-2xl--line-height));
    }
  }
  .sm\:text-sm {
    @media (width >= 40rem) {
      font-size: var(--text-sm);
      line-height: var(--tw-leading, var(--text-sm--line-height));
    }
  }
  .md\:order-1 {
    @media (width >= 48rem) {
      order: 1;
    }
  }
  .md\:order-2 {
    @media (width >= 48rem) {
      order: 2;
    }
  }
  .md\:col-span-1 {
    @media (width >= 48rem) {
      grid-column: span 1 / span 1;
    }
  }
  .md\:col-start-1 {
    @media (width >= 48rem) {
      grid-column-start: 1;
    }
  }
  .md\:col-start-2 {
    @media (width >= 48rem) {
      grid-column-start: 2;
    }
  }
  .md\:col-start-3 {
    @media (width >= 48rem) {
      grid-column-start: 3;
    }
  }
  .md\:-mx-10 {
    @media (width >= 48rem) {
      margin-inline: calc(var(--spacing) * -10);
    }
  }
  .md\:mx-auto {
    @media (width >= 48rem) {
      margin-inline: auto;
    }
  }
  .md\:-mt-10 {
    @media (width >= 48rem) {
      margin-top: calc(var(--spacing) * -10);
    }
  }
  .md\:mt-4 {
    @media (width >= 48rem) {
      margin-top: calc(var(--spacing) * 4);
    }
  }
  .md\:mt-14 {
    @media (width >= 48rem) {
      margin-top: calc(var(--spacing) * 14);
    }
  }
  .md\:-mb-10 {
    @media (width >= 48rem) {
      margin-bottom: calc(var(--spacing) * -10);
    }
  }
  .md\:mb-3 {
    @media (width >= 48rem) {
      margin-bottom: calc(var(--spacing) * 3);
    }
  }
  .md\:mb-5 {
    @media (width >= 48rem) {
      margin-bottom: calc(var(--spacing) * 5);
    }
  }
  .md\:mb-6 {
    @media (width >= 48rem) {
      margin-bottom: calc(var(--spacing) * 6);
    }
  }
  .md\:mb-14 {
    @media (width >= 48rem) {
      margin-bottom: calc(var(--spacing) * 14);
    }
  }
  .md\:mb-16 {
    @media (width >= 48rem) {
      margin-bottom: calc(var(--spacing) * 16);
    }
  }
  .md\:ml-8 {
    @media (width >= 48rem) {
      margin-left: calc(var(--spacing) * 8);
    }
  }
  .md\:block {
    @media (width >= 48rem) {
      display: block;
    }
  }
  .md\:contents {
    @media (width >= 48rem) {
      display: contents;
    }
  }
  .md\:flex {
    @media (width >= 48rem) {
      display: flex;
    }
  }
  .md\:hidden {
    @media (width >= 48rem) {
      display: none;
    }
  }
  .md\:inline {
    @media (width >= 48rem) {
      display: inline;
    }
  }
  .md\:h-10 {
    @media (width >= 48rem) {
      height: calc(var(--spacing) * 10);
    }
  }
  .md\:h-16 {
    @media (width >= 48rem) {
      height: calc(var(--spacing) * 16);
    }
  }
  .md\:h-\[calc\(2\.5rem\+2\.25rem\)\] {
    @media (width >= 48rem) {
      height: calc(2.5rem + 2.25rem);
    }
  }
  .md\:w-40 {
    @media (width >= 48rem) {
      width: calc(var(--spacing) * 40);
    }
  }
  .md\:w-44 {
    @media (width >= 48rem) {
      width: calc(var(--spacing) * 44);
    }
  }
  .md\:grid-cols-2 {
    @media (width >= 48rem) {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }
  .md\:grid-cols-3 {
    @media (width >= 48rem) {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }
  .md\:grid-cols-4 {
    @media (width >= 48rem) {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }
  .md\:grid-cols-\[auto_40px_1fr\] {
    @media (width >= 48rem) {
      grid-template-columns: auto 40px 1fr;
    }
  }
  .md\:grid-rows-\[auto_auto_auto\] {
    @media (width >= 48rem) {
      grid-template-rows: auto auto auto;
    }
  }
  .md\:flex-row {
    @media (width >= 48rem) {
      flex-direction: row;
    }
  }
  .md\:items-center {
    @media (width >= 48rem) {
      align-items: center;
    }
  }
  .md\:justify-between {
    @media (width >= 48rem) {
      justify-content: space-between;
    }
  }
  .md\:justify-center {
    @media (width >= 48rem) {
      justify-content: center;
    }
  }
  .md\:gap-3 {
    @media (width >= 48rem) {
      gap: calc(var(--spacing) * 3);
    }
  }
  .md\:gap-4 {
    @media (width >= 48rem) {
      gap: calc(var(--spacing) * 4);
    }
  }
  .md\:gap-6 {
    @media (width >= 48rem) {
      gap: calc(var(--spacing) * 6);
    }
  }
  .md\:gap-12 {
    @media (width >= 48rem) {
      gap: calc(var(--spacing) * 12);
    }
  }
  .md\:gap-16 {
    @media (width >= 48rem) {
      gap: calc(var(--spacing) * 16);
    }
  }
  .md\:space-y-3 {
    @media (width >= 48rem) {
      :where(& > :not(:last-child)) {
        --tw-space-y-reverse: 0;
        margin-block-start: calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));
        margin-block-end: calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)));
      }
    }
  }
  .md\:gap-x-6 {
    @media (width >= 48rem) {
      column-gap: calc(var(--spacing) * 6);
    }
  }
  .md\:gap-y-8 {
    @media (width >= 48rem) {
      row-gap: calc(var(--spacing) * 8);
    }
  }
  .md\:p-10 {
    @media (width >= 48rem) {
      padding: calc(var(--spacing) * 10);
    }
  }
  .md\:px-4 {
    @media (width >= 48rem) {
      padding-inline: calc(var(--spacing) * 4);
    }
  }
  .md\:px-10 {
    @media (width >= 48rem) {
      padding-inline: calc(var(--spacing) * 10);
    }
  }
  .md\:px-14 {
    @media (width >= 48rem) {
      padding-inline: calc(var(--spacing) * 14);
    }
  }
  .md\:py-2 {
    @media (width >= 48rem) {
      padding-block: calc(var(--spacing) * 2);
    }
  }
  .md\:py-6 {
    @media (width >= 48rem) {
      padding-block: calc(var(--spacing) * 6);
    }
  }
  .md\:py-8 {
    @media (width >= 48rem) {
      padding-block: calc(var(--spacing) * 8);
    }
  }
  .md\:py-10 {
    @media (width >= 48rem) {
      padding-block: calc(var(--spacing) * 10);
    }
  }
  .md\:py-16 {
    @media (width >= 48rem) {
      padding-block: calc(var(--spacing) * 16);
    }
  }
  .md\:py-20 {
    @media (width >= 48rem) {
      padding-block: calc(var(--spacing) * 20);
    }
  }
  .md\:py-22 {
    @media (width >= 48rem) {
      padding-block: calc(var(--spacing) * 22);
    }
  }
  .md\:py-24 {
    @media (width >= 48rem) {
      padding-block: calc(var(--spacing) * 24);
    }
  }
  .md\:py-28 {
    @media (width >= 48rem) {
      padding-block: calc(var(--spacing) * 28);
    }
  }
  .md\:pt-8 {
    @media (width >= 48rem) {
      padding-top: calc(var(--spacing) * 8);
    }
  }
  .md\:pt-10 {
    @media (width >= 48rem) {
      padding-top: calc(var(--spacing) * 10);
    }
  }
  .md\:pt-16 {
    @media (width >= 48rem) {
      padding-top: calc(var(--spacing) * 16);
    }
  }
  .md\:pt-24 {
    @media (width >= 48rem) {
      padding-top: calc(var(--spacing) * 24);
    }
  }
  .md\:pt-28 {
    @media (width >= 48rem) {
      padding-top: calc(var(--spacing) * 28);
    }
  }
  .md\:pt-\[calc\(var\(--site-header-height\)\+1\.5rem\)\] {
    @media (width >= 48rem) {
      padding-top: calc(var(--site-header-height) + 1.5rem);
    }
  }
  .md\:pr-5 {
    @media (width >= 48rem) {
      padding-right: calc(var(--spacing) * 5);
    }
  }
  .md\:pb-10 {
    @media (width >= 48rem) {
      padding-bottom: calc(var(--spacing) * 10);
    }
  }
  .md\:pb-12 {
    @media (width >= 48rem) {
      padding-bottom: calc(var(--spacing) * 12);
    }
  }
  .md\:pb-16 {
    @media (width >= 48rem) {
      padding-bottom: calc(var(--spacing) * 16);
    }
  }
  .md\:pb-20 {
    @media (width >= 48rem) {
      padding-bottom: calc(var(--spacing) * 20);
    }
  }
  .md\:pb-28 {
    @media (width >= 48rem) {
      padding-bottom: calc(var(--spacing) * 28);
    }
  }
  .md\:pb-40 {
    @media (width >= 48rem) {
      padding-bottom: calc(var(--spacing) * 40);
    }
  }
  .md\:pl-5 {
    @media (width >= 48rem) {
      padding-left: calc(var(--spacing) * 5);
    }
  }
  .md\:text-center {
    @media (width >= 48rem) {
      text-align: center;
    }
  }
  .md\:text-right {
    @media (width >= 48rem) {
      text-align: right;
    }
  }
  .md\:text-2xl {
    @media (width >= 48rem) {
      font-size: var(--text-2xl);
      line-height: var(--tw-leading, var(--text-2xl--line-height));
    }
  }
  .md\:text-3xl {
    @media (width >= 48rem) {
      font-size: var(--text-3xl);
      line-height: var(--tw-leading, var(--text-3xl--line-height));
    }
  }
  .md\:text-4xl {
    @media (width >= 48rem) {
      font-size: var(--text-4xl);
      line-height: var(--tw-leading, var(--text-4xl--line-height));
    }
  }
  .md\:text-7xl {
    @media (width >= 48rem) {
      font-size: var(--text-7xl);
      line-height: var(--tw-leading, var(--text-7xl--line-height));
    }
  }
  .md\:text-base {
    @media (width >= 48rem) {
      font-size: var(--text-base);
      line-height: var(--tw-leading, var(--text-base--line-height));
    }
  }
  .md\:text-lg {
    @media (width >= 48rem) {
      font-size: var(--text-lg);
      line-height: var(--tw-leading, var(--text-lg--line-height));
    }
  }
  .md\:text-sm {
    @media (width >= 48rem) {
      font-size: var(--text-sm);
      line-height: var(--tw-leading, var(--text-sm--line-height));
    }
  }
  .md\:text-xl {
    @media (width >= 48rem) {
      font-size: var(--text-xl);
      line-height: var(--tw-leading, var(--text-xl--line-height));
    }
  }
  .md\:text-\[0\.65rem\] {
    @media (width >= 48rem) {
      font-size: 0.65rem;
    }
  }
  .md\:text-\[0\.9375rem\] {
    @media (width >= 48rem) {
      font-size: 0.9375rem;
    }
  }
  .md\:text-\[1\.625rem\] {
    @media (width >= 48rem) {
      font-size: 1.625rem;
    }
  }
  .md\:leading-relaxed {
    @media (width >= 48rem) {
      --tw-leading: var(--leading-relaxed);
      line-height: var(--leading-relaxed);
    }
  }
  .lg\:relative {
    @media (width >= 64rem) {
      position: relative;
    }
  }
  .lg\:sticky {
    @media (width >= 64rem) {
      position: sticky;
    }
  }
  .lg\:top-\[calc\(var\(--site-header-height\)\+1\.5rem\)\] {
    @media (width >= 64rem) {
      top: calc(var(--site-header-height) + 1.5rem);
    }
  }
  .lg\:mx-auto {
    @media (width >= 64rem) {
      margin-inline: auto;
    }
  }
  .lg\:mb-0 {
    @media (width >= 64rem) {
      margin-bottom: calc(var(--spacing) * 0);
    }
  }
  .lg\:-ml-5 {
    @media (width >= 64rem) {
      margin-left: calc(var(--spacing) * -5);
    }
  }
  .lg\:ml-14 {
    @media (width >= 64rem) {
      margin-left: calc(var(--spacing) * 14);
    }
  }
  .lg\:block {
    @media (width >= 64rem) {
      display: block;
    }
  }
  .lg\:flex {
    @media (width >= 64rem) {
      display: flex;
    }
  }
  .lg\:hidden {
    @media (width >= 64rem) {
      display: none;
    }
  }
  .lg\:h-\[72px\] {
    @media (width >= 64rem) {
      height: 72px;
    }
  }
  .lg\:h-\[620px\] {
    @media (width >= 64rem) {
      height: 620px;
    }
  }
  .lg\:h-full {
    @media (width >= 64rem) {
      height: 100%;
    }
  }
  .lg\:min-h-0 {
    @media (width >= 64rem) {
      min-height: calc(var(--spacing) * 0);
    }
  }
  .lg\:w-\[42\%\] {
    @media (width >= 64rem) {
      width: 42%;
    }
  }
  .lg\:w-full {
    @media (width >= 64rem) {
      width: 100%;
    }
  }
  .lg\:max-w-3xl {
    @media (width >= 64rem) {
      max-width: var(--container-3xl);
    }
  }
  .lg\:max-w-7xl {
    @media (width >= 64rem) {
      max-width: var(--container-7xl);
    }
  }
  .lg\:grid-cols-3 {
    @media (width >= 64rem) {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }
  .lg\:grid-cols-4 {
    @media (width >= 64rem) {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }
  .lg\:grid-cols-\[1fr_20rem\] {
    @media (width >= 64rem) {
      grid-template-columns: 1fr 20rem;
    }
  }
  .lg\:flex-col {
    @media (width >= 64rem) {
      flex-direction: column;
    }
  }
  .lg\:flex-row {
    @media (width >= 64rem) {
      flex-direction: row;
    }
  }
  .lg\:items-center {
    @media (width >= 64rem) {
      align-items: center;
    }
  }
  .lg\:justify-between {
    @media (width >= 64rem) {
      justify-content: space-between;
    }
  }
  .lg\:justify-center {
    @media (width >= 64rem) {
      justify-content: center;
    }
  }
  .lg\:gap-0 {
    @media (width >= 64rem) {
      gap: calc(var(--spacing) * 0);
    }
  }
  .lg\:gap-10 {
    @media (width >= 64rem) {
      gap: calc(var(--spacing) * 10);
    }
  }
  .lg\:gap-12 {
    @media (width >= 64rem) {
      gap: calc(var(--spacing) * 12);
    }
  }
  .lg\:gap-14 {
    @media (width >= 64rem) {
      gap: calc(var(--spacing) * 14);
    }
  }
  .lg\:border-0 {
    @media (width >= 64rem) {
      border-style: var(--tw-border-style);
      border-width: 0px;
    }
  }
  .lg\:px-0 {
    @media (width >= 64rem) {
      padding-inline: calc(var(--spacing) * 0);
    }
  }
  .lg\:px-2 {
    @media (width >= 64rem) {
      padding-inline: calc(var(--spacing) * 2);
    }
  }
  .lg\:px-10 {
    @media (width >= 64rem) {
      padding-inline: calc(var(--spacing) * 10);
    }
  }
  .lg\:px-20 {
    @media (width >= 64rem) {
      padding-inline: calc(var(--spacing) * 20);
    }
  }
  .lg\:py-4 {
    @media (width >= 64rem) {
      padding-block: calc(var(--spacing) * 4);
    }
  }
  .lg\:py-10 {
    @media (width >= 64rem) {
      padding-block: calc(var(--spacing) * 10);
    }
  }
  .lg\:py-16 {
    @media (width >= 64rem) {
      padding-block: calc(var(--spacing) * 16);
    }
  }
  .lg\:py-28 {
    @media (width >= 64rem) {
      padding-block: calc(var(--spacing) * 28);
    }
  }
  .lg\:pt-0 {
    @media (width >= 64rem) {
      padding-top: calc(var(--spacing) * 0);
    }
  }
  .lg\:pr-0 {
    @media (width >= 64rem) {
      padding-right: calc(var(--spacing) * 0);
    }
  }
  .lg\:pr-12 {
    @media (width >= 64rem) {
      padding-right: calc(var(--spacing) * 12);
    }
  }
  .lg\:pb-0 {
    @media (width >= 64rem) {
      padding-bottom: calc(var(--spacing) * 0);
    }
  }
  .lg\:pl-8 {
    @media (width >= 64rem) {
      padding-left: calc(var(--spacing) * 8);
    }
  }
  .lg\:pl-12 {
    @media (width >= 64rem) {
      padding-left: calc(var(--spacing) * 12);
    }
  }
  .lg\:text-3xl {
    @media (width >= 64rem) {
      font-size: var(--text-3xl);
      line-height: var(--tw-leading, var(--text-3xl--line-height));
    }
  }
  .lg\:text-4xl {
    @media (width >= 64rem) {
      font-size: var(--text-4xl);
      line-height: var(--tw-leading, var(--text-4xl--line-height));
    }
  }
  .lg\:text-\[1\.75rem\] {
    @media (width >= 64rem) {
      font-size: 1.75rem;
    }
  }
  .xl\:h-\[680px\] {
    @media (width >= 80rem) {
      height: 680px;
    }
  }
  .xl\:w-\[40\%\] {
    @media (width >= 80rem) {
      width: 40%;
    }
  }
  .xl\:max-w-\[88rem\] {
    @media (width >= 80rem) {
      max-width: 88rem;
    }
  }
  .xl\:gap-4 {
    @media (width >= 80rem) {
      gap: calc(var(--spacing) * 4);
    }
  }
  .xl\:gap-8 {
    @media (width >= 80rem) {
      gap: calc(var(--spacing) * 8);
    }
  }
  .xl\:gap-20 {
    @media (width >= 80rem) {
      gap: calc(var(--spacing) * 20);
    }
  }
  .xl\:px-4 {
    @media (width >= 80rem) {
      padding-inline: calc(var(--spacing) * 4);
    }
  }
  .xl\:px-12 {
    @media (width >= 80rem) {
      padding-inline: calc(var(--spacing) * 12);
    }
  }
  .xl\:px-14 {
    @media (width >= 80rem) {
      padding-inline: calc(var(--spacing) * 14);
    }
  }
  .xl\:px-24 {
    @media (width >= 80rem) {
      padding-inline: calc(var(--spacing) * 24);
    }
  }
  .xl\:py-20 {
    @media (width >= 80rem) {
      padding-block: calc(var(--spacing) * 20);
    }
  }
  .xl\:text-4xl {
    @media (width >= 80rem) {
      font-size: var(--text-4xl);
      line-height: var(--tw-leading, var(--text-4xl--line-height));
    }
  }
  .xl\:text-\[1\.875rem\] {
    @media (width >= 80rem) {
      font-size: 1.875rem;
    }
  }
}
[x-cloak] {
  display: none !important;
}
:root {
  --font-body: 'Zen Kaku Gothic New', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', 'Yu Gothic', YuGothic, Meiryo, sans-serif;
  --heading-tracking: 0.06em;
  --heading-leading: 1.55;
  --text-tracking: 0.05em;
  --text-leading: 1.65;
  --text-weight: 500;
  --text-size: 1rem;
  --text-size-sm: 0.875rem;
  --text-size-13: 0.8125rem;
  --text-size-xs: 0.75rem;
  --site-header-height: 4.25rem;
}
@media (min-width: 768px) {
  :root {
    --site-header-height: 5rem;
  }
}
* {
  font-family: var(--font-body);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
html {
  scroll-padding-top: var(--site-header-height);
  scrollbar-width: thin;
  scrollbar-color: #C8B8A2 #ffffff;
}
body {
  background: #ffffff;
  color: #1A1A1A;
  font-weight: var(--text-weight);
  font-size: var(--text-size);
  line-height: var(--text-leading);
  letter-spacing: var(--text-tracking);
  font-feature-settings: 'palt' 1;
  overflow-anchor: none;
}
h1, h2, h3, h4, h5, h6 {
  font-weight: 700;
  letter-spacing: var(--heading-tracking);
  line-height: var(--heading-leading);
  font-feature-settings: normal;
}
.font-serif.leading-snug,
h1.leading-snug, h2.leading-snug, h3.leading-snug, h4.leading-snug {
  line-height: var(--heading-leading);
}
section:not(.hero-intro) h2.font-serif,
section:not(.hero-intro) h3.font-serif {
  font-weight: 500;
}
.page-header h1.font-serif {
  font-weight: 500;
}
.page-header h1.font-serif:not([id]) {
  font-size: 2.25rem;
  line-height: var(--heading-leading);
}
@media (min-width: 768px) {
  .page-header h1.font-serif:not([id]) {
    font-size: 3rem;
  }
}
.page-header--split {
  --page-header-photo: url('/images/backgrounds/hero-bg.jpg');
  background-color: #fff;
}
.page-header__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}
.page-header__text {
  padding: 0 1.5rem;
}
.page-header__lede {
  margin: 1rem 0 0;
  max-width: 26rem;
  font-size: var(--text-size-sm);
  line-height: var(--text-leading);
  font-weight: var(--text-weight);
  letter-spacing: var(--text-tracking);
  color: var(--color-muted);
}
.page-header__photo {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  background-image: var(--page-header-photo);
  background-size: cover;
  background-position: var(--page-header-photo-position, center);
  animation: page-header-photo-reveal 1.1s cubic-bezier(0.77, 0, 0.175, 1) 0.1s both;
}
@keyframes page-header-photo-reveal {
  from {
    clip-path: inset(0 0 0 100%);
  }
  to {
    clip-path: inset(0 0 0 0);
  }
}
@media (prefers-reduced-motion: reduce) {
  .page-header__photo {
    animation: none;
  }
}
@media (min-width: 768px) {
  .page-header__grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 60%);
    align-items: center;
    gap: clamp(1.5rem, 3vw, 3rem);
  }
  .page-header__text {
    padding: 0 2rem 0 max(2.5rem, calc((100vw - 80rem) / 2 + 2.5rem));
  }
  .page-header__photo {
    aspect-ratio: auto;
    height: clamp(13rem, 19vw, 17rem);
  }
}
.company-profile-table {
  width: min(100%, 58rem);
  margin-inline: auto;
  border-collapse: collapse;
}
.company-profile-table tr:not(:last-child) {
  border-bottom: 1px solid #EEEEEE;
}
.company-profile-table th {
  width: 28%;
  padding: 1.625rem 2rem 1.625rem 0;
  text-align: left;
  vertical-align: middle;
  font-size: var(--text-size);
  font-weight: 700;
  color: var(--color-ink);
  letter-spacing: var(--text-tracking);
}
.company-profile-table td {
  padding: 1.625rem 0;
  vertical-align: middle;
  font-size: var(--text-size);
  font-weight: var(--text-weight);
  color: var(--color-ink);
  line-height: var(--text-leading);
  letter-spacing: var(--text-tracking);
}
.company-profile-table tr:not(:last-child) th {
  position: relative;
}
.company-profile-table tr:not(:last-child) th::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 66%;
  border-bottom: 2px solid #DDD9D2;
}
.text-muted {
  color: var(--color-muted);
  font-weight: var(--text-weight);
}
.text-body,
.news-list-title,
.news-top-row__title {
  font-size: var(--text-size);
  line-height: var(--text-leading);
  font-weight: var(--text-weight);
  letter-spacing: var(--text-tracking);
  font-feature-settings: 'palt' 1;
}
.text-body-sm,
.hero-intro__lede,
.hero-intro__stats-inline,
.hero-intro__stat-inline-label,
.works-pickup-item__title {
  font-size: var(--text-size-sm);
  line-height: var(--text-leading);
  font-weight: var(--text-weight);
  letter-spacing: var(--text-tracking);
  font-feature-settings: 'palt' 1;
}
.text-body-xs,
.news-list-cat,
.news-top-row__cat {
  font-size: var(--text-size-xs);
  line-height: var(--text-leading);
  font-weight: var(--text-weight);
  letter-spacing: var(--text-tracking);
  font-feature-settings: 'palt' 1;
}
.news-list-cat {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.25rem 0.75rem;
  color: var(--color-ink);
  border: 1px solid #DDD9D2;
  background: #fff;
}
.news-list-title {
  color: var(--color-ink);
}
.concept-point__label {
  font-family: var(--font-body);
  font-weight: var(--text-weight);
  letter-spacing: var(--text-tracking);
  font-feature-settings: 'palt' 1;
}
.hero-intro__head-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.125rem;
  width: 100%;
  max-width: 36rem;
}
@media (min-width: 768px) {
  .hero-intro__head-block {
    gap: 1.375rem;
    max-width: 42rem;
  }
}
@media (min-width: 1024px) {
  .hero-intro--layout .hero-intro__head-block {
    align-items: flex-start;
    max-width: 44rem;
  }
}
.hero-intro__lede {
  margin: 0;
  max-width: 28rem;
  text-align: center;
}
@media (min-width: 768px) {
  .hero-intro__lede {
    font-size: var(--text-size);
  }
}
@media (min-width: 1024px) {
  .hero-intro--layout .hero-intro__lede {
    text-align: left;
  }
}
.hero-intro__stats-inline {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.75rem 1.25rem;
  margin: 0;
  font-family: var(--font-body);
}
@media (min-width: 1024px) {
  .hero-intro--layout .hero-intro__stats-inline {
    justify-content: flex-start;
  }
}
.hero-intro__stat-inline {
  display: inline-flex;
  align-items: baseline;
  gap: 0.4em;
}
.hero-intro__stat-inline-value {
  font-size: 1.0625rem;
  line-height: 1.2;
  font-weight: var(--text-weight);
  letter-spacing: var(--text-tracking);
  font-feature-settings: 'palt' 1;
  font-variant-numeric: tabular-nums;
  color: var(--color-ink);
}
@media (min-width: 768px) {
  .hero-intro__stat-inline-value {
    font-size: 1.5rem;
  }
}
.hero-intro__stat-inline-label {
  color: var(--color-muted);
}
.hero-intro__stat-inline-accent {
  color: #e8621a;
}
.hero-intro__stat-inline-sep {
  width: 1px;
  height: 1.125rem;
  background: #ddd9d2;
  flex-shrink: 0;
}
@media (min-width: 768px) {
  .hero-intro__stat-inline-sep {
    height: 1.25rem;
  }
}
.font-serif {
  font-family: var(--font-body);
  font-feature-settings: 'palt' 1;
}
.site-btn {
  --site-btn-ease: cubic-bezier(0.22, 1, 0.36, 1);
  --site-btn-fill: 0.52s;
  --site-btn-color: 0.34s;
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-style: solid;
  border-width: 1px;
  font-weight: 500;
  text-decoration: none;
  cursor: pointer;
  overflow: hidden;
  isolation: isolate;
  transition: border-color var(--site-btn-color) ease;
}
.site-btn::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform var(--site-btn-fill) var(--site-btn-ease);
}
.site-btn:hover::before,
.site-btn:focus-visible::before {
  transform: scaleX(1);
}
.site-btn__inner {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  transition: color var(--site-btn-color) var(--site-btn-ease);
}
.site-btn .site-btn__inner svg {
  flex-shrink: 0;
  transition: transform 0.3s var(--site-btn-ease);
}
.site-btn:hover .site-btn__inner svg,
.site-btn:focus-visible .site-btn__inner svg {
  transform: translateX(3px);
}
.site-btn:focus-visible {
  outline: 2px solid #e8621a;
  outline-offset: 3px;
}
.site-btn--sm {
  padding: 0.65rem 1.125rem;
  font-size: 0.9375rem;
  line-height: 1.25;
}
@media (min-width: 1280px) {
  .site-btn--sm {
    font-size: 1rem;
  }
}
.site-btn--md {
  padding: 0.65rem 1.35rem;
  font-size: 0.875rem;
  letter-spacing: var(--text-tracking);
}
.site-btn--compact {
  padding: 0.5rem 1.25rem;
  font-size: 0.875rem;
  line-height: 1.25;
  letter-spacing: var(--text-tracking);
}
.site-btn--field {
  height: 2.75rem;
  padding: 0 1.5rem;
  font-size: 0.875rem;
  line-height: 1.25;
  letter-spacing: var(--text-tracking);
}
.site-btn--lg {
  padding: 1rem 2rem;
  font-size: 0.875rem;
  line-height: 1.25;
}
.site-btn--menu {
  padding: 0.625rem 1.25rem;
  font-size: 1.125rem;
  line-height: 1.25;
}
.site-btn--footer {
  padding: 0.625rem 1.25rem;
  font-size: 0.875rem;
}
@media (max-width: 767px) {
  footer .site-btn--footer {
    padding: 0.45rem 0.85rem;
    font-size: 0.75rem;
    letter-spacing: var(--text-tracking);
  }
}
.site-btn--outline-ink {
  color: #1a1a1a;
  border-color: #1a1a1a;
  background: transparent;
}
.site-btn--outline-ink::before {
  background: #1a1a1a;
}
.site-btn--outline-ink:hover .site-btn__inner,
.site-btn--outline-ink:focus-visible .site-btn__inner {
  color: #f7f4ef;
}
.site-btn--primary {
  color: #fff;
  border-color: #e8621a;
  background-color: #e8621a;
}
.site-btn--primary::before {
  background: #c4521a;
}
.site-btn--primary .site-btn__inner {
  color: #fff;
}
.site-btn--outline-muted {
  color: #1a1a1a;
  border-color: #ddd9d2;
  background: transparent;
}
.site-btn--outline-muted::before {
  background: #1a1a1a;
}
.site-btn--outline-muted:hover,
.site-btn--outline-muted:focus-visible {
  border-color: #1a1a1a;
}
.site-btn--outline-muted:hover .site-btn__inner,
.site-btn--outline-muted:focus-visible .site-btn__inner {
  color: #f7f4ef;
}
.site-btn--outline-light {
  color: #f7f4ef;
  border-color: rgba(247, 244, 239, 0.45);
  background: transparent;
}
.site-btn--outline-light::before {
  background: #f7f4ef;
}
.site-btn--outline-light:hover,
.site-btn--outline-light:focus-visible {
  border-color: #f7f4ef;
}
.site-btn--outline-light:hover .site-btn__inner,
.site-btn--outline-light:focus-visible .site-btn__inner {
  color: #1a1a1a;
}
.site-btn--dark {
  color: #f7f4ef;
  border-color: #1a1a1a;
  background-color: #1a1a1a;
}
.site-btn--dark::before {
  background: #e8621a;
}
.site-btn--dark .site-btn__inner {
  color: #f7f4ef;
}
.site-btn--dark-invert {
  color: #f7f4ef;
  border-color: #1a1a1a;
  background-color: #1a1a1a;
}
.site-btn--dark-invert::before {
  background: #ffffff;
}
.site-btn--dark-invert:hover .site-btn__inner,
.site-btn--dark-invert:focus-visible .site-btn__inner {
  color: #1a1a1a;
}
.site-btn--dark-invert .site-btn__inner {
  color: #f7f4ef;
}
@media (prefers-reduced-motion: reduce) {
  .site-btn::before {
    transition-duration: 0.01ms;
  }
}
.font-mono-label {
  font-family: var(--font-body);
  font-weight: var(--text-weight);
  letter-spacing: var(--text-tracking);
  font-feature-settings: 'palt' 1;
}
.bg-dots {
  background-image: radial-gradient(circle, rgba(26,26,26,0.10) 1px, transparent 1px);
  background-size: 36px 36px;
}
.bg-grid-dark {
  background-image: linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size: 44px 44px;
}
[data-reveal] {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.8s cubic-bezier(0.16,1,0.3,1), transform 0.8s cubic-bezier(0.16,1,0.3,1);
}
[data-reveal].is-revealed {
  opacity: 1;
  transform: translateY(0);
}
[data-reveal][data-delay="100"] {
  transition-delay: 0.1s;
}
[data-reveal][data-delay="200"] {
  transition-delay: 0.2s;
}
[data-reveal][data-delay="300"] {
  transition-delay: 0.3s;
}
[data-reveal][data-delay="400"] {
  transition-delay: 0.4s;
}
[data-reveal][data-delay="500"] {
  transition-delay: 0.5s;
}
.reveal-underline {
  position: relative;
  display: inline;
}
.reveal-underline::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -0.15em;
  width: 100%;
  height: 1px;
  background: #E8621A;
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 0.75s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: 0.5s;
}
.is-revealed .reveal-underline::after {
  transform: scaleX(1);
}
.hero-intro__title {
  --hero-title-lh: 1.34;
  font-size: 1.25rem;
  line-height: var(--hero-title-lh);
  letter-spacing: var(--heading-tracking);
  font-weight: 500;
  text-wrap: balance;
}
@media (min-width: 768px) {
  .hero-intro__title {
    font-size: 2rem;
    white-space: nowrap;
  }
}
@media (min-width: 1280px) {
  .hero-intro__title {
    font-size: 2.375rem;
  }
}
.hero-intro__title-row,
.hero-intro__title-accent {
  line-height: inherit;
}
.hero-intro__title-row {
  display: block;
}
.hero-intro__title-row--lede {
  word-break: keep-all;
  overflow-wrap: normal;
  line-break: strict;
  margin-bottom: 0.35em;
}
.hero-intro__lede-line--first {
  --lede-underline-delay: 0.9s;
}
.hero-intro__lede-line--second {
  --lede-underline-delay: 1.04s;
}
.hero-intro__lede-line {
  position: relative;
  display: inline-block;
  max-width: 100%;
}
@media (min-width: 1024px) {
  .hero-intro__title-wrap .hero-intro__title-accent {
    white-space: nowrap;
  }
  .hero-intro--layout .hero-intro__title-row {
    display: inline;
  }
  .hero-intro--layout .hero-intro__title-row--lede {
    margin-bottom: 0;
  }
  .hero-intro--layout .hero-intro__title-accent {
    display: inline;
    margin-top: 0;
  }
}
.hero-intro__lede-line::after {
  content: none;
}
.hero-intro__title-accent {
  display: block;
  margin-top: 0.4em;
  font-size: 0.9em;
  letter-spacing: var(--heading-tracking);
  font-feature-settings: normal;
}
.hero-intro__title-wrap .hero-intro__title {
  margin-bottom: 0;
}
@media (min-width: 1024px) {
  .hero-intro--layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.88fr);
    grid-template-rows: minmax(0, 1fr);
    column-gap: clamp(0.5rem, 1.2vw, 1.25rem);
    align-items: stretch;
    min-height: 100svh;
    padding-top: 0;
    padding-bottom: 0;
  }
  .hero-intro__left-col {
    grid-column: 1;
    grid-row: 1;
    align-self: stretch;
    min-height: 100svh;
    padding-top: calc(var(--site-header-height) + 1.25rem);
    box-sizing: border-box;
    position: relative;
    z-index: 1;
    background-image: none;
  }
  .hero-intro__media-col {
    position: absolute !important;
    top: calc(var(--site-header-height) + 1.25rem);
    bottom: clamp(1.5rem, 3vh, 2.5rem);
    left: clamp(10rem, 28%, 22rem);
    right: 0;
    width: auto !important;
    min-height: 0 !important;
    grid-column: 1 / -1;
    grid-row: 1;
    z-index: 0;
  }
  .hero-intro--layout .hero-intro__title-wrap {
    margin-left: clamp(2rem, 5vw, 4rem);
    margin-right: 0;
    margin-bottom: 0;
    padding-left: 0;
    padding-right: 0;
    padding-top: 0;
    padding-bottom: clamp(2.5rem, 8vh, 5.5rem);
    width: 100%;
    max-width: min(44rem, calc(100% - 2rem));
    text-align: left;
    align-items: flex-start;
    justify-content: flex-end;
    min-height: 100%;
  }
  .hero-intro--layout .hero-intro__head-block {
    align-items: flex-start;
  }
}
.hero-intro__stat-value {
  font-family: var(--font-body);
  font-weight: var(--text-weight);
  font-size: 2.625rem;
  line-height: 1.15;
  letter-spacing: var(--text-tracking);
}
@media (min-width: 768px) {
  .hero-intro__stat-value {
    font-size: 3.125rem;
  }
}
.hero-intro__stat-figures {
  display: inline-block;
  letter-spacing: var(--text-tracking);
  font-feature-settings: 'palt' 1;
}
.hero-intro__stat-unit {
  color: #e8621a;
  letter-spacing: var(--text-tracking);
}
.hero-intro__stat-label {
  font-size: var(--text-size-xs);
  margin-top: 0.6rem;
  letter-spacing: var(--text-tracking);
  font-weight: var(--text-weight);
}
@media (min-width: 768px) {
  .hero-intro__stat-label {
    font-size: var(--text-size-sm);
    margin-top: 0.675rem;
  }
}
.hero-char {
  display: inline-block;
  transition: opacity 0.38s ease, transform 0.38s ease;
  transition-delay: calc(var(--ci) * 0.022s);
}
@media (prefers-reduced-motion: no-preference) {
  html.hero-anim .hero-intro--chars-prepared:not(.hero-intro--active) .hero-char {
    opacity: 0;
    transform: translateY(0.22em);
  }
}
.hero-intro.hero-intro--active .hero-char {
  opacity: 1;
  transform: translateY(0);
}
.hero-intro__stats {
  position: relative;
}
.hero-intro__visual-fade {
  display: none;
}
@media (max-width: 1023px) {
  .hero-intro--layout {
    min-height: 100svh;
    background: #ffffff;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  .hero-intro--layout .hero-intro__title-row {
    display: inline;
  }
  .hero-intro--layout .hero-intro__title-accent {
    display: inline;
    margin-top: 0;
  }
  .hero-intro--layout .hero-intro__media-col {
    order: -1;
    position: static;
    z-index: 0;
    width: 100%;
    flex: 1 1 auto;
    min-height: 52svh;
    margin-top: 0 !important;
    overflow: hidden;
  }
  .hero-intro--layout .hero-intro__visual-frame {
    flex: 1 1 auto;
    min-height: 52svh;
  }
  .hero-intro--layout .hero-intro__img {
    object-position: 58% 40%;
  }
  .hero-intro--layout .hero-intro__title-wrap {
    position: relative;
    z-index: 1;
    flex: 0 0 auto;
    margin: 0 !important;
    padding-left: 1rem !important;
    padding-right: 1rem !important;
    padding-top: clamp(1.75rem, 5vh, 2.5rem);
    padding-bottom: clamp(2rem, 6vh, 3rem);
  }
  .hero-intro--layout .hero-intro__lede {
    font-size: 0.8125rem;
    max-width: none;
  }
  .hero-intro--layout .hero-intro__photo-tagline {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 2;
    color: rgba(255, 255, 255, 0.82) !important;
    margin: 0;
    padding-top: 0 !important;
    padding-bottom: max(0.5rem, env(safe-area-inset-bottom, 0px)) !important;
  }
  .hero-intro--layout .hero-intro__photo-tagline.section-label::after {
    background: rgba(255, 255, 255, 0.5);
  }
}
@media (min-width: 1024px) {
  .hero-intro--layout .hero-intro__visual-frame {
    flex: 1 1 auto;
    min-height: 0;
    margin-top: 0;
    padding-bottom: 0;
  }
  .hero-intro--layout .hero-intro__visual {
    flex: 1 1 auto;
    min-height: 0;
  }
  .hero-intro__media-col .hero-intro__photo-tagline.section-label {
    position: absolute;
    right: clamp(1.25rem, 4vw, 3rem);
    bottom: clamp(1.25rem, 3vh, 2.5rem);
    z-index: 6;
    width: auto;
    max-width: min(100% - 2rem, 24rem);
    margin: 0;
    padding: 0;
    justify-content: flex-end;
    color: rgba(255, 255, 255, 0.92);
    text-shadow: 0 1px 12px rgba(26, 26, 26, 0.25);
  }
  .hero-intro__media-col .hero-intro__photo-tagline.section-label::after {
    display: none;
  }
}
.hero-intro__visual-inner {
  clip-path: inset(0);
  transition: clip-path 1.28s cubic-bezier(0.77, 0, 0.175, 1);
  transition-delay: 0.08s;
}
@media (min-width: 1024px) {
  .hero-intro.hero-intro--layout .hero-intro__visual-inner > .hero-intro__img {
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    max-width: none;
    height: 100%;
    object-fit: cover;
    object-position: 50% 28%;
    filter: brightness(1.05) contrast(1.02) saturate(1.02);
    transform: scale(1.08);
    transform-origin: 50% 35%;
  }
}
@media (prefers-reduced-motion: no-preference) {
  @keyframes hero-intro-img-drift {
    0% {
      transform: scale(1.06) translate(0, 0);
    }
    35% {
      transform: scale(1.1) translate(-0.9%, -0.45%);
    }
    70% {
      transform: scale(1.12) translate(0.55%, -0.75%);
    }
    100% {
      transform: scale(1.08) translate(0.25%, -0.35%);
    }
  }
  @media (min-width: 1024px) {
    .hero-intro.hero-intro--layout .hero-intro__visual-inner > .hero-intro__img {
      animation: hero-intro-img-drift 28s ease-in-out infinite;
    }
  }
}
@media (prefers-reduced-motion: no-preference) {
  html.hero-anim .hero-intro:not(.hero-intro--active) [data-hero-piece] {
    opacity: 0;
    transform: translateY(1.5rem);
  }
  html.hero-anim .hero-intro:not(.hero-intro--active) .hero-intro__visual-inner {
    clip-path: inset(0 0 0 100%);
  }
}
.hero-intro [data-hero-piece] {
  transition: opacity 0.85s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.85s cubic-bezier(0.16, 1, 0.3, 1);
}
.hero-intro [data-hero-delay="160"] {
  transition-delay: 0.16s;
}
.hero-intro [data-hero-delay="200"] {
  transition-delay: 0.2s;
}
.hero-intro [data-hero-delay="220"] {
  transition-delay: 0.22s;
}
.hero-intro [data-hero-delay="240"] {
  transition-delay: 0.24s;
}
.hero-intro__photo-tagline.section-label[data-hero-piece] {
  transition: opacity 1.28s cubic-bezier(0.77, 0, 0.175, 1) 0.08s,
    transform 1.28s cubic-bezier(0.77, 0, 0.175, 1) 0.08s;
}
.hero-intro.hero-intro--active [data-hero-piece] {
  opacity: 1;
  transform: translateY(0);
}
.hero-intro.hero-intro--active .hero-intro__visual-inner {
  clip-path: inset(0 0 0 0);
}
@media (prefers-reduced-motion: reduce) {
  .hero-intro [data-hero-piece],
  .hero-intro .hero-char,
  .hero-intro .hero-intro__img {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
    animation: none !important;
  }
  .hero-intro.hero-intro--layout {
    animation: none !important;
  }
  .hero-intro .hero-intro__lede-line::after {
    transform: scaleX(1) !important;
    transition: none !important;
  }
  .hero-intro .hero-intro__visual-inner {
    clip-path: none !important;
    transition: none !important;
  }
}
.hero-lede__shell {
  border-radius: 0;
}
.hero-lede--cream {
  background: var(--color-cream);
}
.hero-lede--interlude {
  position: relative;
  background: #ffffff;
  overflow: hidden;
}
.hero-lede--stats-photo::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background-image: linear-gradient(
      to left,
      rgba(255, 255, 255, 0.92) 0%,
      rgba(255, 255, 255, 0.45) 18%,
      rgba(255, 255, 255, 0.12) 38%,
      transparent 58%
    ),
    linear-gradient(
      100deg,
      rgba(255, 255, 255, 0.98) 0%,
      rgba(255, 255, 255, 0.95) 26%,
      rgba(255, 255, 255, 0.88) 48%,
      rgba(255, 255, 255, 0.72) 70%,
      rgba(255, 255, 255, 0.48) 100%
    ),
    url('/images/backgrounds/philosophy-stats-bg.jpg');
  background-size: cover, cover, cover;
  background-position: right center, left center, center;
}
.hero-lede.hero-lede--index-philosophy.hero-lede--interlude {
  margin-top: 0;
  margin-bottom: 0;
}
@media (min-width: 768px) {
  .hero-lede.hero-lede--index-philosophy.hero-lede--interlude {
    margin-top: 0;
    margin-bottom: 0;
  }
}
.section-divider--cream-dots {
  width: 100%;
  height: 24px;
  background-color: #ffffff;
  background-image: radial-gradient(circle, var(--color-cream) 7px, transparent 7px);
  background-size: 36px 36px;
  background-position: center center;
  background-repeat: repeat-x;
}
.story-desktop-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(22rem, 34rem) minmax(0, 1fr);
  align-items: stretch;
  column-gap: clamp(1.5rem, 3vw, 2.5rem);
}
.story-desktop-layout__photo,
.story-desktop-layout__stack {
  max-width: min(100%, 18rem);
  justify-self: center;
  width: 100%;
}
.story-desktop-layout__text .section-label {
  justify-content: center;
}
.story-chapter__copy h2,
.story-chapter__copy p {
  word-break: keep-all;
  overflow-wrap: normal;
  line-break: strict;
  text-wrap: pretty;
}
@media (min-width: 768px) {
  body[data-page="story"] section.story-chapter--closing {
    padding-bottom: 5rem !important;
  }
  body[data-page="story"] section.story-closing-section {
    padding-top: 3rem !important;
    padding-bottom: 8rem !important;
  }
  body[data-page="story"] .story-closing-section__statement {
    font-size: 1.4375rem;
    line-height: var(--heading-leading);
    letter-spacing: var(--heading-tracking);
  }
  body[data-page="story"] section.story-services-section {
    padding-top: 5rem !important;
    padding-bottom: 8rem !important;
  }
}
.advantage-grid__item {
  padding: 1.25rem 0;
}
@media (min-width: 768px) {
  .advantage-grid__item {
    padding: 2rem 2.5rem;
  }
  .advantage-grid__item:nth-child(odd) {
    border-right: 1px solid rgba(26, 26, 26, 0.08);
  }
  .advantage-grid__item:nth-child(-n + 2) {
    border-bottom: 1px solid rgba(26, 26, 26, 0.08);
  }
}
@media (max-width: 767px) {
  .advantage-grid__item:not(:last-child) {
    border-bottom: 1px solid rgba(26, 26, 26, 0.08);
  }
}
.advantage-grid__head {
  display: contents;
}
.advantage-grid__num {
  display: none;
}
.index-advantage-section .advantage-grid__body p {
  font-size: var(--text-size-13);
  line-height: var(--text-leading);
  font-weight: var(--text-weight);
  color: var(--color-muted);
}
.index-advantage-section .advantage-grid__icon {
  width: 4.75rem;
  height: 4.75rem;
  margin-top: -0.125rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
.index-advantage-section .advantage-grid__icon--sm {
  width: 4rem;
  height: 4rem;
  margin-top: 0.25rem;
}
@media (min-width: 768px) {
  .index-advantage-section .advantage-grid__body p {
    font-size: 0.875rem;
  }
  .index-advantage-section .advantage-grid__icon {
    width: 6rem;
    height: 6rem;
    margin-top: -0.25rem;
  }
  .index-advantage-section .advantage-grid__icon--sm {
    width: 5rem;
    height: 5rem;
    margin-top: 0.375rem;
  }
}
.concept-advantage-list {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.concept-advantage-list__item {
  display: grid;
  grid-template-columns: clamp(4.5rem, 11vw, 7rem) minmax(0, 1fr);
  gap: clamp(1.25rem, 3vw, 2.5rem);
  align-items: center;
  padding-block: clamp(1.375rem, 2.8vw, 2rem);
}
.concept-advantage-list__item + .concept-advantage-list__item {
  border-top: 1px solid rgba(26, 26, 26, 0.09);
}
.concept-advantage-list__icon {
  width: clamp(4.5rem, 11vw, 7rem);
  height: clamp(4.5rem, 11vw, 7rem);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.concept-advantage-list__body {
  --concept-advantage-num-width: 2.25rem;
}
.concept-advantage-list__head {
  display: flex;
  align-items: center;
  gap: 0.875rem;
  margin-bottom: 0.625rem;
}
.concept-advantage-list__num {
  color: #E8621A;
  font-family: var(--font-body);
  font-size: clamp(1.25rem, 2.4vw, 1.5625rem);
  font-weight: 600;
  letter-spacing: 0.06em;
  line-height: 1;
  width: var(--concept-advantage-num-width);
  text-align: right;
  transform: translateY(-0.08em);
  flex-shrink: 0;
}
.concept-advantage-list__head h3 {
  margin: 0;
}
.concept-advantage-list__body p:not(.concept-advantage-list__num) {
  margin: 0;
  font-size: 0.875rem;
  line-height: var(--text-leading);
  font-weight: var(--text-weight);
  color: var(--color-muted);
  margin-left: calc(var(--concept-advantage-num-width) + 0.875rem);
}
.concept-advantage-list__body p:not(.concept-advantage-list__num) + p:not(.concept-advantage-list__num),
.concept-advantage-list__body p:not(.concept-advantage-list__num) + .concept-point__list {
  margin-top: 0.75rem;
}
.concept-advantage-list__body .concept-point__list li {
  font-size: var(--text-size-13);
  line-height: var(--text-leading);
}
.concept-advantage-list__body .concept-point__list {
  margin-left: calc(var(--concept-advantage-num-width) + 0.875rem);
}
@media (min-width: 768px) {
  .concept-advantage-list__item {
    grid-template-columns: minmax(0, 1fr) minmax(0, clamp(30rem, 56vw, 44rem)) minmax(0, 1fr);
    gap: clamp(2rem, 4vw, 3.5rem);
  }
  .concept-advantage-list__body {
    grid-column: 2;
    max-width: none;
    justify-self: center;
  }
  .concept-advantage-list__icon {
    justify-self: end;
  }
  .concept-advantage-list__item--reverse .concept-advantage-list__icon {
    grid-column: 3;
    grid-row: 1;
    justify-self: start;
  }
  .concept-advantage-list__item--reverse .concept-advantage-list__body {
    grid-row: 1;
  }
  .concept-advantage-list__icon {
    width: clamp(5.5rem, 12vw, 8.5rem);
    height: clamp(5.5rem, 12vw, 8.5rem);
  }
  .concept-advantage-list__icon--02 {
    width: clamp(4.6rem, 10.2vw, 7.1rem);
    height: clamp(4.6rem, 10.2vw, 7.1rem);
  }
  .concept-advantage-list__body p:not(.concept-advantage-list__num) {
    font-size: 0.9375rem;
  }
  .concept-advantage-list__body .concept-point__list li {
    font-size: 0.875rem;
  }
}
.concept-card {
  --concept-card-base-y: 0px;
  --concept-card-hover-y: 0px;
  transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.45s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: transform;
  box-shadow: 0 1px 0 rgba(26, 26, 26, 0.03);
}
@media (min-width: 768px) {
  .concept-card--offset {
    --concept-card-base-y: 2rem;
  }
}
[data-reveal].is-revealed.concept-card {
  transform: translate3d(0, calc(var(--concept-card-base-y) + var(--concept-card-hover-y)), 0);
}
[data-reveal].is-revealed.concept-card:hover {
  --concept-card-hover-y: -6px;
  box-shadow: 0 18px 32px rgba(26, 26, 26, 0.045),
    0 6px 12px rgba(26, 26, 26, 0.022);
}
@media (prefers-reduced-motion: reduce) {
  .concept-card {
    transition: none;
  }
}
.concept-promise-section {
  position: relative;
  overflow: visible;
  background-color: #ffffff;
  padding-top: clamp(4.25rem, 8vw, 6rem);
  padding-bottom: clamp(4.25rem, 8vw, 6rem);
  margin-bottom: 0;
}
.concept-promise-section::after {
  content: none;
}
.concept-promise-section__inner {
  position: relative;
  z-index: 1;
}
.concept-promise-section__copy {
  max-width: min(100%, 44rem);
  margin-inline: auto;
  text-align: center;
}
@media (min-width: 768px) {
  .concept-promise-section #concept-promise-heading {
    white-space: nowrap;
  }
}
@media (min-width: 768px) {
  .concept-promise-section {
    padding-top: clamp(4.75rem, 6.5vw, 7rem);
    padding-bottom: clamp(4.75rem, 6.5vw, 7rem);
  }
}
@media (min-width: 1024px) {
  .concept-promise-section {
    padding-top: clamp(5rem, 5.5vw, 7.5rem);
    padding-bottom: clamp(5rem, 5.5vw, 7.5rem);
  }
}
.hero-lede--index-philosophy .why-omori-panel__headline {
  font-feature-settings: 'palt' 1, 'kern' 1;
}
.hero-lede--index-philosophy .why-omori-point__label {
  writing-mode: vertical-rl;
  text-orientation: mixed;
  line-height: 1;
  padding-top: 2px;
}
.hero-lede--index-philosophy .why-omori-panel__points {
  position: relative;
}
.hero-lede--index-philosophy .why-omori-panel__divider-dot {
  display: none;
}
@media (min-width: 1024px) {
  .hero-lede--index-philosophy .why-omori-panel__divider-dot {
    display: block;
    position: absolute;
    left: 0;
    top: 50%;
    z-index: 1;
    width: 6px;
    height: 6px;
    margin-left: -3px;
    background: #e8621a;
    transform: translateY(-50%) rotate(45deg);
  }
}
.hero-lede--interlude > * {
  position: relative;
  z-index: 2;
}
.hero-lede--interlude .hero-lede__shell {
  padding-top: 3.5rem;
  padding-bottom: 3.75rem;
}
@media (min-width: 768px) {
  .hero-lede--interlude .hero-lede__shell {
    padding-top: 4.25rem;
    padding-bottom: 4.5rem;
  }
}
@media (min-width: 1024px) {
  .hero-lede--interlude .hero-lede__shell {
    padding-top: 4.5rem;
    padding-bottom: 4.75rem;
  }
}
.hero-lede--index-philosophy.hero-lede--interlude .hero-lede__shell {
  padding-top: 0;
  padding-bottom: 0;
}
.hero-lede--interlude .hero-intro__stat-value {
  font-size: clamp(2.25rem, 2.1vw + 1.6rem, 3.05rem);
  font-weight: var(--text-weight);
  line-height: 1.22;
  padding-top: 0.06em;
  width: 100%;
  text-align: center;
}
.hero-lede--interlude .hero-intro__stat-label {
  letter-spacing: var(--text-tracking);
  color: var(--color-ink);
  font-weight: var(--text-weight);
  margin-top: 0.5rem;
  width: 100%;
  text-align: center;
}
@media (min-width: 768px) {
  .hero-lede--interlude .hero-intro__stat-label {
    margin-top: 0.55rem;
  }
}
.hero-lede--interlude .hero-intro__stat {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.hero-lede--interlude .hero-intro__stat-figures {
  display: inline-flex;
  align-items: baseline;
  justify-content: center;
}
.hero-lede--interlude {
  margin: 1.25rem 0;
}
@media (min-width: 768px) {
  .hero-lede--interlude {
    margin: 1.75rem 0;
  }
}
.cta-ideal-home--photo-bg {
  --cta-bg-inset: clamp(1.25rem, 5vw, 2rem);
  position: relative;
  overflow: hidden;
  background-color: #ffffff;
}
@media (min-width: 768px) {
  .cta-ideal-home--photo-bg {
    --cta-bg-inset: clamp(1.25rem, 3vw, 2.5rem);
  }
}
@media (min-width: 1024px) {
  .cta-ideal-home--photo-bg {
    --cta-bg-inset: clamp(1.5rem, 3.5vw, 3rem);
  }
}
.cta-ideal-home--photo-bg::after {
  content: '';
  position: absolute;
  inset: var(--cta-bg-inset);
  pointer-events: none;
  z-index: 0;
  background-image: linear-gradient(
      180deg,
      rgba(18, 22, 18, 0.58) 0%,
      rgba(18, 22, 18, 0.50) 50%,
      rgba(18, 22, 18, 0.60) 100%
    ),
    url('/images/backgrounds/ideal-home-cta-bg.webp');
  background-size: cover, cover;
  background-position: center, center 68%;
}
.cta-ideal-home--photo-bg > * {
  position: relative;
  z-index: 2;
}
.cta-ideal-home--photo-bg .cta-ideal-home__heading {
  color: #ffffff;
  text-shadow: 0 1px 18px rgba(0, 0, 0, 0.45);
}
.cta-ideal-home--photo-bg .cta-ideal-home__lede {
  color: rgba(255, 255, 255, 0.92);
  text-shadow: 0 1px 14px rgba(0, 0, 0, 0.5);
}
.cta-ideal-home--photo-bg .site-btn--outline-ink {
  border-color: rgba(255, 255, 255, 0.75);
}
.cta-ideal-home--photo-bg .site-btn--outline-ink .site-btn__inner {
  color: #ffffff;
}
.cta-ideal-home--photo-bg .site-btn--outline-ink::before {
  background: #ffffff;
}
.cta-ideal-home--photo-bg .site-btn--outline-ink:hover .site-btn__inner,
.cta-ideal-home--photo-bg .site-btn--outline-ink:focus-visible .site-btn__inner {
  color: #1a1a1a;
}
.cta-ideal-home .section-label {
  width: 100%;
  justify-content: flex-start;
  font-size: 0.75rem;
  letter-spacing: var(--text-tracking);
}
.cta-ideal-home--photo-bg .section-label {
  color: rgba(255, 255, 255, 0.92);
  justify-content: center;
}
.cta-ideal-home--photo-bg .section-label::before {
  background: rgba(255, 255, 255, 0.6);
}
.cta-ideal-home .section-label::before {
  width: 22px;
}
@media (max-width: 767px) {
  .cta-ideal-home__actions {
    flex-wrap: nowrap;
    gap: 0.625rem;
    width: 100%;
  }
  .cta-ideal-home__actions .site-btn--lg {
    flex: 1 1 0;
    min-width: 0;
    padding: 0.65rem 1rem;
    font-size: var(--text-size-13);
  }
  .cta-ideal-home__actions .site-btn__inner {
    gap: 0.25rem;
    justify-content: center;
    white-space: nowrap;
  }
  .cta-ideal-home__actions .site-btn__inner svg {
    width: 0.875rem;
    height: 0.875rem;
  }
}
.hero-lede__stats {
  padding-top: 0.25rem;
}
.hero-lede .hero-intro__stat-figures [data-hero-count] {
  display: inline-block;
  text-align: right;
  font-variant-numeric: tabular-nums;
}
.hero-lede .hero-intro__stat:nth-child(1) .hero-intro__stat-figures [data-hero-count] {
  min-width: 3.5ch;
}
.hero-lede .hero-intro__stat:nth-child(2) .hero-intro__stat-figures [data-hero-count] {
  min-width: 2.75ch;
}
.hero-lede.hero-lede--interlude .hero-intro__stat-figures [data-hero-count] {
  text-align: center;
}
.hero-lede.hero-lede--interlude .hero-intro__stat:nth-child(1) .hero-intro__stat-figures [data-hero-count] {
  min-width: 3.5ch;
}
.hero-lede.hero-lede--interlude .hero-intro__stat:nth-child(2) .hero-intro__stat-figures [data-hero-count] {
  min-width: 2.75ch;
}
.hero-lede__aside {
  border-top: 1px solid rgba(221, 217, 210, 0.75);
  padding-top: 1.25rem;
}
@media (min-width: 1024px) {
  .hero-lede__aside {
    border-top: none;
    padding-top: 0;
    padding-left: clamp(1rem, 2vw, 1.75rem);
    margin-left: 0;
  }
}
.hero-lede__text {
  font-feature-settings: 'palt' 1, 'kern' 1;
}
.section-label {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  font-family: var(--font-body);
  font-size: var(--text-size-sm);
  font-weight: 600;
  letter-spacing: 0.12em;
  line-height: 1.4;
  text-transform: uppercase;
  color: #e8621a;
  font-feature-settings: 'palt' 1;
}
.section-label::before {
  content: '';
  display: block;
  width: 36px;
  height: 1px;
  background: currentColor;
  flex-shrink: 0;
}
.hero-intro__photo-tagline.section-label {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.65em;
  width: 100%;
  font-size: var(--text-size-sm);
  letter-spacing: var(--text-tracking);
  white-space: nowrap;
}
@media (min-width: 1024px) {
  .hero-intro__photo-tagline.section-label {
    font-size: 1rem;
    letter-spacing: var(--text-tracking);
    gap: 0.7em;
  }
}
.hero-intro__photo-tagline__text {
  flex: 0 0 auto;
}
.hero-intro__photo-tagline.section-label::before {
  content: none;
  display: none;
  width: 0;
}
.hero-intro__photo-tagline.section-label::after {
  content: '';
  display: block;
  flex: 1 1 0%;
  min-width: 2.5rem;
  width: 0;
  height: 1px;
  align-self: center;
  background: currentColor;
  opacity: 0.55;
  transform-origin: left center;
  transition: transform 0.95s cubic-bezier(0.22, 1, 0.36, 1);
  transition-delay: 0.08s;
}
@media (prefers-reduced-motion: no-preference) {
  html.hero-anim .hero-intro:not(.hero-intro--active) .hero-intro__photo-tagline.section-label::after {
    transform: scaleX(0.15);
  }
}
.hero-intro.hero-intro--active .hero-intro__photo-tagline.section-label::after {
  transform: scaleX(1);
}
@media (prefers-reduced-motion: reduce) {
  .hero-intro__photo-tagline.section-label::after {
    transform: scaleX(1) !important;
    transition: none !important;
  }
}
.hero-intro .hero-scroll-hint {
  text-decoration: none;
  opacity: 1;
  color: rgba(26, 26, 26, 0.68);
  transition: opacity 0.4s ease,
    color 0.3s ease;
}
.hero-intro .hero-scroll-hint:hover {
  color: #c4521a;
  opacity: 0.88;
}
@media (min-width: 1024px) {
  .hero-intro .hero-scroll-hint {
    position: absolute;
    bottom: 0;
    left: clamp(0.75rem, 2vw, 2rem);
    right: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.6rem;
    width: auto;
  }
}
.hero-scroll-hint__label {
  font-size: 0.58rem;
  letter-spacing: var(--text-tracking);
  text-transform: uppercase;
}
.hero-scroll-hint__rail {
  position: relative;
  width: 1px;
  height: 5rem;
  flex-shrink: 0;
}
.hero-scroll-hint__rail-line {
  position: absolute;
  inset: 0;
  background: currentColor;
}
.hero-scroll-hint__rail-dot {
  position: absolute;
  left: 50%;
  top: 0;
  width: 4px;
  height: 4px;
  margin-left: -2px;
  border-radius: 50%;
  background: #e8621a;
  box-shadow: 0 0 8px rgba(232, 98, 26, 0.5);
  animation: hero-scroll-rail-dot 2.2s cubic-bezier(0.45, 0, 0.55, 1) infinite;
}
@media (prefers-reduced-motion: reduce) {
  .hero-scroll-hint__rail-dot {
    animation: none;
    top: 50%;
    margin-top: -2px;
    opacity: 0.6;
  }
}
@keyframes hero-scroll-rail-dot {
  0% {
    top: 0;
    opacity: 1;
  }
  70% {
    top: calc(100% - 4px);
    opacity: 0.2;
  }
  71% {
    top: 0;
    opacity: 0;
  }
  100% {
    top: 0;
    opacity: 1;
  }
}
#header {
  transition: background-color 0.35s ease;
  background-color: transparent;
  border-bottom: none;
  box-shadow: none;
}
#header.scrolled,
#header.header-solid {
  background-color: transparent;
}
@media (prefers-reduced-motion: reduce) {
  #header {
    transition-duration: 0.01ms;
  }
}
#header img {
  display: block;
}
#header .header-logo-link .header-logo-img {
  width: auto;
  height: auto;
  max-height: 3.125rem;
  object-fit: contain;
}
@media (min-width: 768px) {
  #header .header-logo-link .header-logo-img {
    max-height: 3.625rem;
  }
}
#header .header-logo-link .header-brand {
  line-height: 1.15;
  display: inline-flex;
  align-items: center;
}
.header-brand {
  letter-spacing: var(--text-tracking);
  font-weight: var(--text-weight);
}
.header-nav-link {
  font-size: 0.9375rem;
  font-weight: var(--text-weight);
  letter-spacing: var(--text-tracking);
  color: #1A1A1A;
  line-height: 1.25;
  transition: color 0.2s ease;
}
@media (min-width: 1280px) {
  .header-nav-link {
    font-size: 1rem;
  }
}
.header-nav-link:hover {
  color: #E8621A;
}
#header nav .text-sm {
  font-weight: var(--text-weight);
  letter-spacing: var(--text-tracking);
}
footer {
  font-weight: var(--text-weight);
  letter-spacing: var(--text-tracking);
}
footer a:not(.site-btn) {
  font-weight: var(--text-weight);
}
footer .footer-tagline {
  font-size: var(--text-size-13);
  line-height: var(--text-leading);
  font-weight: var(--text-weight);
  letter-spacing: var(--text-tracking);
}
footer .footer-phone {
  font-weight: var(--text-weight);
  letter-spacing: var(--text-tracking);
}
footer .footer-meta {
  font-weight: var(--text-weight);
  letter-spacing: var(--text-tracking);
}
@media (max-width: 767px) {
  footer .footer-address {
    max-width: 18rem;
  }
  footer .footer-contact-block {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.625rem 1rem;
  }
  footer .footer-contact-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.125rem 0.625rem;
  }
  footer .footer-contact-meta .footer-phone {
    margin: 0;
  }
  footer .footer-contact-meta .footer-meta {
    font-size: 0.6875rem;
    line-height: 1.4;
  }
}
@media (min-width: 768px) {
  footer .footer-contact-block .site-btn {
    margin-bottom: 1.25rem;
  }
  footer .footer-contact-meta .footer-phone {
    margin-bottom: 0.25rem;
  }
}
.hamburger-btn__lines {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 6px;
  width: 26px;
  height: 22px;
}
.hamburger-btn__line {
  display: block;
  width: 100%;
  height: 2px;
  background-color: #1A1A1A;
  transform-origin: center;
  transition: transform 0.25s ease, opacity 0.2s ease;
}
.hamburger-btn[aria-expanded="true"] .hamburger-btn__line:nth-child(1) {
  transform: translateY(8px) rotate(45deg);
}
.hamburger-btn[aria-expanded="true"] .hamburger-btn__line:nth-child(2) {
  opacity: 0;
}
.hamburger-btn[aria-expanded="true"] .hamburger-btn__line:nth-child(3) {
  transform: translateY(-8px) rotate(-45deg);
}
.mobile-menu-panel {
  width: 100%;
  transition: max-height 0.42s cubic-bezier(0.4, 0, 0.2, 1),
    opacity 0.32s ease;
}
.mobile-menu-panel--collapsed {
  max-height: 0;
  opacity: 0;
  pointer-events: none;
  overflow: hidden;
}
.mobile-menu-panel--open {
  max-height: min(85vh, 480px);
  opacity: 1;
  pointer-events: auto;
}
.mobile-menu-panel__inner {
  opacity: 0;
  transform: translateY(-8px);
  transition: opacity 0.35s ease,
    transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.mobile-menu-panel--open .mobile-menu-panel__inner {
  opacity: 1;
  transform: translateY(0);
}
.mobile-menu-nav {
  width: 100%;
}
.mobile-menu-nav__cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem 1.75rem;
  width: 100%;
  align-items: stretch;
}
.mobile-menu-nav__col {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  min-width: 0;
}
.mobile-menu-nav__col--right {
  justify-content: flex-start;
}
.mobile-menu-nav__eyebrow {
  width: 100%;
  margin-bottom: 1rem;
}
.mobile-menu-nav__link {
  display: block;
  padding: 0.6rem 0.35rem;
  color: #1a1a1a;
  text-decoration: none;
  transition: color 0.2s ease;
}
.mobile-menu-nav__link:not(.mobile-menu-nav__link--sub):hover,
.mobile-menu-nav__link:not(.mobile-menu-nav__link--sub):focus-visible {
  color: #e8621a;
}
.mobile-menu-nav__link:not(.mobile-menu-nav__link--sub) .mobile-menu-nav__text {
  font-family: var(--font-body);
  font-size: 1.25rem;
  font-weight: var(--text-weight);
  letter-spacing: var(--text-tracking);
  line-height: var(--text-leading);
}
.mobile-menu-nav__link--sub {
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
  padding: 0.45rem 0.35rem;
}
.mobile-menu-nav__link--sub:hover,
.mobile-menu-nav__link--sub:focus-visible {
  color: #e8621a;
}
.mobile-menu-nav__num {
  flex-shrink: 0;
  color: #e8621a;
  font-size: 0.6875rem;
  letter-spacing: var(--text-tracking);
}
.mobile-menu-nav__link--sub .mobile-menu-nav__text {
  font-size: 0.9375rem;
  font-weight: var(--text-weight);
  letter-spacing: var(--text-tracking);
  color: var(--color-muted);
  transition: color 0.2s ease;
}
.mobile-menu-nav__link--sub:hover .mobile-menu-nav__text,
.mobile-menu-nav__link--sub:focus-visible .mobile-menu-nav__text {
  color: #e8621a;
}
.mobile-nav-services {
  margin: 0;
  padding: 0;
}
.mobile-nav-services__label {
  display: block;
  padding: 0.6rem 0.35rem 0.35rem;
}
.mobile-nav-services__label .mobile-menu-nav__text {
  font-size: 1.0625rem;
  font-weight: var(--text-weight);
  letter-spacing: var(--text-tracking);
}
.mobile-nav-services__links {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.mobile-menu-nav__cta {
  display: block;
  width: 100%;
  margin-top: 1.35rem;
  padding: 0;
  text-decoration: none;
}
.mobile-menu-nav__cta .site-btn {
  display: flex;
  width: 100%;
  justify-content: center;
}
@keyframes mobile-menu-nav-in {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes mobile-menu-text-reveal {
  from {
    opacity: 0;
    transform: translateX(-14px);
    clip-path: inset(0 100% 0 0);
  }
  to {
    opacity: 1;
    transform: translateX(0);
    clip-path: inset(0 0 0 0);
  }
}
.mobile-menu-panel--open .mobile-menu-nav__col {
  animation: mobile-menu-nav-in 0.5s cubic-bezier(0.22, 1, 0.36, 1) backwards;
}
.mobile-menu-panel--open .mobile-menu-nav__text {
  display: inline-block;
  animation: mobile-menu-text-reveal 0.55s cubic-bezier(0.22, 1, 0.36, 1) backwards;
}
.mobile-menu-panel--open .mobile-menu-nav__col--left {
  animation-delay: 0.04s;
}
.mobile-menu-panel--open .mobile-menu-nav__col--right {
  animation-delay: 0.1s;
}
.mobile-menu-panel--open .mobile-menu-nav__col--left > *:nth-child(1) .mobile-menu-nav__text {
  animation-delay: 0.12s;
}
.mobile-menu-panel--open .mobile-menu-nav__col--left > *:nth-child(2) .mobile-menu-nav__text {
  animation-delay: 0.18s;
}
.mobile-menu-panel--open .mobile-menu-nav__col--left > *:nth-child(3) .mobile-nav-services__label .mobile-menu-nav__text {
  animation-delay: 0.24s;
}
.mobile-menu-panel--open .mobile-menu-nav__col--left .mobile-nav-services__links .mobile-menu-nav__link:nth-child(1) .mobile-menu-nav__text {
  animation-delay: 0.3s;
}
.mobile-menu-panel--open .mobile-menu-nav__col--left .mobile-nav-services__links .mobile-menu-nav__link:nth-child(2) .mobile-menu-nav__text {
  animation-delay: 0.36s;
}
.mobile-menu-panel--open .mobile-menu-nav__col--left .mobile-nav-services__links .mobile-menu-nav__link:nth-child(3) .mobile-menu-nav__text {
  animation-delay: 0.42s;
}
.mobile-menu-panel--open .mobile-menu-nav__col--right > *:nth-child(1) .mobile-menu-nav__text {
  animation-delay: 0.16s;
}
.mobile-menu-panel--open .mobile-menu-nav__col--right > *:nth-child(2) .mobile-menu-nav__text {
  animation-delay: 0.22s;
}
.mobile-menu-panel--open .mobile-menu-nav__col--right > *:nth-child(3) .mobile-menu-nav__text {
  animation-delay: 0.28s;
}
.mobile-menu-panel--open .mobile-menu-nav > .mobile-menu-nav__cta {
  animation: mobile-menu-nav-in 0.5s cubic-bezier(0.22, 1, 0.36, 1) backwards;
  animation-delay: 0.32s;
}
.mobile-menu-panel--open .mobile-menu-nav > .mobile-menu-nav__cta .site-btn__inner {
  display: inline-flex;
  animation: mobile-menu-text-reveal 0.55s cubic-bezier(0.22, 1, 0.36, 1) backwards;
  animation-delay: 0.38s;
}
.mobile-menu-panel--open .mobile-menu-nav__eyebrow {
  animation: mobile-menu-nav-in 0.45s cubic-bezier(0.22, 1, 0.36, 1) backwards;
  animation-delay: 0.02s;
}
@media (max-width: 1023px) {
  body.mobile-menu-open {
    overflow: hidden;
  }
  #header:has(.mobile-menu-panel--open),
  #header.header-menu-open {
    position: fixed;
    inset: 0;
    left: 0;
    right: 0;
    width: 100%;
    max-width: none;
    min-height: 100dvh;
    min-height: 100svh;
    display: flex;
    flex-direction: column;
    background-color: var(--color-cream);
    transition: background-color 0.35s ease;
  }
  #header.header-menu-open .header-bar,
  #header:has(.mobile-menu-panel--open) .header-bar {
    flex-shrink: 0;
    width: 100%;
    max-width: none;
    margin-inline: 0;
    padding-inline: 1.25rem;
  }
  #header.header-menu-open .mobile-menu-panel--open,
  #header:has(.mobile-menu-panel--open) .mobile-menu-panel--open {
    flex: 1 1 auto;
    width: 100%;
    max-width: none;
    max-height: none;
    min-height: 0;
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .mobile-menu-panel__inner {
    width: 100%;
    max-width: none;
    box-sizing: border-box;
    padding: 1.25rem 1.5rem max(1.25rem, env(safe-area-inset-bottom));
  }
  .mobile-menu-nav,
  .mobile-menu-nav__eyebrow {
    max-width: none;
    width: 100%;
    margin-inline: 0;
  }
  .mobile-menu-nav__link:not(.mobile-menu-nav__link--sub) .mobile-menu-nav__text {
    font-size: 1.0625rem;
  }
}
@media (prefers-reduced-motion: reduce) {
  .mobile-menu-panel,
  .mobile-menu-panel__inner {
    transition-duration: 0.01ms;
  }
  .mobile-menu-panel--open .mobile-menu-nav__col,
  .mobile-menu-panel--open .mobile-menu-nav > .mobile-menu-nav__cta,
  .mobile-menu-panel--open .mobile-menu-nav__text,
  .mobile-menu-panel--open .mobile-menu-nav__eyebrow {
    animation: none;
  }
  .mobile-menu-panel--open .mobile-menu-panel__inner {
    opacity: 1;
    transform: none;
  }
}
.works-pickup-section {
  background-color: #ffffff;
}
.works-pickup-section__shell {
  width: 100%;
}
.works-pickup-grid {
  width: 100%;
  max-width: 60rem;
  margin-inline: auto;
}
@media (min-width: 1024px) {
  .works-pickup-grid {
    max-width: 64rem;
  }
  .works-pickup-grid--four {
    max-width: none;
  }
}
@media (max-width: 767px) {
  .works-pickup-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: 1rem;
    row-gap: 1.5rem;
  }
}
.works-pickup-item {
  color: inherit;
  text-decoration: none;
}
.works-pickup-item:focus-visible {
  outline: 2px solid #E8621A;
  outline-offset: 4px;
}
.works-pickup-item__body {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
  padding-top: 1.125rem;
}
@media (min-width: 768px) {
  .works-pickup-item__body {
    gap: 1rem;
    padding-top: 1.25rem;
  }
}
.works-pickup-item__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.375rem 0.5rem;
}
.works-pickup-item__date {
  flex-shrink: 0;
  margin-right: 0.125rem;
  font-size: var(--text-size-xs);
  line-height: 1.25;
  font-weight: var(--text-weight);
  letter-spacing: var(--text-tracking);
  font-feature-settings: normal;
  color: var(--color-muted);
}
@media (min-width: 768px) {
  .works-pickup-item__date {
    font-size: var(--text-size-sm);
  }
}
.detail-aside-item__date,
#other-works-list time.detail-aside-item__date {
  font-size: var(--text-size-xs);
  line-height: 1.25;
  font-weight: var(--text-weight);
  letter-spacing: var(--text-tracking);
  font-feature-settings: normal;
  color: var(--color-muted);
}
@media (min-width: 768px) {
  .detail-aside-item__date,
  #other-works-list time.detail-aside-item__date {
    font-size: var(--text-size-13);
  }
}
#other-blogs-list time.detail-aside-item__date {
  font-size: 0.6875rem;
  color: rgba(26, 26, 26, 0.45);
}
@media (min-width: 768px) {
  #other-blogs-list time.detail-aside-item__date {
    font-size: 0.6875rem;
  }
}
.detail-aside-item__thumb {
  flex-shrink: 0;
  width: 4.5rem;
  height: 3.375rem;
}
.detail-aside-item__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.25rem 0.375rem;
}
.detail-aside-item__meta .works-pickup-item__tag {
  padding: 0.0625rem 0.3125rem;
  font-size: 0.625rem;
  letter-spacing: 0.03em;
}
@media (min-width: 768px) {
  .detail-aside-item__meta .works-pickup-item__tag {
    padding: 0.125rem 0.375rem;
    font-size: 0.6875rem;
  }
}
.detail-meta-date,
#detail-updated.detail-meta-date {
  font-size: var(--text-size-sm);
  line-height: var(--text-leading);
  font-weight: var(--text-weight);
  letter-spacing: var(--text-tracking);
  font-feature-settings: normal;
  color: var(--color-muted);
}
.detail-main-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.375rem 0.5rem;
}
.detail-main-meta .detail-meta-date {
  flex-shrink: 0;
  margin-right: 0.125rem;
}
.works-pickup-item__title {
  color: var(--color-ink, #1a1a1a);
  margin: 0;
  min-height: calc(2 * var(--text-leading) * 1em);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  overflow: hidden;
}
.works-pickup-item__tag {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  padding: 0.125rem 0.4375rem;
  font-size: 0.6875rem;
  line-height: 1.35;
  font-weight: var(--text-weight);
  letter-spacing: 0.04em;
  font-feature-settings: 'palt' 1;
  color: var(--color-muted);
  background: rgba(26, 26, 26, 0.07);
  border: none;
}
@media (min-width: 768px) {
  .works-pickup-item__tag {
    padding: 0.1875rem 0.5rem;
    font-size: 0.75rem;
  }
}
@media (min-width: 768px) {
  .works-pickup-item__title {
    font-size: var(--text-size);
  }
}
.text-date {
  font-size: var(--text-size-sm);
  line-height: var(--text-leading);
  font-weight: var(--text-weight);
  letter-spacing: var(--text-tracking);
  font-feature-settings: normal;
  color: #E8621A;
}
.text-date--sm {
  font-size: var(--text-size-xs);
}
@media (min-width: 768px) {
  .text-date {
    font-size: var(--text-size-sm);
  }
  .text-date--sm {
    font-size: var(--text-size-sm);
  }
}
#news-top-list {
  display: grid;
  row-gap: 0.5rem;
}
.news-top-row {
  display: grid;
  grid-template-columns: 7.5rem 5rem minmax(0, 1fr) 1.5rem;
  align-items: center;
  column-gap: 1.125rem;
  padding: 1.5rem 1.5rem;
  color: inherit;
  text-decoration: none;
  background: #fff;
}
.news-top-row__date {
  white-space: nowrap;
  color: var(--color-muted, #3a3a3a);
}
.news-top-row__cat {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 5rem;
  padding: 0.2rem 0.5rem;
  color: var(--color-ink, #1a1a1a);
  border: 1px solid #DDD9D2;
  background: #fff;
  white-space: nowrap;
}
.news-top-row__title {
  color: var(--color-ink, #1a1a1a);
  text-align: left;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  overflow: hidden;
  transition: color 0.2s ease;
}
.news-top-row:hover .news-top-row__title,
.news-top-row:hover .news-top-row__arrow {
  color: #E8621A;
}
.news-top-row__arrow {
  width: 1.375rem;
  height: 1.375rem;
  color: var(--color-muted, #3a3a3a);
  transition: color 0.2s ease;
}
@media (min-width: 768px) {
  #news-top-list {
    row-gap: 0.625rem;
  }
  .news-top-row {
    grid-template-columns: 9rem 5.5rem minmax(0, 1fr) 1.5rem;
    column-gap: 1.75rem;
    padding: 1.875rem 2rem;
  }
  .news-top-row__cat {
    width: 5.5rem;
    font-size: var(--text-size-xs);
  }
  .news-top-row__title {
    font-size: var(--text-size);
    -webkit-line-clamp: 2;
    line-clamp: 2;
  }
}
.list-card-link {
  color: inherit;
  text-decoration: none;
}
.list-card-link:focus-visible {
  outline: 2px solid #E8621A;
  outline-offset: 3px;
}
.list-card-elev {
  transition: transform 0.55s cubic-bezier(0.22, 1, 0.36, 1),
    border-color 0.5s ease,
    box-shadow 0.55s cubic-bezier(0.22, 1, 0.36, 1);
  background: #fff;
  border: 1px solid #ddd9d2;
  box-shadow: 0 1px 0 rgba(26, 26, 26, 0.03);
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.list-card-elev::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  z-index: 1;
  box-shadow: inset 0 0 0 1px rgba(232, 98, 26, 0.0);
  opacity: 0;
  transform: scale(0.985);
  transition: opacity 0.45s cubic-bezier(0.22, 1, 0.36, 1),
    transform 0.55s cubic-bezier(0.22, 1, 0.36, 1),
    box-shadow 0.55s cubic-bezier(0.22, 1, 0.36, 1);
}
.list-card-elev:hover {
  transform: translateY(-2px);
  border-color: rgba(232, 98, 26, 0.35);
  box-shadow: 0 20px 44px rgba(26, 26, 26, 0.07),
    0 8px 14px rgba(26, 26, 26, 0.04);
}
.list-card-elev:hover::after,
.list-card-link:focus-visible .list-card-elev::after {
  opacity: 1;
  transform: scale(1);
  box-shadow: inset 0 0 0 1px rgba(232, 98, 26, 0.32);
}
@media (prefers-reduced-motion: reduce) {
  .list-card-elev {
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
  }
  .list-card-elev::after {
    transition: none;
    transform: none;
  }
  .list-card-elev:hover {
    transform: none;
  }
}
.list-card-static:hover {
  transform: none;
  border-color: #ddd9d2;
  box-shadow: 0 1px 0 rgba(26, 26, 26, 0.03);
}
.list-card-navy-cta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  width: 100%;
  padding: 0.75rem 1rem;
  font-size: 0.8rem;
  font-weight: 500;
  color: #f7f4ef;
  background: #1a1a1a;
  transition: background-color 0.45s ease, color 0.45s ease;
}
.list-card-link:hover .list-card-navy-cta {
  background-color: #2a2a2a;
}
.list-card-navy-cta svg {
  transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}
.list-card-link:hover .list-card-navy-cta svg {
  transform: translateX(2px);
}
.list-card-arrow {
  position: absolute;
  right: 0.95rem;
  bottom: 0.95rem;
  width: 2.5rem;
  height: 2.5rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 9999px;
  border: 1px solid rgba(221, 217, 210, 0.95);
  background: rgba(255, 255, 255, 0.92);
  color: #1A1A1A;
  box-shadow: 0 10px 22px rgba(26, 26, 26, 0.08);
  transition: transform 0.45s cubic-bezier(0.22, 1, 0.36, 1), border-color 0.3s ease, background-color 0.3s ease, color 0.3s ease;
}
.list-card-arrow--footer {
  position: static;
  right: auto;
  bottom: auto;
  width: auto;
  height: auto;
  border-radius: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  color: var(--color-muted);
  transition: color 0.25s ease, transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
}
.list-card-link:hover .list-card-arrow,
.list-card-link:focus-visible .list-card-arrow {
  transform: translateX(2px);
  border-color: rgba(232, 98, 26, 0.55);
  color: #E8621A;
}
.list-card-link:hover .list-card-arrow--footer,
.list-card-link:focus-visible .list-card-arrow--footer {
  color: #1A1A1A;
}
@media (prefers-reduced-motion: reduce) {
  .list-card-arrow {
    transition: none;
  }
  .list-card-link:hover .list-card-arrow,
  .list-card-link:focus-visible .list-card-arrow {
    transform: none;
  }
}
.section-viewall-link {
  text-decoration: none;
  border-bottom-color: currentColor;
}
.section-viewall-link:hover,
.section-viewall-link:focus-visible {
  color: #1A1A1A;
  border-bottom-color: #1A1A1A;
}
.section-viewall-link:focus-visible {
  outline: 2px solid #E8621A;
  outline-offset: 3px;
}
.section-viewall-link svg {
  transition: transform 0.3s cubic-bezier(0.22, 1, 0.36, 1);
}
.section-viewall-link:hover svg,
.section-viewall-link:focus-visible svg {
  transform: translateX(2px);
}
@media (prefers-reduced-motion: reduce) {
  .section-viewall-link svg {
    transition: none;
  }
}
.buyback-reason-section {
  padding-top: clamp(2.5rem, 5vw, 4rem);
  padding-bottom: clamp(6rem, 10vw, 8.5rem);
}
.buyback-reason-lead {
  text-align: center;
}
.buyback-reason-lead h2 {
  margin: 0;
}
.buyback-reason-lead h2::after {
  content: "";
  display: block;
  width: 2.5rem;
  height: 1px;
  margin: clamp(1rem, 2.2vw, 1.35rem) auto 0;
  background: #E8621A;
}
.buyback-reason-lead p {
  margin: 1rem auto 0;
  max-width: 44rem;
  color: var(--color-muted);
  font-size: 1rem;
  line-height: var(--text-leading);
}
.buyback-section-heading {
  margin-block: clamp(6.5rem, 10vw, 9rem) clamp(3.5rem, 6vw, 6rem);
  text-align: center;
}
.buyback-section-heading__title {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(1.25rem, 3vw, 2.5rem);
  width: 100%;
}
.buyback-section-heading__copy {
  flex: 0 1 auto;
  max-width: 42rem;
}
.buyback-section-heading__copy h2 {
  margin: 0;
}
.buyback-section-heading__line {
  flex: 1 1 0;
  max-width: clamp(8rem, 25vw, 18rem);
  height: 1px;
  background: rgba(26, 26, 26, 0.22);
}
.buyback-section-intro {
  margin: clamp(0.65rem, 1.5vw, 0.85rem) 0 0;
  color: var(--color-muted);
  font-size: 1rem;
  line-height: var(--text-leading);
  text-align: center;
}
.buyback-reason-list {
  margin-top: 0;
  max-width: min(100%, 72rem);
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  gap: clamp(5.5rem, 10vw, 9.5rem);
}
.buyback-reason-item {
  display: grid;
  gap: clamp(1.75rem, 5vw, 4rem);
  align-items: center;
}
.buyback-reason-item__body {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.buyback-reason-item__worry,
.buyback-reason-item__solution {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.buyback-reason-item__worry h3,
.buyback-reason-item__solution h4 {
  margin: 0;
}
.buyback-reason-item__worry h3 {
  font-size: clamp(1.2rem, 1.8vw, 1.375rem);
}
.buyback-reason-item__header {
  display: flex;
  align-items: baseline;
  gap: 1rem;
}
.buyback-reason-item__media {
  overflow: hidden;
  background: var(--color-cream);
  aspect-ratio: 16 / 11.4;
}
.buyback-reason-item__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
p.buyback-reason-item__num {
  margin: 0;
  color: #E8621A !important;
  font-family: var(--font-body);
  font-size: clamp(1.25rem, 2vw, 1.5rem) !important;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.12em;
}
.buyback-reason-item__bridge {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  margin: clamp(1.5rem, 2.5vw, 2rem) 0 0;
  color: #E8621A;
  font-size: 1rem;
  letter-spacing: 0.18em;
}
.buyback-reason-item__bridge::after {
  content: "";
  width: 2.25rem;
  height: 1px;
  background: rgba(232, 98, 26, 0.55);
}
.buyback-reason-item__solution h4 {
  color: var(--color-ink);
  font-size: clamp(1.125rem, 1.6vw, 1.25rem);
  font-weight: 500;
  line-height: var(--heading-leading);
}
.buyback-reason-item__worry p,
.buyback-reason-item__solution p {
  margin: 0;
  color: var(--color-muted);
  font-size: 1rem;
  line-height: var(--text-leading);
}
@media (min-width: 768px) {
  .buyback-reason-item {
    grid-template-columns: minmax(0, 0.88fr) minmax(17rem, 1fr);
  }
  .buyback-reason-item--reverse {
    grid-template-columns: minmax(17rem, 1fr) minmax(0, 0.88fr);
  }
  .buyback-reason-item--reverse .buyback-reason-item__media {
    grid-column: 2;
    grid-row: 1;
  }
  .buyback-reason-item--reverse .buyback-reason-item__body {
    grid-column: 1;
    grid-row: 1;
    justify-self: end;
  }
  .buyback-reason-item__media {
    width: 100%;
  }
  .buyback-reason-item__body {
    max-width: 37rem;
  }
}
.buyback-flow-cta {
  padding: 0 clamp(1.5rem, 5vw, 4.5rem) clamp(3.5rem, 7vw, 5.5rem);
}
.buyback-flow-cta__inner {
  max-width: min(100%, 64rem);
  margin-inline: auto;
  padding: clamp(1.5rem, 4vw, 2.5rem) 0 0;
  border-top: 1px solid rgba(26, 26, 26, 0.14);
  position: relative;
  text-align: center;
}
.buyback-flow-cta__inner::before {
  content: "";
  position: absolute;
  top: -1px;
  left: 50%;
  width: clamp(3.25rem, 8vw, 5.5rem);
  height: 1px;
  background: #E8621A;
  transform: translateX(-50%);
}
.buyback-flow-cta__label {
  margin: 0 0 0.75rem;
  color: #C85A1A;
  font-size: 0.75rem;
  letter-spacing: 0.16em;
}
.buyback-flow-cta__inner h2 {
  margin: 0;
}
.buyback-flow-cta__inner p:not(.buyback-flow-cta__label) {
  max-width: 43rem;
  margin: 1rem auto 0;
  color: var(--color-muted);
  font-size: var(--text-size-sm);
  line-height: var(--text-leading);
}
.buyback-flow-cta__actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.875rem;
  margin-top: clamp(1.5rem, 3vw, 2rem);
}
@media (max-width: 767px) {
  body[data-page] section.buyback-reason-section .buyback-reason-lead h2.font-serif.text-ink {
    font-size: 1.1875rem !important;
    line-height: 1.45 !important;
  }
  body[data-page] section.buyback-reason-section .buyback-reason-lead p {
    font-size: 0.8125rem !important;
    line-height: 1.75 !important;
  }
  body[data-page] section.buyback-flow-cta .buyback-flow-cta__inner h2.font-serif.text-ink {
    font-size: 0.9375rem !important;
    line-height: 1.5 !important;
  }
  body[data-page] section.buyback-flow-cta .buyback-flow-cta__inner p:not(.buyback-flow-cta__label) {
    font-size: 0.8125rem !important;
    line-height: 1.7 !important;
  }
  body[data-page] section.buyback-flow-cta .buyback-flow-cta__actions .site-btn--lg {
    padding: 0.7rem 1.5rem;
    font-size: 0.8125rem;
  }
  body[data-page] section.buyback-flow-cta .buyback-flow-cta__actions .site-btn--lg .site-btn__inner svg {
    width: 0.875rem;
    height: 0.875rem;
  }
  body[data-page^="service-"] section.buyback-flow-cta {
    padding-top: 2.25rem !important;
    padding-bottom: 2.25rem !important;
  }
  body[data-page] section.buyback-flow-cta .buyback-flow-cta__inner {
    padding-top: 1.375rem !important;
    padding-bottom: 1.75rem !important;
    border-bottom: 1px solid rgba(26, 26, 26, 0.14);
  }
  body[data-page] section.buyback-flow-cta .buyback-flow-cta__inner::after {
    content: "";
    position: absolute;
    bottom: -1px;
    left: 50%;
    width: clamp(3.25rem, 8vw, 5.5rem);
    height: 1px;
    background: #E8621A;
    transform: translateX(-50%);
  }
  body[data-page] section.buyback-reason-section .buyback-section-heading {
    margin-top: 3rem !important;
    margin-bottom: 2.5rem !important;
  }
  body[data-page] section.buyback-reason-section .buyback-reason-list {
    gap: 4.25rem !important;
  }
  body[data-page] section.buyback-reason-section .buyback-reason-item {
    gap: 1.375rem !important;
  }
  body[data-page] section.buyback-reason-section .buyback-section-heading__copy h2.font-serif.text-ink {
    font-size: 1rem !important;
    line-height: 1.5 !important;
  }
  body[data-page] section.buyback-reason-section .buyback-section-intro {
    display: none;
  }
  body[data-page] section.buyback-reason-section .buyback-section-heading__line {
    flex: 0 0 clamp(1.25rem, 6vw, 2.5rem);
  }
  body[data-page] section.buyback-reason-section .buyback-reason-item__worry h3.font-serif {
    font-size: 1.0625rem !important;
  }
  body[data-page] section.buyback-reason-section p.buyback-reason-item__num {
    font-size: 1.0625rem !important;
    line-height: 1.45 !important;
    letter-spacing: 0.06em !important;
  }
  body[data-page] section.buyback-reason-section .buyback-reason-item__bridge {
    font-size: 0.8125rem !important;
    margin-top: 1rem !important;
  }
  body[data-page] section.buyback-reason-section .buyback-reason-item__solution h4 {
    font-size: 1.0625rem !important;
  }
  body[data-page] section.buyback-reason-section .buyback-reason-item__worry p:not(.buyback-reason-item__num),
  body[data-page] section.buyback-reason-section .buyback-reason-item__solution p {
    font-size: 0.8125rem !important;
    line-height: 1.75 !important;
  }
}
.index-solution {
  overflow-x: clip;
  padding-inline: clamp(1.5rem, 5vw, 4.5rem);
}
body[data-page^="service-"] section.index-solution {
  padding-bottom: clamp(4rem, 8vw, 7rem);
}
.services-showcase {
  --services-showcase-inset: clamp(1.5rem, 4vw, 2.5rem);
  --services-showcase-photo-h: clamp(12.75rem, 25vw, 18.5rem);
  --services-showcase-overlap: clamp(2.75rem, 5vw, 4.75rem);
  max-width: 90rem;
  margin-inline: auto;
  padding-inline: 0;
  row-gap: clamp(4.25rem, 8vw, 6.5rem);
}
.services-showcase__header {
  max-width: 90rem;
  margin-inline: auto;
  padding-inline: var(--services-showcase-inset);
  margin-bottom: 0;
}
.services-showcase__header + .services-showcase__row {
  margin-top: calc(-1 * clamp(1.75rem, 3.5vw, 2.75rem));
}
.services-showcase__row--photo-left[data-reveal] {
  transform: translateX(-32px);
}
.services-showcase__row--photo-right[data-reveal] {
  transform: translateX(32px);
}
.services-showcase__row[data-reveal].is-revealed {
  transform: translateX(0);
}
.services-showcase__body {
  display: flex;
  flex-direction: column;
  gap: 1.75rem;
}
.services-showcase__media {
  overflow: hidden;
  height: var(--services-showcase-photo-h);
  width: 100%;
}
@media (max-width: 767px) {
  .services-showcase {
    --services-showcase-inset: 0.75rem;
    counter-reset: service-mobile-no;
  }
  .services-showcase__body {
    display: flex;
    flex-direction: column;
    gap: 0;
  }
  .services-showcase__header.text-center {
    padding-left: 0.75rem !important;
    padding-right: 0.75rem !important;
  }
  .services-showcase__header.text-center h2 {
    white-space: nowrap;
    font-size: clamp(1.125rem, 5vw, 1.3125rem) !important;
    line-height: 1.35 !important;
  }
  .services-showcase__row--photo-left[data-reveal],
  .services-showcase__row--photo-right[data-reveal],
  .services-showcase__row[data-reveal].is-revealed {
    transform: none !important;
  }
  .services-showcase__row {
    overflow: clip;
    counter-increment: service-mobile-no;
  }
  .services-showcase__media {
    height: clamp(11.25rem, 44vw, 13rem);
    position: relative;
    z-index: 0;
  }
  .services-showcase__row--photo-left .services-showcase__media {
    width: 100%;
    margin: 0;
  }
  body[data-page] .services-showcase__row--photo-left .services-showcase__content {
    margin: -2.55rem 1.15rem 0 !important;
  }
  body[data-page] .services-showcase__row--photo-right .services-showcase__content {
    margin: -2.55rem 1.15rem 0 !important;
  }
  .services-showcase__row--photo-right .services-showcase__media {
    width: 100%;
    margin: 0;
    order: 1;
  }
  .services-showcase__row--photo-right .services-showcase__content {
    order: 2;
  }
  body[data-page] .services-showcase .services-showcase__content {
    position: relative;
    z-index: 1;
    max-width: none;
    padding: 0.72rem 0.9rem !important;
    text-align: center;
  }
  .services-showcase__label {
    display: none;
  }
  body[data-page] .services-showcase .services-showcase__title.font-serif {
    margin: 0 0 0 !important;
    font-size: 0.92rem !important;
    line-height: 1.24 !important;
    white-space: nowrap;
    text-align: center;
  }
  .services-showcase__title::before {
    content: counter(service-mobile-no, decimal-leading-zero) " ";
    color: #E8621A;
    font-family: var(--font-body);
    font-weight: 600;
    letter-spacing: 0.11em;
    margin-right: 0.25rem;
  }
  body[data-page] .services-showcase .services-showcase__content .services-showcase__desc.text-sm.text-muted {
    margin: 0.72rem 0 0.84rem !important;
    line-height: 1.65 !important;
    font-size: 0.73rem !important;
    text-align: center;
  }
  body[data-page] .services-showcase .services-showcase__btn.site-btn--lg {
    align-self: center;
    margin-top: 0 !important;
    padding: 0.36rem 0.62rem !important;
    font-size: 0.76rem !important;
    line-height: 1.2 !important;
    min-height: auto !important;
  }
}
.services-showcase__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.services-showcase__content {
  background: #ffffff;
  padding-block: clamp(1.25rem, 2.5vw, 1.875rem);
  padding-inline: var(--services-showcase-inset);
}
.services-subtitle {
  color: #E8621A;
  font-family: var(--font-body);
  font-size: var(--text-size-sm);
  font-weight: 600;
  letter-spacing: 0.12em;
  line-height: 1.4;
  text-transform: uppercase;
  font-feature-settings: 'palt' 1;
}
.services-showcase__label {
  margin: 0 0 0.5rem;
  font-weight: 600;
}
.services-showcase__title {
  margin: 0.375rem 0 1.125rem;
}
@media (min-width: 768px) {
  .services-showcase__title {
    margin: 0.5rem 0 1rem;
  }
}
.services-showcase__desc {
  margin: 0;
  line-height: 1.9;
}
.services-showcase__btn {
  align-self: flex-start;
  margin-top: 1.375rem;
  padding-block: 0.65rem;
}
@media (min-width: 768px) {
  .services-showcase__btn {
    margin-top: 1.25rem;
  }
}
@media (min-width: 768px) {
  .services-showcase__body {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 0;
    align-items: center;
    min-height: var(--services-showcase-photo-h);
  }
  .services-showcase__row--photo-left .services-showcase__body {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    transform: translateX(clamp(0.75rem, 2vw, 1.5rem));
  }
  .services-showcase__row--photo-right .services-showcase__body {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    transform: translateX(calc(-1 * clamp(0.75rem, 2vw, 1.5rem)));
  }
  .services-showcase__row--photo-left .services-showcase__media,
  .services-showcase__row--photo-right .services-showcase__media {
    height: var(--services-showcase-photo-h);
    max-width: none;
    position: relative;
    z-index: 0;
  }
  .services-showcase__row--photo-left .services-showcase__media {
    grid-column: 1;
    width: min(100%, clamp(30rem, 48vw, 42rem));
    justify-self: end;
    margin: 0;
  }
  .services-showcase__row--photo-left .services-showcase__content {
    grid-column: 2;
    max-width: clamp(22rem, 34vw, 28rem);
    justify-self: start;
    margin-left: calc(var(--services-showcase-overlap) * -1);
    padding: clamp(1.125rem, 2vw, 1.5rem) clamp(1.5rem, 2.8vw, 2.25rem);
    position: relative;
    z-index: 1;
  }
  .services-showcase__row--photo-right .services-showcase__content {
    grid-column: 1;
    max-width: clamp(22rem, 34vw, 28rem);
    justify-self: end;
    margin-right: calc(var(--services-showcase-overlap) * -1);
    padding: clamp(1.125rem, 2vw, 1.5rem) clamp(1.5rem, 2.8vw, 2.25rem);
    position: relative;
    z-index: 1;
  }
  .services-showcase__row--photo-right .services-showcase__media {
    grid-column: 2;
    width: min(100%, clamp(30rem, 48vw, 42rem));
    justify-self: start;
    margin-left: 0;
  }
}
.solution-card-link {
  display: flex;
  position: relative;
  overflow: hidden;
  isolation: isolate;
  color: inherit;
  text-decoration: none;
}
.services-cards-grid--three .solution-card-link {
  align-items: center;
  text-align: center;
}
.services-cards-grid--three .solution-card-link__head {
  justify-content: center;
}
.services-cards-grid--three .solution-card-desc {
  text-align: center;
}
.solution-card-link__icon {
  position: relative;
  z-index: 1;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  background: var(--color-cream);
  color: var(--color-ink);
}
.solution-card-link__icon svg {
  width: 1.25rem;
  height: 1.25rem;
}
@media (min-width: 768px) {
  .solution-card-link__icon {
    width: 4.25rem;
    height: 4.25rem;
  }
  .solution-card-link__icon svg {
    width: 1.65rem;
    height: 1.65rem;
  }
}
.solution-card-link::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  background: var(--color-cream);
  transform: translateY(-100%);
  transition: transform 0.55s cubic-bezier(0.22, 1, 0.36, 1);
}
.solution-card-link > * {
  position: relative;
  z-index: 1;
}
.solution-card-link:focus-visible {
  outline: 2px solid #E8621A;
  outline-offset: 3px;
}
.solution-card-link:hover::before,
.solution-card-link:focus-visible::before {
  transform: translateY(0);
}
.solution-card-desc {
  min-height: 1.75em;
}
@media (prefers-reduced-motion: reduce) {
  .solution-card-link,
  .solution-card-link::before {
    transition: none;
  }
}
input[type="text"],
input[type="email"],
input[type="password"],
input[type="tel"],
input[type="number"],
input[type="date"],
textarea,
select {
  font-family: var(--font-body);
  font-size: var(--text-size);
  line-height: var(--text-leading);
  font-weight: var(--text-weight);
  letter-spacing: var(--text-tracking);
  font-feature-settings: 'palt' 1;
  color: var(--color-ink);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  border-radius: 0 !important;
  border: 1px solid #DDD9D2 !important;
  background: #fff;
}
select {
  appearance: none;
  -webkit-appearance: none;
  padding-right: 2.5rem;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%231A1A1A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  background-size: 0.75rem;
}
input:focus, textarea:focus, select:focus {
  outline: none !important;
  border-color: #1A1A1A !important;
  box-shadow: none !important;
}
[data-admin-modal-panel] {
  transition: transform 0.22s cubic-bezier(0.4,0,0.2,1), opacity 0.22s ease;
  transform: translateY(10px) scale(0.98);
  opacity: 0;
}
.admin-modal--open [data-admin-modal-panel] {
  transform: translateY(0) scale(1);
  opacity: 1;
}
[data-admin-modal-panel] {
  scrollbar-width: thin;
  scrollbar-color: rgba(26, 26, 26, 0.22) transparent;
}
[data-admin-modal-panel]::-webkit-scrollbar {
  width: 8px;
}
[data-admin-modal-panel]::-webkit-scrollbar-track {
  background: transparent;
}
[data-admin-modal-panel]::-webkit-scrollbar-thumb {
  background: rgba(26, 26, 26, 0.22);
  border-radius: 0;
}
[data-admin-modal-panel]::-webkit-scrollbar-thumb:hover {
  background: rgba(26, 26, 26, 0.32);
}
.admin-btn {
  appearance: none;
  border: 1px solid currentColor;
  background: transparent;
  color: #1a1a1a;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.4rem 0.75rem;
  font-size: var(--text-size-13);
  font-weight: 500;
  line-height: 1.25;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}
.admin-btn:focus-visible {
  outline: 2px solid var(--color-orange);
  outline-offset: 3px;
}
.admin-btn[disabled] {
  opacity: 0.6;
  cursor: not-allowed;
}
.admin-btn--edit {
  color: var(--color-navy);
  border-color: currentColor;
}
.admin-btn--edit:hover {
  background: rgba(35, 54, 84, 0.08);
}
.admin-btn--delete {
  --admin-btn-maroon: #7a1f2b;
  color: var(--admin-btn-maroon);
  border-color: currentColor;
}
.admin-btn--delete:hover {
  background: rgba(122, 31, 43, 0.08);
}
.admin-btn--preview {
  color: var(--color-orange);
  border-color: currentColor;
}
.admin-btn--preview:hover {
  background: rgba(232, 98, 26, 0.08);
}
.loading {
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 2px solid rgba(0,0,0,0.1);
  border-radius: 50%;
  border-top-color: #1A1A1A;
  animation: spin 0.8s linear infinite;
}
@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}
::-webkit-scrollbar {
  width: 6px;
}
::-webkit-scrollbar-track {
  background: #ffffff;
}
::-webkit-scrollbar-thumb {
  background: #E8621A;
  border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover {
  background: #c4521a;
}
@media (max-width: 767px) {
  :root {
    --heading-leading: 1.45;
  }
  body[data-page="index"] .hero-intro.hero-intro--layout {
    position: relative;
    display: block !important;
    min-height: 100svh;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    background: transparent !important;
    overflow: hidden;
  }
  body[data-page="index"] .hero-intro--layout .hero-intro__left-col {
    display: contents;
  }
  body[data-page="index"] .hero-intro--layout .hero-intro__media-col {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 0;
    order: unset;
    width: 100% !important;
    min-height: 0 !important;
    margin-top: 0 !important;
    flex: none !important;
  }
  body[data-page="index"] .hero-intro--layout .hero-intro__visual-frame,
  body[data-page="index"] .hero-intro--layout .hero-intro__visual,
  body[data-page="index"] .hero-intro--layout .hero-intro__visual-inner {
    min-height: 100%;
    height: 100%;
  }
  body[data-page="index"] .hero-intro--layout .hero-intro__img {
    object-position: 68% 28%;
  }
  body[data-page="index"] .hero-intro__visual-fade {
    display: block;
    background: linear-gradient(
      180deg,
      rgba(26, 26, 26, 0.12) 0%,
      rgba(26, 26, 26, 0) 22%,
      rgba(26, 26, 26, 0) 38%,
      rgba(26, 26, 26, 0.45) 68%,
      rgba(26, 26, 26, 0.84) 100%
    );
  }
  body[data-page="index"] .hero-intro--layout .hero-intro__title-wrap {
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 2;
    display: flex;
    flex-direction: column;
    flex: none !important;
    margin: 0 !important;
    padding: 0 1.25rem max(1.75rem, env(safe-area-inset-bottom, 0px)) !important;
    text-align: left;
  }
  body[data-page="index"] .hero-intro--layout .hero-intro__head-block {
    align-items: flex-start;
    width: 100%;
    max-width: none;
    gap: 0.75rem;
  }
  body[data-page="index"] .hero-intro__title {
    color: #fff;
    font-size: 1.4375rem !important;
    line-height: 1.38 !important;
    text-align: left;
    text-wrap: balance;
  }
  body[data-page="index"] .hero-intro__lede {
    color: rgba(255, 255, 255, 0.9);
    font-size: var(--text-size-13) !important;
    line-height: 1.65 !important;
    text-align: left;
    max-width: 18.5rem;
  }
  body[data-page="index"] .hero-intro__lede-keep {
    white-space: nowrap;
  }
  body[data-page="index"] .hero-intro__stats-inline {
    align-self: flex-start;
    justify-content: flex-start;
    width: 100%;
    margin-top: 1.125rem;
    gap: 0.5rem 0.875rem;
  }
  body[data-page="index"] .hero-intro__stat-inline-value {
    font-size: calc(0.9375rem + 1px) !important;
    color: rgba(255, 255, 255, 0.95);
  }
  body[data-page="index"] .hero-intro__stat-inline-label {
    color: rgba(255, 255, 255, 0.78);
    font-size: calc(0.6875rem + 1px) !important;
  }
  body[data-page="index"] .hero-intro__stat-inline-accent {
    color: #e8621a;
  }
  body[data-page="index"] .hero-intro__stat-inline-sep {
    background: rgba(255, 255, 255, 0.42);
    height: 0.875rem;
  }
  body[data-page] section:not(.hero-intro):not(.page-header):not(.cta-ideal-home):not(.index-advantage-section):not(.concept-advantage-section):not(.works-pickup-section):not(.concept-promise-section):not(.service-reasons-section):not(.buyback-reason-section):not(.flow-section):not(.buyback-flow-cta):not(.story-closing-section):not(.story-chapter--closing):not(.story-services-section):not(.content-list-section) {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
  }
  body[data-page] .index-advantage-section,
  body[data-page] .concept-advantage-section {
    padding-top: 0.5rem !important;
    padding-bottom: 2.25rem !important;
  }
  body[data-page] .works-pickup-section__shell {
    padding-top: 1.5rem !important;
    padding-bottom: 2.25rem !important;
  }
  body[data-page] .py-20,
  body[data-page] .py-16,
  body[data-page] .py-14,
  body[data-page] .py-8,
  body[data-page] .py-24 {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
  }
  body[data-page] .cta-ideal-home {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  body[data-page] .cta-ideal-home__inner {
    padding: 3.5rem 2.5rem 2.75rem !important;
  }
  body[data-page="story"] section.story-chapter--closing {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
  }
  body[data-page="story"] section.story-closing-section {
    padding-top: 1.5rem !important;
    padding-bottom: 2.75rem !important;
  }
  body[data-page="story"] .story-closing-section__statement {
    font-size: 1rem !important;
    line-height: 1.65 !important;
    letter-spacing: var(--text-tracking) !important;
  }
  body[data-page="story"] section.story-services-section {
    padding-top: 2rem !important;
    padding-bottom: 3.5rem !important;
  }
  body[data-page^="service-"] section.index-solution {
    padding-bottom: 4rem !important;
  }
  body[data-page] section:not(.hero-intro) .max-w-7xl,
  body[data-page] section:not(.hero-intro) .max-w-\[1440px\],
  body[data-page] section:not(.hero-intro) > div.px-6 {
    padding-left: 0.9rem !important;
    padding-right: 0.9rem !important;
  }
  body[data-page] .section-label:not(.hero-intro__photo-tagline) {
    font-size: 0.625rem;
    gap: 0.45rem;
    letter-spacing: var(--text-tracking);
  }
  body[data-page] .section-label:not(.hero-intro__photo-tagline)::before {
    width: 1.5rem;
  }
  body[data-page] section:not(.hero-intro) h1.font-serif {
    font-size: 1.75rem !important;
    line-height: 1.35 !important;
  }
  body[data-page] section:not(.hero-intro):not(.cta-ideal-home) h2.font-serif {
    font-size: 1.3125rem !important;
    line-height: 1.4 !important;
  }
  body[data-page] section:not(.hero-intro) h3.font-serif {
    font-size: 1.0625rem !important;
    line-height: 1.45 !important;
  }
  body[data-page] section:not(.hero-intro) p.font-serif.text-2xl,
  body[data-page] section:not(.hero-intro) p.font-serif.text-3xl {
    font-size: 1rem !important;
    line-height: 1.45 !important;
  }
  body[data-page] section:not(.hero-intro) p.font-serif.text-xl {
    font-size: 0.875rem !important;
    line-height: 1.45 !important;
  }
  body[data-page] section:not(.hero-intro) p.text-base,
  body[data-page] section:not(.hero-intro) .text-body,
  body[data-page] section:not(.hero-intro) p.text-body,
  body[data-page] section:not(.hero-intro) label.text-body,
  body[data-page] section:not(.hero-intro) dd.text-body,
  body[data-page] section:not(.hero-intro) span.text-body,
  body[data-page] section:not(.hero-intro) p.text-muted,
  body[data-page] section:not(.hero-intro) p.text-muted.leading-relaxed,
  body[data-page] section:not(.hero-intro) .story-mobile-block p.leading-relaxed,
  body[data-page] section:not(.hero-intro) .company-profile-table th,
  body[data-page] section:not(.hero-intro) .company-profile-table td {
    font-size: 0.875rem !important;
    line-height: 1.65 !important;
  }
  body[data-page] .company-profile-table th {
    padding: 1.125rem 0.75rem 1.125rem 0;
  }
  body[data-page] .company-profile-table td {
    padding: 1.125rem 0;
  }
  body[data-page] section:not(.hero-intro) p.text-sm,
  body[data-page] section:not(.hero-intro) .text-body-sm,
  body[data-page] section:not(.hero-intro) p.text-body-sm,
  body[data-page] section:not(.hero-intro) span.text-body-sm,
  body[data-page] section:not(.hero-intro) dt.text-body-sm,
  body[data-page] section:not(.hero-intro) label.text-body-sm,
  body[data-page] section:not(.hero-intro) p.text-muted.text-sm,
  body[data-page] section:not(.hero-intro) .text-sm.leading-relaxed,
  body[data-page] section:not(.hero-intro) p.text-sm.text-muted,
  body[data-page] section:not(.hero-intro) div.text-sm.text-muted,
  body[data-page] section:not(.hero-intro) span.text-sm,
  body[data-page] section:not(.hero-intro) li.text-sm {
    font-size: var(--text-size-13) !important;
    line-height: 1.65 !important;
  }
  body[data-page] section:not(.hero-intro) input[type="text"],
  body[data-page] section:not(.hero-intro) input[type="email"],
  body[data-page] section:not(.hero-intro) input[type="tel"],
  body[data-page] section:not(.hero-intro) textarea,
  body[data-page] section:not(.hero-intro) select {
    font-size: 0.875rem !important;
    line-height: 1.65 !important;
  }
  body[data-page="contact"] .contact-type-grid {
    gap: 0.5rem !important;
  }
  body[data-page="contact"] .contact-type-option {
    padding: 0.6875rem 0.8125rem !important;
    gap: 0.125rem !important;
  }
  body[data-page="contact"] .contact-type-option__title {
    font-size: var(--text-size-sm) !important;
    line-height: 1.5 !important;
  }
  body[data-page="contact"] .contact-type-option__desc {
    font-size: var(--text-size-13) !important;
    line-height: 1.55 !important;
  }
  body[data-page="contact"] #contact-form label.contact-field-label {
    font-size: var(--text-size-13) !important;
    line-height: 1.5 !important;
    font-weight: 600 !important;
  }
  body[data-page="contact"] #contact-form input[type="text"],
  body[data-page="contact"] #contact-form input[type="email"],
  body[data-page="contact"] #contact-form input[type="tel"],
  body[data-page="contact"] #contact-form select,
  body[data-page="contact"] #contact-form textarea {
    font-size: var(--text-size-13) !important;
    line-height: 1.5 !important;
  }
  body[data-page="contact"] #contact-form select {
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
  }
  body[data-page="contact"] #contact-form textarea {
    min-height: 7.5rem;
  }
  body[data-page] .cta-ideal-home__lede {
    font-size: 0.75rem !important;
    line-height: 1.58 !important;
  }
  body[data-page] section.cta-ideal-home h2.cta-ideal-home__heading {
    font-size: 1.0625rem !important;
    line-height: 1.4 !important;
  }
  body[data-page] section.cta-ideal-home .cta-ideal-home__heading-lead {
    font-size: 0.875rem !important;
    line-height: 1.4 !important;
  }
  body[data-page] .cta-ideal-home .flex.flex-wrap.gap-4 {
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: stretch;
    justify-content: center;
    gap: 0.625rem;
  }
  body[data-page] .cta-ideal-home .site-btn {
    flex: 1 1 0;
    min-width: 0;
    width: auto;
    justify-content: center;
    padding: 0.65rem 1rem;
    font-size: var(--text-size-13);
  }
  body[data-page] .cta-ideal-home--photo-bg::after {
    top: 2.5rem;
    background-image: linear-gradient(
        180deg,
        rgba(18, 22, 18, 0.58) 0%,
        rgba(18, 22, 18, 0.50) 50%,
        rgba(18, 22, 18, 0.60) 100%
      ),
      url('/images/backgrounds/ideal-home-cta-bg.webp');
    background-position: center, center 68%;
    background-size: cover, cover;
  }
  body[data-page] section img.object-contain:not(.w-full) {
    max-width: min(82%, 13.5rem) !important;
    margin-left: auto;
    margin-right: auto;
  }
  body[data-page] section .relative.h-64 {
    height: 11rem;
  }
  body[data-page] section .relative.h-\[220px\] {
    height: 10rem;
  }
  body[data-page] section .mb-16 {
    margin-bottom: 2.25rem !important;
  }
  body[data-page] section .mb-14 {
    margin-bottom: 2rem !important;
  }
  body[data-page] section .mb-12 {
    margin-bottom: 1.75rem !important;
  }
  body[data-page] section .mb-10 {
    margin-bottom: 1.5rem !important;
  }
  body[data-page] section .mb-8 {
    margin-bottom: 1.25rem !important;
  }
  body[data-page] section .mb-6 {
    margin-bottom: 0.875rem !important;
  }
  body[data-page] section .mb-5 {
    margin-bottom: 0.75rem !important;
  }
  body[data-page] section .mb-4 {
    margin-bottom: 0.625rem !important;
  }
  body[data-page] section .mt-12 {
    margin-top: 1.75rem !important;
  }
  body[data-page] section .mt-10 {
    margin-top: 1.5rem !important;
  }
  body[data-page] section .mt-7 {
    margin-top: 1.125rem !important;
  }
  body[data-page] section .mt-5 {
    margin-top: 0.75rem !important;
  }
  body[data-page] section .gap-16 {
    gap: 2.25rem !important;
  }
  body[data-page] section .gap-12 {
    gap: 1.75rem !important;
  }
  body[data-page] section .gap-10 {
    gap: 1.5rem !important;
  }
  body[data-page] .story-mobile-block {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  body[data-page] .story-mobile-block h2.font-serif {
    font-size: 1.1875rem !important;
    line-height: 1.4 !important;
  }
  body[data-page] .story-mobile-hero {
    width: auto;
  }
  body[data-page] .story-mobile-collage {
    height: 6rem;
    align-items: stretch;
  }
  body[data-page] .story-mobile-collage__main,
  body[data-page] .story-mobile-collage__cell {
    min-height: 0;
  }
  body[data-page] .advantage-grid__item {
    padding: 1.375rem 0 !important;
  }
  body[data-page] .index-advantage-section .advantage-grid__body h3.font-serif {
    font-size: 0.8125rem !important;
    line-height: 1.4 !important;
    margin-bottom: 0.375rem !important;
    word-break: keep-all;
    line-break: strict;
  }
  body[data-page] .index-advantage-section .advantage-grid__head {
    display: flex;
    align-items: baseline;
    gap: 0.4rem;
  }
  body[data-page] .index-advantage-section .advantage-grid__num {
    display: block;
    color: #e8621a;
    font-family: var(--font-body);
    font-weight: 600;
    font-size: 1rem;
    line-height: 1;
    letter-spacing: 0.04em;
    flex-shrink: 0;
    transform: translateY(0.02em);
  }
  body[data-page] .index-advantage-section .advantage-grid__icon {
    width: 4.25rem !important;
    height: 4.25rem !important;
    margin-top: -0.125rem !important;
  }
  body[data-page] .index-advantage-section .advantage-grid__icon--sm {
    width: 3.75rem !important;
    height: 3.75rem !important;
    margin-top: 0.25rem !important;
  }
  body[data-page] .index-advantage-section .advantage-grid__item {
    align-items: center;
  }
  body[data-page] .index-advantage-section .advantage-grid__item:nth-child(even) {
    flex-direction: row-reverse;
  }
  body[data-page] .index-advantage-section .advantage-grid__icon,
  body[data-page] .index-advantage-section .advantage-grid__icon--sm {
    margin-top: 0 !important;
  }
  body[data-page] .index-advantage-section .advantage-grid__icon img {
    width: 100% !important;
    max-width: 100% !important;
    height: 100% !important;
    margin: 0 !important;
  }
  body[data-page] section.index-advantage-section .advantage-grid__body p.text-muted {
    font-size: 0.75rem !important;
    line-height: 1.75 !important;
    letter-spacing: var(--text-tracking) !important;
  }
  body[data-page="story"] {
    overflow-x: clip;
  }
  body[data-page="story"] section .max-w-7xl,
  body[data-page="story"] section .max-w-3xl {
    padding-left: 0.85rem !important;
    padding-right: 0.85rem !important;
  }
  body[data-page="story"] .story-chapter__copy h2,
  body[data-page="story"] .story-chapter__copy p {
    word-break: normal;
    overflow-wrap: anywhere;
    line-break: auto;
  }
  body[data-page]:not([data-page="index"]) .page-header--split .page-header__grid {
    display: flex;
    flex-direction: column;
    gap: 0;
    overflow-x: clip;
  }
  body[data-page]:not([data-page="index"]) .page-header--split .page-header__text {
    display: contents;
  }
  body[data-page]:not([data-page="index"]) .page-header--split .page-header__grid .section-label,
  body[data-page]:not([data-page="index"]) .page-header--split .page-header__grid h1.font-serif,
  body[data-page]:not([data-page="index"]) .page-header--split .page-header__lede {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }
  body[data-page]:not([data-page="index"]) .page-header--split .page-header__grid .section-label {
    order: 1;
  }
  body[data-page]:not([data-page="index"]) .page-header--split .page-header__grid h1.font-serif {
    order: 2;
  }
  body[data-page]:not([data-page="index"]) .page-header--split .page-header__photo {
    order: 3;
    margin-top: 1.5rem;
    max-width: 100%;
  }
  body[data-page]:not([data-page="index"]) .page-header--split .page-header__lede {
    order: 4;
    margin-top: 1.25rem;
  }
  body[data-page="concept"] .concept-checklist {
    margin-top: 1.25rem !important;
    margin-bottom: 1.25rem !important;
    padding: 0.75rem 0.875rem !important;
  }
  body[data-page="concept"] .concept-checklist > div {
    gap: 0.5rem !important;
    padding-top: 0.25rem !important;
    padding-bottom: 0.25rem !important;
  }
  body[data-page="concept"] .concept-checklist span.text-sm {
    font-size: var(--text-size-13) !important;
    line-height: 1.55 !important;
  }
  body[data-page="concept"] .concept-checklist-after {
    margin-top: 0 !important;
  }
  body[data-page="concept"] .concept-advantage-section {
    padding-top: 2.25rem !important;
    padding-bottom: 0 !important;
  }
  body[data-page="concept"] .concept-advantage-section .mb-12.text-center {
    margin-bottom: 0 !important;
  }
  body[data-page="concept"] .concept-advantage-list__item {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0 !important;
    min-width: 0;
    overflow-x: clip;
  }
  body[data-page="concept"] .concept-advantage-list__icon {
    order: 2;
    width: 5.25rem !important;
    height: 5.25rem !important;
    margin: 1.125rem auto 1.25rem;
  }
  body[data-page="concept"] .concept-advantage-list__icon--02 {
    width: 4.4rem !important;
    height: 4.4rem !important;
  }
  body[data-page="concept"] .concept-advantage-list__body {
    display: contents;
  }
  body[data-page="concept"] .concept-advantage-list__head {
    order: 1;
    margin-bottom: 0.5rem !important;
    min-width: 0;
  }
  body[data-page="concept"] .concept-advantage-list__head h3.font-serif {
    font-size: 0.9375rem !important;
    line-height: 1.4 !important;
    word-break: keep-all;
    line-break: strict;
    min-width: 0;
  }
  body[data-page="concept"] .concept-advantage-list__body p:not(.concept-advantage-list__num) {
    order: 3;
    margin-left: 0 !important;
    font-size: var(--text-size-13) !important;
    line-height: var(--text-leading) !important;
    letter-spacing: var(--text-tracking) !important;
    overflow-wrap: anywhere;
  }
  body[data-page="concept"] .concept-advantage-list__body p:not(.concept-advantage-list__num) + p:not(.concept-advantage-list__num),
  body[data-page="concept"] .concept-advantage-list__body p:not(.concept-advantage-list__num) + .concept-point__list {
    margin-top: 0.625rem !important;
  }
  body[data-page="concept"] .concept-advantage-list__body .concept-point__list li {
    font-size: var(--text-size-xs) !important;
    line-height: var(--text-leading) !important;
    white-space: normal;
  }
  body[data-page="concept"] .concept-advantage-list__body .concept-point__list {
    order: 4;
    margin-left: 0 !important;
    min-width: 0;
  }
  body[data-page] .news-top-row {
    grid-template-columns: auto auto minmax(0, 1fr) 1rem;
    grid-template-areas: none;
    align-items: center;
    column-gap: 0.5rem;
    row-gap: 0 !important;
    padding: 0.75rem 0.875rem !important;
  }
  body[data-page] .news-top-row__date {
    grid-area: auto;
    justify-self: start;
    font-size: 0.625rem !important;
    letter-spacing: var(--text-tracking) !important;
  }
  body[data-page] .news-top-row__cat {
    grid-area: auto;
    justify-self: start;
    width: auto !important;
    padding: 0.1rem 0.35rem !important;
    font-size: 0.5625rem !important;
  }
  body[data-page] .news-top-row__title {
    grid-area: auto;
    -webkit-line-clamp: 1 !important;
    line-clamp: 1 !important;
    font-size: 0.6875rem !important;
    line-height: var(--text-leading) !important;
    letter-spacing: var(--text-tracking) !important;
  }
  body[data-page] .news-top-row__arrow {
    grid-area: auto;
    width: 1rem !important;
    height: 1rem !important;
    align-self: center;
  }
  body[data-page] section:has(#works-top-grid) .mb-12 {
    margin-bottom: 1.25rem !important;
  }
  body[data-page] section:has(#works-top-grid) h2.font-serif {
    font-size: 1.1875rem !important;
  }
  body[data-page] #works-top-grid,
  body[data-page] #works-grid,
  body[data-page] #news-list {
    gap: 1.75rem !important;
  }
  body[data-page] #works-top-grid .works-pickup-item__media,
  body[data-page] #works-grid .works-pickup-item__media,
  body[data-page] #news-list .works-pickup-item__media {
    aspect-ratio: 3 / 2;
    max-height: 9.25rem;
  }
  body[data-page] #works-top-grid .works-pickup-item__body,
  body[data-page] #works-grid .works-pickup-item__body,
  body[data-page] #news-list .works-pickup-item__body {
    padding-top: 0.875rem !important;
    gap: 0.625rem !important;
    min-height: 0 !important;
  }
  body[data-page] #works-top-grid .works-pickup-item__title,
  body[data-page] #works-grid .works-pickup-item__title,
  body[data-page] #news-list .works-pickup-item__title {
    font-size: 0.75rem !important;
    line-height: var(--text-leading) !important;
    min-height: calc(2 * var(--text-leading) * 1em) !important;
  }
  body[data-page] #works-top-grid .works-pickup-item__date,
  body[data-page] #works-grid .works-pickup-item__date,
  body[data-page] #news-list .works-pickup-item__date {
    font-size: 0.625rem !important;
  }
  body[data-page] #works-top-grid .works-pickup-item__tag,
  body[data-page] #works-grid .works-pickup-item__tag,
  body[data-page] #news-list .works-pickup-item__tag {
    font-size: 0.5625rem !important;
    line-height: 1.35 !important;
    padding: 0.0625rem 0.3125rem !important;
  }
  body[data-page="concept"] .concept-promise-section {
    display: flex;
    flex-direction: column;
    padding-top: clamp(2.75rem, 6.5vw, 4rem) !important;
    padding-bottom: clamp(2.75rem, 6.5vw, 3.5rem) !important;
    margin-bottom: 0;
  }
  body[data-page="concept"] .concept-promise-section #concept-promise-heading {
    font-size: 1.125rem !important;
    line-height: 1.4 !important;
    white-space: nowrap;
  }
  body[data-page="concept"] .concept-promise-section__inner {
    order: 1;
  }
  body[data-page="concept"] .concept-promise-section__copy {
    margin-inline: auto;
    text-align: center;
  }
  body[data-page="concept"] .concept-promise-section::after {
    content: none !important;
  }
  body[data-page] section.py-20.bg-cream:not(.hero-intro):not(.page-header):not(.cta-ideal-home):not(.index-advantage-section):not(.concept-advantage-section):not(.works-pickup-section):not(.concept-promise-section):not(.service-reasons-section):not(.flow-section) {
    padding-bottom: 3rem !important;
  }
  body[data-page]:not([data-page="index"]) .page-header {
    padding-top: calc(var(--site-header-height) + 1.75rem) !important;
    padding-bottom: 1.5rem !important;
  }
  body[data-page]:not([data-page="index"]) .page-header + section {
    padding-top: 2rem !important;
  }
  body[data-page^="service-"] .page-header + section.bg-cream {
    padding-bottom: 3.5rem !important;
  }
  body[data-page^="service-"] .page-header + section.bg-cream .grid {
    gap: 1rem !important;
  }
  body[data-page^="service-"] .page-header + section.bg-cream .grid > div {
    max-width: 21.5rem;
    margin-inline: auto;
    padding: 1.25rem !important;
  }
  body[data-page^="service-"] .page-header + section.bg-cream .h-52 {
    height: 9rem !important;
    margin-bottom: 1rem !important;
  }
  body[data-page^="service-"] .page-header + section.bg-cream img.object-contain {
    max-width: 10rem !important;
  }
  body[data-page^="service-"] .page-header + section.bg-cream .flex.items-center.gap-3 {
    margin-bottom: 0.625rem !important;
  }
  body[data-page^="service-"] .page-header + section.bg-cream .flex.items-center.gap-3 .font-serif.text-lg {
    font-size: 1.0625rem !important;
  }
  body[data-page^="service-"] .page-header + section.bg-cream .text-sm.text-muted {
    font-size: var(--text-size-13) !important;
    line-height: 1.65 !important;
  }
  body[data-page^="service-"] .page-header + section + div.relative.bg-white > div.absolute {
    top: 20% !important;
  }
  body[data-page^="service-"] .page-header + section + div.relative.bg-white > div.absolute p {
    font-size: 1.1875rem !important;
  }
  body[data-page^="service-"] .page-header + section + div.relative.bg-white {
    padding-bottom: 1.5rem !important;
  }
  body[data-page^="service-"] section.service-reasons-section.bg-white {
    padding-top: 0 !important;
    padding-bottom: 1.5rem !important;
  }
  body[data-page^="service-"] section.service-reasons-section .text-center {
    margin-bottom: 1.25rem !important;
  }
  body[data-page^="service-"] section.service-reasons-section .text-center > p.font-serif.text-xl.text-ink {
    font-size: clamp(0.75rem, 3.15vw, var(--text-size-13)) !important;
    line-height: 1.35 !important;
    letter-spacing: -0.02em;
    margin-bottom: 0.625rem !important;
    white-space: nowrap;
  }
  body[data-page^="service-"] section.service-reasons-section .text-center > p.font-serif.text-2xl {
    font-size: 1.25rem !important;
    line-height: 1.35 !important;
    margin-bottom: 0.75rem !important;
  }
  body[data-page^="service-"] section.service-reasons-section .text-center > p.text-muted {
    font-size: var(--text-size-13) !important;
    line-height: 1.65 !important;
  }
  body[data-page^="service-"] .reason-item__row {
    gap: 1.125rem !important;
  }
  body[data-page^="service-"] .reason-item__num-col {
    width: 3.25rem;
  }
  body[data-page^="service-"] .reason-item__digit {
    font-size: 3.25rem !important;
    line-height: 1 !important;
  }
  body[data-page^="service-"] .reason-item__label-mobile {
    margin-top: 0.25rem !important;
    margin-left: 0 !important;
    text-align: left;
  }
  body[data-page^="service-"] .reason-item__head .reason-item__title {
    font-size: 1.0625rem !important;
    line-height: 1.4 !important;
    word-break: keep-all;
    margin: 0 !important;
    padding-top: 0;
    align-self: center;
  }
  body[data-page="service-income"] .reason-item:last-child .reason-item__head .reason-item__title {
    white-space: nowrap;
    word-break: normal;
    font-size: 0.9375rem !important;
  }
  body[data-page="service-income"] section.bg-white h2.font-serif:has(.reveal-underline) {
    font-size: clamp(1.0625rem, 5.2vw, 1.375rem) !important;
    line-height: 1.45 !important;
    letter-spacing: -0.02em;
    white-space: nowrap;
  }
  body[data-page^="service-"] .reason-item__body {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  body[data-page^="service-"] .reason-item__desc {
    font-size: var(--text-size-13) !important;
    line-height: 1.65 !important;
    margin-top: 0.75rem !important;
  }
  body[data-page^="service-"] .service-reasons-section .reason-item {
    margin-bottom: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  body[data-page^="service-"] .service-reasons-section .reason-item:first-child {
    padding-top: 1rem !important;
  }
  body[data-page^="service-"] .service-reasons-section .reason-item:not(:last-child) {
    border-bottom: 1px solid #DDD9D2;
    padding-bottom: 1.5rem !important;
  }
  body[data-page^="service-"] .service-reasons-section .reason-item:not(:first-child) {
    padding-top: 1.5rem !important;
  }
  body[data-page^="service-"] section.buyback-reason-section {
    padding-top: 1.5rem !important;
    padding-bottom: 3rem !important;
  }
  body[data-page^="service-"] section.flow-section.bg-cream.py-20 {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }
  body[data-page^="service-"] section.flow-section.bg-cream > div:first-child .mb-14 {
    margin-bottom: 2rem !important;
  }
  body[data-page^="service-"] .flow-steps {
    --flow-arrow: 22px;
    --flow-arrow-gap: 6px;
    gap: 0 !important;
    max-width: 20rem;
    margin-inline: auto;
    padding-inline: 0.75rem;
  }
  body[data-page^="service-"] .flow-step-card {
    width: 100%;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    background: transparent !important;
    filter: none !important;
  }
  body[data-page^="service-"] .flow-step-card:not(:last-child) {
    margin-bottom: var(--flow-arrow-gap) !important;
  }
  body[data-page^="service-"] .flow-step-card:not(.flow-step-card--start) {
    margin-top: calc(-1 * var(--flow-arrow)) !important;
  }
  body[data-page^="service-"] .flow-step-card--start:not(.flow-step-card--last) {
    z-index: 4;
  }
  body[data-page^="service-"] .flow-step-card:not(.flow-step-card--start):not(.flow-step-card--last) {
    z-index: 3;
  }
  body[data-page^="service-"] .flow-step-card--last:not(.flow-step-card--start) {
    z-index: 2;
  }
  body[data-page^="service-"] .flow-step-card__surface {
    display: grid !important;
    grid-template-columns: auto 1fr;
    column-gap: 0.625rem;
    row-gap: 0.75rem;
    align-items: center;
    width: 100%;
    padding: 1.5rem 1.25rem calc(1.5rem + var(--flow-arrow)) !important;
    background: #fff !important;
    border: none !important;
    box-shadow: none !important;
    -webkit-clip-path: polygon(0% 0%, 100% 0%, 100% calc(100% - 22px), 50% 100%, 0% calc(100% - 22px));
    clip-path: polygon(0% 0%, 100% 0%, 100% calc(100% - 22px), 50% 100%, 0% calc(100% - 22px));
  }
  body[data-page^="service-"] .flow-step-card__surface > .font-mono-label {
    grid-column: 1;
    grid-row: 1;
    margin: 0 !important;
    white-space: nowrap;
  }
  body[data-page^="service-"] section.flow-section.bg-cream .flow-step-card__surface > h3.font-serif.text-lg {
    grid-column: 2;
    grid-row: 1;
    margin: 0 !important;
    font-size: 0.9375rem !important;
    line-height: 1.4 !important;
  }
  body[data-page^="service-"] .flow-step-card__surface > p.text-muted {
    grid-column: 1 / -1;
    grid-row: 2;
    margin: 0 !important;
  }
  body[data-page^="service-"] .flow-step-card__surface::before,
  body[data-page^="service-"] .flow-step-card__surface::after {
    content: none !important;
  }
  body[data-page^="service-"] .flow-step-card:not(.flow-step-card--start) .flow-step-card__surface {
    padding-top: calc(1.5rem + var(--flow-arrow)) !important;
    -webkit-clip-path: polygon(
      0% 0%,
      50% 22px,
      100% 0%,
      100% calc(100% - 22px),
      50% 100%,
      0% calc(100% - 22px)
    );
    clip-path: polygon(0% 0%, 50% 22px, 100% 0%, 100% calc(100% - 22px), 50% 100%, 0% calc(100% - 22px));
  }
  body[data-page^="service-"] .flow-step-card--last:not(.flow-step-card--start) .flow-step-card__surface {
    padding-bottom: 1.5rem !important;
    -webkit-clip-path: polygon(0% 0%, 50% 22px, 100% 0%, 100% 100%, 0% 100%) !important;
    clip-path: polygon(0% 0%, 50% 22px, 100% 0%, 100% 100%, 0% 100%) !important;
  }
  body[data-page^="service-"] .flow-step-card--start.flow-step-card--last .flow-step-card__surface {
    padding: 1.5rem 1.25rem !important;
    -webkit-clip-path: none !important;
    clip-path: none !important;
    border: 1px solid rgba(221, 217, 210, 0.7) !important;
  }
  body[data-page^="service-"] .flow-step-card--start.flow-step-card--last {
    margin-bottom: 0 !important;
  }
  body[data-page="blog"] .content-list-section,
  body[data-page="works"] .content-list-section {
    padding-top: 0.75rem !important;
  }
  body[data-page="blog"] #news-list.works-pickup-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    column-gap: 1rem !important;
    row-gap: 1.5rem !important;
  }
  body[data-page="blog"] .news-tabs-select {
    margin-bottom: 1.25rem !important;
    padding: 0.5rem 0.75rem !important;
    font-size: var(--text-size-13) !important;
    line-height: var(--text-leading) !important;
    letter-spacing: var(--text-tracking);
  }
  body[data-page="blog"] #news-pagination {
    padding-top: 1.5rem !important;
  }
  body[data-page="blog"] #news-pagination button,
  body[data-page="blog"] #news-pagination span:not(.sr-only) {
    width: 2.125rem !important;
    height: 2.125rem !important;
    min-width: 2.125rem !important;
    font-size: 0.75rem !important;
  }
  body[data-page="blog"] section.page-header:has(#detail-content),
  body[data-page="works"] section.page-header:has(#detail-content) {
    padding-top: calc(var(--site-header-height) + 1.25rem) !important;
    padding-bottom: 1.5rem !important;
    min-height: 0 !important;
  }
  body[data-page="blog"] #detail-content > .mb-8,
  body[data-page="works"] #detail-content > .mb-8 {
    margin-bottom: 1rem !important;
  }
  body[data-page="blog"] #detail-content > .mb-8 a,
  body[data-page="works"] #detail-content > .mb-8 a {
    font-size: var(--text-size-13) !important;
  }
  body[data-page="blog"] #detail-content > .mb-8 a svg,
  body[data-page="works"] #detail-content > .mb-8 a svg {
    width: 0.875rem !important;
    height: 0.875rem !important;
  }
  body[data-page="blog"] #detail-content .grid,
  body[data-page="works"] #detail-content .grid {
    gap: 3rem !important;
  }
  body[data-page="blog"] #detail-content aside,
  body[data-page="works"] #detail-content aside {
    padding-top: 0.5rem;
  }
  body[data-page="blog"] #detail-content #detail-title,
  body[data-page="works"] #detail-content #detail-title {
    font-size: 1.25rem !important;
    line-height: 1.45 !important;
    margin-bottom: 0.75rem !important;
  }
  body[data-page="blog"] #detail-content .detail-main-meta,
  body[data-page="works"] #detail-content .detail-main-meta {
    gap: 0.25rem 0.375rem !important;
    margin-bottom: 0.875rem !important;
  }
  body[data-page="blog"] #detail-content .detail-meta-date,
  body[data-page="blog"] #detail-content #detail-updated,
  body[data-page="works"] #detail-content .detail-meta-date,
  body[data-page="works"] #detail-content #detail-updated {
    font-size: 0.625rem !important;
    line-height: var(--text-leading) !important;
  }
  body[data-page="blog"] #detail-content #detail-category.news-list-cat {
    padding: 0.1rem 0.35rem !important;
    font-size: 0.5625rem !important;
    line-height: 1.35 !important;
  }
  body[data-page="works"] #detail-content .detail-main-meta .works-pickup-item__tag {
    font-size: 0.5625rem !important;
    line-height: 1.35 !important;
    padding: 0.0625rem 0.3125rem !important;
  }
  body[data-page="blog"] #detail-content #detail-thumb,
  body[data-page="works"] #detail-content #detail-thumb {
    margin-bottom: 1rem !important;
  }
  body[data-page="blog"] #detail-content #detail-description,
  body[data-page="works"] #detail-content #detail-description {
    font-size: var(--text-size-13) !important;
    line-height: 1.7 !important;
  }
  body[data-page="works"] #detail-content #detail-cost {
    font-size: var(--text-size-13) !important;
    line-height: 1.55 !important;
    margin-bottom: 0.75rem !important;
  }
  body[data-page="works"] #detail-content #detail-description {
    margin-bottom: 1.5rem !important;
  }
  body[data-page="works"] #detail-content #detail-gallery {
    gap: 0.5rem !important;
  }
  body[data-page="blog"] #detail-content aside h2.font-serif,
  body[data-page="works"] #detail-content aside h2.font-serif {
    font-size: 1rem !important;
    line-height: 1.45 !important;
  }
  body[data-page="blog"] #detail-content aside .h-px.w-10,
  body[data-page="works"] #detail-content aside .h-px.w-10 {
    width: 1.75rem !important;
  }
  body[data-page="blog"] #other-blogs-list a,
  body[data-page="works"] #other-works-list a {
    padding-top: 0.625rem !important;
    padding-bottom: 0.625rem !important;
  }
  body[data-page="blog"] #other-blogs-list .detail-aside-item__thumb,
  body[data-page="works"] #other-works-list .detail-aside-item__thumb {
    width: 3.5rem !important;
    height: 2.625rem !important;
  }
  body[data-page="blog"] #other-blogs-list a .line-clamp-2,
  body[data-page="works"] #other-works-list a .line-clamp-2 {
    font-size: var(--text-size-13) !important;
    line-height: 1.55 !important;
  }
  body[data-page="blog"] #other-blogs-list time.detail-aside-item__date {
    font-size: 0.625rem !important;
    margin-top: 0.25rem !important;
  }
  body[data-page="works"] #other-works-list .detail-aside-item__meta {
    margin-top: 0.25rem !important;
    gap: 0.2rem 0.3rem !important;
  }
  body[data-page="works"] #other-works-list .detail-aside-item__meta .works-pickup-item__tag {
    font-size: 0.5625rem !important;
    line-height: 1.35 !important;
    padding: 0.0625rem 0.3125rem !important;
  }
  body[data-page="blog"] #detail-content aside .site-btn--md,
  body[data-page="works"] #detail-content aside .site-btn--md {
    padding: 0.5rem 1.05rem;
    font-size: var(--text-size-13);
  }
}
@media (min-width: 768px) {
  body[data-page="blog"] .content-list-section,
  body[data-page="works"] .content-list-section {
    padding-top: 3.5rem !important;
  }
}
@media (max-width: 1023px) {
  [data-page="index"] .site-btn--md {
    padding: 0.5rem 1.05rem;
    font-size: var(--text-size-13);
    letter-spacing: var(--text-tracking);
  }
  [data-page="index"] .site-btn--lg {
    padding: 0.65rem 1.35rem;
    font-size: var(--text-size-13);
  }
  [data-page="index"] .site-btn--sm {
    padding: 0.5rem 0.95rem;
    font-size: var(--text-size-13);
  }
  [data-page="index"] .site-btn--md .site-btn__inner,
  [data-page="index"] .site-btn--lg .site-btn__inner,
  [data-page="index"] .site-btn--sm .site-btn__inner {
    gap: 0.35rem;
  }
  [data-page="index"] .site-btn--md .site-btn__inner svg,
  [data-page="index"] .site-btn--lg .site-btn__inner svg,
  [data-page="index"] .site-btn--sm .site-btn__inner svg {
    width: 0.875rem;
    height: 0.875rem;
  }
}
@media print {
  header, footer, .no-print {
    display: none;
  }
}
@media (min-width: 768px) and (max-width: 1023px) {
  body[data-page^="service-"] .flow-step-card {
    margin-top: 0 !important;
  }
  body[data-page^="service-"] .flow-step-card__surface {
    -webkit-clip-path: none !important;
    clip-path: none !important;
    filter: none !important;
    border: 1px solid rgba(221, 217, 210, 0.7) !important;
    padding: 2rem !important;
  }
}
@media (min-width: 1024px) {
  .flow-step-card {
    filter: none;
    margin-top: 0;
    padding: 0;
    background: transparent;
    min-width: 0;
  }
  .flow-step-card__surface {
    display: flex !important;
    flex-direction: column;
    width: 100%;
    height: 100%;
    min-height: 100%;
    border: none !important;
    box-shadow: none !important;
    -webkit-clip-path: polygon(0 0, calc(100% - 36px) 0, 100% 50%, calc(100% - 36px) 100%, 0 100%, 36px 50%);
    clip-path: polygon(0 0, calc(100% - 36px) 0, 100% 50%, calc(100% - 36px) 100%, 0 100%, 36px 50%);
  }
  .flow-step-card--start .flow-step-card__surface {
    -webkit-clip-path: polygon(0 0, calc(100% - 36px) 0, 100% 50%, calc(100% - 36px) 100%, 0 100%);
    clip-path: polygon(0 0, calc(100% - 36px) 0, 100% 50%, calc(100% - 36px) 100%, 0 100%);
  }
  .flow-step-card--last:not(.flow-step-card--start) .flow-step-card__surface {
    -webkit-clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%, 36px 50%);
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%, 36px 50%);
  }
  .flow-step-card--last.flow-step-card--start .flow-step-card__surface {
    -webkit-clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
    clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  }
  .flow-step-card__surface > h3.font-serif {
    font-size: 1.125rem !important;
    line-height: 1.75rem !important;
  }
}
@property --tw-translate-x {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-translate-y {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-translate-z {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-rotate-x {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-y {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-z {
  syntax: "*";
  inherits: false;
}
@property --tw-skew-x {
  syntax: "*";
  inherits: false;
}
@property --tw-skew-y {
  syntax: "*";
  inherits: false;
}
@property --tw-space-y-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-space-x-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-divide-y-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-border-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}
@property --tw-gradient-position {
  syntax: "*";
  inherits: false;
}
@property --tw-gradient-from {
  syntax: "<color>";
  inherits: false;
  initial-value: #0000;
}
@property --tw-gradient-via {
  syntax: "<color>";
  inherits: false;
  initial-value: #0000;
}
@property --tw-gradient-to {
  syntax: "<color>";
  inherits: false;
  initial-value: #0000;
}
@property --tw-gradient-stops {
  syntax: "*";
  inherits: false;
}
@property --tw-gradient-via-stops {
  syntax: "*";
  inherits: false;
}
@property --tw-gradient-from-position {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 0%;
}
@property --tw-gradient-via-position {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 50%;
}
@property --tw-gradient-to-position {
  syntax: "<length-percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-leading {
  syntax: "*";
  inherits: false;
}
@property --tw-font-weight {
  syntax: "*";
  inherits: false;
}
@property --tw-ordinal {
  syntax: "*";
  inherits: false;
}
@property --tw-slashed-zero {
  syntax: "*";
  inherits: false;
}
@property --tw-numeric-figure {
  syntax: "*";
  inherits: false;
}
@property --tw-numeric-spacing {
  syntax: "*";
  inherits: false;
}
@property --tw-numeric-fraction {
  syntax: "*";
  inherits: false;
}
@property --tw-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-inset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-inset-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-inset-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-ring-color {
  syntax: "*";
  inherits: false;
}
@property --tw-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-inset-ring-color {
  syntax: "*";
  inherits: false;
}
@property --tw-inset-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-ring-inset {
  syntax: "*";
  inherits: false;
}
@property --tw-ring-offset-width {
  syntax: "<length>";
  inherits: false;
  initial-value: 0px;
}
@property --tw-ring-offset-color {
  syntax: "*";
  inherits: false;
  initial-value: #fff;
}
@property --tw-ring-offset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-backdrop-blur {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-brightness {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-contrast {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-grayscale {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-hue-rotate {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-invert {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-opacity {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-saturate {
  syntax: "*";
  inherits: false;
}
@property --tw-backdrop-sepia {
  syntax: "*";
  inherits: false;
}
@property --tw-duration {
  syntax: "*";
  inherits: false;
}
@property --tw-ease {
  syntax: "*";
  inherits: false;
}
@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}
@layer properties {
  @supports ((-webkit-hyphens: none) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color:rgb(from red r g b)))) {
    *, ::before, ::after, ::backdrop {
      --tw-translate-x: 0;
      --tw-translate-y: 0;
      --tw-translate-z: 0;
      --tw-rotate-x: initial;
      --tw-rotate-y: initial;
      --tw-rotate-z: initial;
      --tw-skew-x: initial;
      --tw-skew-y: initial;
      --tw-space-y-reverse: 0;
      --tw-space-x-reverse: 0;
      --tw-divide-y-reverse: 0;
      --tw-border-style: solid;
      --tw-gradient-position: initial;
      --tw-gradient-from: #0000;
      --tw-gradient-via: #0000;
      --tw-gradient-to: #0000;
      --tw-gradient-stops: initial;
      --tw-gradient-via-stops: initial;
      --tw-gradient-from-position: 0%;
      --tw-gradient-via-position: 50%;
      --tw-gradient-to-position: 100%;
      --tw-leading: initial;
      --tw-font-weight: initial;
      --tw-ordinal: initial;
      --tw-slashed-zero: initial;
      --tw-numeric-figure: initial;
      --tw-numeric-spacing: initial;
      --tw-numeric-fraction: initial;
      --tw-shadow: 0 0 #0000;
      --tw-shadow-color: initial;
      --tw-shadow-alpha: 100%;
      --tw-inset-shadow: 0 0 #0000;
      --tw-inset-shadow-color: initial;
      --tw-inset-shadow-alpha: 100%;
      --tw-ring-color: initial;
      --tw-ring-shadow: 0 0 #0000;
      --tw-inset-ring-color: initial;
      --tw-inset-ring-shadow: 0 0 #0000;
      --tw-ring-inset: initial;
      --tw-ring-offset-width: 0px;
      --tw-ring-offset-color: #fff;
      --tw-ring-offset-shadow: 0 0 #0000;
      --tw-backdrop-blur: initial;
      --tw-backdrop-brightness: initial;
      --tw-backdrop-contrast: initial;
      --tw-backdrop-grayscale: initial;
      --tw-backdrop-hue-rotate: initial;
      --tw-backdrop-invert: initial;
      --tw-backdrop-opacity: initial;
      --tw-backdrop-saturate: initial;
      --tw-backdrop-sepia: initial;
      --tw-duration: initial;
      --tw-ease: initial;
    }
  }
}
