/* Same and Some Construction Company — project-showcase site */

:root {
  --c-paper: #F4EFE4;
  --c-paper-2: #ECE6D8;
  --c-paper-3: #E0D9C7;
  --c-ink: #0D0D0F;
  --c-ink-soft: #1A1A1D;
  --c-red: #E04030;
  --c-red-d: #B03020;
  --c-red-dd: #702010;
  --c-yellow: #F0B020;
  --c-yellow-d: #D09000;
  --c-yellow-dd: #A07000;
  --c-teal: #40C0B0;
  --c-teal-d: #309090;
  --c-teal-dd: #206060;
  --t-1: #0D0D0F;
  --t-2: #3A3A3C;
  --t-3: #6F6E6A;
  --f-display: "Archivo Black", "Helvetica Neue", Arial Black, sans-serif;
  --f-serif: "Fraunces", "Georgia", "Times New Roman", serif;
  --f-body: "Inter", "Helvetica Neue", Arial, sans-serif;
  --f-mono: "DM Mono", "JetBrains Mono", ui-monospace, monospace;
  --wrap: 1280px;
  --gut: clamp(20px, 4vw, 56px);
  --section-y: clamp(76px, 11vw, 148px);
  --r-lg: 24px;
  --line: 1px solid color-mix(in srgb, var(--c-ink) 14%, transparent);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; overflow-x: hidden; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  background: var(--c-paper);
  color: var(--t-1);
  font-family: var(--f-body);
  font-size: 17px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration-color: color-mix(in srgb, currentColor 30%, transparent); text-underline-offset: 3px; }
a:hover { text-decoration-color: currentColor; }
::selection { background: var(--c-yellow); color: var(--c-ink); }
.wrap { max-width: var(--wrap); margin: 0 auto; padding-left: var(--gut); padding-right: var(--gut); }
.visually-hidden { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.skip { position: absolute; left: -100%; top: 0; padding: 10px 16px; background: var(--c-ink); color: var(--c-paper); font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; z-index: 100; }
.skip:focus { left: 0; }

.section-eyebrow { font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--c-red); margin: 0 0 24px; }
.section-title { font-family: var(--f-display); font-weight: 900; font-size: clamp(38px, 5.8vw, 82px); line-height: 0.94; letter-spacing: -0.025em; margin: 0 0 18px; }
.section-title em, .hl-r, .hl-y, .hl-t { font-family: var(--f-serif); font-style: italic; font-weight: 700; letter-spacing: -0.01em; }
.hl-r { color: var(--c-red); }
.hl-y { color: var(--c-yellow-d); }
.hl-t { color: var(--c-teal-d); }
.section-sub { max-width: 58ch; color: var(--t-2); margin: 14px 0 0; font-size: 18px; }
.section-head { margin-bottom: clamp(36px, 5vw, 72px); }

