:root {
  --ab-bg: #f8f1e6;
  --ab-bg-soft: #fdf9f2;
  --ab-surface: #fffaf3;
  --ab-surface-strong: #f5ebdd;
  --ab-line: #e2cfb6;
  --ab-line-soft: #eadac7;
  --ab-text: #23190f;
  --ab-text-soft: #5e4b37;
  --ab-accent: #9a7649;
  --ab-accent-strong: #7f5b31;
  --ab-accent-light: #cfb38d;
  --ab-radius-xl: 30px;
  --ab-radius-lg: 22px;
  --ab-radius-md: 16px;
  --ab-shadow: 0 26px 64px rgba(54, 31, 8, 0.14);
  --ab-shadow-soft: 0 14px 36px rgba(54, 31, 8, 0.09);
  --ab-card-bg: linear-gradient(145deg, rgba(255, 250, 243, 0.96), rgba(246, 234, 217, 0.98));
  --ab-card-bg-soft: linear-gradient(165deg, #fffdf8 0%, #f8efe2 100%);
  --ab-shared-headline: var(--color-text-light, #5a5a5a);
  --ab-font-body: var(--font-primary, "Outfit", "Mitr", sans-serif);
  --ab-font-heading: "Playfair Display", "Cormorant Garamond", serif;
  --ab-font-th: var(--font-th, "Mitr", sans-serif);
}

.about-page-wrapper {
  position: relative;
  overflow-x: clip;
  overflow-y: hidden;
  overflow-y: clip;
  background:
    radial-gradient(60vw 40vw at 102% -2%, rgba(180, 135, 71, 0.28), rgba(180, 135, 71, 0)),
    radial-gradient(54vw 34vw at -8% 100%, rgba(176, 131, 67, 0.24), rgba(176, 131, 67, 0)),
    linear-gradient(180deg, var(--ab-bg-soft) 0%, var(--ab-bg) 100%);
  color: var(--ab-text);
  font-family: var(--ab-font-body);
}

.about-page-wrapper::before,
.about-page-wrapper::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
  z-index: 0;
}

.about-page-wrapper::before {
  width: min(620px, 56vw);
  height: min(620px, 56vw);
  top: -22vw;
  right: -18vw;
  background: radial-gradient(circle, rgba(170, 122, 56, 0.16), rgba(170, 122, 56, 0));
}

.about-page-wrapper::after {
  width: min(500px, 52vw);
  height: min(500px, 52vw);
  bottom: -18vw;
  left: -16vw;
  background: radial-gradient(circle, rgba(164, 114, 55, 0.2), rgba(164, 114, 55, 0));
}

.metal-page-wrapper {
  position: relative;
  z-index: 1;
  min-height: 100vh;
  padding-bottom: clamp(3.4rem, 7vw, 5.4rem);
}

.about-page-wrapper .container {
  position: relative;
  z-index: 1;
  max-width: min(1240px, 92vw);
}

.castelli-hero {
  padding-top: clamp(2.6rem, 6vw, 5rem);
}

.about-hero-shell {
  position: relative;
  margin: 0;
  border-radius: var(--ab-radius-xl);
  overflow: hidden;
  border: 1px solid var(--ab-line);
  background: linear-gradient(158deg, rgba(255, 252, 246, 0.95), rgba(248, 238, 224, 0.97));
  box-shadow: var(--ab-shadow);
}

.about-hero-shell::before,
.about-hero-shell::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.about-hero-shell::before {
  background: linear-gradient(130deg, rgba(255, 255, 255, 0.64) 0%, rgba(255, 255, 255, 0) 48%);
}

.about-hero-shell::after {
  background: radial-gradient(60% 80% at 100% 0%, rgba(172, 121, 54, 0.12), rgba(172, 121, 54, 0));
}

.relative-z {
  position: relative;
  z-index: 2;
}

.hero-copy-col,
.hero-media-col {
  padding: 0;
}

.hero-content-col {
  position: relative;
  z-index: 2;
  height: 100%;
  padding: clamp(1.4rem, 3.1vw, 3rem);
  display: grid;
  align-content: start;
  gap: 1.1rem;
  border-right: 1px solid var(--ab-line-soft);
  background: linear-gradient(160deg, rgba(255, 249, 240, 0.98), rgba(250, 241, 230, 0.96));
}

.hero-top-text {
  max-width: 34rem;
  padding-left: 1rem;
  border-left: 3px solid rgba(156, 114, 64, 0.74);
}

.small-meta {
  margin: 0 0 0.45rem;
  color: #8d6a40;
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 600;
}

.hero-narrative {
  margin: 0;
  color: var(--ab-text-soft);
  font-size: clamp(0.95rem, 1.2vw, 1.02rem);
  line-height: 1.76;
}

.hero-title-wrap {
  display: grid;
  gap: 0.84rem;
  margin-top: 0.25rem;
  max-width: min(560px, 100%);
}

.huge-serif {
  margin: 0;
  display: grid;
  text-transform: uppercase;
  font-family: var(--ab-font-heading);
  font-size: clamp(3.1rem, 7vw, 6rem);
  line-height: 0.9;
  letter-spacing: 0.03em;
  row-gap: 0.08em;
  color: var(--ab-shared-headline);
}

.huge-serif-main {
  color: var(--ab-shared-headline);
}

.huge-serif-sub {
  font-family: var(--ab-font-body);
  font-size: 0.56em;
  font-weight: 600;
  letter-spacing: 0.12em;
  color: var(--ab-accent);
}

.hero-title-rule {
  display: block;
  width: min(250px, 62vw);
  height: 1px;
  background: linear-gradient(to right, rgba(141, 106, 64, 0.74), rgba(141, 106, 64, 0));
}

.hero-title-logo-wrap {
  width: clamp(64px, 6vw, 86px);
  aspect-ratio: 1;
  border-radius: 14px;
  border: 1px solid rgba(146, 107, 61, 0.32);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(145deg, #fff6eb, #f4e4cf);
  box-shadow: 0 10px 22px rgba(74, 45, 16, 0.16);
}

.hero-title-logo {
  width: 68%;
  height: auto;
  object-fit: contain;
}

.hero-modern-line {
  display: flex;
  align-items: flex-start;
  gap: 0.68rem;
  max-width: 34rem;
}

.hero-modern-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: linear-gradient(145deg, #a67f4d, #7d5931);
  margin-top: 0.38rem;
  flex-shrink: 0;
}

.hero-modern-text {
  color: #5e4a34;
  font-size: clamp(0.9rem, 1vw, 0.97rem);
  line-height: 1.72;
}

.hero-action-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.72rem;
  margin-top: 0.2rem;
}

.hero-btn {
  min-height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.72rem 1.2rem;
  border: 1px solid transparent;
  border-radius: 12px;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.74rem;
  font-weight: 600;
  transition: transform 0.24s ease, box-shadow 0.24s ease, background 0.24s ease, border-color 0.24s ease, color 0.24s ease;
}

.hero-btn:focus-visible,
.btn-metal-outline:focus-visible {
  outline: 2px solid #3b2a17;
  outline-offset: 2px;
}

.hero-btn--solid {
  color: #fff;
  border-color: #6f4e2a;
  background: linear-gradient(132deg, #6f4e2a, #8b6438);
  box-shadow: 0 12px 24px rgba(101, 67, 32, 0.24);
}

.hero-btn--solid:hover {
  transform: translateY(-2px);
  background: linear-gradient(132deg, #634624, #7a572f);
}

.hero-btn--ghost {
  color: #76552f;
  border-color: rgba(144, 103, 54, 0.46);
  background: rgba(255, 248, 239, 0.88);
}

.hero-btn--ghost:hover {
  transform: translateY(-2px);
  color: #5d3f21;
  border-color: rgba(125, 87, 44, 0.62);
  background: #fff3e4;
}

.hero-media-col {
  position: relative;
  z-index: 2;
  padding: clamp(0.9rem, 2vw, 1.2rem);
  background: linear-gradient(160deg, rgba(253, 246, 237, 0.98), rgba(245, 231, 211, 0.92));
}

.image-strips-grid {
  position: relative;
  display: grid;
  grid-template-columns: 0.95fr 1.15fr;
  grid-template-rows: 180px 286px;
  gap: 0.72rem;
}

.strip-col {
  position: relative;
  overflow: hidden;
  border-radius: 14px;
  border: 1px solid rgba(153, 114, 64, 0.34);
  box-shadow: 0 10px 24px rgba(66, 41, 15, 0.16);
  isolation: isolate;
}

.strip-col:nth-child(1) {
  grid-column: 1;
  grid-row: 1;
}

.strip-col:nth-child(2) {
  grid-column: 2;
  grid-row: 1;
}

.strip-col:nth-child(3) {
  grid-column: 1 / span 2;
  grid-row: 2;
}

.strip-img,
.strip-img img {
  width: 100%;
  height: 100%;
}

.strip-img img {
  object-fit: cover;
  transition: transform 0.75s ease, filter 0.32s ease;
}

.strip-col::before,
.strip-col::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.strip-col::before {
  background: linear-gradient(150deg, rgba(255, 255, 255, 0.2), rgba(255, 255, 255, 0));
  z-index: 1;
}

.strip-col::after {
  background: linear-gradient(to top, rgba(29, 18, 8, 0.64), rgba(29, 18, 8, 0.08));
  z-index: 1;
}

.strip-col:hover .strip-img img {
  transform: scale(1.04);
}

.strip-col--one .strip-img img {
  object-position: 18% 44%;
  filter: sepia(0.22) saturate(0.95) contrast(1.04);
}

.strip-col--two .strip-img img {
  object-position: 76% 42%;
  filter: sepia(0.28) saturate(1.06) contrast(1.06);
}

.strip-col--three .strip-img img {
  object-position: 50% 58%;
  filter: sepia(0.18) saturate(0.98) brightness(0.94) contrast(1.06);
}

.hero-brand-tile {
  position: absolute;
  right: 0.8rem;
  top: 0.8rem;
  z-index: 4;
  display: flex;
  align-items: center;
  gap: 0.55rem;
  border-radius: 12px;
  border: 1px solid rgba(156, 115, 62, 0.44);
  background: rgba(255, 248, 240, 0.84);
  backdrop-filter: blur(8px);
  padding: 0.5rem 0.66rem;
  box-shadow: 0 10px 22px rgba(61, 37, 12, 0.16);
}

.hero-brand-icon {
  width: 26px;
  height: 26px;
  object-fit: contain;
}

.hero-brand-copy {
  display: grid;
  gap: 0.1rem;
}

.hero-brand-name {
  margin: 0;
  font-size: 0.66rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #4f3517;
  font-weight: 700;
}

.hero-brand-caption {
  color: #7a6043;
  font-size: 0.56rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.spacer-150 {
  height: clamp(3rem, 8vw, 6rem);
}

.spacer-100 {
  height: clamp(2.2rem, 6vw, 4.6rem);
}

.identity-section,
.services-constellation,
.minimal-cta,
.values-showcase,
.metal-cta {
  position: relative;
}

.identity-shell,
.services-shell,
.minimal-cta .container,
.values-showcase .container,
.metal-cta .container {
  border: 1px solid var(--ab-line);
  border-radius: var(--ab-radius-lg);
  background: var(--ab-card-bg);
  box-shadow: var(--ab-shadow-soft);
  overflow: hidden;
}

.identity-shell {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.22fr) minmax(280px, 0.78fr);
}

.identity-shell::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.26;
  background:
    linear-gradient(120deg, rgba(255, 255, 255, 0.72), rgba(255, 255, 255, 0)),
    var(--ab-img-identity, url("/images/about_identity_bg.webp")) center / cover no-repeat,
    url("/images/about_office.jpg") center / cover no-repeat;
}

.identity-copy,
.identity-aside {
  position: relative;
  z-index: 1;
}

.identity-copy {
  position: relative;
  padding: clamp(1.25rem, 3vw, 2.5rem);
}

.identity-copy::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(95deg, rgba(255, 250, 243, 0.9) 0%, rgba(255, 250, 243, 0.74) 64%, rgba(255, 250, 243, 0.26) 100%);
  pointer-events: none;
}

.identity-copy > * {
  position: relative;
  z-index: 1;
}

.identity-kicker,
.services-kicker,
.meta-label {
  margin: 0;
  color: #8f6d45;
  font-size: 0.68rem;
  letter-spacing: 0.17em;
  text-transform: uppercase;
  font-weight: 600;
}

.identity-title {
  margin: 0.42rem 0 0;
  display: grid;
  font-family: var(--ab-font-heading);
  font-size: clamp(2.5rem, 5.2vw, 4.8rem);
  line-height: 0.86;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--ab-shared-headline);
}

