:root {
  --paper: #faf8f4;
  --paper-2: #f0ece3;
  --ink: #5f2b7f;
  --ink-2: #4a2163;
  --dim: #9e7aad;
  --accent: #d1592f;
}

* { box-sizing: border-box; }
body { margin: 0; background: var(--paper); color: var(--ink); font-family: Inter, system-ui, sans-serif; font-size: 15px; line-height: 1.55; }
a { color: inherit; }

.shell { width: min(1440px, 100%); margin: 0 auto; padding: 0 16px; }
.shell-outer { width: min(1440px, 100%); margin: 0 auto; padding: 0 16px; border-bottom: 1px solid var(--ink); }

.folio-bar { border-bottom: 1px solid var(--ink); display: none; justify-content: space-between; font-family: "JetBrains Mono", monospace; font-size: 10px; letter-spacing: .16em; text-transform: uppercase; padding: 10px 20px; }
.site-header, .site-footer { border-bottom: 1px solid var(--ink); }
.masthead { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding-top: 14px; padding-bottom: 14px; }
.brand { display: inline-flex; align-items: center; gap: 12px; text-decoration: none; }
.brand img { height: 42px; }
.brand span,
.brand .brand-tagline { font-size: 10px; text-transform: uppercase; letter-spacing: .18em; color: var(--dim); max-width: none; line-height: 1.35; white-space: nowrap; }
.nav-toggle { border: 1px solid var(--ink); background: transparent; color: var(--ink); font: inherit; padding: 8px 12px; font-size: 12px; text-transform: uppercase; letter-spacing: .14em; }
.main-nav { display: none; position: absolute; left: 0; right: 0; top: 112px; z-index: 20; background: var(--paper); border-top: 1px solid var(--ink); border-bottom: 1px solid var(--ink); padding: 16px; gap: 12px; flex-direction: column; }
.main-nav.open { display: flex; }
.main-nav a { text-decoration: none; font-size: 12px; letter-spacing: .14em; text-transform: uppercase; font-weight: 500; }
.main-nav a[aria-current="page"] { font-weight: 700; border-bottom: 1px solid var(--ink); padding-bottom: 4px; }
.quote-link { background: var(--ink); color: var(--paper); display: inline-flex; align-items: center; justify-content: center; padding: 9px 18px; min-height: 38px; width: fit-content; line-height: 1; }

.hero { width: min(1440px, 100%); margin: 0 auto; padding: 44px 16px 34px; border-bottom: 1px solid var(--ink); }
.hero .eyebrow { font-size: 11px; text-transform: uppercase; letter-spacing: .22em; color: var(--accent); margin: 0 0 14px; }
.hero h1 { margin: 0; font-family: Fraunces, Georgia, serif; font-size: clamp(2.2rem, 11vw, 8rem); line-height: .95; letter-spacing: -.03em; font-weight: 400; }
.hero h1 em { color: var(--accent); font-style: italic; }
.hero .lead { margin: 18px 0 0; font-size: 1rem; color: var(--ink-2); max-width: 760px; }

.prose { width: min(1440px, 100%); margin: 0 auto; padding: 28px 16px 40px; }
.no-pad { padding: 0; margin-top: 12px; }
.prose p, .prose li { color: var(--ink-2); }
.prose ul { padding-left: 22px; }

.grid-three { width: min(1440px, 100%); margin: 0 auto; padding: 24px 16px 40px; display: grid; gap: 16px; }
.card { border: 1px solid var(--ink); padding: 18px; background: #fff; }
.card h2, .card h3 { margin: 0 0 10px; font-family: Fraunces, Georgia, serif; font-weight: 400; letter-spacing: -.01em; }

.services-index { padding-top: 10px; }
.service-row { display: grid; grid-template-columns: 42px 1fr 24px; gap: 14px; text-decoration: none; padding: 26px 0; border-top: 1px solid var(--ink); }
.service-row:last-child { border-bottom: 1px solid var(--ink); }
.service-no { font-family: Fraunces, Georgia, serif; font-size: 30px; color: var(--accent); font-style: italic; line-height: 1; }
.service-row h2 { margin: 0 0 8px; font-family: Fraunces, Georgia, serif; font-size: 2rem; line-height: 1.05; font-weight: 400; }
.service-row p { margin: 0; color: var(--ink-2); }
.service-arrow { font-family: Fraunces, Georgia, serif; font-size: 28px; color: var(--accent); align-self: center; }

.about-essay { padding-top: 26px; }
.timeline { background: var(--paper-2); padding-top: 36px; padding-bottom: 36px; }
.timeline h2 { margin: 0 0 24px; font-family: Fraunces, Georgia, serif; font-size: clamp(2rem, 7vw, 3.5rem); font-weight: 400; letter-spacing: -.02em; }
.timeline h2 em { color: var(--accent); }
.timeline-row { display: grid; grid-template-columns: 80px 1fr; gap: 18px; border-top: 1px solid var(--ink); padding: 14px 0; }
.timeline-row:last-child { border-bottom: 1px solid var(--ink); }
.year { font-family: Fraunces, Georgia, serif; font-size: 30px; color: var(--accent); font-style: italic; line-height: 1; }
.timeline-row p { margin: 0; color: var(--ink-2); }

.service-back { padding-top: 14px; padding-bottom: 14px; }
.service-back a { text-decoration: none; font-family: "JetBrains Mono", monospace; font-size: 11px; text-transform: uppercase; letter-spacing: .16em; color: var(--accent); }
.service-body { padding-top: 26px; }

.blog-list { padding-top: 8px; }
.blog-row { display: grid; grid-template-columns: 40px 1fr; gap: 12px; text-decoration: none; padding: 22px 0; border-top: 1px solid var(--ink); }
.blog-row:last-child { border-bottom: 1px solid var(--ink); }
.blog-no { font-family: Fraunces, Georgia, serif; font-size: 26px; color: var(--accent); font-style: italic; }
.blog-meta, .blog-side, .meta { font-family: "JetBrains Mono", monospace; font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--dim); }
.blog-row h3 { margin: 0 0 8px; font-family: Fraunces, Georgia, serif; font-size: 1.7rem; font-weight: 400; line-height: 1.1; }
.blog-row p { margin: 0; color: var(--ink-2); }

.pagination { width: min(1440px, 100%); margin: 0 auto; padding: 16px; display: flex; justify-content: space-between; }

.contact-layout { padding-top: 24px; padding-bottom: 40px; display: grid; gap: 24px; }
.contact-details { border: 1px solid var(--ink); background: #fff; }
.detail-row { display: grid; gap: 6px; padding: 14px 16px; border-top: 1px solid var(--ink); }
.detail-row:first-child { border-top: 0; }
.detail-row span { font-family: "JetBrains Mono", monospace; font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--dim); }
.detail-row strong { font-family: Fraunces, Georgia, serif; font-weight: 500; font-size: 20px; }