.site-header { position: sticky; top: 0; z-index: 50; background: color-mix(in srgb, var(--c-paper) 88%, transparent); backdrop-filter: saturate(140%) blur(10px); -webkit-backdrop-filter: saturate(140%) blur(10px); border-bottom: var(--line); }
.header-inner { display: flex; align-items: center; gap: 24px; min-height: 92px; }
.brand { display: inline-flex; align-items: center; gap: 14px; text-decoration: none; }
.brand-lockup { min-width: 220px; }
.brand-mark { display: inline-flex; width: 58px; flex: 0 0 58px; }
.lockup-type { display: flex; flex-direction: column; justify-content: center; line-height: 0.84; min-width: 150px; }
.lockup-line { font-family: var(--f-display); font-size: 25px; letter-spacing: -0.035em; display: block; }
.lockup-red { color: var(--c-red); }
.lockup-yellow { color: var(--c-yellow); }
.lockup-teal { color: var(--c-teal); }
.lockup-company { display: block; margin-top: 7px; font-family: var(--f-display); font-size: 8px; letter-spacing: 0.22em; color: var(--c-ink); white-space: nowrap; }
.brand-word { font-family: var(--f-display); font-size: 22px; letter-spacing: -0.01em; background: linear-gradient(90deg, var(--c-red) 0 45%, var(--c-yellow) 45% 56%, var(--c-teal) 56% 100%); -webkit-background-clip: text; background-clip: text; color: transparent; -webkit-text-fill-color: transparent; white-space: nowrap; }
.primary-nav { margin-left: auto; display: flex; gap: 30px; }
.primary-nav a { font-size: 14.5px; font-weight: 500; text-decoration: none; color: var(--t-2); position: relative; }
.primary-nav a:hover { color: var(--t-1); }
.primary-nav a::after { content: ""; position: absolute; left: 0; right: 100%; bottom: -6px; height: 2px; background: var(--c-red); transition: right .25s ease; }
.primary-nav a:hover::after { right: 0; }
.menu-toggle { display: none; margin-left: auto; width: 44px; height: 44px; background: transparent; border: 1px solid color-mix(in srgb, var(--c-ink) 16%, transparent); border-radius: 999px; flex-direction: column; align-items: center; justify-content: center; gap: 4px; cursor: pointer; }
.menu-toggle span { display:block; width: 18px; height: 2px; background: var(--c-ink); transition: transform .2s ease, opacity .2s ease; }
.menu-toggle[aria-expanded="true"] span:nth-child(1){ transform: translateY(6px) rotate(45deg); }
.menu-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.menu-toggle[aria-expanded="true"] span:nth-child(3){ transform: translateY(-6px) rotate(-45deg); }
.mobile-nav { display: none; flex-direction: column; gap: 4px; padding: 10px 16px 22px; border-top: var(--line); background: var(--c-paper); }
.mobile-nav a { padding: 12px 4px; font-size: 18px; font-weight: 500; text-decoration: none; color: var(--t-1); border-bottom: var(--line); }
@media (max-width: 840px) { .primary-nav { display: none; } .menu-toggle { display: inline-flex; } }
@media (max-width: 560px) {
  .header-inner { min-height: 82px; }
  .brand-lockup { min-width: 0; gap: 10px; }
  .brand-mark { width: 42px; flex-basis: 42px; }
  .brand-mark svg { width: 42px; height: 42px; }
  .lockup-line { font-size: 18px; }
  .lockup-company { font-size: 6px; letter-spacing: .16em; margin-top: 5px; }
}

.hero { position: relative; display: grid; grid-template-columns: 1fr; gap: clamp(34px, 5vw, 72px); align-items: center; padding: clamp(72px, 9vw, 126px) var(--gut) clamp(56px, 7vw, 104px); max-width: min(1480px, 100%); margin: 0 auto; }
.hero-inner { padding: 0; max-width: 1180px; margin: 0 auto; text-align: center; }
.eyebrow { display: inline-flex; align-items: center; gap: 10px; font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--t-2); margin-bottom: clamp(28px, 4vw, 44px); }
.dot { width: 9px; height: 9px; border-radius: 2px; transform: rotate(45deg); display: inline-block; }
.dot-r { background: var(--c-red); } .dot-y { background: var(--c-yellow); } .dot-t { background: var(--c-teal); }
.hero-title { font-family: var(--f-display); font-weight: 900; font-size: clamp(48px, 7.7vw, 124px); line-height: 0.88; letter-spacing: -0.04em; margin: 0 auto 30px; max-width: 12ch; text-wrap: balance; }
.hero-title em { display: inline-block; transform: translateY(0.04em); }
.hero-lede { max-width: 64ch; font-size: clamp(18px, 1.45vw, 22px); color: var(--t-2); line-height: 1.5; margin: 0 auto; }
.hero-panel { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 24px; min-width: 0; width: min(1080px, 100%); margin: 0 auto; align-items: stretch; }
.hp-card { position: relative; border-radius: var(--r-lg); padding: clamp(24px, 3vw, 38px); display: flex; flex-direction: column; justify-content: space-between; overflow: hidden; border: 1px solid color-mix(in srgb, var(--c-ink) 8%, transparent); min-height: 348px; height: 100%; }
.hp-paper { background: linear-gradient(160deg, #FAF7EE 0%, var(--c-paper) 60%, var(--c-paper-2) 100%); }
.hp-ink { background: var(--c-ink); color: var(--c-paper); }
.hp-kicker { font-family: var(--f-mono); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--c-yellow); margin: 0; }
.hp-tag { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--c-red); }
.hp-ink .hp-tag { color: var(--c-yellow); }
.hp-stack { flex: 1; display: flex; align-items: center; justify-content: center; padding: 0 0 10px; min-height: 158px; }
.hp-stack svg { max-width: 36%; height: auto; }
.hp-quote { font-family: var(--f-serif); font-style: italic; font-weight: 650; font-size: clamp(42px, 4vw, 68px); line-height: .98; color: var(--c-paper); margin: auto 0 0; max-width: 9ch; overflow-wrap: normal; }
.hp-quote em { color: var(--c-yellow); }
.hp-note { font-family: var(--f-body); font-size: clamp(15px, 1.15vw, 18px); line-height: 1.45; color: color-mix(in srgb, var(--c-paper) 76%, transparent); max-width: 37ch; margin: 28px 0 0; }
.hp-meta-mono { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: color-mix(in srgb, var(--c-paper) 60%, transparent); }
.mark-notes { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; border-top: var(--line); padding-top: 18px; text-align: center; align-items: start; justify-items: center; }
.mark-notes span { display: flex; flex-direction: column; align-items: center; justify-content: flex-start; }
.mini-cube { width: 52px; height: 52px; margin-bottom: 12px; }
.mark-notes strong { display: block; font-family: var(--f-display); font-size: clamp(16px, 1.5vw, 24px); line-height: .95; letter-spacing: -.02em; }
.mark-notes small { display: block; margin-top: 6px; font-family: var(--f-mono); font-size: 10px; letter-spacing: .13em; text-transform: uppercase; color: var(--t-3); }
@media (max-width: 980px) { .hero-title { max-width: 11.5ch; } .hero-panel { grid-template-columns: 1fr 1fr; grid-template-rows: none; } .hp-stack svg { max-width: 50%; } .hp-quote { font-size: clamp(32px, 5vw, 54px); } }
@media (max-width: 680px) { .hero-panel { grid-template-columns: 1fr; } }
@media (max-width: 360px) {
  .hero-title { font-size: clamp(40px, 13vw, 46px); max-width: 10.5ch; }
  .hero-lede { font-size: 16px; }
  .hp-quote { font-size: 30px; }
}