.identity-title .accent {
  color: #7f5f39;
}

.identity-subtitle {
  margin: 0.88rem 0 0;
  color: #4d3a27;
  font-size: clamp(1rem, 1.5vw, 1.28rem);
  line-height: 1.58;
  text-transform: uppercase;
}

.identity-narrative {
  margin-top: 1.1rem;
  display: grid;
  gap: 0.94rem;
}

.identity-paragraph {
  margin: 0;
  color: #4d3c2b;
  font-size: 0.96rem;
  line-height: 1.8;
}

.identity-aside {
  border-left: 1px solid var(--ab-line-soft);
  display: grid;
  grid-template-rows: repeat(2, minmax(0, 1fr));
  background: linear-gradient(180deg, rgba(255, 249, 240, 0.88), rgba(246, 233, 215, 0.92));
}

.identity-metric {
  position: relative;
  padding: 1.3rem 1.1rem;
  border-bottom: 1px solid var(--ab-line-soft);
  transition: background 0.24s ease, transform 0.24s ease;
}

.identity-metric:last-child {
  border-bottom: 0;
}

.identity-metric:hover {
  background: rgba(255, 255, 255, 0.5);
  transform: translateY(-1px);
}

.metric-code {
  display: inline-block;
  margin-bottom: 0.6rem;
  font-family: var(--ab-font-heading);
  font-size: 2rem;
  line-height: 1;
  color: rgba(137, 97, 50, 0.58);
}