.contact-form { width: 100%; margin: 0; background: var(--paper-2); }
.contact-form-hero { border: 1px solid var(--ink); background: #fff; }
.contact-form-hero.card { padding: 20px; }
.contact-form-hero .display-lg {
  margin: 0 0 12px;
  white-space: nowrap;
  font-size: clamp(1.9rem, 3.2vw, 2.7rem);
  line-height: 1.05;
}
.contact-form-hero .form-row { margin-bottom: 16px; }
.contact-form-hero .form-textarea { min-height: 160px; }
.contact-form-hero .btn { width: 100%; display: block; text-align: center; padding: 18px 18px; }

.contact-details-hero { margin-top: 22px; border-top: 1px solid var(--ink); }
.contact-details-hero .detail-row {
  padding: 14px 0;
  border-top: 1px solid var(--ink);
}
.contact-details-hero .detail-row:first-child { border-top: 0; }
.contact-details-hero .detail-row span { padding-left: 0; }
.contact-details-hero .detail-row strong { padding-left: 0; }
.form-row { display: grid; gap: 6px; margin-bottom: 12px; }
.form-row > span { font-family: "JetBrains Mono", monospace; font-size: 11px; letter-spacing: .16em; text-transform: uppercase; }
.form-control { width: 100%; border: none; border-bottom: 1px solid var(--ink); background: transparent; padding: 10px 0; font-size: 16px; }
.form-textarea { border: 1px solid var(--ink); padding: 12px; min-height: 130px; }
.btn { margin-top: 8px; border: none; background: var(--ink); color: var(--paper); padding: 13px 18px; text-transform: uppercase; letter-spacing: .14em; }

.footer-grid { display: grid; gap: 6px; padding-top: 18px; padding-bottom: 18px; color: var(--ink-2); }

@media (min-width: 1024px) {
  .folio-bar { display: flex; }
  .shell, .shell-outer, .hero, .prose, .grid-three, .pagination { padding-left: 40px; padding-right: 40px; }
  .nav-toggle { display: none; }
  .main-nav { display: flex; position: static; border: 0; padding: 0; flex-direction: row; align-items: center; gap: 28px; }

  .hero .lead { font-size: 1.12rem; }
  .grid-three { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 24px; }

  .service-row { grid-template-columns: 60px 1fr 60px; gap: 32px; padding: 40px 0; }
  .service-no { font-size: 50px; }
  .service-row h2 { font-size: 4.1rem; }
  .service-row p { font-size: 1.1rem; max-width: 700px; }
  .service-arrow { font-size: 42px; text-align: right; }

  .timeline-row { grid-template-columns: 160px 1fr; gap: 40px; padding: 24px 0; }
  .year { font-size: 50px; }
  .timeline-row p { font-size: 1.12rem; }

  .blog-row { grid-template-columns: 60px 160px 1fr 170px; gap: 32px; align-items: baseline; padding: 36px 0; }
  .blog-no { font-size: 34px; }
  .blog-row h3 { font-size: 2.1rem; }
  .blog-side { text-align: right; }

  .contact-layout { grid-template-columns: 1fr 1fr; gap: 32px; }
  .detail-row { grid-template-columns: 180px 1fr; align-items: baseline; gap: 18px; }

  .footer-grid { grid-template-columns: 1fr 1fr; align-items: baseline; }
}

.section-rule { border-bottom: 1px solid var(--ink); }
.page-hero { padding: 56px 0; }
.editorial-grid {
  width: min(1440px, 100%);
  margin: 0 auto;
  padding: 0 16px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}
.editorial-grid-two {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
  padding-top: 10px;
  padding-bottom: 10px;
}
.rail { font-family: "JetBrains Mono", monospace; font-size: 11px; letter-spacing: .2em; text-transform: uppercase; color: var(--dim); }
.kicker { font-family: "JetBrains Mono", monospace; font-size: 12px; letter-spacing: .22em; text-transform: uppercase; color: var(--accent); margin-bottom: 12px; }
.display-xl { font-family: Fraunces, Georgia, serif; font-weight: 400; font-size: clamp(2.4rem, 10.8vw, 8rem); line-height: .96; letter-spacing: -.03em; margin: 0; }
.display-lg { font-family: Fraunces, Georgia, serif; font-weight: 400; font-size: clamp(2rem, 6.8vw, 3.8rem); line-height: 1; letter-spacing: -.02em; margin: 0 0 22px; }
.display-xl em, .display-lg em { color: var(--accent); }
.standfirst { margin: 0; font-size: 18px; line-height: 1.58; color: var(--ink-2); }
.plain-link { text-decoration: none; }

/* Hero standfirst should align to grid, not page-wide prose */
.editorial-grid .prose { width: auto; margin: 0; padding: 0; }
.page-hero .standfirst { max-width: 520px; margin-top: 18px; }
.page-hero .standfirst p { margin: 0; }
.page-hero .standfirst + .standfirst { margin-top: 16px; }

.svc-row { display: grid; grid-template-columns: 44px 1fr; gap: 16px; padding: 28px 16px; border-top: 1px solid var(--ink); text-decoration: none; }
.svc-row:first-child { border-top: 0; }
.svc-no { font-family: Fraunces, Georgia, serif; font-size: 30px; color: var(--accent); font-style: italic; line-height: 1; }
.svc-title { margin: 0 0 10px; font-family: Fraunces, Georgia, serif; font-size: 2rem; line-height: .98; font-weight: 400; letter-spacing: -.02em; }
.svc-lede { margin: 0; color: var(--ink-2); font-size: 16px; }
.svc-art { display: none; }
.svc-art-inner { border: 1px solid var(--ink); background: var(--paper-2); aspect-ratio: 3/2; display: grid; place-items: center; font-family: "JetBrains Mono", monospace; font-size: 11px; letter-spacing: .12em; text-transform: uppercase; }

.about-layout { padding-top: 30px; padding-bottom: 30px; display: grid; grid-template-columns: 1fr; gap: 18px; }
.prose-tight { padding: 0; margin: 0; }
.about-art { min-height: 220px; border: 1px solid var(--ink); background: repeating-linear-gradient(135deg, #5f2b7f10 0 12px, transparent 12px 24px), var(--paper-2); }
.timeline-bg { background: var(--paper-2); padding: 40px 0; }

.blog-list-xl { padding-top: 12px; padding-bottom: 12px; }
.blog-row-xl { display: grid; grid-template-columns: 42px 1fr; gap: 14px; text-decoration: none; border-top: 1px solid var(--ink); padding: 26px 0; }
.blog-row-xl h3 { margin: 0 0 10px; font-family: Fraunces, Georgia, serif; font-weight: 400; font-size: 2rem; line-height: 1.04; letter-spacing: -.01em; }
.blog-row-xl p { margin: 0; color: var(--ink-2); }
.blog-cat, .blog-side { font-family: "JetBrains Mono", monospace; font-size: 11px; letter-spacing: .13em; text-transform: uppercase; color: var(--dim); }

.contact-facts {
  border: 1px solid var(--ink);
  background: var(--paper);
}
.fact { padding: 18px 20px; border-top: 1px solid #d4c3dc; }
.fact:first-child { border-top: 0; }
.fact span { display: block; font-family: "JetBrains Mono", monospace; font-size: 11px; text-transform: uppercase; letter-spacing: .18em; color: var(--dim); }
.fact strong { font-family: Fraunces, Georgia, serif; font-size: 22px; font-weight: 500; }
.form-wrap { padding-top: 28px; padding-bottom: 36px; }
.service-body-xl { padding-top: 26px; padding-bottom: 34px; }

@media (min-width: 1024px) {
  .editorial-grid { padding: 0 40px; grid-template-columns: 60px 1fr 1fr; gap: 32px; align-items: start; }
  .editorial-grid-two { grid-template-columns: 60px 1fr; gap: 32px; }
  .page-hero { padding: 60px 0 72px; }
  .contact-facts { max-width: 520px; justify-self: end; }

  .svc-row { grid-template-columns: 60px 1fr 360px; gap: 32px; padding: 56px 40px; }
  .svc-no { font-size: 48px; }
  .svc-title { font-size: 4.3rem; }
  .svc-lede { font-size: 18px; max-width: 560px; }
  .svc-art { display: block; }

  .about-layout { grid-template-columns: 60px 7fr 5fr; gap: 32px; padding: 80px 40px; }
  .about-art { min-height: 520px; }

  .blog-row-xl { grid-template-columns: 60px 150px 1fr 200px; gap: 32px; align-items: baseline; padding: 40px 0; }
  .blog-row-xl h3 { font-size: 2.2rem; }
  .blog-side { text-align: right; }

  .form-wrap { padding: 40px; }
  .contact-form { max-width: 620px; margin-left: auto; }
  .contact-form-hero { max-width: 480px; margin-left: 0; }
  .contact-details-hero .detail-row { grid-template-columns: 180px 1fr; align-items: baseline; gap: 18px; }
}

/* Home page exact-style pass */
.home-hero,.home-stats,.home-services,.home-process,.home-feature,.home-quotes,.home-sustain,.home-cta{border-top:1px solid var(--ink);padding-top:28px;padding-bottom:28px}
.home-kicker{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin:8px 0 20px}
.home-display{font-family:Fraunces,Georgia,serif;font-size:clamp(3rem,9.4vw,9.2rem);line-height:.95;letter-spacing:-.03em;font-weight:400;margin:0 0 28px}
.home-display em{color:var(--accent);font-style:italic}
.home-intro-grid{display:grid;grid-template-columns:1fr;gap:24px;border-top:1px solid var(--ink);padding-top:24px}
.home-intro-copy{font-family:Fraunces,Georgia,serif;font-size:26px;line-height:1.25;margin:0 0 20px}
.home-intro-actions{display:flex;gap:12px;flex-wrap:wrap}
.home-btn{border:1px solid var(--ink);padding:12px 18px;text-decoration:none;text-transform:uppercase;letter-spacing:.14em;font-size:12px}
.home-btn-solid{background:var(--ink);color:var(--paper)}
.home-issue{border-left:1px solid var(--ink);padding-left:20px}
.home-issue>p{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--dim);margin:0 0 8px}
.home-issue ul{list-style:none;padding:0;margin:0}
.home-issue li:not(:has(.home-issue-link)){display:flex;justify-content:space-between;border-top:1px solid #d4c3dc;padding:9px 0}
.home-issue li:has(.home-issue-link){border-top:1px solid #d4c3dc}
.home-issue li span{font-family:Fraunces,Georgia,serif;font-size:34px;font-style:italic;line-height:1}
.home-issue li em{font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--dim)}
.home-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-bottom:1px solid var(--ink)}
.home-stats div{border-right:1px solid var(--ink);border-top:1px solid var(--ink);padding:18px}
.home-stats div:nth-child(2n){border-right:0}
.home-stats strong{display:block;font-family:Fraunces,Georgia,serif;font-size:56px;line-height:.95}
.home-stats span{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--dim)}
.home-services-head{display:grid;grid-template-columns:1fr;gap:14px;border-bottom:1px solid var(--ink);padding-bottom:16px}
.home-services-head h2{margin:0;font-family:Fraunces,Georgia,serif;font-size:clamp(2.4rem,6vw,5.2rem);line-height:.95;font-weight:400}
.home-services-head h2 em{font-style:italic}
.home-services-head h2 .home-services-accent{color:var(--accent)}
.home-service-row--print p{color:var(--accent)}
.home-intro-copy-secondary{margin-top:18px}
.home-issue-link{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:center;text-decoration:none;color:inherit;padding:12px 0}
.home-issue li:has(.home-issue-link){display:block;border-top:1px solid rgba(95,43,127,.08);border-bottom:1px solid rgba(95,43,127,.08)}
.home-issue li:has(.home-issue-link):first-of-type{border-top:0}
.home-issue-link:hover span{color:var(--accent)}
.home-feature-media video,.home-feature-media img{display:block;width:100%;height:100%;object-fit:cover}
.home-feature figure video{aspect-ratio:1/1}
.home-services-grid{display:grid;grid-template-columns:1fr;gap:18px}
.home-services-content{min-width:0}
.home-service-row{display:grid;grid-template-columns:32px 1fr;gap:12px;border-bottom:1px solid var(--ink);padding:14px 0}
.home-service-row b{color:var(--accent);font-family:Fraunces,Georgia,serif;font-style:italic;font-size:36px;font-weight:400}
.home-service-row h3{margin:0;font-family:Fraunces,Georgia,serif;font-size:44px;font-weight:500}
.home-service-row p{margin:8px 0 6px;font-size:16px;color:var(--ink-2)}
.home-service-row small{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2)}
.home-process{background:var(--paper-2);border-bottom:1px solid var(--ink)}
.home-process h2,.home-feature h2,.home-quotes h2,.home-sustain h2,.home-cta h2{margin:0 0 12px;font-family:Fraunces,Georgia,serif;font-weight:400;line-height:1}
.home-process h2{font-size:clamp(2.3rem,5vw,5.2rem)}
.home-process h2 em,.home-sustain h2 em,.home-quotes h2 em,.home-cta h2 em{font-style:italic}
.home-process-grid{display:grid;grid-template-columns:1fr;gap:0;border:1px solid var(--ink);margin-top:18px}
.home-process-grid article{padding:18px;border-top:1px solid var(--ink)}
.home-process-grid article:first-child{border-top:0}
.home-process-grid span{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.home-process-grid h3{margin:8px 0;font-family:Fraunces,Georgia,serif;font-size:44px}
.home-feature{display:grid;grid-template-columns:1fr;gap:22px}
.home-feature h2{font-size:clamp(2.2rem,5vw,4.8rem)}
.home-feature figure{margin:0;border:1px solid var(--ink)}
.home-feature img{display:block;width:100%;height:auto}
.home-quotes{background:var(--paper-2)}
.home-quotes h2{font-size:clamp(2.1rem,5vw,4.6rem)}
.home-quotes-grid{display:grid;grid-template-columns:1fr;gap:14px}
.home-quotes-grid blockquote{margin:0;border-top:1px solid var(--ink);padding-top:12px;font-family:Fraunces,Georgia,serif;font-size:40px;line-height:1.12}
.home-sustain{display:grid;grid-template-columns:1fr;gap:22px}
.home-sustain h2{font-size:clamp(2.2rem,5vw,4.8rem)}
.home-sustain-stats{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--ink)}
.home-sustain-stats div{padding:14px;border-top:1px solid var(--ink);border-right:1px solid var(--ink)}
.home-sustain-stats div:nth-child(2n){border-right:0}
.home-sustain-stats strong{display:block;color:var(--accent);font-family:Fraunces,Georgia,serif;font-size:60px;line-height:1}
.home-sustain-stats span{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase}
.home-cta{background:var(--ink);color:var(--paper);display:grid;grid-template-columns:1fr;gap:14px;border-bottom:0}
.home-cta h2{font-size:clamp(2.4rem,6vw,5.6rem)}
.home-cta h2 em{color:var(--accent)}
.home-cta a{display:inline-block;background:var(--accent);padding:14px 18px;color:#fff;text-decoration:none;text-transform:uppercase;letter-spacing:.15em;font-size:12px}
.home-cta p{font-family:Fraunces,Georgia,serif;font-size:44px;line-height:1.12;margin:0 0 14px}

@media (min-width: 1024px){
  .home-hero,.home-stats,.home-services,.home-process,.home-feature,.home-quotes,.home-sustain,.home-cta{padding-left:40px;padding-right:40px}
  .home-intro-grid{grid-template-columns:1.15fr .85fr;gap:34px}
  .home-stats{grid-template-columns:repeat(5,1fr)}
  .home-stats div{border-top:0}.home-stats div:nth-child(2n){border-right:1px solid var(--ink)}.home-stats div:last-child{border-right:0}
  .home-services-head{grid-template-columns:1fr 1fr;gap:30px;align-items:end}
  .home-services-grid{grid-template-columns:60px 1fr;gap:32px;align-items:start}
  .home-service-row{grid-template-columns:70px 320px 1fr 1fr;gap:30px;align-items:center;padding:18px 0}
  .home-service-row h3{font-size:54px}.home-service-row p{margin:0}
  .home-process-grid{grid-template-columns:repeat(3,1fr)}
  .home-process-grid article{border-top:0;border-left:1px solid var(--ink);min-height:220px}.home-process-grid article:nth-child(3n+1){border-left:0}.home-process-grid article:nth-child(n+4){border-top:1px solid var(--ink)}
  .home-feature{grid-template-columns:1fr 1fr;gap:34px;align-items:start}
  .home-quotes-grid{grid-template-columns:repeat(3,1fr);gap:34px}
  .home-sustain{grid-template-columns:1fr 1fr;gap:34px;align-items:start}
  .home-cta{grid-template-columns:1fr 1fr;gap:34px;align-items:center}
}

/* Services index + service details exact-style pass */
.srv-hero,.srv-index,.sdetail-hero,.sdetail-brief,.sdetail-caps,.sdetail-shop,.sdetail-work,.sdetail-run,.sdetail-other{border-top:1px solid var(--ink);padding-top:28px;padding-bottom:28px}
.srv-hero-grid,.sdetail-head{display:grid;grid-template-columns:1fr;gap:18px}
.srv-title{margin:0;font-family:Fraunces,Georgia,serif;font-size:clamp(3rem,8.8vw,8rem);line-height:.95;font-weight:400;letter-spacing:-.03em}
.srv-title em{font-style:italic}
.srv-standfirst{font-size:34px;line-height:1.2;color:var(--ink-2);margin:0;max-width:560px}
.srv-index{display:grid;gap:0}
.srv-row{display:grid;grid-template-columns:40px 1fr;gap:14px;padding:24px 0;border-top:1px solid var(--ink);text-decoration:none}
.srv-row:first-child{border-top:0}
.srv-roman{font-family:Fraunces,Georgia,serif;font-size:44px;color:var(--accent);font-style:italic;line-height:1}
.srv-row h2{margin:0 0 8px;font-family:Fraunces,Georgia,serif;font-size:56px;line-height:.96;font-weight:400}
.srv-row h2 span{color:var(--accent)}
.srv-row p{margin:0 0 8px;color:var(--ink-2);font-size:16px}
.srv-row small{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-2)}
.srv-thumb{display:none}
.srv-thumb img{display:block;width:100%;height:100%;object-fit:cover;border:1px solid var(--ink)}

.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

.sdetail-head h1{margin:0;font-family:Fraunces,Georgia,serif;font-size:clamp(3rem,8.4vw,7.5rem);line-height:.9;font-weight:400;letter-spacing:-.03em}
.sdetail-head h1 br:last-child{display:none}
.sdetail-head p{margin:0;font-size:16px;color:var(--ink-2);max-width:460px}

.sdetail-hl-red{color:#d1592f}

/* Clothing service hero tweaks */
.sdetail-hero--clothing .rail{color:#d1592f}
.sdetail-hero--clothing .rail-roman-xl{
  color:#d1592f;
  font-size:clamp(4.25rem,10.5vw,7.75rem);
  line-height:.84;
}
.sdetail-hero--clothing .sdetail-head h1{font-size:clamp(3.4rem,9.2vw,8.6rem)}

/* Design service hero tweaks */
.sdetail-hero--design .rail{color:#d1592f}
.sdetail-hero--design .rail-roman-xl{
  color:#d1592f;
  font-size:clamp(4.25rem,10.5vw,7.75rem);
  line-height:.84;
}
.sdetail-hero--design .sdetail-head h1{
  font-size:clamp(3.6rem,9.6vw,9.2rem);
  line-height:.74;
}
.sdetail-hero--design .sdetail-head h1 span{display:inline-block;white-space:nowrap}

.sdetail-head .rail--roman-only{font-family:Fraunces,Georgia,serif;font-size:inherit;letter-spacing:normal;text-transform:none;color:inherit;line-height:1}
.rail-roman-xl{display:block;font-family:Fraunces,Georgia,serif;font-size:clamp(3.25rem,9.5vw,6.75rem);font-style:italic;font-weight:400;color:var(--accent);line-height:.88}

/* Print service hero — Litho in right column; cream panel */
.sdetail-hero.sdetail-hero--print{
  background-color:#fefbf8;
  padding-top:clamp(44px,5.5vw,68px);
  padding-bottom:40px;
  padding-left:clamp(20px,5vw,28px);
  padding-right:clamp(20px,5vw,28px);
}
.sdetail-hero--print .kicker{color:var(--accent);margin:0 0 clamp(18px,2.6vw,26px)}
.sdetail-hero--print .kicker a{color:inherit}
.sdetail-hero--print .sdetail-hl-lead{color:var(--ink);font-weight:400;font-style:normal}
.sdetail-hero--print .sdetail-hl-accent{color:var(--accent);font-weight:400;font-style:italic}
.sdetail-hero--print .rail-roman-xl{color:var(--accent)}
.sdetail-hero--print .sdetail-lede-sans,.sdetail-print-lede{
  font-family:Inter,system-ui,sans-serif;
  color:var(--ink-2);
  font-weight:400;
  letter-spacing:0.01em;
  line-height:1.55;
  font-size:clamp(17px,3.2vw,20px);
  text-align:left;
  hyphens:none;
  font-variant-numeric:proportional-nums;
}

/* Print hero headline — match home-display scale and rhythm */
.sdetail-head--print-hero{
  --print-display:clamp(3rem,9.4vw,9.2rem);
  --print-lh:0.96;
  --print-line-box:calc(var(--print-display) * var(--print-lh));
  --print-above-headline:clamp(2.6rem,4.2vw,3.1rem);
}
.sdetail-hero--print .sdetail-head.sdetail-head--print-hero h1{
  font-size:var(--print-display);
  line-height:var(--print-lh) !important;
  font-family:Fraunces,Georgia,serif !important;
  text-transform:none !important;
  letter-spacing:-0.03em !important;
  padding-bottom:0;
  margin:0;
  font-weight:400;
}
.sdetail-head--print-hero .rail--roman-only{
  display:flex;
  justify-content:flex-end;
  align-items:flex-start;
  padding-top:var(--print-above-headline);
  align-self:start;
  margin-left:clamp(-18px,-2.2vw,-10px);
  /* Make the Roman “I” visibly hug the left */
  transform:translateX(clamp(-18px,-2.2vw,-10px));
}
.sdetail-head--print-hero .rail-roman-xl{font-size:calc(var(--print-display) * 0.36);line-height:0.92}

/* Storage & fulfilment — red Roman V, larger headline, red “fulfilment.” (overrides shared print-hero) */
.sdetail-hero.sdetail-hero--print.sdetail-hero--storage .sdetail-head--print-hero{
  --print-display:clamp(5.75rem,18.5vw,11.35rem);
}
.sdetail-hero.sdetail-hero--print.sdetail-hero--storage .sdetail-head.sdetail-head--print-hero h1{
  font-size:calc(var(--print-display) + 2pt);
}
.sdetail-hero.sdetail-hero--print.sdetail-hero--storage .sdetail-head--print-hero .rail-roman-xl{
  color:#d1592f;
  font-size:calc(var(--print-display) * 0.42);
  line-height:.88;
}
.sdetail-hero--storage .sdetail-hl-fulfilment-red{
  color:#d1592f;
  font-weight:400;
  font-style:italic;
}

/* Stacked accent lines — tight rhythm */
.sdetail-hero--print .sdetail-head--print-hero h1 .sdetail-hl-accent{display:inline-block;margin-top:0.015em}

.sdetail-hl-lead{color:#5f2b7f;font-weight:400;font-style:normal}
.sdetail-hl-accent{color:var(--accent);font-weight:400;font-style:italic}
.sdetail-hl-blue{color:var(--ink);font-weight:400;font-style:normal}
.sdetail-hl-red{color:#d1592f;font-weight:400;font-style:italic}

.sdetail-lede-sans{font-family:Inter,system-ui,sans-serif;color:var(--ink);line-height:1.45}
.sdetail-hero-art{margin:18px 0 0;border:1px solid var(--ink);background:var(--paper-2)}
.sdetail-hero-art img{display:block;width:100%;height:auto}
.sdetail-brief,
.sdetail-caps,
.sdetail-shop,
.sdetail-work,
.sdetail-run,
.sdetail-other{
  align-items:start;
  row-gap:20px;
}
.sdetail-brief{display:grid;grid-template-columns:1fr;gap:16px}
.sdetail-brief .rail .rail-num,
.sdetail-brief .rail .rail-title,
.sdetail-caps .rail .rail-num,
.sdetail-caps .rail .rail-title,
.sdetail-work .rail .rail-num,
.sdetail-work .rail .rail-title,
.sdetail-shop .rail .rail-num,
.sdetail-shop .rail .rail-title,
.sdetail-run .rail .rail-num,
.sdetail-run .rail .rail-title{display:block}
.sdetail-brief .rail .rail-num,
.sdetail-caps .rail .rail-num,
.sdetail-shop .rail .rail-num,
.sdetail-work .rail .rail-num{margin-bottom:8px}
.sdetail-brief > .rail,
.sdetail-caps > .rail,
.sdetail-shop > .rail,
.sdetail-work > .rail,
.sdetail-run > .rail,
.sdetail-other > .rail{
  min-width:0;
  line-height:1.35;
}
.sdetail-caps .rail .rail-title,
.sdetail-brief .rail .rail-title,
.sdetail-work .rail .rail-title,
.sdetail-shop .rail .rail-title,
.sdetail-run .rail .rail-title,
.sdetail-other .rail .rail-title{
  white-space:nowrap;
}
.sdetail-brief .prose p{font-family:Fraunces,Georgia,serif;font-size:20px;line-height:1.24;color:var(--ink);margin:0}
.sdetail-brief--print .prose .rich-text p ~ *{display:none}
.sdetail-brief--storage .prose .rich-text p ~ *{display:none}
.sdetail-brief--promotional .prose .rich-text p ~ *{display:none}
.sdetail-brief--promotional .prose .rich-text p:first-child{
  font-size:clamp(18px,2.2vw,28px);
  line-height:1.22;
  max-width:62ch;
  line-clamp:6;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:6;
  overflow:hidden;
}
.sdetail-caps{display:grid;grid-template-columns:1fr;gap:16px;background:var(--paper-2)}
.sdetail-caps h2{margin:0 0 16px;font-family:Fraunces,Georgia,serif;font-size:56px;font-weight:400;line-height:1}
.sdetail-caps h2 em{font-style:italic}
.sdetail-caps.sdetail-caps--clothing{
  padding-top:56px;
  padding-bottom:56px;
}
.sdetail-caps.sdetail-caps--clothing h2{margin-bottom:44px}
.sdetail-caps.sdetail-caps--design{
  padding-top:56px;
  padding-bottom:56px;
}
.sdetail-caps.sdetail-caps--design h2{margin-bottom:44px}
.sdetail-caps.sdetail-caps--promotional{
  padding-top:44px;
  padding-bottom:44px;
}
.sdetail-caps.sdetail-caps--promotional h2{margin-bottom:44px}
.sdetail-caps.sdetail-caps--promotional .caps-grid{margin-top:6px}
.sdetail-caps.sdetail-caps--storage{
  padding-top:44px;
  padding-bottom:44px;
}
.sdetail-caps.sdetail-caps--storage h2{margin-bottom:44px}
.sdetail-caps.sdetail-caps--storage .caps-grid{margin-top:6px}
.sdetail-caps--storage .caps-grid--with-desc article{
  padding:22px;
  min-height:200px;
}
.sdetail-caps--storage .caps-grid--with-desc h3{font-size:32px}
.sdetail-caps--storage .caps-grid--with-desc p{
  font-size:14px;
  max-width:46ch;
  line-clamp:5;
  -webkit-line-clamp:5;
}
.sdetail-caps--storage .caps-grid--with-desc article:nth-child(n+4) span{
  color:#d1592f;
}
.caps-grid{display:grid;grid-template-columns:1fr;border:1px solid var(--ink);background:var(--paper)}
.caps-grid article{padding:16px;border-top:1px solid var(--ink)}
.caps-grid article:first-child{border-top:0}
.caps-grid span{font-family:"JetBrains Mono",monospace;color:var(--accent);font-size:10px;letter-spacing:.16em}
.caps-grid h3{margin:8px 0 0;font-family:Fraunces,Georgia,serif;font-size:34px;line-height:1.08}
.caps-grid--with-desc{grid-auto-rows:1fr}
.caps-grid--with-desc article{display:flex;flex-direction:column;align-items:flex-start}
.caps-grid--with-desc h3{font-size:30px}
.caps-grid--with-desc p{
  margin:10px 0 0;
  font-size:13px;
  line-height:1.55;
  color:var(--ink-2);
  max-width:34ch;
  line-clamp:4;
  display:-webkit-box;
  -webkit-box-orient:vertical;
  -webkit-line-clamp:4;
  overflow:hidden;
}
.sdetail-caps--promotional .caps-grid--with-desc article{
  padding:22px;
  min-height:200px;
}
.sdetail-caps--promotional .caps-grid--with-desc h3{font-size:32px}
.sdetail-caps--promotional .caps-grid--with-desc p{
  font-size:14px;
  max-width:46ch;
  line-clamp:5;
  -webkit-line-clamp:5;
}
.sdetail-shop{
  display:grid;
  grid-template-columns:1fr;
  gap:16px;
}
.sdetail-shop-card{
  background:#5f2b7f;
  color:#fff;
  padding:clamp(28px,4vw,48px);
  border-radius:2px;
}
.sdetail-shop-kicker{
  color:#d1592f;
  margin:0 0 18px;
}
.sdetail-shop-card h2{
  margin:0 0 18px;
  font-family:Fraunces,Georgia,serif;
  font-size:clamp(2.4rem,5.8vw,4.5rem);
  line-height:1.02;
  font-weight:400;
  letter-spacing:-.02em;
  color:#fff;
}
.sdetail-shop-card h2 em{
  color:#d1592f;
  font-style:italic;
}
.sdetail-shop-lede{
  margin:0 0 28px;
  max-width:52ch;
  font-size:16px;
  line-height:1.5;
  color:#ccc;
}
.sdetail-shop-btn{
  display:inline-block;
  background:#d1592f;
  color:#fff;
  text-decoration:none;
  text-transform:uppercase;
  letter-spacing:.15em;
  font-size:11px;
  padding:16px 20px;
}
.sdetail-work{display:grid;grid-template-columns:1fr;gap:16px}
.work-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.work-grid figure{margin:0;border:1px solid #c0a8cf;background:#ece5d8}
.work-grid img{display:block;width:100%;height:auto}
.sdetail-run{display:grid;grid-template-columns:1fr;gap:24px;background:var(--paper-2)}
.sdetail-run.sdetail-run--clothing{
  padding-top:56px;
  padding-bottom:56px;
  padding-inline:clamp(28px,6vw,56px);
}
.sdetail-run.sdetail-run--clothing > .rail{
  margin-left:calc(clamp(28px,6vw,56px) * -1);
  margin-top:6px;
  align-self:start;
}
.sdetail-run.sdetail-run--promotional{
  padding-top:56px;
  padding-bottom:56px;
  padding-inline:clamp(28px,6vw,56px);
}
.sdetail-run.sdetail-run--promotional .sdetail-run-inner{gap:34px}
.sdetail-run.sdetail-run--promotional > .rail{
  margin-left:calc(clamp(28px,6vw,56px) * -1);
  margin-top:6px;
  align-self:start;
}
.sdetail-run.sdetail-run--design{
  padding-top:56px;
  padding-bottom:56px;
  padding-inline:clamp(28px,6vw,56px);
}
.sdetail-run.sdetail-run--design .sdetail-run-inner{
  gap:34px;
}
.sdetail-run.sdetail-run--design > .rail{
  margin-left:calc(clamp(28px,6vw,56px) * -1);
  margin-top:6px;
  align-self:start;
}
.sdetail-run--design .fyi-table div{
  padding:22px 0;
  align-items:start;
}
.sdetail-run--design .steps-list--with-desc .step-row:first-child{
  border-top:1px solid var(--ink);
}
.sdetail-run.sdetail-run--storage{
  padding-top:56px;
  padding-bottom:56px;
  padding-inline:clamp(28px,6vw,56px);
}
.sdetail-run.sdetail-run--storage .sdetail-run-inner{gap:34px}
.sdetail-run.sdetail-run--storage > .rail{
  margin-left:calc(clamp(28px,6vw,56px) * -1);
  margin-top:6px;
  align-self:start;
}
.sdetail-run--storage .steps-list--with-desc .step-row:first-child{
  border-top:1px solid var(--ink);
}
@media (min-width:1024px){
  .sdetail-run.sdetail-run--clothing{
    padding-left:40px;
    padding-right:40px;
    grid-template-columns:60px 1fr;
    column-gap:32px;
  }
  .sdetail-run.sdetail-run--clothing > .rail{margin-left:0}
  .sdetail-run.sdetail-run--promotional > .rail{margin-left:0}
}
.sdetail-run-inner{display:grid;grid-template-columns:1fr;gap:24px}
.sdetail-run h2{margin:0 0 12px;font-family:Fraunces,Georgia,serif;font-size:64px;line-height:.94;font-weight:400}
.sdetail-run h2 em{font-style:italic}
.fyi-table div{display:grid;grid-template-columns:180px 1fr;gap:18px;padding:18px 0;border-top:1px solid var(--ink);align-items:center}
.fyi-table div:last-child{border-bottom:1px solid var(--ink)}
.fyi-table span{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--dim);line-height:1.2}
.fyi-table strong{font-family:Fraunces,Georgia,serif;font-size:20px;font-weight:500;color:var(--ink);line-height:1.22}
.steps-list > div{display:grid;grid-template-columns:36px 1fr;gap:8px;border-top:1px solid var(--ink);padding:10px 0}
.steps-list b{color:var(--accent);font-family:Fraunces,Georgia,serif;font-size:30px;font-style:italic;line-height:1}
.steps-list h4{margin:0;font-family:Fraunces,Georgia,serif;font-size:32px;line-height:1.05}
.steps-list--with-desc > div{border-top:0;padding:0}
.steps-list--with-desc .step-row{display:grid;grid-template-columns:60px 1fr;gap:22px;border-top:1px solid var(--ink);padding:22px 0;align-items:start}
.steps-list--with-desc .step-row:last-child{border-bottom:1px solid var(--ink)}
.steps-list--with-desc .step-row:first-child{border-top:0}
.steps-list--with-desc b{font-size:30px;color:#d1592f;margin-top:2px}
.steps-list--with-desc .step-body{display:block}
.steps-list--with-desc .step-body h4{font-size:24px;line-height:1.08;margin:0 0 8px}
.steps-list--with-desc .step-body p{margin:0;color:var(--ink-2);font-size:13px;line-height:1.65;max-width:56ch}
.sdetail-other{display:grid;grid-template-columns:1fr;gap:16px}
.sdetail-other h3{margin:0 0 14px;font-family:Fraunces,Georgia,serif;font-size:46px;font-weight:400}
.sdetail-other h3 em{font-style:italic}
.other-grid{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--ink)}
.other-grid a{border-top:1px solid var(--ink);border-right:1px solid var(--ink);text-decoration:none;background:var(--paper)}
.other-grid a:nth-child(2n){border-right:0}
.other-card{padding:28px 22px;min-height:180px;display:flex;flex-direction:column;gap:12px}
.other-roman{font-family:Fraunces,Georgia,serif;color:var(--accent);font-style:italic;font-size:26px;line-height:1}
.other-title{
  font-family:Fraunces,Georgia,serif;
  font-size:24px;
  /* line-height:1.06; */
  color:var(--ink);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.other-arrow{margin-top:auto;font-family:Fraunces,Georgia,serif;font-size:22px;line-height:1;color:var(--ink)}

@media (min-width:1024px){
  .srv-hero,.srv-index,.sdetail-hero,.sdetail-brief,.sdetail-caps,.sdetail-shop,.sdetail-work,.sdetail-run,.sdetail-other{padding-left:40px;padding-right:40px}
  .sdetail-run.sdetail-run--promotional{
    padding-left:40px;
    padding-right:40px;
    grid-template-columns:60px 1fr;
    column-gap:32px;
  }
  .sdetail-run.sdetail-run--promotional > .rail{margin-left:0}
  .sdetail-run.sdetail-run--design{
    padding-left:40px;
    padding-right:40px;
    grid-template-columns:60px 1fr;
    column-gap:32px;
  }
  .sdetail-run.sdetail-run--design > .rail{margin-left:0}
  .sdetail-run--design .steps-list--with-desc{
    border-left:1px solid var(--ink);
    padding-left:34px;
    margin-left:0;
  }
  .sdetail-run.sdetail-run--storage{
    padding-left:40px;
    padding-right:40px;
    grid-template-columns:60px 1fr;
    column-gap:32px;
  }
  .sdetail-run.sdetail-run--storage > .rail{margin-left:0}
  .sdetail-run--storage .steps-list--with-desc{
    border-left:1px solid var(--ink);
    padding-left:34px;
    margin-left:0;
  }
  .sdetail-hero.sdetail-hero--print{padding-left:clamp(48px,6vw,88px);padding-right:40px}
  .srv-hero-grid,.sdetail-head{grid-template-columns:60px 1.2fr 1fr;gap:32px;align-items:end}
  .srv-row{grid-template-columns:60px 1fr 460px;gap:30px;padding:40px 0}
  .srv-thumb{display:block}
  .srv-row h2{font-size:72px}.srv-row p{font-size:20px}

  .sdetail-head h1{font-size:92px}.sdetail-head p{font-size:17px}
  .sdetail-hero--clothing .sdetail-head h1{font-size:104px}
  .sdetail-hero--design .sdetail-head h1{font-size:112px}
  /* Print hero: rail | headline | Litho (right); rail I hugs kicker; Litho pinned right */
  .sdetail-head.sdetail-head--print-hero{
    grid-template-columns:28px minmax(0,1.05fr) minmax(0,1.18fr);
    column-gap:10px;
    row-gap:0;
    align-items:stretch;
    justify-items:stretch;
  }
  .sdetail-head--print-hero{
    --print-display:148px;
    --print-above-headline:clamp(2.65rem,4vw,3.15rem);
    --print-lh:0.96;
    --print-line-box:calc(var(--print-display) * var(--print-lh));
  }
  .sdetail-hero--print .sdetail-head.sdetail-head--print-hero h1{
    font-size:var(--print-display);
    line-height:var(--print-lh) !important;
    letter-spacing:-0.03em !important;
  }
  .sdetail-hero.sdetail-hero--print.sdetail-hero--storage .sdetail-head--print-hero{
    --print-display:clamp(9.4rem,min(16vw,20vh),15.25rem);
  }
  .sdetail-hero.sdetail-hero--print.sdetail-hero--storage .sdetail-head.sdetail-head--print-hero h1{
    font-size:calc(var(--print-display) + 4pt);
  }
  .sdetail-hero.sdetail-hero--print.sdetail-hero--storage .sdetail-head--print-hero .rail-roman-xl{
    font-size:calc(var(--print-display) * 0.42);
    line-height:.88;
  }
  /* Pull Roman “I” into the hero’s left padding */
  .sdetail-head--print-hero > .rail.rail--roman-only{
    margin-left:clamp(-26px,-2.1vw,-14px);
    padding-top:var(--print-above-headline);
    align-self:start;
    transform:translateX(clamp(-26px,-2.3vw,-14px));
  }
  .sdetail-head--print-hero > p.sdetail-print-lede{
    margin:0;
    /* Bottom-right, but not flush to the edge */
    margin-inline-end:clamp(14px,2.4vw,44px);
    margin-bottom:clamp(10px,1.6vw,22px);
    align-self:end;
    max-width:min(24rem,100%);
    width:fit-content;
    padding:0;
    justify-self:end;
    text-align:left;
    font-size:clamp(19px,1.55vw,25px);
    line-height:1.55;
    color:var(--ink-2);
  }
  .sdetail-hero--clothing .sdetail-head--print-hero > p.sdetail-print-lede{
    /* Nudge left a touch vs default */
    margin-inline-end:clamp(26px,3vw,58px);
  }
  .sdetail-head--print-hero .rail + div{display:flex;flex-direction:column;align-items:stretch;min-width:0;align-self:start}
  .sdetail-brief{
    grid-template-columns:minmax(5.5rem,7.25rem) 1fr;
    column-gap:32px;
    align-items:start;
  }
  .sdetail-brief .prose p{font-size:36px}
  .sdetail-caps,
  .sdetail-shop,
  .sdetail-work,
  .sdetail-other{
    grid-template-columns:minmax(6.75rem,8.75rem) 1fr;
    column-gap:32px;
    align-items:start;
  }
  .sdetail-caps > .rail,
  .sdetail-brief > .rail,
  .sdetail-shop > .rail,
  .sdetail-work > .rail,
  .sdetail-other > .rail{
    padding-top:0.45em;
  }
  .caps-grid{grid-template-columns:repeat(3,1fr)}
  .caps-grid article{border-top:0;border-left:1px solid var(--ink);min-height:170px}
  .caps-grid--with-desc article{min-height:240px;padding:18px}
  .caps-grid article:nth-child(3n+1){border-left:0}
  .caps-grid article:nth-child(n+4){border-top:1px solid var(--ink)}

  .work-grid{grid-template-columns:repeat(3,1fr);gap:14px}

  .sdetail-run-inner{grid-template-columns:1fr 1fr;gap:34px}
  .sdetail-run.sdetail-run--print,
  .sdetail-run.sdetail-run--promotional,
  .sdetail-run.sdetail-run--clothing,
  .sdetail-run.sdetail-run--design,
  .sdetail-run.sdetail-run--storage{
    grid-template-columns:minmax(6.75rem,8.75rem) 1fr;
    column-gap:32px;
    align-items:start;
  }
  .sdetail-run > .rail{padding-top:0.45em}
  .steps-list h4{font-size:34px}
  .sdetail-other .other-grid{grid-template-columns:repeat(4,1fr)}
  .sdetail-other .other-grid a{border-right:1px solid var(--ink);border-top:0}
  .sdetail-other .other-grid a:last-child{border-right:0}
}

/* Global CTA + links footer on every page */
.global-cta{margin-top:24px;background:var(--ink);color:var(--paper);display:grid;grid-template-columns:1fr;gap:14px;padding:26px;border-top:1px solid var(--ink)}
.global-cta h2{margin:0;font-family:Fraunces,Georgia,serif;font-size:clamp(2.2rem,5.4vw,5rem);line-height:1;font-weight:400}
.global-cta h2 em{color:var(--accent);font-style:italic}
.global-cta p{font-family:Fraunces,Georgia,serif;font-size:34px;line-height:1.1;margin:0 0 12px}
.global-cta a{display:inline-block;background:var(--accent);color:#fff;text-decoration:none;text-transform:uppercase;letter-spacing:.15em;font-size:12px;padding:13px 16px}

.global-links{display:grid;grid-template-columns:1fr;gap:20px;padding-top:26px;padding-bottom:26px;border-top:1px solid var(--ink)}
.global-links-logo{height:42px;width:auto;display:block;margin-bottom:8px}
.global-links h4{margin:0 0 8px;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--dim)}
.global-links a,.global-links span{display:block;text-decoration:none;color:var(--ink-2);margin-bottom:6px}

@media (min-width:1024px){
  .global-cta{grid-template-columns:1fr 1fr;gap:34px;padding:40px}
  .global-links{grid-template-columns:1.3fr 1fr 1fr 1fr;gap:34px;padding-top:34px;padding-bottom:34px}
}

/* Blog page match */
.blog-hero,.blog-featured,.blog-filter,.blog-list-page,.blog-subscribe,.about-hero,.about-essay-page,.about-timeline-page,.about-team-page{border-top:1px solid var(--ink);padding-top:28px;padding-bottom:28px}
.blog-hero{padding-top:88px;padding-bottom:56px}
.blog-hero-grid,.about-hero-grid{display:grid;grid-template-columns:1fr;gap:18px}
.blog-hero h1,.about-hero h1{margin:0;font-family:Fraunces,Georgia,serif;font-size:clamp(3rem,8.2vw,7.6rem);line-height:.94;font-weight:400;letter-spacing:-.03em}
.blog-hero h1 em,.about-hero h1 em{font-style:italic}
.blog-hero-accent{color:#d1592f}
.blog-hero-lede{margin:0;color:var(--ink-2);font-size:16px;max-width:460px}
.blog-featured{display:grid;grid-template-columns:60px 1fr;gap:20px;align-items:start;padding-top:56px}
.feature-thumb{
  min-height:360px;
  border:1px solid var(--ink);
  background:repeating-linear-gradient(135deg,#5f2b7f10 0 12px,transparent 12px 24px),#f4f1ea;
  position:relative;
  overflow:hidden;
}

.feature-thumb-label{
  position:absolute;
  left:12px;
  right:12px;
  bottom:12px;
  background:#1a1a1a;
  color:#f7f4ee;
  border:1px solid rgba(255,255,255,.18);
  padding:8px 10px;
  font-family:"JetBrains Mono",monospace;
  font-size:10px;
  letter-spacing:.14em;
  text-transform:uppercase;
  line-height:1.15;
}
.blog-featured h2{margin:0 0 10px;font-family:Fraunces,Georgia,serif;font-size:56px;line-height:.95;font-weight:400}
.blog-featured h2 a{
  text-decoration: underline;
  text-underline-offset: 6px;
  text-decoration-color: #5f2b7f;
  text-decoration-thickness: 1px;
}
.meta-row{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);border-top:1px solid #d6c5df;padding-top:10px}
.blog-featured .meta-row-featured{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:0 12px;
  line-height:1.4;
  color:var(--dim);
}
.blog-featured .meta-row-featured .meta-sep{
  opacity:.65;
}
.blog-featured .meta-row-featured > span:not(.meta-sep){
  display:inline;
}
.read-piece{display:inline-block;margin-top:12px;color:var(--accent);font-family:Fraunces,Georgia,serif;font-style:italic;font-size:34px;text-decoration:none}
.blog-featured .read-piece{font-size:26px}
.blog-filter{background:var(--paper-2);display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.blog-filter span{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);margin-right:8px}
.blog-filter a{
  font-family:"JetBrains Mono",monospace;
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  padding:12px 18px;
  min-height:40px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:1px solid #ad85c4;
  text-decoration:none;
}
.blog-filter a.active{background:var(--ink);color:#fff}
.blog-list-page{display:grid;gap:0}
.blog-row-page{display:grid;grid-template-columns:34px 1fr;gap:10px;border-top:1px solid var(--ink);padding:18px 0;text-decoration:none}
.blog-row-page:first-child{border-top:0}
.blog-num{font-family:Fraunces,Georgia,serif;color:var(--accent);font-style:italic;font-size:38px;line-height:1}
.blog-tag{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--accent)}
.blog-row-page h3{margin:0 0 8px;font-family:Fraunces,Georgia,serif;font-size:42px;line-height:.98;font-weight:400}
.blog-row-page p{margin:0;color:var(--ink-2)}
.blog-side-meta{font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.13em;text-transform:uppercase;color:var(--dim);display:flex;flex-wrap:wrap;gap:0 8px;align-items:center}
.blog-side-meta .meta-sep{opacity:.65}
.blog-subscribe{display:grid;grid-template-columns:1fr;gap:20px}
.blog-subscribe .rail{margin:0}
.blog-subscribe .kicker{margin:0 0 12px}
.blog-subscribe h2{margin:0 0 10px;font-family:Fraunces,Georgia,serif;font-size:64px;line-height:.95;font-weight:400}
.blog-subscribe h2 em{font-style:italic}
.blog-subscribe-copy{
  margin:0;
  font-size:18px;
  line-height:1.7;
  color:var(--ink-2);
  max-width:520px;
}
.blog-subscribe form{border:1px solid var(--ink);padding:22px;background:#f7f4ee}
.blog-subscribe label{display:block;font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:6px}
.blog-subscribe input{
  width:100%;
  border:1px solid #af87c6;
  padding:14px 12px;
  background:transparent;
  margin-bottom:14px;
  border-radius:0;
  outline:none;
}
.blog-subscribe button{
  width:100%;
  border:0;
  background:var(--ink);
  color:#fff;
  text-transform:uppercase;
  letter-spacing:.14em;
  padding:16px 12px;
  border-radius:0;
}
.blog-subscribe-note{
  margin-top:10px;
  font-family:"JetBrains Mono",monospace;
  font-size:9px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--dim);
}

/* About page match */
.about-hero-grid p{margin:0;color:var(--ink-2);font-size:16px;max-width:430px;align-self:end}
.about-essay-page{display:grid;grid-template-columns:1fr;gap:18px}
.essay-cols .essay-rich p{margin:0 0 10px;color:var(--ink-2);font-size:15px;line-height:1.65}
.essay-cols .essay-rich p:first-child{font-family:Fraunces,Georgia,serif;font-size:54px;line-height:1.02;color:var(--ink);margin-bottom:16px}
.about-placeholder{min-height:420px;border:1px solid #d5c6dd;background:repeating-linear-gradient(135deg,#efe9de 0 12px,#f5f2ec 12px 24px)}
.about-timeline-page{background:var(--paper-2);display:grid;grid-template-columns:1fr;gap:16px}
.about-timeline-page h2{margin:0 0 14px;font-family:Fraunces,Georgia,serif;font-size:56px;font-weight:400}
.about-timeline-page h2 em{font-style:italic}
.timeline-row-page{display:grid;grid-template-columns:80px 1fr;gap:14px;border-top:1px solid var(--ink);padding:12px 0}
.timeline-row-page strong{font-family:Fraunces,Georgia,serif;color:var(--accent);font-style:italic;font-size:42px;line-height:1}
.timeline-row-page span{align-self:center;color:var(--ink-2)}
.about-team-page{display:grid;grid-template-columns:1fr;gap:20px}
.team-head h2{margin:0 0 10px;font-family:Fraunces,Georgia,serif;font-size:64px;line-height:.95;font-weight:400}
.team-head h2 em{font-style:italic}
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.team-grid article{min-width:0}
.portrait-box{height:210px;border:1px solid #ddcee5;background:repeating-linear-gradient(135deg,#f1ece4 0 12px,#f8f5ef 12px 24px)}
.team-grid h4{margin:8px 0 2px;font-family:Fraunces,Georgia,serif;font-size:30px;font-weight:500}
.team-grid p{margin:0;color:var(--ink-2)}
.team-grid small{font-family:"JetBrains Mono",monospace;font-size:10px;color:var(--dim);letter-spacing:.12em;text-transform:uppercase}

@media (min-width:1024px){
  .blog-hero,.blog-featured,.blog-filter,.blog-list-page,.blog-subscribe,.about-hero,.about-essay-page,.about-timeline-page,.about-team-page{padding-left:40px;padding-right:40px}
  .blog-hero-grid,.about-hero-grid{grid-template-columns:60px 1.2fr 1fr;gap:32px;align-items:end}
  .blog-featured{grid-template-columns:60px 1fr;gap:32px}
  .blog-row-page{grid-template-columns:60px 110px 1fr 140px;gap:22px;align-items:baseline;padding:24px 0}
  .blog-row-page h3{font-size:48px}
  .blog-side-meta{text-align:right;justify-content:flex-end}
  .blog-subscribe{grid-template-columns:60px 1fr 1fr;gap:32px;align-items:start}
  .blog-subscribe form{padding:22px;align-self:center}

  .about-essay-page{grid-template-columns:60px 1.4fr 1fr;gap:30px}
  .essay-cols .essay-rich{column-count:2;column-gap:24px}
  .essay-cols .essay-rich p:first-child{column-span:all}
  .about-timeline-page{grid-template-columns:60px 1fr;gap:30px;padding:40px}
  .timeline-row-page{grid-template-columns:130px 1fr;gap:30px;padding:18px 0}
  .about-team-page{grid-template-columns:60px 1fr;gap:30px}
  .team-head{display:grid;grid-template-columns:1fr 1fr;gap:30px;grid-column:2}
  .team-grid{grid-column:2;grid-template-columns:repeat(4,1fr);gap:18px}
}

/* Exact Home calibration from provided inline reference */
body{background:#faf8f4;color:#5f2b7f;font-family:Inter,system-ui,sans-serif;font-size:15px;line-height:1.55}
.folio-bar{padding:12px 40px;border-bottom:1px solid #5f2b7f;font-size:11px;letter-spacing:.2em;text-transform:uppercase}
.masthead{padding:20px 40px;border-bottom:1px solid #5f2b7f}
.brand img{height:56px}
.brand span,.brand .brand-tagline{font-size:10px;letter-spacing:.22em;color:#9e7aad;max-width:none;line-height:1.4;white-space:nowrap}
.main-nav{gap:32px}
.main-nav a{font-size:13px;letter-spacing:.14em;text-transform:uppercase;}
.quote-link{background:#5f2b7f;color:#faf8f4;padding:10px 18px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;display:inline-flex;align-items:center;justify-content:center;min-height:38px;line-height:1}

.home-hero{padding:56px 40px 64px;border-bottom:1px solid #5f2b7f}
.home-kicker{font-size:12px;letter-spacing:.22em;color:#d1592f;margin-bottom:32px;text-transform:uppercase}
.home-display{font-family:Fraunces,Georgia,serif;font-weight:400;font-size:148px;line-height:.96;letter-spacing:-.03em;margin:0}
.home-display em{font-style:italic;color:#d1592f}
.home-intro-grid{grid-template-columns:60px 7fr 5fr 60px;gap:32px;margin-top:56px;border-top:1px solid #5f2b7f;padding-top:32px}
.home-intro-grid>div:first-child{grid-column:2}
.home-intro-grid>.home-issue{grid-column:3}
.home-intro-copy{font-family:Fraunces,Georgia,serif;font-size:26px;line-height:1.4;color:#4a2163;max-width:640px;margin:0}
.home-intro-actions{margin-top:32px;gap:12px}
.home-btn{padding:13px 22px;font-size:13px;letter-spacing:.14em;text-transform:uppercase;border:1px solid #5f2b7f}
.home-btn-solid{padding:14px 22px;background:#5f2b7f;color:#faf8f4;border:0}
.home-issue{border-left:1px solid #5f2b7f;padding-left:32px}
.home-issue>p{font-size:11px;letter-spacing:.2em;color:#9e7aad;text-transform:uppercase;margin-bottom:20px}
.home-issue li:not(:has(.home-issue-link)){display:grid;grid-template-columns:1fr auto;gap:16px;border-bottom:1px solid rgba(95,43,127,.08);padding-bottom:12px}
.home-issue li:has(.home-issue-link){border-top:1px solid rgba(95,43,127,.08);border-bottom:1px solid rgba(95,43,127,.08)}
.home-issue li:has(.home-issue-link):first-of-type{border-top:0}
.home-issue-link{align-items:center;padding:14px 0}
.home-issue li span{font-family:Fraunces,Georgia,serif;font-size:19px;font-style:italic;font-weight:500;line-height:1.1}
.home-issue li em{font-family:"JetBrains Mono",monospace;font-size:11px;color:#9e7aad;align-self:center}

.home-stats{grid-template-columns:repeat(5,1fr);border-bottom:1px solid #5f2b7f}
.home-stats div{padding:32px 28px;border-right:1px solid #5f2b7f;border-top:0}
.home-stats div:last-child{border-right:0}
.home-stats strong{font-family:Fraunces,Georgia,serif;font-size:64px;letter-spacing:-.02em;line-height:1}
.home-stats span{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:#9e7aad;margin-top:10px}

.home-services{padding:80px 40px;border-bottom:1px solid #5f2b7f}
.home-services-grid{display:grid;grid-template-columns:60px 1fr;gap:32px;align-items:start}
.home-services-grid .rail{margin-top:6px}
.home-services-head{grid-template-columns:1fr 1fr;gap:40px;margin-bottom:48px}
.home-services-head .home-kicker{color:#d1592f;margin:0 0 16px}
.home-services-head h2{font-family:Fraunces,Georgia,serif;font-size:72px;line-height:1;letter-spacing:-.02em}
.home-services-head h2 .home-services-accent{color:#d1592f}
.home-service-row--print p{color:#d1592f}
.home-services-head p{font-size:17px;line-height:1.6;color:#4a2163}
.home-service-row{grid-template-columns:60px 260px 1fr 1fr 40px;gap:32px;padding:28px 0;border-bottom:1px solid #5f2b7f;align-items:baseline}
.home-service-row b{font-family:Fraunces,Georgia,serif;font-size:32px;color:#d1592f;font-style:italic}
.home-service-row h3{font-family:Fraunces,Georgia,serif;font-size:34px;font-weight:500;letter-spacing:-.01em}
.home-service-row p{font-size:16px;line-height:1.55;color:#4a2163}
.home-service-row small{font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:#4a2163}

.home-process{padding:80px 40px;background:#f0ece3;border-bottom:1px solid #5f2b7f}
.home-process h2{font-family:Fraunces,Georgia,serif;font-size:72px;line-height:1;letter-spacing:-.02em;margin:0 0 24px}
.home-process p{font-size:17px;line-height:1.6;color:#4a2163;max-width:620px;margin:0 0 56px}
.home-process-grid{grid-template-columns:repeat(3,1fr);border-top:1px solid #5f2b7f;border-left:1px solid #5f2b7f}
.home-process-grid article{border-right:1px solid #5f2b7f;border-bottom:1px solid #5f2b7f;padding:28px 24px 32px;min-height:240px}
.home-process-grid span{font-family:"JetBrains Mono",monospace;font-size:12px;color:#d1592f;letter-spacing:.08em}
.home-process-grid h3{font-family:Fraunces,Georgia,serif;font-size:34px;letter-spacing:-.01em;margin:0 0 12px}

.home-feature{padding:80px 40px;border-bottom:1px solid #5f2b7f;grid-template-columns:60px 1fr 1fr;gap:32px}
.home-feature > div:first-child{grid-column:2}
.home-feature figure{grid-column:3}
.home-feature h2{font-family:Fraunces,Georgia,serif;font-size:60px;line-height:1.02;letter-spacing:-.02em;margin:0 0 24px}
.home-feature p{font-size:15px;line-height:1.7;color:#4a2163}

.home-quotes{padding:80px 40px;background:#f0ece3;border-bottom:1px solid #5f2b7f}
.home-quotes h2{font-family:Fraunces,Georgia,serif;font-size:60px;line-height:1.02;letter-spacing:-.02em;margin:0 0 48px}
.home-quotes-grid{grid-template-columns:repeat(3,1fr);gap:40px}
.home-quotes-grid blockquote{font-family:Fraunces,Georgia,serif;font-size:22px;line-height:1.4;border-top:1px solid #5f2b7f;padding-top:20px}

.home-sustain{padding:80px 40px;border-bottom:1px solid #5f2b7f;grid-template-columns:60px 1fr 1fr;gap:32px;align-items:center}
.home-sustain > div:first-child{grid-column:2}
.home-sustain h2{font-family:Fraunces,Georgia,serif;font-size:60px;line-height:1.02;letter-spacing:-.02em}
.home-sustain p{font-size:16px;line-height:1.65;color:#4a2163;max-width:540px}
.home-sustain-stats{grid-template-columns:1fr 1fr;gap:2px;background:#5f2b7f;border:0}
.home-sustain-stats div{background:#faf8f4;padding:32px 24px;border:0}
.home-sustain-stats strong{font-family:Fraunces,Georgia,serif;font-size:64px;line-height:1;color:#d1592f}
.home-sustain-stats span{font-size:12px;letter-spacing:.18em;color:#4a2163;text-transform:uppercase;margin-top:12px}

@media (max-width: 1200px){
  .home-display{font-size:96px}
  .home-intro-grid{grid-template-columns:1fr;padding-top:24px}
  .home-intro-grid>div:first-child,.home-intro-grid>.home-issue{grid-column:auto}
  .home-stats{grid-template-columns:1fr 1fr}
  .home-services-head,.home-service-row,.home-process-grid,.home-feature,.home-quotes-grid,.home-sustain{grid-template-columns:1fr}
}

/* Missing tags + italics/content refinements */
.home-hero-grid-top{display:grid;grid-template-columns:60px 1fr 60px;gap:32px;align-items:end}
.home-rail-left,.home-rail-right{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:#9e7aad;writing-mode:vertical-rl}
.home-rail-left{transform:rotate(180deg)}
.home-issue li div small{display:block;font-size:13px;color:#4a2163;margin-top:4px;font-style:normal}
.home-service-row i{font-family:Fraunces,Georgia,serif;font-size:28px;color:#d1592f;font-style:italic;justify-self:end}
.home-service-arrow{font-family:Fraunces,Georgia,serif;font-size:28px;color:#d1592f;font-style:italic;justify-self:end;text-decoration:none;line-height:1}

@media (max-width:1200px){
  .home-hero-grid-top{grid-template-columns:1fr}
  .home-rail-left,.home-rail-right{writing-mode:initial;transform:none}
  .home-service-row i{display:none}
}

/* Remove placeholder-column dependency */
.home-intro-main{grid-column:2}
.home-intro-grid>.home-issue{grid-column:3}

@media (max-width:1200px){
  .home-intro-main,.home-intro-grid>.home-issue{grid-column:auto}
}

/* Home section fixes: In practice + Sustainability */
.home-feature,
.home-sustain {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}

.home-feature .rail,
.home-sustain .rail {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #9e7aad;
  margin: 0;
}

.home-feature .home-kicker,
.home-sustain .home-kicker {
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #d1592f;
  margin: 0 0 16px;
}

.home-feature h2,
.home-sustain h2 {
  margin: 0 0 24px;
  font-family: Fraunces, Georgia, serif;
  font-weight: 400;
  font-size: 60px;
  line-height: 1.02;
  letter-spacing: -0.02em;
}

.home-feature h2 em,
.home-sustain h2 em {
  font-style: italic;
}

.home-feature p,
.home-sustain p {
  color: #4a2163;
}

@media (min-width: 1201px) {
  .home-feature {
    grid-template-columns: 60px 1fr 1fr;
    gap: 32px;
    align-items: start;
  }

  .home-feature > .rail {
    grid-column: 1;
    margin-top: 6px;
  }

  .home-feature > div:not(.rail) {
    grid-column: 2;
  }

  .home-feature > figure {
    grid-column: 3;
    margin: 0;
    border: 1px solid #5f2b7f;
  }

  .home-sustain {
    grid-template-columns: 60px 1fr 1fr;
    gap: 32px;
    align-items: center;
  }

  .home-sustain > .rail {
    grid-column: 1;
  }

  .home-sustain > div:nth-child(2) {
    grid-column: 2;
  }

  .home-sustain > .home-sustain-stats {
    grid-column: 3;
  }
}

/* About page reference-matched styles */
.about-ref-hero,
.about-ref-essay,
.about-ref-timeline,
.about-ref-team {
  border-bottom: 1px solid #5f2b7f;
}

.about-ref-hero {
  padding: 60px 40px;
}

.about-ref-hero-grid {
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: 32px;
  align-items: end;
}
.about-ref-hero-main {
  display: grid;
  grid-template-columns: 1fr minmax(240px, 36%);
  gap: 32px;
  align-items: end;
  min-width: 0;
}

.about-ref-hero .rail,
.about-ref-essay .rail,
.about-ref-timeline .rail,
.about-ref-team .rail {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #9e7aad;
  margin: 0;
}

.about-ref-hero h1 {
  margin: 0;
  font-family: Fraunces, Georgia, serif;
  font-weight: 400;
  font-size: 128px;
  line-height: 0.96;
  letter-spacing: -0.03em;
}

.about-ref-hero h1 em {
  font-style: italic;
  hyphens: none;
}
.about-ref-hero-34 {
  white-space: nowrap;
}
.about-ref-hero-line {
  display: block;
  white-space: nowrap;
}
.about-ref-accent{color:#d1592f}

.about-ref-hero p {
  margin: 0;
  font-size: 19px;
  line-height: 1.55;
  color: #4a2163;
}

.about-ref-essay {
  padding: 80px 40px;
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: 32px;
}

.about-ref-rich > p:first-child {
  margin: 0 0 28px;
  font-family: Fraunces, Georgia, serif;
  font-size: 32px;
  line-height: 1.35;
  letter-spacing: -0.01em;
}

.about-ref-rich > p:first-child::first-letter {
  float: left;
  font-family: Fraunces, Georgia, serif;
  font-weight: 500;
  font-size: 88px;
  line-height: 0.8;
  margin-right: 10px;
  margin-top: 6px;
  color: #d1592f;
}

.about-ref-rich > p:not(:first-child) {
  margin: 0 0 14px;
  font-size: 15px;
  line-height: 1.7;
  color: #4a2163;
}

/* Wagtail sometimes saves blank lines as empty <p> tags; hide them so columns align */
.about-ref-rich > p:empty {
  display: none;
  margin: 0;
}

.about-ref-rich > p:last-child {
  margin-bottom: 0;
}
.about-ref-continuity{
  margin:24px 0 0;
  font-family:Fraunces,Georgia,serif;
  font-size:34px;
  line-height:1.1;
  color:#5f2b7f;
}

@media (min-width: 901px) {
  .about-ref-rich {
    column-count: 2;
    column-gap: 32px;
  }

  .about-ref-rich > p {
    break-inside: avoid;
  }

  .about-ref-rich > p:first-child {
    column-span: all;
  }
}

.about-ref-archive {
  aspect-ratio: 4/5;
  background: repeating-linear-gradient(
      135deg,
      rgba(95, 43, 127, 0.024) 0px,
      rgba(95, 43, 127, 0.024) 12px,
      transparent 12px,
      transparent 24px
    ),
    #f0ece3;
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(95, 43, 127, 0.08);
}

.about-ref-archive > div {
  position: absolute;
  bottom: 12px;
  left: 12px;
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #4a2163;
  background: #faf8f4;
  padding: 3px 8px;
}

.about-ref-timeline {
  padding: 80px 40px;
  background: #f0ece3;
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: 32px;
}

.about-ref-timeline h2 {
  margin: 0 0 40px;
  font-family: Fraunces, Georgia, serif;
  font-weight: 400;
  font-size: 56px;
  letter-spacing: -0.02em;
}

.about-ref-timeline h2 em {
  font-style: italic;
}

.about-ref-timeline-list {
  border-top: 1px solid #5f2b7f;
}

.about-ref-timeline-row {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 40px;
  padding: 24px 0;
  border-bottom: 1px solid #5f2b7f;
  align-items: baseline;
}

.about-ref-timeline-row strong {
  font-family: Fraunces, Georgia, serif;
  font-weight: 400;
  font-size: 48px;
  color: #d1592f;
  font-style: italic;
  letter-spacing: -0.02em;
}

.about-ref-timeline-row span {
  font-size: 18px;
  line-height: 1.5;
  color: #4a2163;
}

.about-ref-team {
  padding: 80px 40px;
  scroll-margin-top: 80px;
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: 32px;
}

.about-ref-team-head {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: end;
  margin-bottom: 48px;
}

.about-ref-team-head .home-kicker {
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #d1592f;
  margin: 0 0 16px;
}

.about-ref-team-head h2 {
  margin: 0;
  font-family: Fraunces, Georgia, serif;
  font-weight: 400;
  font-size: 72px;
  line-height: 1;
  letter-spacing: -0.02em;
}

.about-ref-team-head h2 em {
  font-style: italic;
}

.about-ref-team-head p {
  margin: 0;
  font-size: 17px;
  line-height: 1.6;
  color: #4a2163;
}

.about-ref-team-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
}

.about-ref-portrait {
  aspect-ratio: 3/4;
  background: repeating-linear-gradient(
      135deg,
      rgba(95, 43, 127, 0.024) 0px,
      rgba(95, 43, 127, 0.024) 12px,
      transparent 12px,
      transparent 24px
    ),
    #f0ece3;
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(95, 43, 127, 0.08);
}

.about-ref-portrait > div {
  position: absolute;
  bottom: 12px;
  left: 12px;
  font-family: "JetBrains Mono", monospace;
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #4a2163;
  background: #faf8f4;
  padding: 3px 8px;
}

.about-ref-meta {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: baseline;
  margin-top: 14px;
  gap: 12px;
}

.about-ref-meta h4 {
  margin: 0;
  font-family: Fraunces, Georgia, serif;
  font-weight: 500;
  font-size: 24px;
  letter-spacing: -0.01em;
}

.about-ref-meta small {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  color: #9e7aad;
}

.about-ref-team-grid article p {
  margin: 2px 0 0;
  font-size: 13px;
  color: #4a2163;
  font-style: italic;
}

@media (max-width: 1200px) {
  .about-ref-hero h1 {
    font-size: 96px;
  }

  .about-ref-team-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 900px) {
  .about-ref-hero,
  .about-ref-essay,
  .about-ref-timeline,
  .about-ref-team {
    padding: 48px 20px;
  }

  .about-ref-hero-grid,
  .about-ref-essay,
  .about-ref-timeline,
  .about-ref-team,
  .about-ref-team-head {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .about-ref-hero-main {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .about-ref-hero-line {
    white-space: normal;
  }

  .about-ref-hero h1 {
    font-size: 60px;
    line-height: 0.98;
  }

  .about-ref-timeline-row {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .about-ref-team-grid {
    grid-template-columns: 1fr;
  }
}

/* Services page reference-matched styles */
.services-ref-hero {
  padding: 60px 40px;
  border-bottom: 1px solid #5f2b7f;
}

.services-ref-hero-grid {
  display: grid;
  grid-template-columns: 60px 1fr 1fr;
  gap: 32px;
  align-items: end;
}

.services-ref-hero .rail {
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: #9e7aad;
}

.services-ref-hero .kicker {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: #d1592f;
  margin: 0 0 16px;
}

.services-ref-hero h1 {
  margin: 0;
  font-family: Fraunces, Georgia, serif;
  font-weight: 400;
  font-size: 128px;
  line-height: 0.96;
  letter-spacing: -0.03em;
}

.services-ref-hero h1 em {
  font-style: italic;
}
.services-ref-accent{color:#d1592f}

.services-ref-hero p {
  margin: 0;
  font-size: 17px;
  line-height: 1.6;
  color: #4a2163;
}

.services-ref-list {
  border-bottom: 1px solid #5f2b7f;
}

.services-ref-row {
  display: grid;
  grid-template-columns: 60px 1fr 1fr;
  gap: 32px;
  align-items: start;
  text-decoration: none;
  color: inherit;
  border-bottom: 1px solid #5f2b7f;
  padding-top: 56px;
  padding-bottom: 56px;
  transition: background 0.2s;
}

.services-ref-row:last-child {
  border-bottom: 0;
}

.services-ref-roman {
  font-family: Fraunces, Georgia, serif;
  font-weight: 400;
  font-size: 48px;
  color: #d1592f;
  font-style: italic;
  line-height: 1;
}

.services-ref-row h3 {
  margin: 0 0 16px;
  font-family: Fraunces, Georgia, serif;
  font-weight: 400;
  font-size: 72px;
  line-height: 0.98;
  letter-spacing: -0.02em;
  display: flex;
  align-items: baseline;
  gap: 20px;
  flex-wrap: wrap;
}

.services-ref-row h3 span { padding-bottom: 4px; }

.services-ref-row h3 i {
  font-family: Fraunces, Georgia, serif;
  font-weight: 500;
  font-style: italic;
  font-size: 36px;
  color: #d1592f;
}

.services-ref-row p {
  margin: 0 0 20px;
  max-width: 520px;
  font-size: 18px;
  line-height: 1.55;
  color: #4a2163;
}

.services-ref-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  font-family: "JetBrains Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #4a2163;
}

.services-ref-thumb {
  border: 1px solid #5f2b7f;
  aspect-ratio: 3/2;
  overflow: hidden;
  background: #f0ece3;
}

.services-ref-thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Service detail heroes — same layout/type as /services/ index hero */
.sdetail-hero.services-ref-hero,
.sdetail-hero.services-ref-hero.sdetail-hero--print,
.sdetail-hero.services-ref-hero.sdetail-hero--clothing,
.sdetail-hero.services-ref-hero.sdetail-hero--design,
.sdetail-hero.services-ref-hero.sdetail-hero--storage {
  border-top: 0;
  padding: 60px 40px;
  border-bottom: 1px solid #5f2b7f;
  background: var(--paper);
}
.sdetail-hero.services-ref-hero .services-ref-hero-grid {
  display: grid;
  grid-template-columns: minmax(4.25rem, 5.75rem) 1fr 1fr;
  gap: 32px;
  align-items: end;
}
.sdetail-hero.services-ref-hero .rail--roman-hero {
  align-self: start;
  padding-top: calc(12px + 16px);
  font-family: inherit;
  font-size: inherit;
  text-transform: none;
  letter-spacing: normal;
  color: inherit;
  line-height: 1;
}
.sdetail-hero.services-ref-hero .rail--roman-hero .rail-roman-xl {
  display: block;
  font-family: Fraunces, Georgia, serif;
  font-size: clamp(3rem, calc(var(--sdetail-hero-display, 128px) * 0.42), 4.5rem);
  font-style: italic;
  font-weight: 400;
  color: #d1592f;
  line-height: 0.88;
  letter-spacing: normal;
  text-transform: none;
}
.sdetail-hero.services-ref-hero.sdetail-hero--storage .rail--roman-hero .rail-roman-xl {
  color: #d1592f;
}
.sdetail-hero.services-ref-hero .kicker {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: #d1592f;
  margin: 0 0 16px;
}
.sdetail-hero.services-ref-hero .kicker a {
  color: inherit;
}
.sdetail-hero.services-ref-hero {
  --sdetail-hero-display: 128px;
}
.sdetail-hero.services-ref-hero h1 {
  margin: 0;
  font-family: Fraunces, Georgia, serif;
  font-weight: 400;
  font-size: var(--sdetail-hero-display);
  line-height: 0.96;
  letter-spacing: -0.03em;
  color: #5f2b7f;
}
.sdetail-hero.services-ref-hero h1 em {
  font-style: italic;
}
.sdetail-hero.services-ref-hero h1 .services-ref-accent {
  color: #d1592f;
}
.sdetail-hero.services-ref-hero > p,
.sdetail-hero.services-ref-hero .services-ref-hero-grid > p {
  margin: 0;
  font-size: 17px;
  line-height: 1.6;
  color: #4a2163;
}
.sdetail-hero.services-ref-hero .sdetail-hero-art {
  margin: 32px 0 0;
  border: 1px solid #5f2b7f;
  background: #f0ece3;
}
.sdetail-hero.services-ref-hero .sdetail-hero-art img {
  display: block;
  width: 100%;
  height: auto;
}

@media (max-width: 1200px) {
  .services-ref-hero h1 {
    font-size: 96px;
  }
  .sdetail-hero.services-ref-hero {
    --sdetail-hero-display: 96px;
  }
  .sdetail-hero.services-ref-hero h1 {
    font-size: 96px;
  }

  .services-ref-row h3 {
    font-size: 60px;
  }
}

@media (max-width: 900px) {
  .services-ref-hero {
    padding: 48px 20px;
  }
  .sdetail-hero.services-ref-hero {
    padding: 48px 20px;
  }

  .services-ref-hero-grid,
  .services-ref-row {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .sdetail-hero.services-ref-hero .services-ref-hero-grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .services-ref-hero h1 {
    font-size: 60px;
    line-height: 0.98;
  }
  .sdetail-hero.services-ref-hero {
    --sdetail-hero-display: 60px;
  }
  .sdetail-hero.services-ref-hero h1 {
    font-size: 60px;
    line-height: 0.98;
  }
  .sdetail-hero.services-ref-hero .rail--roman-hero {
    padding-top: calc(12px + 12px);
  }

  .services-ref-row {
    padding-top: 36px;
    padding-bottom: 36px;
  }

  .services-ref-row h3 {
    font-size: 42px;
  }
}

/* Home > Services hard overrides (avoid earlier collisions) */
.home-services.shell{padding:80px 40px !important}
.home-services .home-services-grid{grid-template-columns:60px 1fr !important;gap:32px !important}
.home-services .rail{margin-top:6px}
.home-services .home-kicker{color:var(--accent) !important}
.home-services .home-services-rowwrap{display:grid;grid-template-columns:60px 1fr;gap:32px}
.home-services .rail-spacer{min-height:1px}

/* Home > Process hard overrides (match Services layout) */
.home-process.shell{padding:80px 40px !important}
.home-process .home-process-gridwrap{display:grid;grid-template-columns:60px 1fr;gap:32px}
.home-process .rail{margin-top:6px}
.home-process .home-kicker{color:var(--accent) !important}
.home-process h2{color:var(--ink)}

/* Home > Feature tweaks */
.home-feature .rail{margin-top:6px}
.home-feature-copy{display:grid;grid-template-columns:1fr;gap:18px;max-width:620px}
.home-feature-copy p{margin:0 0 12px}
@media (min-width:1024px){
  .home-feature-copy{grid-template-columns:1fr 1fr;gap:32px;max-width:none}
}

/* Home > Feature hard overrides (pin rail to far-left) */
.home-feature.shell{padding:80px 40px !important}
.home-feature{display:grid;grid-template-columns:60px 1fr 1fr;gap:32px;align-items:start}
.home-feature > .rail{grid-column:1 !important;margin-top:6px}
.home-feature > .home-feature-body{grid-column:2 !important;min-width:0}
.home-feature > figure{grid-column:3 !important;margin:0;border:1px solid var(--ink);overflow:hidden}
.home-feature > figure video,.home-feature > figure img{display:block;width:100%;height:100%;object-fit:cover}
.home-feature-video{position:relative;aspect-ratio:1/1;width:100%;overflow:hidden;background:var(--paper-2)}
.home-feature-video iframe{position:absolute;top:50%;left:50%;width:177.78%;height:100%;transform:translate(-50%,-50%);border:0;display:block;pointer-events:none}

/* Home > Quotes hard overrides */
.home-quotes.shell{padding:80px 40px !important}
.home-quotes-wrap{display:grid;grid-template-columns:60px 1fr;gap:32px}
.home-quotes .rail{margin-top:6px}
.home-quote{min-width:0}
.home-quote-rule{height:1px;background:var(--ink);opacity:.7;margin:0 0 16px}
.home-quote-mark{font-family:Fraunces,Georgia,serif;font-size:56px;line-height:1;color:var(--accent);margin:0 0 12px}
.home-quote-text{margin:0 0 18px;font-family:Fraunces,Georgia,serif;font-size:22px;line-height:1.4;color:var(--ink)}
.home-quote-meta strong{display:block;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-2);font-family:"JetBrains Mono",monospace}
.home-quote-meta span{display:block;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-2);font-family:"JetBrains Mono",monospace;margin-top:2px}

/* Home > Sustainability hard overrides (pin rail to far-left) */
.home-sustain.shell{padding:80px 40px !important}
.home-sustain{display:grid;grid-template-columns:60px 1fr 1fr;gap:32px;align-items:center}
.home-sustain > .rail{grid-column:1 !important;margin-top:6px}
.home-sustain > div:nth-child(2){grid-column:2 !important;min-width:0}
.home-sustain > .home-sustain-stats{grid-column:3 !important}
.home-sustain-tags{display:grid;grid-template-columns:1fr;gap:12px 22px;margin-top:22px}
.home-sustain-tags span{display:inline-flex;align-items:center;gap:10px;font-family:"JetBrains Mono",monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-2)}
.home-sustain-tags span::before{content:none}
@media (min-width:1024px){
  .home-sustain-tags{grid-template-columns:repeat(3,max-content)}
}

/* Global CTA + footer reference-match overrides */
.global-cta{margin-top:0;border-top:1px solid var(--ink);border-bottom:0;padding:80px 60px !important;grid-template-columns:1.15fr .85fr !important;gap:32px !important;align-items:start}
.global-cta-left .kicker{margin:0 0 14px;font-size:11px;color:#faf8f4 !important}
.global-cta-letline{display:inline-block;position:relative}
.global-cta-letline .global-cta-colophon{position:absolute;left:-82px;bottom:.35em;font-family:"JetBrains Mono",monospace;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:rgba(250,248,244,.55)}
.global-cta-letline em{white-space:nowrap}
.global-cta-right{display:grid;align-content:start;gap:10px;align-self:center;margin-top:10px}
.global-cta .global-cta-label{margin:0;font-family:"JetBrains Mono",monospace;font-size:10px !important;letter-spacing:.24em;text-transform:uppercase;color:rgba(250,248,244,.65) !important}
.global-cta .global-cta-contact{margin:0;font-family:Fraunces,Georgia,serif;font-size:34px;line-height:1.1}
.global-cta .global-cta-phone{display:inline-block}
.global-cta .global-cta-email{display:inline-block;font-size:20px;line-height:1.15;color:rgba(250,248,244,.65)}
.global-cta .global-cta-email em{font-style:italic}
.global-cta-btn{display:block;margin-top:16px;background:var(--accent);color:#fff;text-decoration:none;text-transform:uppercase;letter-spacing:.15em;font-size:12px;padding:18px 20px;text-align:center}
.global-cta h2{font-size:clamp(3.8rem,7.4vw,6.8rem) !important;line-height:.98;letter-spacing:-.02em}

@media (min-width:1024px){
  .global-cta{
    padding-left:120px !important;
    padding-right:120px !important;
    gap:40px !important;
  }
}

.global-links{padding:56px 40px !important;border-top:1px solid var(--ink)}
.global-links-logo{height:64px;width:auto;display:block;margin-bottom:10px}
.global-links > div:first-child p{font-size:13px;line-height:1.6;max-width:320px}
.site-footer{border-top:0}
.footer-meta{display:grid;grid-template-columns:1fr;gap:10px;border-top:1px solid var(--ink);padding-top:18px;padding-bottom:18px;color:var(--dim);font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase}
@media (min-width:1024px){
  .global-links{padding-left:120px !important;padding-right:120px !important}
  .footer-meta{grid-template-columns:1fr 1fr 1fr;gap:22px}
  .footer-meta span:nth-child(2){text-align:center}
  .footer-meta span:nth-child(3){text-align:right}
}

/*
 * Mobile pass — the "Exact Home calibration" and "hard override" blocks above set
 * desktop grids/padding/type unconditionally, so they leak onto phones/tablets.
 * The base (top ~1050 lines) is already mobile-first, so this just supplies the
 * missing mobile counterpart below the site's existing 1024px breakpoint.
 * ponytail: single appended max-width block instead of gating each desktop rule —
 * smaller, lower-risk diff; desktop (>=1024px) is untouched.
 */
@media (max-width: 1023px) {
  /* Rein in desktop horizontal padding that overflows small screens */
  .masthead { padding-left: 16px; padding-right: 16px; }
  .home-hero,
  .home-services.shell,
  .home-process.shell,
  .home-feature.shell,
  .home-quotes.shell,
  .home-sustain.shell,
  .global-links { padding-left: 20px !important; padding-right: 20px !important; }
  .global-cta { padding: 48px 20px !important; }

  /* Collapse leaked multi-column grids back to a single column */
  .home-feature,
  .home-sustain,
  .home-services .home-services-grid,
  .home-services .home-services-rowwrap,
  .home-process .home-process-gridwrap,
  .home-quotes-wrap,
  .other-grid,
  .global-cta { grid-template-columns: 1fr !important; }

  /* Undo explicit grid-column placement (would spawn implicit off-screen columns) */
  .home-feature > .rail,
  .home-feature > .home-feature-body,
  .home-feature > figure,
  .home-sustain > .rail,
  .home-sustain > div:nth-child(2),
  .home-sustain > .home-sustain-stats { grid-column: auto !important; }

  /* Shrink fixed display type so long words don't force horizontal scroll */
  .home-display { font-size: clamp(2.6rem, 12vw, 5rem); }
  .home-services-head h2,
  .home-process h2 { font-size: clamp(2.2rem, 9vw, 3.4rem); }
  .home-feature h2,
  .home-sustain h2 { font-size: clamp(2rem, 8vw, 3rem); }
  .blog-featured h2 { font-size: clamp(2rem, 10vw, 3rem); }
  .home-stats strong,
  .home-sustain-stats strong { font-size: clamp(1.9rem, 9vw, 3.2rem); }

  /* nowrap labels that can push past the viewport edge */
  .brand .brand-tagline { white-space: normal; }
  .contact-form-hero .display-lg { white-space: normal; }
  .other-title { white-space: normal; }
  .blog-featured > div { min-width: 0; }
}