.ticker { border-top: var(--line); border-bottom: var(--line); background: var(--c-paper-2); overflow: hidden; }
.ticker-track { display: flex; gap: 40px; align-items: center; white-space: nowrap; padding: 18px 0; font-family: var(--f-mono); font-size: 13px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--t-2); animation: ticker 38s linear infinite; }
.ticker-track .sep { color: var(--c-red); font-weight: 600; }
@keyframes ticker { from { transform: translateX(0); } to { transform: translateX(-50%); } }

.projects { padding: var(--section-y) 0; background: var(--c-paper-2); border-top: var(--line); border-bottom: var(--line); }
.portfolio-head { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr); column-gap: clamp(28px, 5vw, 90px); align-items: end; }
.portfolio-head .section-eyebrow, .portfolio-head .section-title { grid-column: 1; }
.portfolio-head .section-sub { grid-column: 2; grid-row: 2; margin: 0; }
.showcase-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px; }
.showcase-card { min-height: 480px; grid-column: span 4; min-width: 0; container-type: inline-size; position: relative; display: flex; flex-direction: column; justify-content: flex-end; gap: 14px; padding: clamp(22px, 3vw, 36px); border-radius: var(--r-lg); overflow: hidden; text-decoration: none; color: var(--c-paper); border: 1px solid color-mix(in srgb, var(--c-ink) 12%, transparent); isolation: isolate; }
.showcase-card::before { content: ""; position: absolute; inset: 0; z-index: -2; background: var(--c-ink); }
.showcase-card::after { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg, rgba(13,13,15,0.05), rgba(13,13,15,0.86)); }
.showcase-card h3 { font-family: var(--f-display); font-size: clamp(30px, 14cqw, 72px); line-height: 0.92; letter-spacing: -0.035em; margin: 0; max-width: none; overflow-wrap: normal; }
.addr-line { display: block; white-space: nowrap; }
.showcase-card.santa h3,
.showcase-card.gertrude h3 { font-size: clamp(34px, 12cqw, 66px); max-width: none; }
.showcase-card p { margin: 0; max-width: 44ch; color: color-mix(in srgb, var(--c-paper) 86%, transparent); overflow-wrap: break-word; }
.card-count { display: none; }
.card-kicker { font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--c-yellow); }
.card-link { margin-top: 8px; font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--c-paper); text-decoration: underline; text-underline-offset: 5px; }
.showcase-card dl { display: grid; grid-template-columns: repeat(auto-fit, minmax(118px, 1fr)); gap: 14px; width: 100%; max-width: 620px; margin: 10px 0 0; padding-top: 18px; border-top: 1px solid rgba(244,239,228,.25); }
.showcase-card dt { font-family: var(--f-mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: rgba(244,239,228,.55); }
.showcase-card dd { margin: 2px 0 0; font-family: var(--f-display); font-size: clamp(13px, 3.4cqw, 15px); line-height: 1.05; color: var(--c-paper); overflow-wrap: break-word; }
.showcase-card.feature { grid-column: span 8; min-height: 620px; }
.showcase-card.feature-castle { grid-column: span 7; min-height: 660px; }
.showcase-card.feature-broadway { grid-column: 6 / span 7; min-height: 640px; order: 4; }
.showcase-card.santa { grid-column: span 5; min-height: 540px; }
.showcase-card.gertrude { grid-column: span 5; min-height: 540px; order: 3; }
.showcase-card.madison { grid-column: 1 / -1; min-height: 560px; order: 5; }
.showcase-card.madison h3 { font-size: clamp(42px, 9cqw, 92px); max-width: none; }
.showcase-card.madison p { max-width: 46ch; font-size: clamp(16px, 1.25vw, 20px); }
.castle::before { background:
  linear-gradient(135deg, rgba(224,64,48,.82), rgba(13,13,15,.42)),
  radial-gradient(circle at 78% 18%, rgba(244,239,228,.20) 0 2px, transparent 2px 20px),
  repeating-linear-gradient(90deg, transparent 0 26px, rgba(244,239,228,.22) 26px 28px),
  repeating-linear-gradient(0deg, transparent 0 26px, rgba(244,239,228,.14) 26px 28px),
  var(--c-red); }
.santa::before { background:
  linear-gradient(145deg, rgba(240,176,32,.9), rgba(160,112,0,.74)),
  repeating-radial-gradient(circle at 72% 20%, rgba(244,239,228,.22) 0 2px, transparent 2px 18px),
  repeating-linear-gradient(135deg, rgba(13,13,15,.10) 0 2px, transparent 2px 24px),
  var(--c-yellow); }
.broadway::before { background:
  linear-gradient(90deg, rgba(13,13,15,.72), rgba(13,13,15,.28)),
  repeating-linear-gradient(90deg, rgba(244,239,228,.18) 0 16px, transparent 16px 72px),
  linear-gradient(135deg, var(--c-teal-dd), var(--c-ink)); }
.gertrude::before { background:
  linear-gradient(150deg, rgba(48,144,144,.9), rgba(13,13,15,.55)),
  repeating-linear-gradient(0deg, rgba(244,239,228,.14) 0 1px, transparent 1px 18px),
  repeating-linear-gradient(90deg, rgba(244,239,228,.10) 0 1px, transparent 1px 18px),
  var(--c-teal-dd); }
.madison::before { background:
  linear-gradient(135deg, rgba(13,13,15,.72), rgba(13,13,15,.88)),
  repeating-linear-gradient(45deg, rgba(240,176,32,.22) 0 2px, transparent 2px 18px),
  var(--c-ink); }
.showcase-card.coming { color: var(--c-paper); }
@media (max-width: 1040px) { .showcase-card, .showcase-card.feature, .showcase-card.feature-castle, .showcase-card.feature-broadway, .showcase-card.santa, .showcase-card.gertrude { grid-column: span 6; min-height: 520px; margin-top: 0; } .showcase-card.madison { grid-column: span 12; min-height: 500px; } }
@media (max-width: 720px) {
  .ticker-track { animation-duration: 18s; }
  .portfolio-head { display: block; }
  .portfolio-head .section-sub { margin-top: 14px; }
  .showcase-grid { grid-template-columns: 1fr; gap: 18px; }
  .showcase-card,
  .showcase-card.feature,
  .showcase-card.feature-castle,
  .showcase-card.feature-broadway,
  .showcase-card.santa,
  .showcase-card.gertrude,
  .showcase-card.madison {
    grid-column: 1;
    min-height: 470px;
    order: initial;
    padding: clamp(20px, 6vw, 28px);
    gap: 12px;
  }
  .showcase-card h3,
  .showcase-card.santa h3,
  .showcase-card.gertrude h3,
  .showcase-card.madison h3 {
    font-size: clamp(34px, 12.5cqw, 50px);
    line-height: .94;
  }
  .showcase-card p { font-size: 15.5px; line-height: 1.42; }
  .showcase-card dl {
    grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
    gap: 12px;
    padding-top: 14px;
  }
  .addr-line {
    white-space: normal;
    overflow-wrap: anywhere;
  }
}
@media (max-width: 380px) {
  .showcase-card h3,
  .showcase-card.santa h3,
  .showcase-card.gertrude h3,
  .showcase-card.madison h3 {
    font-size: clamp(30px, 11.5cqw, 42px);
  }
}

.statement { background: var(--c-ink); color: var(--c-paper); padding: var(--section-y) 0; }
.statement-inner { display: flex; flex-direction: column; gap: 24px; }
.statement .section-eyebrow { color: var(--c-red); }
.manifesto { font-family: var(--f-serif); font-weight: 400; font-size: clamp(27px, 3.45vw, 50px); line-height: 1.16; letter-spacing: -0.005em; margin: 0; max-width: 31ch; color: var(--c-paper); }
.manifesto em { font-style: normal; font-weight: inherit; color: inherit; }
.manifesto strong { font-style: normal; font-weight: inherit; color: inherit; }
.better { font-family: var(--f-display); font-size: clamp(42px, 6vw, 90px); letter-spacing: -0.025em; line-height: 0.96; margin: 32px 0 0; }
.better .b-y { color: var(--c-yellow); display: inline-block; }
.better .b-t { color: var(--c-teal); display: inline-block; }
.better .b-r { color: var(--c-red); display: inline-block; }
.manifesto-close { font-family: var(--f-serif); font-size: clamp(22px, 2.25vw, 34px); line-height: 1.18; margin: 0; max-width: 31ch; color: var(--c-paper); }
.manifesto-close em { color: inherit; font-style: normal; }

.archive { padding: var(--section-y) 0; }
.archive-inner { display: grid; grid-template-columns: .85fr 1.15fr; gap: clamp(32px, 6vw, 96px); align-items: start; }
.archive-list { list-style: none; margin: 0; padding: 0; border-top: var(--line); }
.archive-list a { display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 24px; padding: 22px 0; border-bottom: var(--line); text-decoration: none; }
.archive-list span { font-family: var(--f-display); font-size: clamp(24px, 3vw, 42px); letter-spacing: -.02em; line-height: 1; }
.archive-list small { font-family: var(--f-mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--t-3); }
.archive-list a:hover span { color: var(--c-red); }
@media (max-width: 820px) { .archive-inner { grid-template-columns: 1fr; } .archive-list a { grid-template-columns: 1fr; gap: 8px; } .archive-list small { grid-column: 1; } }

.quiet-note { min-height: 92svh; padding: clamp(92px, 12vw, 168px) 0; background: var(--c-red); color: #fff; display: flex; align-items: center; }
.note-inner { max-width: var(--wrap); width: 100%; }
.quiet-note .section-eyebrow { color: var(--c-yellow); margin: 0 0 clamp(30px, 5vw, 62px); }
.quiet-note h2 { font-family: var(--f-display); font-size: clamp(62px, 11vw, 154px); line-height: .86; letter-spacing: -.045em; margin: 0 0 clamp(28px, 4vw, 52px); max-width: 10.8ch; }
.quiet-note p:not(.section-eyebrow) { font-family: var(--f-serif); font-size: clamp(26px, 4.25vw, 58px); line-height: 1.08; margin: 0; max-width: 28ch; color: rgba(255,255,255,.9); }
@media (max-width: 760px) {
  .quiet-note .section-eyebrow { margin: 0 0 22px; }
}

.site-footer { background: var(--c-ink); color: var(--c-paper); padding-top: 84px; }
.footer-inner { display: grid; grid-template-columns: minmax(270px, .78fr) minmax(420px, 1.22fr); gap: clamp(36px, 6vw, 96px); align-items: start; }
.footer-lockup { display: inline-flex; flex-direction: column; line-height: .84; min-width: 210px; }
.footer-line { font-family: var(--f-display); font-size: 44px; letter-spacing: -.035em; display: block; }
.footer-red { color: var(--c-red); }
.footer-yellow { color: var(--c-yellow); }
.footer-teal { color: var(--c-teal); }
.footer-company { margin-top: 10px; font-family: var(--f-display); font-size: 12px; letter-spacing: .22em; color: var(--c-paper); white-space: nowrap; }
.foot-brand .footer-word { font-size: 28px; }
.foot-tag { font-family: var(--f-mono); font-weight: 400; font-size: 12px; letter-spacing: .12em; text-transform: uppercase; line-height: 1.6; margin: 22px 0 18px; color: color-mix(in srgb, var(--c-paper) 76%, transparent); max-width: 32ch; }
.foot-meta { font-size: 14px; color: color-mix(in srgb, var(--c-paper) 65%, transparent); margin: 0; }
.footer-contact { display: grid; grid-template-columns: minmax(220px, .75fr) minmax(280px, 1.25fr); gap: clamp(24px, 4vw, 48px); padding-top: 4px; }
.footer-copy h3 { font-family: var(--f-display); font-size: clamp(42px, 5vw, 76px); line-height: .9; letter-spacing: -.035em; margin: 0 0 18px; color: var(--c-paper); }
.footer-copy p { font-size: 17px; line-height: 1.5; color: color-mix(in srgb, var(--c-paper) 72%, transparent); margin: 0; max-width: 28ch; }
.contact-form { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.contact-form label { display: flex; flex-direction: column; gap: 8px; }
.contact-form label.full { grid-column: 1 / -1; }
.contact-form span { font-family: var(--f-mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--c-yellow); }
.contact-form input, .contact-form textarea { width: 100%; border: 1px solid color-mix(in srgb, var(--c-paper) 20%, transparent); background: color-mix(in srgb, var(--c-paper) 6%, transparent); color: var(--c-paper); border-radius: 14px; padding: 14px 15px; font: inherit; outline: none; }
.contact-form textarea { resize: vertical; min-height: 118px; }
.contact-form input:focus, .contact-form textarea:focus { border-color: var(--c-yellow); box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-yellow) 24%, transparent); }
.contact-form button { justify-self: start; border: 0; border-radius: 999px; padding: 13px 20px; background: var(--c-yellow); color: var(--c-ink); font-family: var(--f-display); font-size: 14px; letter-spacing: .02em; cursor: pointer; }
.form-status { margin: 0; align-self: center; color: color-mix(in srgb, var(--c-paper) 72%, transparent); font-size: 14px; }
.foot-bottom { margin-top: 56px; padding: 22px 0; border-top: 1px solid color-mix(in srgb, var(--c-paper) 16%, transparent); display: flex; justify-content: space-between; align-items: center; font-size: 12.5px; color: color-mix(in srgb, var(--c-paper) 55%, transparent); }
.foot-bottom .mono { font-family: var(--f-mono); letter-spacing: 0.14em; text-transform: uppercase; }
@media (max-width: 960px) { .footer-inner, .footer-contact { grid-template-columns: 1fr; } .foot-bottom { flex-direction: column; gap: 8px; align-items: flex-start; } }
@media (max-width: 560px) { .contact-form { grid-template-columns: 1fr; } }

.thanks-page { min-height: 100dvh; background: var(--c-paper); }
.thanks-main { min-height: 100dvh; display: grid; place-items: center; padding: var(--gut); }
.thanks-card { width: min(860px, 100%); padding: clamp(38px, 7vw, 84px); border: var(--line); border-radius: var(--r-lg); background: linear-gradient(160deg, #FAF7EE 0%, var(--c-paper) 62%, var(--c-paper-2) 100%); }
.thanks-card h1 { font-family: var(--f-display); font-size: clamp(58px, 9vw, 128px); line-height: .88; letter-spacing: -.04em; margin: 0 0 22px; }
.thanks-card p:not(.section-eyebrow) { font-family: var(--f-serif); font-size: clamp(22px, 3vw, 36px); line-height: 1.18; max-width: 25ch; margin: 0 0 34px; color: var(--t-2); }
.thanks-link { display: inline-flex; min-height: 44px; align-items: center; border-radius: 999px; padding: 12px 18px; background: var(--c-ink); color: var(--c-paper); font-family: var(--f-display); font-size: 14px; letter-spacing: .02em; text-decoration: none; }

@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; animation: none !important; }
  html { scroll-behavior: auto; }
}