.metric-label {
  margin: 0 0 0.3rem;
  color: #4f3820;
  font-size: 0.75rem;
  letter-spacing: 0.13em;
  text-transform: uppercase;
}

.metric-value {
  margin: 0;
  color: #5b4631;
  font-size: 0.92rem;
  line-height: 1.64;
}

.services-shell {
  position: relative;
  padding: clamp(1.3rem, 2.8vw, 2.45rem);
  background: var(--ab-card-bg-soft);
}

.services-shell::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(500px 230px at 104% -4%, rgba(172, 122, 56, 0.2), rgba(172, 122, 56, 0)),
    radial-gradient(460px 210px at -10% 102%, rgba(182, 138, 82, 0.18), rgba(182, 138, 82, 0));
  pointer-events: none;
}

.services-heading,
.service-grid {
  position: relative;
  z-index: 1;
}

.services-heading {
  display: grid;
  gap: 0.92rem;
  margin-bottom: 1.45rem;
}

.services-kicker {
  margin-bottom: 0.18rem;
}

.services-title {
  margin: 0;
  font-family: var(--ab-font-heading);
  font-size: clamp(2rem, 4.6vw, 4rem);
  letter-spacing: 0.03em;
  line-height: 0.92;
  text-transform: uppercase;
  color: var(--ab-shared-headline);
}

