:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#16191f;background:#f4f2ec;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html{min-width:320px;scroll-behavior:smooth}body{min-width:320px;min-height:100vh;margin:0}button,a{font:inherit}a{color:inherit}#root{min-height:100vh}@media (prefers-reduced-motion: reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}:root{--ink: #16191f;--muted: #5c6470;--paper: #f4f2ec;--surface: #fffdf8;--line: #d8d2c6;--blue: #274d73;--green: #315c4a;--rust: #9c4f34;--shadow: 0 24px 70px rgba(22, 25, 31, .12)}.hero{position:relative;min-height:clamp(520px,72vh,760px);display:grid;align-items:end;overflow:hidden;color:#fffdf8;isolation:isolate}.hero__video,.hero__shade{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.hero__video{object-fit:cover;z-index:-2}.hero__shade{z-index:-1;background:linear-gradient(90deg,#0c1218e0,#0c121885 48%,#0c12182e),linear-gradient(0deg,#16191fd1,#16191f1f 58%)}.hero__content{width:min(1120px,calc(100% - 40px));margin:0 auto;padding:96px 0 72px}.eyebrow,.section-kicker,.project-card__meta{margin:0;color:var(--rust);font-size:.78rem;font-weight:800;letter-spacing:.12em;line-height:1.2;text-transform:uppercase}.hero .eyebrow{color:#f1c8a7}h1,h2,h3,p{margin-top:0}h1{max-width:840px;margin-bottom:28px;font-size:clamp(4.25rem,11vw,8.75rem);line-height:.88;letter-spacing:0}h2{margin-bottom:18px;font-size:clamp(2rem,5vw,4.75rem);line-height:.98;letter-spacing:0}h3{margin-bottom:14px;color:var(--ink);font-size:1.35rem;line-height:1.1;letter-spacing:0}.hero__lede{max-width:680px;margin-bottom:32px;color:#fffdf8d6;font-size:clamp(1.15rem,2.1vw,1.6rem);line-height:1.45}.hero__actions,.contact{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.button{min-height:48px;display:inline-flex;align-items:center;justify-content:center;border:1px solid transparent;border-radius:8px;padding:0 18px;font-weight:800;text-decoration:none;transition:background-color .18s ease,border-color .18s ease,color .18s ease,transform .18s ease}.button:hover{transform:translateY(-2px)}.button:focus-visible,.project-card a:focus-visible{outline:3px solid rgba(156,79,52,.52);outline-offset:4px}.button--primary{background:#fffdf8;color:var(--ink)}.button--primary:hover{background:#f1c8a7}.button--secondary{border-color:#fffdf880;color:#fffdf8}.button--secondary:hover{border-color:#fffdf8;background:#fffdf81f}main{display:grid;gap:80px;width:min(1120px,calc(100% - 40px));margin:0 auto;padding:88px 0 64px}.project-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.project-card{min-height:320px;display:flex;flex-direction:column;border:1px solid var(--line);border-radius:8px;padding:24px;background:var(--surface)}.project-card__meta{margin-bottom:36px;color:var(--green)}.project-card p:not(.project-card__meta){color:var(--muted);line-height:1.62}.project-card a{width:fit-content;margin-top:auto;color:var(--blue);font-weight:850;text-decoration-thickness:.1em;text-underline-offset:.24em}.project-card a:hover{color:var(--rust)}.project-card__status{width:fit-content;margin-top:auto;border:1px solid rgba(49,92,74,.28);border-radius:999px;padding:7px 10px;color:var(--green);font-size:.9rem;font-weight:850;line-height:1}.contact{flex-direction:column;align-items:flex-start;border-top:1px solid var(--line);padding-top:56px}.contact h2{max-width:780px;margin-bottom:8px}.contact p:not(.section-kicker){max-width:620px;margin-bottom:18px;color:var(--muted);font-size:1.08rem;line-height:1.68}.contact .button--primary{background:var(--ink);color:#fffdf8}.contact .button--primary:hover{background:var(--blue)}@media (max-width: 860px){.hero{min-height:620px}.hero__shade{background:linear-gradient(180deg,#0c121847,#0c1218e0),linear-gradient(90deg,#0c1218ad,#0c12182e)}.project-grid{grid-template-columns:1fr}.project-card{min-height:auto}}@media (max-width: 560px){.hero__content{width:min(100% - 28px,1120px);padding-bottom:52px}h1{font-size:clamp(3.25rem,18vw,5.5rem)}main{width:min(100% - 28px,1120px);gap:60px;padding-top:64px}.button{width:100%}}@media (prefers-reduced-motion: reduce){.hero__video{display:none}.hero{background:linear-gradient(90deg,#0c1218db,#0c121857),url(/images/background.png) center / cover no-repeat}}
