/* ============================================================
   ONE source of CSS truth. Generated deterministically from the
   business's brand color + chosen fonts. No inline-critical split,
   no validator !important patches. Structure is fixed & bulletproof.
   ============================================================ */
:root{
  --primary:#BA3E47;
  --accent:#149460;
  --ink:#0C0C0F;
  --canvas:#FFFFFF;
  --surface:#F2F0EB;
  --muted:#5A5852;
  --line:#0C0C0F;
  --header-h:88px;
  --maxw:1280px;
  --pad-y:clamp(72px,9vh,120px);
  --display:"Archivo Black",system-ui,sans-serif;
  --body:"IBM Plex Sans",system-ui,sans-serif;
  --mono:"IBM Plex Mono",ui-monospace,monospace;
  --dw:900;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--canvas);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,56px)}
h1,h2,h3{font-family:var(--display);font-weight:var(--dw);text-transform:uppercase;letter-spacing:-.02em;line-height:.98}

.btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--body);font-weight:700;font-size:15px;padding:17px 30px;border:2px solid var(--ink);border-radius:0;cursor:pointer;transition:transform .15s ease,background .15s ease,color .15s ease;white-space:nowrap}
.btn--primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn--primary:hover{transform:translateY(-2px)}
.btn--ghost{background:transparent;color:#fff;border-color:#fff}
.btn--ghost:hover{background:#fff;color:var(--ink)}
.btn--dark{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn--dark:hover{transform:translateY(-2px)}
.btn--ghost-dark{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn--ghost-dark:hover{background:var(--ink);color:#fff}
.eyebrow{font-family:var(--mono);text-transform:uppercase;font-size:12px;font-weight:600;letter-spacing:.16em;color:var(--primary)}

/* header — sticky, fixed height; hero clears it */
/* Header uses the site's OWN theme colors (canvas bg + ink text), never a
   hardcoded white — on a dark-theme lead a white bar made the light-ink nav +
   brand invisible until hover. color-mix keeps a translucent blur over the hero
   while guaranteeing the same fg/bg contrast as the body. */
.site-header{position:sticky;top:0;z-index:50;height:var(--header-h);display:flex;align-items:center;color:var(--ink);background:color-mix(in srgb,var(--canvas) 90%,transparent);backdrop-filter:blur(10px);border-bottom:1px solid color-mix(in srgb,var(--ink) 14%,transparent)}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;width:100%}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--display);font-weight:var(--dw);font-size:17px;letter-spacing:-.01em;min-width:0}
.brand img{height:40px;width:auto;flex:none}
.brand span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nav{display:flex;align-items:center;gap:28px;flex:none}
.nav a{font-size:14px;font-weight:600;color:var(--ink)}
.nav a:not(.btn):hover{color:var(--primary)}
.nav a[aria-current=page]{color:var(--primary)}
.nav .btn{padding:11px 20px;font-size:13px}
@media(max-width:820px){.nav a:not(.btn){display:none}.brand{font-size:14px;gap:9px}.brand img{height:34px}}
@media(max-width:520px){.brand img + span{display:none}}

/* HERO — column flex, bottom-anchored, grows DOWN, clears the nav.
   Cannot clip up behind the sticky header at any viewport height. */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;padding-top:calc(var(--header-h) + 32px);padding-bottom:clamp(48px,7vh,96px);overflow:hidden;color:#fff}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 40%;z-index:0}
.hero-overlay{position:absolute;inset:0;z-index:1;pointer-events:none;background:linear-gradient(180deg,rgba(0,0,0,.5) 0%,rgba(0,0,0,.22) 24%,rgba(0,0,0,.46) 56%,rgba(0,0,0,.9) 100%),linear-gradient(90deg,rgba(0,0,0,.72) 0%,rgba(0,0,0,.32) 42%,rgba(0,0,0,0) 72%)}
.hero-inner{position:relative;z-index:2;max-width:920px}
.hero .eyebrow{color:#fff;opacity:.92;text-shadow:0 1px 10px rgba(0,0,0,.7)}
.hero-title{font-size:clamp(40px,7vw,104px);line-height:.94;margin:18px 0 20px;max-width:14ch;text-shadow:0 2px 28px rgba(0,0,0,.5),0 1px 3px rgba(0,0,0,.35)}
.hero-sub{font-size:clamp(16px,1.5vw,20px);max-width:60ch;color:#fff;margin-bottom:30px;text-shadow:0 1px 14px rgba(0,0,0,.7)}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:34px}
.hero-chips{display:flex;flex-wrap:wrap;border:1px solid rgba(255,255,255,.4)}
.hero-chips .chip{font-family:var(--mono);text-transform:uppercase;font-size:12px;font-weight:600;letter-spacing:.12em;padding:14px 22px;border-right:1px solid rgba(255,255,255,.4)}
.hero-chips .chip:last-child{border-right:0}

/* page header (sub-page hero) — same cover/cap discipline, capped height */
.page-header{position:relative;min-height:46vh;display:flex;flex-direction:column;justify-content:flex-end;padding-top:calc(var(--header-h) + 24px);padding-bottom:48px;overflow:hidden;color:#fff}
.page-header-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.page-header-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,.4),rgba(0,0,0,.7))}
.page-header-inner{position:relative;z-index:2}
.page-header h1{font-size:clamp(34px,5.5vw,76px);margin-top:12px}

/* brand band */
.brand-band{background:var(--primary);color:#fff;padding:clamp(56px,8vh,104px) 0}
.brand-band p{font-family:var(--display);font-weight:var(--dw);text-transform:uppercase;font-size:clamp(26px,4.2vw,64px);line-height:1.04;letter-spacing:-.02em;max-width:20ch}

/* trust strip */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.trust .wrap{display:flex;flex-wrap:wrap}
.trust .item{flex:1 1 0;min-width:200px;padding:28px 24px;border-right:1px solid rgba(0,0,0,.12)}
.trust .item:last-child{border-right:0}
.trust .k{font-family:var(--display);font-weight:var(--dw);font-size:clamp(26px,3vw,40px);line-height:1}
.trust .l{font-family:var(--mono);text-transform:uppercase;font-size:11px;letter-spacing:.14em;color:var(--muted);margin-top:8px}

.section{padding:var(--pad-y) 0}
.section--surface{background:var(--surface)}
.section-head{max-width:760px;margin-bottom:48px}
.section-head h2{font-size:clamp(30px,4.5vw,60px);margin-top:14px}

/* SERVICES bento — children default to auto/explicit placement, NEVER 1/-1 */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.svc{background:var(--canvas);display:flex;flex-direction:column;grid-column:auto}
.svc--flagship{grid-column:span 2;grid-row:span 2}
.svc-img{width:100%;aspect-ratio:4/3;object-fit:cover}
.svc--flagship .svc-img{aspect-ratio:16/10}
.svc-body{padding:24px;display:flex;flex-direction:column;gap:10px;flex:1}
.svc h3{font-size:clamp(17px,1.6vw,24px);line-height:1.05}
.svc--flagship h3{font-size:clamp(24px,2.4vw,38px)}
.svc-desc{color:var(--muted);font-size:15px}
.svc .num{font-family:var(--mono);font-size:12px;color:var(--primary);letter-spacing:.1em}
.svc .more{margin-top:auto;font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:var(--primary)}
@media(max-width:820px){.services-grid{grid-template-columns:1fr 1fr}.svc--flagship{grid-column:span 2;grid-row:auto}}
@media(max-width:540px){.services-grid{grid-template-columns:1fr}.svc--flagship{grid-column:auto}}

/* GALLERY — tiles pinned to one cell at 4/3; never auto-span a row */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.gallery-grid figure{margin:0}
.gallery-grid img{width:100%;aspect-ratio:4/3;object-fit:cover}
@media(max-width:820px){.gallery-grid{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.gallery-grid{grid-template-columns:1fr}}

/* services page — alternating feature blocks */
.feature-blocks{display:flex;flex-direction:column;gap:64px}
.feature-block{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.feature-block--rev .fb-media{order:2}
.fb-media img{width:100%;aspect-ratio:4/3;object-fit:cover}
.fb-body .num{font-family:var(--mono);color:var(--primary);font-size:13px;letter-spacing:.1em}
.fb-body h2{font-size:clamp(26px,3.4vw,46px);margin:10px 0 16px}
.fb-body p{color:var(--muted);margin-bottom:24px;max-width:54ch}
@media(max-width:820px){.feature-block{grid-template-columns:1fr}.feature-block--rev .fb-media{order:0}}

/* cta banner */
.cta-banner{background:var(--primary);color:#fff;padding:clamp(56px,8vh,96px) 0}
.cta-banner .wrap{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:28px}
.cta-banner p{font-family:var(--display);font-weight:var(--dw);text-transform:uppercase;font-size:clamp(26px,3.6vw,52px);line-height:1.02;letter-spacing:-.02em;max-width:16ch}
.cta-banner-actions{display:flex;flex-wrap:wrap;gap:14px}

/* about */
.about-story{display:grid;grid-template-columns:.8fr 1.2fr;gap:48px;align-items:start}
.about-portrait img{width:100%;aspect-ratio:3/4;object-fit:cover}
.about-copy p{margin-top:16px;font-size:17px}
.about-copy .eyebrow{display:block;margin-bottom:8px}
@media(max-width:820px){.about-story{grid-template-columns:1fr}}
.cred-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1px;background:var(--line);border:1px solid var(--line)}
.cred{background:var(--canvas);padding:28px}
.cred .l{font-family:var(--mono);text-transform:uppercase;font-size:11px;letter-spacing:.14em;color:var(--muted)}
.cred .v{font-family:var(--display);font-weight:var(--dw);font-size:18px;margin-top:8px;line-height:1.1}
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
.review{background:var(--surface);border-left:3px solid var(--primary);padding:28px}
.review p{font-size:16px}
.review cite{display:block;margin-top:16px;font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-style:normal}

/* faq */
.faq details{border-bottom:1px solid rgba(0,0,0,.18)}
.faq summary{list-style:none;cursor:pointer;padding:26px 0;font-family:var(--display);font-weight:var(--dw);text-transform:uppercase;font-size:clamp(16px,1.6vw,22px);letter-spacing:-.01em;display:flex;justify-content:space-between;align-items:center;gap:20px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--primary);font-family:var(--body);font-size:28px;line-height:1}
.faq details[open] summary::after{content:"–"}
.faq p{padding:0 0 26px;max-width:70ch;color:var(--muted)}

/* contact */
.contact-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:48px}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
.field label{font-family:var(--mono);text-transform:uppercase;font-size:11px;letter-spacing:.12em;color:var(--muted)}
.field input,.field textarea{font-family:var(--body);font-size:15px;padding:14px;border:2px solid var(--line);border-radius:0;background:#fff}
.info-card{background:var(--ink);color:#fff;padding:36px}
.info-card .row{padding:18px 0;border-bottom:1px solid rgba(255,255,255,.15)}
.info-card .row:last-child{border-bottom:0}
.info-card .l{font-family:var(--mono);text-transform:uppercase;font-size:11px;letter-spacing:.14em;opacity:.6}
.info-card .v{font-size:17px;margin-top:6px}
.info-card a:hover{color:var(--primary)}

/* footer */
.site-footer{background:var(--ink);color:rgba(255,255,255,.7);padding:48px 0;font-size:14px}
.site-footer .wrap{display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px}
.foot-links{display:flex;flex-wrap:wrap;gap:18px}
.site-footer a:hover{color:#fff}

/* reveal — settles at transform:none (never translateY(0)): no Safari seam */
.fade-up{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.fade-up.visible{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.fade-up{opacity:1;transform:none;transition:none}}