.service-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  gap: 0.9rem;
}

.service-card {
  position: relative;
  min-height: 258px;
  padding: 1.02rem;
  border: 1px solid rgba(145, 105, 54, 0.35);
  border-radius: var(--ab-radius-md);
  overflow: hidden;
  box-shadow: 0 14px 30px rgba(55, 33, 10, 0.14);
  isolation: isolate;
}

.service-card::before,
.service-card::after {
  content: "";
  position: absolute;
  inset: 0;
}

.service-card::before {
  background-image: var(--service-bg, url("/images/about_office.jpg"));
  background-size: cover;
  filter: sepia(0.28) saturate(1.02) brightness(0.65) contrast(1.08);
  transform: scale(1.03);
}

.service-card::after {
  background: linear-gradient(to top, rgba(23, 14, 7, 0.93) 15%, rgba(23, 14, 7, 0.5) 68%, rgba(23, 14, 7, 0.28) 100%);
}

.service-card > * {
  position: relative;
  z-index: 1;
}

.service-card--listing {
  min-height: 320px;
}

.service-card--listing::before {
  background-position: 50% 60%;
}

.service-card--matching::before {
  background-position: 76% 44%;
  filter: sepia(0.34) saturate(1.1) brightness(0.63) contrast(1.12);
}

.service-card--support::before {
  background-position: 24% 48%;
  filter: sepia(0.22) saturate(0.95) brightness(0.66) contrast(1.08);
}

.service-icon-wrap {
  color: #f8ead6;
  font-size: 1.38rem;
  margin-bottom: 0.8rem;
}

.service-card-title {
  margin: 0 0 0.52rem;
  font-family: var(--ab-font-heading);
  font-size: 1.62rem;
  line-height: 1.03;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: #fff7eb;
}

.service-card-desc {
  margin: 0;
  color: #f0dcc2;
  font-size: 0.88rem;
  line-height: 1.7;
}

