:root{--color-dark:#1c1a17;--color-dark-overlay:#0000008c;--color-light:#f5f2ee;--color-accent:#c8974a;--color-text-dark:#1c1a17;--color-text-light:#f5f2ee;--color-text-muted:#9a9a9a;--color-border:#2a2a2a;--color-placeholder-a:#d6d1ca;--color-placeholder-b:#bfb9b0;--font-display:"Cormorant Garamond", Georgia, serif;--font-body:"Jost", system-ui, -apple-system, sans-serif;--radius:14px;--site-pad:2.5rem}@media (width<=768px){:root{--site-pad:1.25rem}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);color:var(--color-text-dark);background:var(--color-light);font-weight:400;line-height:1.6;overflow-x:hidden}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}.fade-up{opacity:0;transition:opacity .6s,transform .6s;transform:translateY(30px)}.fade-up.is-visible{opacity:1;transform:translateY(0)}.hero-bg-img{object-fit:cover;width:100%;height:100%}.about-landscape,.about-portrait,.process-landscape{border-radius:var(--radius);object-fit:cover}.project-card-img{object-fit:cover;width:100%;height:100%}.topbar{z-index:201;background:var(--color-dark);color:var(--color-text-light);padding:.5rem var(--site-pad);letter-spacing:.04em;justify-content:flex-end;align-items:center;gap:2rem;font-size:.78rem;display:flex;position:relative}.topbar-item{color:var(--color-text-light);align-items:center;gap:.5rem;transition:color .3s;display:inline-flex}.topbar-item:hover{color:var(--color-accent)}.topbar-icon{font-size:.85rem;line-height:1}@media (width<=768px){.topbar{padding:.6rem var(--site-pad);flex-direction:column;align-items:flex-start;gap:.4rem;font-size:.72rem}}.nav{z-index:200;padding:1.25rem var(--site-pad);background:#fff;justify-content:space-between;align-items:center;display:flex;position:relative}.nav-logo{color:var(--color-text-dark);align-items:center;gap:.9rem;line-height:1;display:inline-flex}.nav-logo img{width:auto;height:56px;display:block}.nav-logo-text{flex-direction:column;gap:.15rem;display:flex}.nav-logo-name{font-family:var(--font-display);letter-spacing:.01em;color:var(--color-text-dark);font-size:1.05rem;font-weight:600}.nav-logo-title{letter-spacing:.14em;text-transform:uppercase;color:var(--color-text-muted);font-size:.7rem;font-weight:500}@media (width<=768px){.nav-logo{gap:.6rem}.nav-logo img{height:40px}.nav-logo-name{font-size:.85rem}.nav-logo-title{letter-spacing:.1em;font-size:.55rem}}@media (width<=380px){.nav-logo-title{display:none}}.nav-links{gap:2.5rem;list-style:none;display:flex}.nav-links a{text-transform:uppercase;letter-spacing:.12em;color:var(--color-text-dark);font-size:.75rem;font-weight:500;transition:color .3s;position:relative}.nav-links a:after{content:"";background:var(--color-accent);width:0;height:1px;transition:width .3s;position:absolute;bottom:-4px;left:0}.nav-links a:hover:after{width:100%}.hamburger{cursor:pointer;z-index:110;background:0 0;border:none;flex-direction:column;gap:5px;padding:4px;display:none;position:relative}.hamburger span{background:var(--color-text-dark);width:24px;height:2px;transition:transform .3s,opacity .3s;display:block}.hamburger.open span{background:var(--color-text-light)}.hamburger.open span:first-child{transform:translateY(7px)rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:translateY(-7px)rotate(-45deg)}.mobile-menu{z-index:105;opacity:0;pointer-events:none;background:#1c1a17f7;flex-direction:column;justify-content:center;align-items:center;gap:2.5rem;transition:opacity .3s;display:flex;position:fixed;inset:0}.mobile-menu.open{opacity:1;pointer-events:all}.mobile-menu a{font-family:var(--font-display);color:var(--color-text-light);font-size:2rem;font-weight:600;transition:color .3s}.mobile-menu a:hover{color:var(--color-accent)}@media (width<=768px){.nav-links{display:none}.hamburger{display:flex}}.hero{min-height:calc(100vh - 100px);padding:0 var(--site-pad) var(--site-pad);background:#fff;flex-direction:column;justify-content:flex-end;display:flex;position:relative}.hero-card{border-radius:20px;flex-direction:column;flex:1;justify-content:flex-end;padding:4rem 2.5rem 3rem;display:flex;position:relative;overflow:hidden}.hero-bg{z-index:0;position:absolute;inset:0;overflow:hidden}.hero-bg-video{object-fit:cover;pointer-events:none;width:auto;min-width:100%;height:auto;min-height:100%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.hero-overlay{background:var(--color-dark-overlay);z-index:1;position:absolute;inset:0}@media (width<=768px){.hero{padding:0 var(--site-pad) var(--site-pad)}.hero-card{border-radius:16px;padding:4rem 1.25rem 2rem}}.hero-content{z-index:2;justify-content:space-between;align-items:flex-end;gap:2rem;width:100%;display:flex;position:relative}.hero-left{max-width:600px}.hero-headline{font-family:var(--font-display);color:var(--color-text-light);font-size:clamp(2.2rem,5vw,4rem);font-weight:700;line-height:1.1}.hero-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:1rem;display:flex}.hero-stats{flex-wrap:wrap;justify-content:flex-end;gap:.75rem;display:flex}.stat-pill{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--color-text-light);background:#ffffff0f;border:1px solid #ffffff14;border-radius:50px;align-items:center;gap:.65rem;padding:.65rem 1.25rem;font-size:.82rem;font-weight:400;display:flex}.stat-pill .dot{background:var(--color-accent);border-radius:50%;flex-shrink:0;width:8px;height:8px}.btn-gold{background:var(--color-accent);color:var(--color-dark);font-family:var(--font-body);letter-spacing:.04em;border-radius:6px;align-items:center;gap:.5rem;width:fit-content;padding:.9rem 2rem;font-size:.85rem;font-weight:500;transition:background .3s;display:inline-flex;overflow:hidden}.btn-gold .btn-arrow{transition:transform .25s;display:inline-block}.btn-gold:hover .btn-arrow{animation:.3s forwards arrow-slide}@keyframes arrow-slide{0%{opacity:1;transform:translate(0)}49%{opacity:0;transform:translate(6px,-6px)}50%{opacity:0;transform:translate(-6px,6px)}to{opacity:1;transform:translate(0)}}.btn-gold:hover{background:#d4a355}@media (width<=768px){.hero-content{flex-direction:column;align-items:flex-start}.hero-right{align-items:stretch;width:100%}.hero-right .btn-gold{justify-content:center;width:100%}.hero-stats{justify-content:flex-start}}.about{padding:7rem var(--site-pad);background:var(--color-light)}.about-grid{grid-template-columns:1fr 1fr;align-items:start;gap:3rem;max-width:1400px;margin:0 auto;display:grid}.eyebrow{text-transform:uppercase;letter-spacing:.15em;color:var(--color-accent);margin-bottom:1rem;font-size:.7rem;font-weight:500}.section-heading{font-family:var(--font-display);color:var(--color-text-dark);margin-bottom:1.25rem;font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:700;line-height:1.15}.section-body{color:#5a5650;margin-bottom:2rem;font-size:.95rem;font-weight:300;line-height:1.75}.about-text{flex-direction:column;align-items:flex-start;display:flex;position:sticky;top:2rem}.about-bricks{flex-direction:column;gap:.75rem;min-width:0;display:flex;overflow:hidden}.brick-row{gap:.75rem;min-width:0;display:flex}.brick{object-fit:cover;border-radius:var(--radius);min-width:0;height:200px}.brick-wide{flex:1.6}.brick-narrow{flex:1}.brick-caption{color:var(--color-text-muted);letter-spacing:.04em;text-align:right;margin-top:.5rem;font-size:.78rem;font-style:italic}.circle-btn{background:var(--color-accent);width:48px;height:48px;color:var(--color-dark);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1.1rem;transition:background .3s;display:flex;overflow:hidden}.circle-btn .btn-arrow{transition:transform .25s;display:inline-block}.circle-btn:hover .btn-arrow{animation:.3s forwards arrow-slide}.circle-btn:hover{background:#d4a355}@media (width<=768px){.about-grid{grid-template-columns:1fr}.about-text{position:static}.brick{height:140px}}.pull-quote{background:var(--color-dark);padding:6rem var(--site-pad);text-align:center}.pull-quote blockquote{font-family:var(--font-display);color:var(--color-text-light);max-width:800px;margin:0 auto;font-size:clamp(1.6rem,3.5vw,2.6rem);font-style:italic;font-weight:600;line-height:1.35}.pull-quote-services{font-family:var(--font-display);letter-spacing:.04em;color:var(--color-text-light);max-width:900px;margin:0 auto 1rem;font-size:clamp(1.4rem,3vw,2.2rem);font-weight:600;line-height:1.3}.pull-quote-sub{letter-spacing:.22em;text-transform:uppercase;color:var(--color-accent);margin:0;font-size:clamp(.85rem,1.4vw,1rem);font-weight:500}.process{padding:7rem var(--site-pad);background:var(--color-light)}.process-header{text-align:center;max-width:700px;margin:0 auto 3rem}.process-cards{grid-template-columns:1fr 1fr;gap:1.25rem;max-width:1400px;margin:0 auto;display:grid}.process-card{border-radius:var(--radius);background:#fff;border:1px solid #e8e4df;overflow:hidden}.process-card-img{aspect-ratio:16/10;object-fit:cover;width:100%}.process-card-body{padding:2rem}.process-card-step{font-family:var(--font-display);color:var(--color-accent);opacity:.6;margin-bottom:.75rem;font-size:2.5rem;font-weight:700;line-height:1;display:block}.process-card h4{font-family:var(--font-display);color:var(--color-text-dark);margin-bottom:.75rem;font-size:1.5rem;font-weight:700}.process-card p{color:#5a5650;font-size:.9rem;font-weight:300;line-height:1.75}.process-closing{color:#5a5650;text-align:center;max-width:700px;margin:2rem auto 0;font-size:.9rem;font-weight:300;line-height:1.7}@media (width<=768px){.process-cards{grid-template-columns:1fr}}.projects{padding:7rem var(--site-pad);background:var(--color-light)}.projects-header{text-align:center;max-width:600px;margin:0 auto 3rem}.projects-row{grid-template-columns:repeat(4,1fr);gap:1.25rem;max-width:1400px;margin:0 auto;display:grid}.project-card{aspect-ratio:4/3;border-radius:var(--radius);cursor:pointer;width:100%;font:inherit;color:inherit;text-align:left;background:0 0;border:none;padding:0;display:block;position:relative;overflow:hidden}.project-card:focus-visible{outline:2px solid var(--color-accent);outline-offset:3px}.project-card-overlay{opacity:0;background:#1c1a17b3;align-items:flex-end;padding:1.25rem;transition:opacity .3s;display:flex;position:absolute;inset:0}.project-card:hover .project-card-overlay{opacity:1}.project-card-label{color:var(--color-text-light);font-size:.85rem;font-weight:500}@media (width<=768px){.projects-row{grid-template-columns:1fr 1fr}}.lightbox{z-index:1000;background:#000000d9;justify-content:center;align-items:center;padding:2rem;animation:.2s lightbox-fade;display:flex;position:fixed;inset:0}@keyframes lightbox-fade{0%{opacity:0}to{opacity:1}}.lightbox-close{width:44px;height:44px;color:var(--color-text-light);background:#0006;border-radius:50%;justify-content:center;align-items:center;font-size:2rem;line-height:1;transition:background .2s,color .2s;display:flex;position:absolute;top:1.25rem;right:1.5rem}.lightbox-close:hover{background:var(--color-accent);color:var(--color-dark)}.lightbox-figure{flex-direction:column;align-items:center;gap:1rem;max-width:min(1200px,92vw);max-height:88vh;display:flex}.lightbox-img{object-fit:contain;border-radius:var(--radius);max-width:100%;max-height:80vh;box-shadow:0 20px 60px #00000080}.lightbox-caption{font-family:var(--font-display);color:var(--color-text-light);letter-spacing:.04em;text-align:center;font-size:1.25rem}.showcase{padding:7rem var(--site-pad);background:var(--color-dark);text-align:center}.showcase-inner{max-width:800px;margin:0 auto}.showcase .eyebrow{color:var(--color-accent)}.showcase .section-heading{color:var(--color-text-light)}.showcase-video{border-radius:var(--radius);background:#111;width:100%;margin-top:2rem;padding-bottom:56.07%;position:relative;overflow:hidden}.showcase-video iframe{width:100%;height:100%;position:absolute;top:0;left:0}.contact{background:var(--color-dark);padding:7rem var(--site-pad);text-align:center}.contact .eyebrow{color:var(--color-accent)}.contact .section-heading{color:var(--color-text-light)}.contact .section-body{color:var(--color-text-muted);max-width:520px;margin:0 auto 2rem}.contact-form{text-align:left;flex-direction:column;gap:1rem;max-width:560px;margin:2.5rem auto 0;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.form-field{flex-direction:column;gap:.4rem;display:flex}.form-field>span{letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted);font-size:.75rem;font-weight:400}.form-field>span em{text-transform:none;letter-spacing:0;opacity:.7;font-style:normal}.form-field input,.form-field textarea{color:var(--color-text-light);border:1px solid var(--color-border);background:#ffffff0a;border-radius:6px;width:100%;padding:.75rem .9rem;font-family:inherit;font-size:.95rem;transition:border-color .25s,background .25s}.form-field textarea{resize:vertical;min-height:120px;font-family:inherit}.form-field input:focus,.form-field textarea:focus{border-color:var(--color-accent);background:#ffffff0f;outline:none}.form-note{color:var(--color-text-muted);border-left:2px solid var(--color-accent);background:#c8974a14;border-radius:4px;padding:.75rem 1rem;font-size:.82rem;line-height:1.55}.form-note strong{color:var(--color-accent);font-weight:600}.form-submit{justify-content:center;align-self:stretch;width:100%;margin-top:.5rem}@media (width<=640px){.form-row{grid-template-columns:1fr}}.contact-details{border-top:1px solid var(--color-border);grid-template-columns:repeat(3,minmax(0,1fr));gap:2.5rem;max-width:760px;margin:4rem auto 0;padding-top:2.5rem;display:grid}.contact-detail{text-align:center;flex-direction:column;align-items:center;gap:.35rem;display:flex}.contact-detail-label{letter-spacing:.18em;text-transform:uppercase;color:var(--color-accent);font-size:.7rem;font-weight:500}.contact-detail-value{color:var(--color-text-light);word-break:break-word;font-size:.95rem;font-weight:400;transition:color .3s}a.contact-detail-value:hover{color:var(--color-accent)}.contact-detail-meta{color:var(--color-text-muted);font-size:.78rem;font-weight:300}@media (width<=768px){.contact-details{grid-template-columns:1fr;gap:1.75rem;margin-top:3rem;padding-top:2rem}}.footer{background:var(--color-dark);border-top:1px solid var(--color-border);padding:2rem var(--site-pad)}.footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;max-width:1400px;margin:0 auto;display:flex}.footer-logo{font-family:var(--font-display);color:var(--color-text-light);font-size:.95rem;font-weight:600}.footer-nav{gap:2rem;list-style:none;display:flex}.footer-nav a{text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);font-size:.75rem;font-weight:400;transition:color .3s}.footer-nav a:hover{color:var(--color-text-light)}.footer-socials{gap:1rem;display:flex}.footer-socials a{color:var(--color-text-muted);transition:color .3s}.footer-socials a:hover{color:var(--color-text-light)}.footer-socials svg{width:18px;height:18px}.footer-copy{text-align:center;width:100%;color:var(--color-text-muted);border-top:1px solid var(--color-border);margin-top:1.5rem;padding-top:1.5rem;font-size:.72rem}@media (width<=768px){.footer-inner{text-align:center;flex-direction:column}.footer-nav{gap:1.5rem}}.projects-cta{letter-spacing:.08em;text-transform:uppercase;color:var(--color-accent);border-bottom:1px solid var(--color-accent);align-items:center;gap:.4rem;margin-top:1.25rem;padding-bottom:2px;font-size:.85rem;transition:opacity .3s;display:inline-flex}.projects-cta:hover{opacity:.75}.portfolio-page{background:var(--color-light);padding:5rem var(--site-pad) 6rem}.portfolio-header{text-align:center;max-width:720px;margin:0 auto 5rem}.portfolio-header .section-heading{margin-bottom:1rem}.projects-list{flex-direction:column;gap:6rem;max-width:1400px;margin:0 auto;display:flex}.project-block{flex-direction:column;gap:1.75rem;display:flex}.project-block-meta{border-bottom:1px solid #1c1a171f;align-items:baseline;gap:1.5rem;padding-bottom:1.25rem;display:flex}.project-block-index{font-family:var(--font-display);color:var(--color-accent);font-size:2rem;line-height:1}.project-block-text{flex:1;min-width:0}.project-block-title{font-family:var(--font-display);color:var(--color-text-dark);margin-bottom:.15rem;font-size:clamp(1.4rem,2.4vw,1.85rem);font-weight:500}.project-block-summary{letter-spacing:.14em;text-transform:uppercase;color:var(--color-text-muted);font-size:.78rem}.project-block-count{letter-spacing:.16em;text-transform:uppercase;color:var(--color-text-muted);white-space:nowrap;font-size:.72rem}.project-block-grid{grid-template-columns:repeat(2,1fr);gap:1.25rem;display:grid}.project-block-figure{border-radius:var(--radius);cursor:zoom-in;aspect-ratio:4/3;background:var(--color-placeholder-a);margin:0;position:relative;overflow:hidden}.project-block-figure img{object-fit:cover;width:100%;height:100%;transition:transform .6s}.project-block-figure:hover img{transform:scale(1.03)}.project-block-label{color:var(--color-text-light);letter-spacing:.18em;text-transform:uppercase;background:#1c1a17d9;border-radius:4px;padding:.4rem .8rem;font-size:.7rem;position:absolute;top:1rem;left:1rem}.section-intro{text-align:center;max-width:720px;margin:0 auto 3rem}.cgi-to-build-section{border-top:1px solid #1c1a171f;max-width:1400px;margin:8rem auto 0;padding-top:6rem}.ba-list{flex-direction:column;gap:6rem;max-width:1400px;margin:0 auto;display:flex}.ba-pair{flex-direction:column;gap:1.75rem;display:flex}.ba-meta{border-bottom:1px solid #1c1a171f;align-items:baseline;gap:1.5rem;padding-bottom:1.25rem;display:flex}.ba-index{font-family:var(--font-display);color:var(--color-accent);font-size:2rem;line-height:1}.ba-title{font-family:var(--font-display);color:var(--color-text-dark);margin-bottom:.15rem;font-size:clamp(1.4rem,2.4vw,1.85rem);font-weight:500}.ba-view{letter-spacing:.14em;text-transform:uppercase;color:var(--color-text-muted);font-size:.78rem}.ba-grid{grid-template-columns:1fr 1fr;gap:1.25rem;display:grid}.ba-grid-gallery{grid-template-columns:repeat(2,1fr)}@media (width<=768px){.ba-grid-gallery{grid-template-columns:1fr}}.ba-figure{border-radius:var(--radius);cursor:zoom-in;aspect-ratio:4/3;background:var(--color-placeholder-a);margin:0;position:relative;overflow:hidden}.ba-figure-tall{aspect-ratio:1}.ba-figure-tall .ba-image{object-fit:contain;background:var(--color-placeholder-a)}.ba-image{object-fit:cover;width:100%;height:100%;transition:transform .6s}.ba-figure:hover .ba-image{transform:scale(1.03)}.ba-label{color:var(--color-text-light);letter-spacing:.18em;text-transform:uppercase;background:#1c1a17d9;border-radius:4px;padding:.4rem .8rem;font-size:.7rem;position:absolute;top:1rem;left:1rem}.ba-label-built{background:var(--color-accent);color:var(--color-text-dark)}.portfolio-cta{text-align:center;max-width:640px;margin:6rem auto 0}.portfolio-cta .section-heading{margin-bottom:1rem}.portfolio-cta .btn-gold{margin-top:1.5rem}@media (width<=768px){.portfolio-page{padding:3rem var(--site-pad) 4rem}.portfolio-header{margin-bottom:3rem}.projects-list{gap:4rem}.project-block-grid{grid-template-columns:1fr;gap:.75rem}.project-block-meta{flex-wrap:wrap;gap:.75rem 1rem}.project-block-index{font-size:1.5rem}.project-block-count{flex-basis:100%;width:100%}.cgi-to-build-section{margin-top:5rem;padding-top:4rem}.ba-list{gap:4rem}.ba-grid{grid-template-columns:1fr;gap:.75rem}.ba-meta{gap:1rem}.ba-index{font-size:1.5rem}.portfolio-cta{margin-top:4rem}}
