.container { width: min(var(--container-max), calc(100% - var(--gutter) * 2)); margin-inline: auto; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }
.skip-link { position: fixed; inset-block-start: 1rem; inset-inline-start: 1rem; z-index: 20; transform: translateY(-160%); background: var(--color-focus); color: var(--color-ink-950); padding: .7rem 1rem; border-radius: var(--radius-sm); }
.skip-link:focus { transform: none; }
.site-header { position: sticky; top: 0; z-index: 10; background: rgba(8,11,16,.9); color: var(--color-stone-50); border-bottom: 1px solid rgba(255,255,255,.08); backdrop-filter: blur(14px); }
.header-inner { min-height: 72px; width: min(var(--container-max), calc(100% - var(--gutter) * 2)); margin-inline: auto; display: flex; align-items: center; gap: 1rem; }
.brand { display: inline-flex; align-items: center; gap: .75rem; font-weight: 750; text-decoration: none; }
.brand-mark { display: grid; place-items: center; width: 2.35rem; aspect-ratio: 1; border: 1px solid var(--color-accent-400); color: var(--color-accent-300); font-family: var(--font-display); }
.brand-name-short { display: none; }
.desktop-nav { margin-inline-start: auto; display: flex; gap: 1.25rem; }
.desktop-nav a, .mobile-menu a, .header-cta, .site-footer a { text-decoration: none; }
.desktop-nav a[aria-current="page"], .mobile-menu a[aria-current="page"] { color: var(--color-accent-300); }
.header-cta, .button-link, .submit-button { min-height: 44px; display: inline-flex; align-items: center; justify-content: center; gap: .35rem; padding: .75rem 1rem; border: 1px solid transparent; background: var(--color-accent-400); color: var(--color-ink-950); text-decoration: none; font-weight: 750; border-radius: var(--radius-sm); }
.button-link.secondary, .header-cta[aria-current="page"] { background: transparent; color: inherit; border-color: rgba(255,255,255,.24); }
.mobile-menu { display: none; margin-inline-start: auto; }
.mobile-menu summary { min-height: 44px; cursor: pointer; padding: .6rem .8rem; border: 1px solid rgba(255,255,255,.2); border-radius: var(--radius-sm); list-style: none; display: inline-flex; align-items: center; gap: .55rem; font-weight: 750; }
.mobile-menu summary::-webkit-details-marker { display: none; }
.menu-icon { position: relative; width: 1rem; height: .7rem; display: inline-block; border-top: 2px solid currentColor; border-bottom: 2px solid currentColor; }
.menu-icon::after { content: ""; position: absolute; inset-inline: 0; top: calc(50% - 1px); height: 2px; background: currentColor; }
.mobile-menu nav { position: absolute; inset-inline: var(--gutter); top: 72px; display: grid; gap: .25rem; padding: .75rem; background: rgba(18,24,35,.98); border: 1px solid rgba(255,255,255,.12); box-shadow: 0 24px 60px rgba(0,0,0,.24); }
.mobile-menu nav a { padding: .85rem .9rem; border-radius: var(--radius-sm); font-weight: 750; }
.mobile-menu nav a:last-child { margin-top: .35rem; background: var(--color-accent-400); color: var(--color-ink-950); text-align: center; }
h1, h2 { font-family: var(--font-display); line-height: .98; text-wrap: balance; letter-spacing: 0; }
h1 { font-size: var(--text-hero); margin: 0; } h2 { font-size: var(--text-2xl); margin: 0 0 1rem; } h3 { margin-block: 0 .5rem; font-size: var(--text-xl); }
.eyebrow { color: var(--color-accent-400); font-size: var(--text-xs); letter-spacing: .12em; text-transform: uppercase; font-weight: 800; }
.hero, .page-hero { color: var(--color-stone-50); background: var(--color-ink-950); }
.hero { padding: clamp(3.5rem, 7vh, 5.25rem) 0 clamp(3rem, 6vh, 4.5rem); }
.page-hero { padding: clamp(3.5rem, 7vh, 5.25rem) 0 clamp(3rem, 6vh, 4.5rem); }
.page-hero.compact { padding-block: clamp(3rem, 6vh, 4rem); }
.page-hero h1 { font-size: var(--text-3xl); max-width: 74rem; }
.dark-grid { background-image: linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px); background-size: 72px 72px; }
.hero-grid, .split { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(18rem, .8fr); gap: clamp(2rem, 6vw, 5rem); align-items: center; }
.hero-copy, .page-hero p { max-width: 46rem; font-size: var(--text-lg); color: var(--color-stone-200); }
.hero-actions { display: flex; flex-wrap: wrap; gap: .75rem; margin-block: 2rem; }
.support-line, .disclosure { color: var(--color-stone-400); }
.delivery-brief { justify-self: end; width: min(100%, 32rem); border-left: 1px solid rgba(223,194,141,.55); background: linear-gradient(145deg, rgba(18,24,35,.55), rgba(8,11,16,.72)); padding: clamp(1.4rem, 2.6vw, 2rem) clamp(1.4rem, 2.6vw, 2rem) clamp(1.75rem, 3vw, 2.25rem); box-shadow: 0 24px 70px rgba(0,0,0,.18); position: relative; overflow: hidden; }
.delivery-brief::before { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(201,166,107,.12), transparent 38%); pointer-events: none; }
.brief-kicker { position: relative; color: var(--color-accent-300); font-size: var(--text-xs); letter-spacing: .12em; text-transform: uppercase; font-weight: 850; }
.brief-title { position: relative; max-width: 24rem; margin: .7rem 0 1.35rem; color: var(--color-stone-50); font-family: var(--font-display); font-size: var(--text-xl); line-height: 1.1; }
.brief-timeline { position: relative; display: grid; gap: .95rem; padding: 0; margin: 0; list-style: none; }
.brief-timeline::before { content: ""; position: absolute; inset-block: .7rem; inset-inline-start: 1.125rem; width: 1px; background: linear-gradient(rgba(201,166,107,.38), rgba(201,166,107,.08)); }
.brief-timeline li { position: relative; display: grid; grid-template-columns: 2.25rem 1fr; gap: .85rem; align-items: start; }
.brief-timeline li > span { display: grid; place-items: center; width: 2.25rem; aspect-ratio: 1; background: rgba(8,11,16,.74); border: 1px solid rgba(202,167,101,.38); color: var(--color-accent-300); font-size: var(--text-xs); font-weight: 900; }
.brief-timeline strong { display: block; color: var(--color-stone-50); font-size: var(--text-base); line-height: 1.2; }
.brief-timeline p { margin: .18rem 0 0; color: var(--color-stone-200); font-size: var(--text-sm); }
.section { padding: clamp(4rem, 8vw, 8rem) 0; } .light { background: var(--color-stone-50); } .ink { background: var(--color-ink-900); color: var(--color-stone-50); } .process-band { background: var(--color-stone-100); }
.section-header { max-width: 52rem; margin-bottom: 2rem; } .section-header h2, .split > h2, .faq-list > h2, .final-cta h2 { font-size: var(--text-2xl); line-height: 1.05; } .section-header.on-dark p, .ink p { color: var(--color-stone-200); }
.three-column, .card-grid, .process-grid, .four-grid, .detail-grid, .work-grid, .insight-grid, .proof-grid, .testimonial-grid, .proof-strip { display: grid; gap: 1rem; }
.three-column { grid-template-columns: repeat(3, 1fr); } .three-column .section-header { grid-column: 1 / -1; }
.card-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.proof-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); align-items: stretch; }
.testimonial-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); align-items: stretch; }
.proof-strip { grid-template-columns: repeat(3, minmax(0, 1fr)); align-items: stretch; }
.four-grid, .process-grid { grid-template-columns: repeat(4, 1fr); }
.detail-grid { grid-template-columns: repeat(3, 1fr); align-items: start; }
.work-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); align-items: start; }
.insight-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); align-items: start; }
.work-card { display: grid; align-content: start; gap: .95rem; }
.insight-card { display: grid; align-content: start; gap: .95rem; min-height: 100%; }
.work-card-meta { display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.work-card-meta .eyebrow { margin: 0; }
.work-card-meta span { color: var(--color-stone-600); font-size: var(--text-xs); font-weight: 850; letter-spacing: .08em; text-transform: uppercase; }
.work-card h2, .work-card p, .insight-card h2, .insight-card p { margin-block: 0; }
.work-status { display: grid; grid-template-columns: minmax(0, 1.1fr) minmax(18rem, .7fr); gap: clamp(1.25rem, 4vw, 3rem); align-items: start; }
.service-card, .process-grid article, .four-grid article, .detail-grid article, .empty-state, .work-status, .work-card, .insight-card, .proof-card, .testimonial-card, form { border: 1px solid rgba(8,11,16,.14); background: rgba(255,255,255,.45); padding: 1.25rem; border-radius: var(--radius-sm); }
.work-status { padding: clamp(1.5rem, 4vw, 2.5rem); }
.service-card h3, .process-grid h3, .four-grid h3, .three-column article h3, .detail-grid h2, .empty-state h2, .contact-grid h2, .work-status h2, .work-status h3, .work-card h2, .insight-card h2, .proof-card h3 { font-family: var(--font-sans); font-size: var(--text-lg); line-height: 1.18; font-weight: 850; letter-spacing: 0; }
.work-status h2 { font-size: var(--text-2xl); max-width: 42rem; }
.work-status aside { border-left: 1px solid rgba(171,133,75,.28); padding-left: 1.25rem; }
.work-status ul { list-style: none; padding: 0; margin: 1rem 0 0; display: grid; gap: .65rem; }
.work-status li { position: relative; padding-left: 1.25rem; }
.work-status li::before { content: ""; position: absolute; inset-inline-start: 0; inset-block-start: .72em; width: .45rem; height: 1px; background: var(--color-accent-500); }
.compact-section { padding-block: clamp(3rem, 6vw, 5rem); }
.proof-card, .testimonial-card { display: grid; gap: .7rem; align-content: start; }
.proof-card h3, .proof-card p { margin: 0; }
.proof-card small { color: var(--color-stone-600); font-size: var(--text-xs); line-height: 1.45; }
.proof-strip .proof-card { gap: .45rem; }
.proof-value { color: var(--color-accent-500); font-family: var(--font-display); font-size: var(--text-2xl); line-height: .95; }
.testimonial-card { min-height: 100%; grid-template-rows: auto 1fr auto; background: var(--color-white); }
.rating-label { margin: 0; color: var(--color-accent-500); font-size: var(--text-xs); font-weight: 850; letter-spacing: .08em; text-transform: uppercase; }
.testimonial-card blockquote { margin: 0; color: var(--color-ink-950); font-size: var(--text-lg); line-height: 1.45; }
.testimonial-card blockquote::before { content: open-quote; }
.testimonial-card blockquote::after { content: close-quote; }
.testimonial-author { margin: 0 0 .15rem; font-weight: 850; }
.testimonial-meta { margin: 0; color: var(--color-stone-600); font-size: var(--text-sm); line-height: 1.45; }
.work-tags { display: flex; flex-wrap: wrap; gap: .4rem; margin: .15rem 0; }
.work-tags span { border: 1px solid rgba(171,133,75,.18); background: rgba(201,166,107,.08); color: var(--color-ink-950); padding: .22rem .48rem; font-size: var(--text-xs); font-weight: 750; }
.work-card .text-link, .insight-card .text-link { width: fit-content; color: var(--color-ink-950); margin-top: .15rem; }
.case-study { display: grid; grid-template-columns: minmax(16rem, .45fr) minmax(0, 1fr); gap: clamp(1.5rem, 5vw, 4rem); align-items: start; }
.case-summary { border: 1px solid rgba(8,11,16,.14); background: rgba(255,255,255,.45); padding: 1.25rem; border-radius: var(--radius-sm); position: sticky; top: 6rem; }
.case-summary h2, .case-summary h3, .case-sections h2 { font-family: var(--font-sans); font-size: var(--text-lg); line-height: 1.18; font-weight: 850; }
.case-summary h3 { margin: 1.6rem 0 .65rem; }
.case-summary h3:first-of-type { margin-top: 1.35rem; }
.case-summary .work-tags { margin: 0 0 .35rem; }
.case-summary .work-tags + h3 { margin-top: 1.75rem; }
.case-summary dl { display: grid; gap: .85rem; margin: 1rem 0 1.25rem; }
.case-summary dt { color: var(--color-stone-600); font-size: var(--text-xs); font-weight: 850; letter-spacing: .08em; text-transform: uppercase; }
.case-summary dd { margin: .1rem 0 0; }
.project-links { display: grid; gap: .45rem; }
.project-links a { width: fit-content; color: var(--color-accent-500); font-weight: 850; text-underline-offset: .2em; }
.case-lead { font-size: var(--text-lg); color: var(--color-ink-700); }
.case-sections { display: grid; gap: 2rem; max-width: 54rem; }
.case-sections section { border-top: 1px solid rgba(8,11,16,.14); padding-top: 1.25rem; }
.case-sections ul { list-style: none; padding: 0; margin: 1rem 0 0; display: grid; gap: .55rem; }
.case-sections li { position: relative; padding-left: 1.25rem; }
.case-sections li::before { content: ""; position: absolute; inset-inline-start: 0; inset-block-start: .72em; width: .45rem; height: 1px; background: var(--color-accent-500); }
.card-index, .process-grid span { color: var(--color-accent-500); font-weight: 850; }
.service-card a, .text-link { color: var(--color-accent-500); font-weight: 800; text-underline-offset: .2em; }
.detail-grid ul, .capability-list, .feedback-list { list-style: none; padding: 0; margin: 1rem 0 0; }
.detail-grid ul { display: grid; gap: .65rem; }
.capability-list { columns: 2; }
.feedback-list { display: grid; gap: .7rem; margin-top: 0; }
.detail-grid li, .capability-list li, .feedback-list li { position: relative; break-inside: avoid; padding-left: 1.25rem; margin-bottom: .7rem; }
.detail-grid li::before, .capability-list li::before, .feedback-list li::before { content: ""; position: absolute; inset-inline-start: 0; inset-block-start: .72em; width: .45rem; height: 1px; background: var(--color-accent-500); }
.faq-list details { border-top: 1px solid rgba(8,11,16,.14); padding: 1rem 0; }
.faq-list summary { cursor: pointer; font-weight: 800; color: var(--color-ink-950); }
.final-cta { padding: clamp(3rem, 7vw, 6rem) 0; background: var(--color-accent-soft); }
.breadcrumbs ol { display: flex; flex-wrap: wrap; gap: .4rem; padding: 0; margin: 0 0 1rem; list-style: none; color: var(--color-stone-200); } .breadcrumbs li + li::before { content: "/"; margin-right: .4rem; color: var(--color-accent-400); }
.site-footer { background: var(--color-ink-950); color: var(--color-stone-100); padding: 4rem 0 2rem; } .footer-grid { display: grid; grid-template-columns: 1.3fr repeat(3, 1fr); gap: 2rem; } .site-footer nav, .site-footer div { display: grid; align-content: start; gap: .4rem; } .site-footer h2 { font: inherit; font-weight: 800; color: var(--color-accent-300); } .footer-bottom { border-top: 1px solid rgba(255,255,255,.1); margin-top: 2rem; padding-top: 1rem; color: var(--color-stone-400); }
.contact-grid { display: grid; grid-template-columns: .7fr 1fr; gap: 2rem; align-items: start; } .field { display: grid; gap: .35rem; margin-bottom: 1rem; } .field.two { grid-template-columns: 1fr 1fr; } input, select, textarea { width: 100%; border: 1px solid var(--color-stone-200); background: var(--color-white); padding: .75rem; border-radius: var(--radius-sm); } .budget-control { position: relative; } .budget-control input { padding-right: 6.25rem; } .budget-currency { position: absolute; inset-block: .35rem; inset-inline-end: .35rem; width: 5.25rem; min-height: 0; padding: 0 .55rem; border-color: rgba(8,11,16,.14); background: var(--color-stone-100); color: var(--color-ink-950); font-size: var(--text-sm); font-weight: 800; } input[type="checkbox"] { width: 1rem; height: 1rem; padding: 0; margin-top: .35rem; accent-color: var(--color-accent-500); } .check { display: grid; grid-template-columns: auto 1fr; gap: .7rem; align-items: start; margin: 1.25rem 0 .45rem; } .check label { line-height: 1.45; } .contact-grid .submit-button { margin-top: 1rem; } .privacy-note { margin: 1.35rem 0 0; max-width: 42rem; color: var(--color-stone-600); } .honeypot { position: absolute; left: -100vw; } .validation-message, .validation-summary, .form-alert, .warning { color: #8a2424; }
.prose { max-width: var(--container-reading); }
.prose h1 { font-size: var(--text-2xl); line-height: 1.05; }
.article-meta { color: var(--color-stone-600); font-size: var(--text-sm); font-weight: 750; }
@media (max-width: 64rem) { .header-inner { min-height: 64px; gap: .75rem; } .brand { min-width: 0; gap: .6rem; } .brand-mark { width: 2rem; flex: 0 0 auto; } .brand-name { min-width: 0; } .brand-name-full { display: none; } .brand-name-short { display: block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .desktop-nav, .header-cta { display: none; } .mobile-menu { display: block; } .mobile-menu nav { top: 64px; } .hero-grid, .split, .contact-grid, .footer-grid, .three-column, .card-grid, .process-grid, .four-grid, .detail-grid, .work-grid, .insight-grid, .proof-grid, .testimonial-grid, .proof-strip, .work-status, .case-study { grid-template-columns: 1fr; } .delivery-brief { justify-self: stretch; width: 100%; } .capability-list { columns: 1; } .work-status aside { border-left: 0; border-top: 1px solid rgba(171,133,75,.28); padding: 1.25rem 0 0; } .case-summary { position: static; } }