.service-link-dot {
  position: absolute;
  right: 0.85rem;
  bottom: 0.85rem;
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(245, 224, 196, 0.62);
  border-radius: 999px;
  color: #f7e7d1;
}

.minimal-cta .container {
  position: relative;
  text-align: center;
  padding: clamp(2rem, 4.6vw, 4.2rem) clamp(1.2rem, 2.4vw, 2.2rem);
}

.minimal-cta .container::before,
.minimal-cta .container::after {
  content: "";
  position: absolute;
  width: min(260px, 34vw);
  aspect-ratio: 4 / 3;
  border-radius: 12px;
  border: 1px solid rgba(156, 115, 62, 0.34);
  box-shadow: 0 12px 26px rgba(57, 34, 12, 0.12);
  pointer-events: none;
}

.minimal-cta .container::before {
  left: 6%;
  top: 18%;
  transform: rotate(-8deg);
  background:
    linear-gradient(130deg, rgba(255, 255, 255, 0.36), rgba(255, 255, 255, 0)),
    var(--ab-img-cta-1, url("/images/about_cta_polaroid_1.webp")) center / cover no-repeat,
    url("/images/about_office.jpg") center / cover no-repeat;
}

.minimal-cta .container::after {
  right: 7%;
  top: 18%;
  transform: rotate(8deg);
  background:
    var(--ab-img-cta-2, url("/images/about_cta_polaroid_2.webp")) center / cover no-repeat,
    url("/images/about_office.jpg") center / cover no-repeat,
    linear-gradient(130deg, rgba(255, 255, 255, 0.42), rgba(255, 255, 255, 0)),
    radial-gradient(circle at 20% 24%, rgba(191, 145, 85, 0.36), rgba(191, 145, 85, 0));
}

.minimal-cta .small-meta {
  position: relative;
  z-index: 1;
  color: #85613b;
}

.cta-huge-link {
  position: relative;
  z-index: 1;
  margin: 0;
}

.cta-huge-link a {
  display: inline-block;
  text-decoration: none;
  font-family: var(--ab-font-heading);
  font-size: clamp(2.2rem, 5.8vw, 5rem);
  line-height: 1.04;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--ab-shared-headline);
  transition: color 0.2s ease;
}

.cta-huge-link a:hover {
  color: var(--ab-accent-strong);
}

.line-center {
  position: relative;
  z-index: 1;
  width: min(220px, 70vw);
  height: 1px;
  margin: 1.2rem auto 0;
  background: linear-gradient(to right, transparent, rgba(145, 108, 63, 0.6), transparent);
}

.values-showcase .container {
  padding: clamp(1.3rem, 3vw, 2.5rem);
}

.huge-label {
  font-family: var(--ab-font-heading);
  font-size: clamp(2.25rem, 4.8vw, 4.2rem);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--ab-shared-headline);
  line-height: 1;
}

.huge-label--accent {
  color: var(--ab-accent);
}

.values-list-wrapper {
  display: grid;
  gap: 0.95rem;
}

.value-row {
  position: relative;
  min-height: 226px;
  overflow: hidden;
  border-radius: var(--ab-radius-md);
  border: 1px solid rgba(145, 105, 55, 0.3);
  padding: 1.06rem 1.08rem 1.08rem clamp(43%, 48vw, 52%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  background: linear-gradient(160deg, #fef7eb, #f6ebdc);
}

.value-row::before,
.value-row::after {
  content: "";
  position: absolute;
  inset: 0;
}

.value-row::before {
  inset: 0 auto 0 0;
  width: 42%;
  background-size: cover;
  filter: sepia(0.36) saturate(0.9) contrast(1.06) brightness(0.9);
}

.value-row:nth-child(1)::before {
  background-image: var(--ab-img-value-1, url("/images/about_value_1.webp")), url("/images/about_office.jpg");
  background-position: 14% 54%;
}

.value-row:nth-child(2)::before {
  background-image: var(--ab-img-value-2, url("/images/about_value_2.webp")), url("/images/about_office.jpg");
  background-position: 82% 48%;
}

.value-row:nth-child(3)::before {
  background-image: var(--ab-img-value-3, url("/images/about_value_3.webp")), url("/images/about_office.jpg");
  background-position: 52% 64%;
}

.value-row::after {
  background: linear-gradient(108deg, rgba(255, 249, 240, 0.05) 28%, rgba(248, 237, 221, 0.92) 58%);
  pointer-events: none;
}

.value-row > * {
  position: relative;
  z-index: 1;
}

.value-num {
  display: inline-flex;
  width: 38px;
  height: 38px;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid rgba(130, 92, 47, 0.44);
  color: #6f502e;
  font-size: 0.86rem;
  margin-bottom: 0.46rem;
  background: rgba(255, 248, 236, 0.84);
}

.value-title {
  margin: 0;
  font-family: var(--ab-font-heading);
  font-size: clamp(1.56rem, 3.3vw, 2.45rem);
  line-height: 0.96;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--ab-shared-headline);
}

.value-desc {
  margin: 0.56rem 0 0;
  color: #5f4b37;
  font-size: 0.84rem;
  line-height: 1.66;
  max-width: 48ch;
}

.metal-cta .container {
  position: relative;
  text-align: center;
  padding: clamp(2rem, 4vw, 3.8rem) clamp(1.2rem, 2.4vw, 2.2rem);
  background:
    radial-gradient(80% 80% at 4% 96%, rgba(176, 131, 71, 0.22), rgba(176, 131, 71, 0)),
    radial-gradient(80% 80% at 96% 4%, rgba(176, 131, 71, 0.2), rgba(176, 131, 71, 0)),
    linear-gradient(155deg, #fffaf2 0%, #f6e9d8 100%);
}

.metal-cta .container::before {
  content: "";
  position: absolute;
  width: 180px;
  height: 180px;
  left: -56px;
  top: -54px;
  border-radius: 50%;
  border: 1px solid rgba(149, 108, 57, 0.3);
  background:
    radial-gradient(circle at 40% 40%, rgba(188, 144, 83, 0.34), rgba(188, 144, 83, 0)),
    url("/images/planliv_icon_128.webp") center / 52px 52px no-repeat;
  pointer-events: none;
}

.meta-label {
  position: relative;
  z-index: 1;
  color: #85613b;
}

.cta-heading {
  position: relative;
  z-index: 1;
  margin: 0.72rem 0 1.2rem;
  font-family: var(--ab-font-heading);
  font-size: clamp(2.8rem, 6.8vw, 5.5rem);
  letter-spacing: 0.06em;
  line-height: 0.88;
  text-transform: uppercase;
  color: var(--ab-shared-headline);
}

.btn-metal-outline {
  position: relative;
  z-index: 1;
  min-width: 210px;
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  border: 1px solid rgba(123, 89, 47, 0.56);
  color: #694726;
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: 0.72rem;
  font-weight: 600;
  background: rgba(255, 248, 237, 0.86);
  transition: transform 0.24s ease, border-color 0.24s ease, background 0.24s ease, color 0.24s ease;
}

.btn-metal-outline:hover {
  color: #513315;
  transform: translateY(-2px);
  border-color: rgba(112, 78, 41, 0.74);
  background: #fff2de;
}

.section-spacing {
  padding: 0;
}

:lang(th) .about-page-wrapper,
html[lang="th"] .about-page-wrapper,
:lang(th) .small-meta,
html[lang="th"] .small-meta,
:lang(th) .hero-narrative,
html[lang="th"] .hero-narrative,
:lang(th) .hero-modern-text,
html[lang="th"] .hero-modern-text,
:lang(th) .hero-btn,
html[lang="th"] .hero-btn,
:lang(th) .identity-subtitle,
html[lang="th"] .identity-subtitle,
:lang(th) .identity-paragraph,
html[lang="th"] .identity-paragraph,
:lang(th) .service-card-desc,
html[lang="th"] .service-card-desc,
:lang(th) .value-desc,
html[lang="th"] .value-desc,
:lang(th) .meta-label,
html[lang="th"] .meta-label {
  font-family: var(--ab-font-th);
}

:lang(th) .hero-btn,
html[lang="th"] .hero-btn,
:lang(th) .small-meta,
html[lang="th"] .small-meta,
:lang(th) .identity-kicker,
html[lang="th"] .identity-kicker,
:lang(th) .services-kicker,
html[lang="th"] .services-kicker,
:lang(th) .meta-label,
html[lang="th"] .meta-label {
  text-transform: none;
  letter-spacing: 0.04em;
}

:lang(th) .huge-serif,
html[lang="th"] .huge-serif,
:lang(th) .identity-title,
html[lang="th"] .identity-title,
:lang(th) .services-title,
html[lang="th"] .services-title,
:lang(th) .service-card-title,
html[lang="th"] .service-card-title,
:lang(th) .value-title,
html[lang="th"] .value-title,
:lang(th) .huge-label,
html[lang="th"] .huge-label,
:lang(th) .cta-heading,
html[lang="th"] .cta-heading,
:lang(th) .cta-huge-link a,
html[lang="th"] .cta-huge-link a {
  font-family: var(--ab-font-th);
  text-transform: none;
  letter-spacing: 0;
  font-weight: 500;
}

:lang(th) .huge-serif,
html[lang="th"] .huge-serif {
  font-size: clamp(3rem, 8vw, 5.5rem);
  line-height: 0.94;
}

:lang(th) .huge-serif-sub,
html[lang="th"] .huge-serif-sub {
  font-family: var(--ab-font-body);
  font-size: 0.44em;
  letter-spacing: 0.11em;
}

@media (max-width: 1199px) {
  .identity-shell {
    grid-template-columns: 1fr;
  }

  .identity-aside {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: none;
    border-left: 0;
    border-top: 1px solid var(--ab-line-soft);
  }

  .service-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .service-card--listing {
    grid-column: 1 / -1;
    min-height: 286px;
  }
}

@media (max-width: 991px) {
  .castelli-hero {
    padding-top: 2.2rem;
  }

  .hero-content-col {
    border-right: 0;
    border-bottom: 1px solid var(--ab-line-soft);
  }

  .hero-media-col {
    padding: 0.8rem;
  }

  .image-strips-grid {
    grid-template-columns: 1fr;
    grid-template-rows: repeat(3, 188px);
    gap: 0.64rem;
  }

  .strip-col:nth-child(1),
  .strip-col:nth-child(2),
  .strip-col:nth-child(3) {
    grid-column: auto;
    grid-row: auto;
  }

  .hero-brand-tile {
    position: static;
    width: fit-content;
    margin-top: 0.45rem;
  }

  .spacer-150 {
    height: clamp(2.5rem, 7vw, 4.4rem);
  }

  .spacer-100 {
    height: clamp(2rem, 5vw, 3.2rem);
  }

  .service-grid {
    grid-template-columns: 1fr;
  }

  .service-card,
  .service-card--listing {
    min-height: 220px;
    grid-column: auto;
  }

  .minimal-cta .container::before,
  .minimal-cta .container::after {
    display: none;
  }

  .value-row {
    min-height: 250px;
    padding: 1rem;
    justify-content: flex-end;
  }

  .value-row::before {
    width: 100%;
    inset: 0;
  }

  .value-row::after {
    background: linear-gradient(to top, rgba(250, 241, 229, 0.94), rgba(250, 241, 229, 0.42));
  }
}

@media (max-width: 640px) {
  .about-page-wrapper .container {
    max-width: calc(100vw - 1.2rem);
  }

  .about-hero-shell,
  .identity-shell,
  .services-shell,
  .minimal-cta .container,
  .values-showcase .container,
  .metal-cta .container {
    border-radius: 18px;
  }

  .hero-content-col,
  .identity-copy,
  .services-shell,
  .values-showcase .container,
  .minimal-cta .container,
  .metal-cta .container {
    padding: 1rem;
  }

  .hero-title-wrap {
    gap: 0.66rem;
  }

  .huge-serif {
    font-size: clamp(2.6rem, 13vw, 4.15rem);
    line-height: 0.92;
  }

  .hero-title-rule {
    width: min(168px, 58vw);
  }

  .hero-title-logo-wrap {
    width: 58px;
  }

  .hero-modern-text {
    font-size: 0.84rem;
    line-height: 1.62;
  }

  .hero-action-row {
    width: 100%;
    gap: 0.58rem;
  }

  .hero-btn {
    width: 100%;
  }

  .identity-aside {
    grid-template-columns: 1fr;
  }

  .huge-label {
    font-size: clamp(1.74rem, 10vw, 2.45rem);
  }

  .value-row {
    min-height: 212px;
  }

  .value-title {
    font-size: clamp(1.34rem, 8vw, 1.88rem);
  }

  .cta-huge-link a {
    font-size: clamp(1.7rem, 11vw, 2.7rem);
  }

  .cta-heading {
    font-size: clamp(2rem, 14vw, 3.3rem);
  }

  .btn-metal-outline {
    width: 100%;
    min-width: 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .hero-btn,
  .strip-img img,
  .identity-metric,
  .service-card,
  .btn-metal-outline {
    transition: none !important;
  }
}
