:root{--cream:#F2EDE3;--cream-deep:#E8DFCC;--cream-pale:#FAF7F0;--ink:#161412;--ink-soft:#2A2723;--ink-mid:#4A453E;--terracotta:#B5472D;--terracotta-deep:#8C3520;--terracotta-pale:#D9876C;--muted:#6B6760;--rule:rgba(22,20,18,0.10);--rule-strong:rgba(22,20,18,0.18);--rule-light:rgba(242,237,227,0.15);--display:'Fraunces','Times New Roman',serif;--body:'Manrope',system-ui,sans-serif;--mono:'JetBrains Mono','Courier New',monospace}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--cream);color:var(--ink);font-family:var(--body);font-weight:400;line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden}
::selection{background:var(--terracotta);color:var(--cream)}
a{color:inherit}

/* SCROLL PROGRESS */
.scroll-progress{position:fixed;top:0;left:0;height:2px;width:0%;background:var(--terracotta);z-index:200;transition:width .05s linear}

/* SECTION COUNTER */
.section-counter{position:fixed;left:1.5rem;top:50%;transform:translateY(-50%);z-index:90;font-family:var(--mono);font-size:.7rem;letter-spacing:.15em;color:var(--ink-mid);writing-mode:vertical-rl;text-orientation:mixed;display:flex;align-items:center;gap:1rem}
.section-counter .dash{width:1px;height:40px;background:var(--ink-mid)}
.section-counter.dark{color:var(--cream)}
.section-counter.dark .dash{background:var(--cream)}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.1rem 2.5rem;display:flex;justify-content:space-between;align-items:center;background:rgba(242,237,227,.78);backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border-bottom:1px solid transparent;transition:all .4s ease}
.nav.scrolled{border-bottom-color:var(--rule);padding:.85rem 2.5rem}
.logo{font-family:var(--display);font-weight:500;font-size:1.4rem;letter-spacing:-.02em;display:flex;align-items:center;gap:.7rem;text-decoration:none;color:var(--ink)}
.logo-mark{width:36px;height:36px;background:var(--ink);color:var(--cream);display:grid;place-items:center;font-size:.95rem;font-weight:600;font-style:italic;transition:transform .4s,background .4s;position:relative;overflow:hidden}
.logo:hover .logo-mark{background:var(--terracotta);transform:rotate(-90deg)}
.logo-text small{display:block;font-family:var(--mono);font-size:.6rem;font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:1px}
.nav-links{display:flex;gap:2.4rem;list-style:none;counter-reset:navlink}
.nav-links li{counter-increment:navlink}
.nav-links a{text-decoration:none;font-size:.85rem;font-weight:500;letter-spacing:.01em;position:relative;padding:.3rem 0;transition:color .3s}
.nav-links a::before{content:counter(navlink,decimal-leading-zero) '.';font-family:var(--mono);font-size:.62rem;color:var(--terracotta);margin-right:.4rem;font-weight:400;letter-spacing:0;vertical-align:1px}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:1px;background:var(--terracotta);transition:width .3s ease}
.nav-links a:hover{color:var(--terracotta)}
.nav-links a:hover::after{width:100%}
.nav-cta{background:var(--ink);color:var(--cream);padding:.7rem 1.5rem;text-decoration:none;font-size:.82rem;font-weight:500;transition:all .3s;position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:.5rem}
.nav-cta::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:var(--terracotta);transition:left .4s ease;z-index:0}
.nav-cta:hover::before{left:0}
.nav-cta span{position:relative;z-index:1}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:.5rem}
.menu-toggle span{display:block;width:24px;height:1.5px;background:var(--ink);margin:5px 0}

/* HERO */
.hero{min-height:100vh;padding:8rem 2.5rem 0;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between}
.hero::before{content:'';position:absolute;top:0;right:0;width:50%;height:100%;background:radial-gradient(ellipse at top right,rgba(181,71,45,.07) 0%,transparent 60%),repeating-linear-gradient(0deg,transparent 0,transparent 119px,rgba(22,20,18,.04) 119px,rgba(22,20,18,.04) 120px);z-index:0;pointer-events:none}
.hero-meta{position:absolute;top:6rem;right:2.5rem;font-family:var(--mono);font-size:.7rem;color:var(--ink-mid);text-align:right;letter-spacing:.05em;line-height:1.7;z-index:2}
.hero-meta span{color:var(--terracotta)}
.hero-content{position:relative;z-index:2;flex:1;display:grid;grid-template-columns:1.4fr 1fr 1.1fr;gap:3rem;align-items:center;padding:2rem 0}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.8rem;font-family:var(--mono);font-size:.72rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--terracotta);margin-bottom:2.2rem;animation:fadeUp .9s ease-out}
.hero-eyebrow::before{content:'◆';font-size:.65rem}
.hero-eyebrow::after{content:'';width:60px;height:1px;background:var(--terracotta)}
.hero h1{font-family:var(--display);font-weight:300;font-size:clamp(2.8rem,7.5vw,7rem);line-height:.92;letter-spacing:-.04em;margin-bottom:2.5rem}
.hero h1 .line{display:block;overflow:hidden}
.hero h1 .line-inner{display:inline-block;animation:lineUp 1.1s cubic-bezier(.16,1,.3,1) backwards}
.hero h1 .line:nth-child(1) .line-inner{animation-delay:.1s}
.hero h1 .line:nth-child(2) .line-inner{animation-delay:.25s}
.hero h1 .line:nth-child(3) .line-inner{animation-delay:.4s}
.hero h1 em{font-style:italic;color:var(--terracotta);font-weight:300}
.hero h1 .strike{position:relative;display:inline-block}
.hero h1 .strike::after{content:'';position:absolute;left:0;right:0;bottom:.18em;height:4px;background:var(--ink);animation:strikeIn .8s 1.2s cubic-bezier(.16,1,.3,1) backwards;transform-origin:left}
.hero-side{align-self:end;padding-bottom:1rem}
.hero-lede{font-size:1.05rem;line-height:1.6;color:var(--ink-soft);max-width:420px;margin-bottom:2.5rem;animation:fadeUp 1s ease-out .6s backwards;padding-left:1.5rem;border-left:1px solid var(--rule-strong)}
.hero-lede strong{color:var(--ink);font-weight:600}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap;animation:fadeUp 1s ease-out .75s backwards}
.btn{padding:1.05rem 2rem;font-size:.85rem;font-weight:500;text-decoration:none;transition:all .3s;display:inline-flex;align-items:center;gap:.55rem;cursor:pointer;border:none;font-family:inherit;position:relative;overflow:hidden;letter-spacing:.01em}
.btn-primary{background:var(--ink);color:var(--cream)}
.btn-primary::before{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:var(--terracotta);transition:left .4s ease}
.btn-primary:hover::before{left:0}
.btn-primary>*{position:relative;z-index:1}
.btn-primary:hover{transform:translateY(-2px)}
.btn-secondary{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.btn-secondary:hover{background:var(--ink);color:var(--cream)}
.btn .arrow{transition:transform .3s}
.btn:hover .arrow{transform:translateX(5px)}

/* HERO VISUAL */
.hero-visual{position:relative;width:100%;min-height:400px;z-index:1;display:grid;grid-template-columns:1.4fr 1fr;grid-template-rows:1fr 1.4fr;gap:.5rem;animation:fadeUp 1.4s ease-out .8s backwards;align-self:stretch}
.hero-tile{position:relative;overflow:hidden;transition:transform .6s cubic-bezier(.16,1,.3,1)}
.hero-tile-a{grid-row:1/3;background:var(--ink);color:var(--cream);background-image:url('https://images.unsplash.com/photo-1488972685288-c3fd157d7c7a?w=600&q=80&auto=format&fit=crop');background-size:cover;background-position:center}
.hero-tile-a::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(22,20,18,.55) 0%,rgba(22,20,18,.25) 45%,rgba(181,71,45,.5) 100%)}
.hero-tile-a::after{content:'';position:absolute;bottom:30%;left:0;right:0;height:1px;background:var(--terracotta);opacity:.6}
.hero-tile-b{background:var(--ink);color:var(--cream);background-image:url('https://images.unsplash.com/photo-1772476259545-c0154ca5ee19?w=600&q=80&auto=format&fit=crop');background-size:cover;background-position:center top}
.hero-tile-b::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(22,20,18,.3) 0%,rgba(181,71,45,.55) 100%)}
.hero-tile-c{background:var(--cream-deep);border:1px solid var(--rule)}
.hero-tile-c::before{content:'';position:absolute;inset:0;background-image:linear-gradient(var(--rule) 1px,transparent 1px),linear-gradient(90deg,var(--rule) 1px,transparent 1px);background-size:28px 28px;opacity:.6}
.hero-tile-c::after{content:'◇';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.4rem;color:var(--terracotta)}
.hero-tile-content{position:relative;z-index:2;padding:1rem 1.1rem;height:100%;display:flex;flex-direction:column;justify-content:space-between}
.hero-tile-num{font-family:var(--mono);font-size:.62rem;letter-spacing:.15em;opacity:.7}
.hero-tile-label{font-family:var(--display);font-style:italic;font-size:1.05rem;line-height:1.15;font-weight:400}
.hero-tile-label strong{display:block;font-style:normal;font-weight:500;font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:.4rem;opacity:.7;font-family:var(--mono)}

/* MARQUEE */
.hero-marquee{position:relative;z-index:2;margin:2rem -2.5rem 0;padding:1.25rem 0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);overflow:hidden;background:var(--cream-pale)}
.marquee-track{display:flex;gap:3.5rem;animation:marquee 40s linear infinite;width:max-content;align-items:center}
.marquee-track span{font-family:var(--display);font-style:italic;font-weight:400;font-size:1.5rem;color:var(--ink);white-space:nowrap;display:inline-flex;align-items:center;gap:3.5rem}
.marquee-track span::after{content:'✦';color:var(--terracotta);font-size:.9rem;font-style:normal}

/* TRUST STRIP */
.trust-strip{background:var(--ink);color:var(--cream);padding:3.5rem 2.5rem;border-bottom:1px solid var(--ink-soft)}
.trust-strip-grid{display:grid;grid-template-columns:1.3fr 3fr;gap:4rem;align-items:center}
.trust-strip h6{font-family:var(--mono);font-size:.72rem;font-weight:400;letter-spacing:.22em;text-transform:uppercase;color:var(--terracotta)}
.trust-strip h6+p{font-family:var(--display);font-weight:300;font-size:1.4rem;line-height:1.3;margin-top:.6rem;letter-spacing:-.01em}
.trust-strip h6+p em{color:var(--terracotta-pale);font-style:italic}
.trust-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;border-left:1px solid var(--rule-light);padding-left:4rem}
.trust-stat-num{font-family:var(--display);font-size:2.6rem;font-weight:300;line-height:1;letter-spacing:-.02em;color:var(--cream)}
.trust-stat-num em{font-style:italic;color:var(--terracotta);font-weight:400}
.trust-stat-label{margin-top:.65rem;font-family:var(--mono);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(242,237,227,.55)}

/* SECTIONS */
.section{padding:7.5rem 2.5rem;position:relative}
.section.dark{background:var(--ink);color:var(--cream)}
.section-header{display:grid;grid-template-columns:1fr 2fr;gap:4rem;align-items:end;margin-bottom:5rem;padding-bottom:2rem;border-bottom:1px solid var(--rule)}
.section.dark .section-header{border-color:var(--rule-light)}
.section-eyebrow{font-family:var(--mono);font-size:.72rem;font-weight:400;letter-spacing:.22em;text-transform:uppercase;color:var(--terracotta);display:flex;align-items:baseline;gap:.7rem}
.section-eyebrow::before{content:counter(section,decimal-leading-zero);font-family:var(--display);font-style:italic;font-weight:400;color:var(--ink);font-size:1.15rem;letter-spacing:0}
.section.dark .section-eyebrow::before{color:var(--cream)}
.section-title{font-family:var(--display);font-weight:300;font-size:clamp(2.2rem,5vw,4.2rem);line-height:1;letter-spacing:-.03em}
.section-title em{font-style:italic;font-weight:300;color:var(--terracotta)}
body{counter-reset:section}
#about,#services,#process,#capabilities,#featured,#why,#team,#clients,#testimonials,#contact{counter-increment:section}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}
.about-text>p:first-child{font-family:var(--display);font-weight:300;font-size:1.65rem;line-height:1.4;color:var(--ink);margin-bottom:2rem;letter-spacing:-.015em}
.about-text>p:first-child::first-letter{font-size:3.4em;float:left;line-height:.8;margin:.1em .12em 0 -.05em;font-style:italic;color:var(--terracotta);font-weight:400}
.about-text p{font-size:1.02rem;line-height:1.7;color:var(--ink-soft);margin-bottom:1.4rem}
.pillars{display:grid;gap:1rem}
.pillar{background:var(--cream-pale);padding:2.2rem 2rem;border-left:3px solid var(--terracotta);transition:transform .5s cubic-bezier(.16,1,.3,1),background .5s;position:relative;overflow:hidden}
.pillar:hover{transform:translateX(8px);background:var(--cream-deep)}
.pillar-tag{display:inline-block;font-family:var(--mono);font-size:.68rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--terracotta);margin-bottom:.85rem}
.pillar h4{font-family:var(--display);font-style:italic;font-weight:400;font-size:1.5rem;margin-bottom:.7rem;letter-spacing:-.01em}
.pillar p{color:var(--ink-soft);font-size:.95rem;line-height:1.6}

/* SERVICES */
#services{background:var(--cream-deep)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--rule);border-left:1px solid var(--rule)}
.service{padding:3rem 2.5rem;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);background:var(--cream-deep);transition:background .5s,color .5s;position:relative;cursor:pointer;overflow:hidden}
.service::before{content:'';position:absolute;top:0;left:0;width:100%;height:0;background:var(--ink);transition:height .5s cubic-bezier(.16,1,.3,1);z-index:0}
.service:hover::before{height:100%}
.service:hover{color:var(--cream)}
.service:hover .service-num,.service:hover .service-arrow{color:var(--terracotta)}
.service:hover .service-desc{color:rgba(242,237,227,.75)}
.service:hover .service-tags li{color:rgba(242,237,227,.5);border-color:rgba(242,237,227,.2)}
.service>*{position:relative;z-index:1}
.service-num{font-family:var(--mono);font-weight:400;font-size:.75rem;letter-spacing:.15em;color:var(--terracotta);margin-bottom:2.2rem;display:block;transition:color .5s}
.service h3{font-family:var(--display);font-weight:400;font-size:1.85rem;line-height:1.1;letter-spacing:-.018em;margin-bottom:1rem}
.service-desc{font-size:.95rem;line-height:1.6;color:var(--ink-soft);margin-bottom:1.5rem;transition:color .5s}
.service-tags{list-style:none;display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:2rem}
.service-tags li{font-family:var(--mono);font-size:.62rem;letter-spacing:.08em;color:var(--ink-mid);border:1px solid var(--rule-strong);padding:.25rem .55rem;transition:all .5s}
.service-arrow{font-family:var(--display);font-style:italic;font-size:1.6rem;color:var(--ink);transition:color .5s,transform .5s;display:inline-block}
.service:hover .service-arrow{transform:translate(8px,-8px)}

/* PROCESS */
#process{background:var(--ink);color:var(--cream)}
.process-intro{max-width:720px;font-family:var(--display);font-weight:300;font-size:1.5rem;line-height:1.4;color:rgba(242,237,227,.75);margin-bottom:5rem;letter-spacing:-.01em}
.process-intro em{font-style:italic;color:var(--terracotta)}
.process-track{position:relative;display:grid;grid-template-columns:repeat(5,1fr);gap:0}
.process-track::before{content:'';position:absolute;top:22px;left:22px;right:22px;height:1px;background:var(--rule-light)}
.process-step{position:relative;padding-right:1.5rem}
.process-dot{width:44px;height:44px;border-radius:50%;background:var(--ink);border:1px solid var(--rule-light);display:grid;place-items:center;font-family:var(--mono);font-size:.72rem;color:var(--cream);margin-bottom:1.5rem;position:relative;z-index:2;transition:all .4s}
.process-step:hover .process-dot{background:var(--terracotta);border-color:var(--terracotta);transform:scale(1.1)}
.process-step h4{font-family:var(--display);font-weight:500;font-size:1.4rem;margin-bottom:.7rem;letter-spacing:-.01em}
.process-step p{font-size:.92rem;line-height:1.55;color:rgba(242,237,227,.65)}
.process-step-tag{font-family:var(--mono);font-size:.62rem;color:var(--terracotta);letter-spacing:.18em;text-transform:uppercase;margin-top:1rem;display:block}

/* CAPABILITIES */
.cap-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.cap-card{background:var(--cream-pale);border:1px solid var(--rule);padding:2rem 1.75rem;transition:all .4s;position:relative;overflow:hidden}
.cap-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--terracotta);transform:scaleX(0);transform-origin:left;transition:transform .5s cubic-bezier(.16,1,.3,1)}
.cap-card:hover::before{transform:scaleX(1)}
.cap-card:hover{background:var(--cream-deep);transform:translateY(-4px)}
.cap-icon{width:40px;height:40px;border:1px solid var(--rule-strong);display:grid;place-items:center;margin-bottom:1.5rem;font-family:var(--display);font-style:italic;font-size:1.2rem;color:var(--terracotta)}
.cap-card h4{font-family:var(--display);font-weight:500;font-size:1.2rem;margin-bottom:.7rem;letter-spacing:-.005em}
.cap-card-tag{font-family:var(--mono);font-size:.62rem;color:var(--terracotta);letter-spacing:.18em;text-transform:uppercase;margin-bottom:.6rem;display:block}
.cap-card p{font-size:.86rem;line-height:1.55;color:var(--ink-soft)}

/* PROJECTS GRID */
#featured{background:var(--ink);color:var(--cream);padding:7.5rem 2.5rem}
#featured .section-header{border-color:var(--rule-light);margin-bottom:4rem}
#featured .section-eyebrow::before{color:var(--cream)}
.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:4rem}
.project-card{background:var(--ink-soft);border:1px solid var(--rule-light);overflow:hidden;transition:transform .5s cubic-bezier(.16,1,.3,1),border-color .4s}
.project-card:hover{transform:translateY(-6px);border-color:rgba(242,237,227,.28)}
.project-img{aspect-ratio:4/3;overflow:hidden;position:relative}
.project-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .7s cubic-bezier(.16,1,.3,1);filter:brightness(.82) saturate(.75)}
.project-card:hover .project-img img{transform:scale(1.05);filter:brightness(.95) saturate(1)}
.project-body{padding:1.75rem}
.project-cat{font-family:var(--mono);font-size:.68rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--terracotta);margin-bottom:.6rem;display:inline-flex;align-items:center;gap:.5rem}
.project-cat::before{content:'';width:20px;height:1px;background:var(--terracotta);flex-shrink:0}
.project-name{font-family:var(--display);font-weight:500;font-size:1.2rem;line-height:1.2;letter-spacing:-.01em;margin-bottom:.5rem;color:var(--cream)}
.project-location{font-family:var(--mono);font-size:.63rem;letter-spacing:.1em;color:rgba(242,237,227,.4);margin-bottom:.85rem;text-transform:uppercase}
.project-desc{font-size:.88rem;line-height:1.55;color:rgba(242,237,227,.65);margin-bottom:1.2rem}
.project-tags{list-style:none;display:flex;flex-wrap:wrap;gap:.4rem}
.project-tags li{font-family:var(--mono);font-size:.6rem;letter-spacing:.07em;color:rgba(242,237,227,.5);border:1px solid var(--rule-light);padding:.2rem .55rem}
.projects-cta{text-align:center}

/* WHY */
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border-left:1px solid var(--rule);border-top:1px solid var(--rule)}
.why-item{padding:3rem 2.5rem;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);display:grid;grid-template-columns:60px 1fr;gap:2rem;align-items:start;transition:background .4s}
.why-item:hover{background:var(--cream-pale)}
.why-num{font-family:var(--display);font-weight:300;font-style:italic;font-size:2.5rem;color:var(--terracotta);line-height:1}
.why-item h4{font-family:var(--display);font-weight:500;font-size:1.5rem;margin-bottom:.7rem;letter-spacing:-.015em}
.why-item p{color:var(--ink-soft);line-height:1.6;font-size:.98rem}

/* TEAM */
#team{background:var(--cream-deep)}
.team-intro{max-width:780px;font-family:var(--display);font-weight:300;font-size:1.55rem;line-height:1.4;color:var(--ink-soft);margin-bottom:4rem;letter-spacing:-.01em}
.team-intro em{font-style:italic;color:var(--terracotta)}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}
.team-card{background:var(--cream-pale);padding:2.2rem;transition:all .5s cubic-bezier(.16,1,.3,1);position:relative;border:1px solid var(--rule);overflow:hidden;cursor:pointer}
.team-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:0;background:var(--ink);transition:height .5s cubic-bezier(.16,1,.3,1);z-index:0}
.team-card:hover::before{height:100%}
.team-card:hover{color:var(--cream)}
.team-card:hover .team-role{color:var(--terracotta)}
.team-card:hover .team-bio{color:rgba(242,237,227,.7)}
.team-card>*{position:relative;z-index:1}
.team-avatar{width:72px;height:72px;border-radius:50%;overflow:hidden;border:2px solid var(--rule);margin-bottom:1.5rem;transition:border-color .4s}
.team-avatar img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;filter:grayscale(15%);transition:filter .5s}
.team-card:hover .team-avatar{border-color:var(--terracotta)}
.team-card:hover .team-avatar img{filter:grayscale(0%)}
.team-card h4{font-family:var(--display);font-weight:500;font-size:1.25rem;letter-spacing:-.01em;margin-bottom:.3rem}
.team-role{font-family:var(--mono);font-size:.68rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--terracotta);margin-bottom:1rem;transition:color .4s}
.team-bio{font-size:.88rem;line-height:1.55;color:var(--ink-soft);margin-bottom:1.2rem;transition:color .4s}
.team-card-cta{font-family:var(--mono);font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--terracotta);transition:color .4s}
.team-card:hover .team-card-cta{color:rgba(242,237,227,.65)}

/* CV MODAL */
.cv-modal{position:fixed;inset:0;z-index:500;display:flex;align-items:center;justify-content:center;padding:2rem}
.cv-modal[hidden]{display:none}
.cv-modal-backdrop{position:absolute;inset:0;background:rgba(22,20,18,.88);cursor:pointer;border:none;width:100%;height:100%;padding:0}
.cv-modal-box{position:relative;z-index:1;background:var(--ink);color:var(--cream);max-width:860px;width:100%;max-height:88vh;overflow-y:auto;border:1px solid var(--rule-light);animation:modalIn .35s cubic-bezier(.16,1,.3,1)}
.cv-modal-close{position:absolute;top:1.25rem;right:1.25rem;background:none;border:1px solid var(--rule-light);color:var(--cream);width:36px;height:36px;cursor:pointer;font-size:1rem;display:grid;place-items:center;transition:all .3s;z-index:2;font-family:var(--body);line-height:1}
.cv-modal-close:hover{background:var(--terracotta);border-color:var(--terracotta)}
.cv-modal-inner{display:grid;grid-template-columns:260px 1fr}
.cv-photo{overflow:hidden;background:var(--ink-soft)}
.cv-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;min-height:400px}
.cv-content{padding:2.5rem 2.5rem 2.5rem 2rem}
.cv-tag{font-family:var(--mono);font-size:.68rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--terracotta);margin-bottom:.6rem;display:inline-flex;align-items:center;gap:.5rem}
.cv-tag::before{content:'';width:20px;height:1px;background:var(--terracotta)}
.cv-name{font-family:var(--display);font-weight:300;font-size:2rem;letter-spacing:-.025em;line-height:1;margin-bottom:.4rem}
.cv-role-title{font-family:var(--mono);font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(242,237,227,.5);margin-bottom:1.5rem}
.cv-bio{font-size:.95rem;line-height:1.65;color:rgba(242,237,227,.8);margin-bottom:1.75rem;padding-bottom:1.75rem;border-bottom:1px solid var(--rule-light)}
.cv-details-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}
.cv-label{font-family:var(--mono);font-size:.63rem;letter-spacing:.18em;text-transform:uppercase;color:var(--terracotta);margin-bottom:.65rem;display:block}
.cv-content ul{list-style:none;padding:0;margin:0 0 .5rem}
.cv-content ul li{font-size:.88rem;color:rgba(242,237,227,.7);line-height:1.5;margin-bottom:.35rem;padding-left:1.1rem;position:relative}
.cv-content ul li::before{content:'—';position:absolute;left:0;color:var(--terracotta)}
@keyframes modalIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

/* CLIENTS */
.clients-row{display:grid;grid-template-columns:repeat(6,1fr);border-top:1px solid var(--rule);border-left:1px solid var(--rule)}
.client{aspect-ratio:3/2;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);display:grid;place-items:center;padding:1.5rem;transition:background .4s;text-align:center}
.client:hover{background:var(--cream-pale)}
.client span{font-family:var(--display);font-weight:400;font-style:italic;font-size:1.1rem;color:var(--ink-mid);letter-spacing:-.005em;line-height:1.2;transition:color .4s}
.client:hover span{color:var(--terracotta)}

/* TESTIMONIALS */
#testimonials{background:var(--ink);color:var(--cream);padding-top:7.5rem;padding-bottom:7.5rem}
#testimonials .section-eyebrow::before{color:var(--cream)}
.testimonial-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}
.testimonial{background:var(--ink-soft);padding:3rem;position:relative;border:1px solid var(--rule-light)}
.testimonial::before{content:'\201C';position:absolute;top:-1rem;left:1.5rem;font-family:var(--display);font-size:6rem;line-height:1;color:var(--terracotta);font-style:italic}
.testimonial blockquote{font-family:var(--display);font-weight:300;font-size:1.4rem;line-height:1.45;letter-spacing:-.01em;color:var(--cream);margin-bottom:2rem;margin-top:1rem}
.testimonial blockquote em{font-style:italic;color:var(--terracotta-pale)}
.testimonial-author{display:flex;align-items:center;gap:1rem;padding-top:1.5rem;border-top:1px solid var(--rule-light)}
.testimonial-avatar{width:48px;height:48px;background:var(--terracotta);color:var(--cream);display:grid;place-items:center;font-family:var(--display);font-style:italic;font-size:1.1rem;border-radius:50%}
.testimonial-name{font-weight:600;font-size:.95rem;color:var(--cream)}
.testimonial-role{font-family:var(--mono);font-size:.68rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(242,237,227,.55);margin-top:.2rem}

/* CONTACT */
#contact{background:var(--cream-pale);padding-bottom:5rem}
.contact-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:5rem;align-items:start}
.contact-info h3{font-family:var(--display);font-weight:300;font-size:2.2rem;line-height:1.15;letter-spacing:-.025em;margin-bottom:2.5rem}
.contact-info h3 em{font-style:italic;color:var(--terracotta)}
.contact-detail{padding:1.5rem 0;border-bottom:1px solid var(--rule)}
.contact-detail:first-of-type{border-top:1px solid var(--rule)}
.contact-detail-label{font-family:var(--mono);font-size:.68rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--terracotta);margin-bottom:.5rem}
.contact-detail a,.contact-detail p{font-family:var(--display);font-weight:400;font-size:1.25rem;color:var(--ink);text-decoration:none;line-height:1.4;transition:color .3s;display:block}
.contact-detail a:hover{color:var(--terracotta)}
.contact-form{background:var(--cream);padding:3rem;border:1px solid var(--rule);position:relative}
.contact-form::before{content:'';position:absolute;top:0;left:0;width:60px;height:3px;background:var(--terracotta)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:1.25rem}
.form-group{margin-bottom:1.25rem}
.form-group label{display:block;font-family:var(--mono);font-size:.68rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:.6rem}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:.85rem 0;background:transparent;border:none;border-bottom:1px solid var(--rule-strong);font-family:var(--body);font-size:1rem;color:var(--ink);transition:border-color .3s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-bottom-color:var(--terracotta)}
.form-group textarea{resize:vertical;min-height:100px}
.contact-form .btn{width:100%;justify-content:center;margin-top:1rem}

/* FOOTER */
.footer{background:var(--ink);color:var(--cream);padding:6rem 2.5rem 2rem;position:relative}
.footer-cta{padding-bottom:5rem;margin-bottom:5rem;border-bottom:1px solid var(--rule-light)}
.footer-cta h2{font-family:var(--display);font-weight:300;font-size:clamp(2.5rem,6vw,5rem);line-height:1;letter-spacing:-.035em;color:var(--cream);max-width:900px}
.footer-cta h2 em{font-style:italic;color:var(--terracotta)}
.footer-cta-row{margin-top:3rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:2rem}
.footer-cta .btn{background:var(--terracotta);color:var(--cream)}
.footer-cta .btn::before{background:var(--cream)}
.footer-cta .btn:hover{color:var(--ink)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;padding-bottom:4rem;border-bottom:1px solid var(--rule-light)}
.footer-brand .logo{color:var(--cream);margin-bottom:1.8rem}
.footer-brand .logo-mark{background:var(--terracotta);color:var(--cream)}
.footer-brand .logo-text small{color:rgba(242,237,227,.55)}
.footer-brand p{font-family:var(--display);font-weight:300;font-size:1.15rem;line-height:1.5;color:rgba(242,237,227,.75);max-width:380px}
.footer-col h5{font-family:var(--mono);font-size:.68rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--terracotta);margin-bottom:1.5rem}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:.7rem}
.footer-col a{color:rgba(242,237,227,.7);text-decoration:none;font-size:.93rem;transition:color .3s}
.footer-col a:hover{color:var(--terracotta)}
.footer-bottom{padding-top:2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;font-family:var(--mono);font-size:.72rem;letter-spacing:.05em;color:rgba(242,237,227,.5)}
.footer-bottom a{color:rgba(242,237,227,.5);text-decoration:none;margin-left:1.5rem;transition:color .3s}
.footer-bottom a:hover{color:var(--terracotta)}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes lineUp{from{transform:translateY(110%)}to{transform:translateY(0)}}
@keyframes strikeIn{from{transform:scaleX(0)}to{transform:scaleX(1)}}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.reveal{opacity:0;transform:translateY(28px);transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1s cubic-bezier(.16,1,.3,1)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* RESPONSIVE */
@media (max-width:1100px){
.hero-content{grid-template-columns:1fr;gap:2rem}
.hero-visual,.hero::before,.hero-meta,.section-counter{display:none}
.section-header{grid-template-columns:1fr;gap:1.5rem}
.about-grid,.contact-grid{grid-template-columns:1fr;gap:3rem}
.services-grid{grid-template-columns:repeat(2,1fr)}
.trust-stats{grid-template-columns:repeat(2,1fr);padding-left:0;border-left:none;padding-top:2rem;border-top:1px solid var(--rule-light)}
.trust-strip-grid{grid-template-columns:1fr;gap:2rem}
.process-track{grid-template-columns:1fr 1fr;gap:2rem 1.5rem}
.process-track::before{display:none}
.cap-grid{grid-template-columns:repeat(2,1fr)}
.projects-grid{grid-template-columns:repeat(2,1fr)}
.why-grid{grid-template-columns:1fr}
.team-grid{grid-template-columns:repeat(2,1fr)}
.cv-modal-inner{grid-template-columns:200px 1fr}
.clients-row{grid-template-columns:repeat(3,1fr)}
.testimonial-grid{grid-template-columns:1fr}
.footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
.nav{padding:1rem 1.25rem}
.nav-links,.nav-cta{display:none}
.menu-toggle{display:flex;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.hero{padding:6rem 1.25rem 2rem;min-height:auto}
.hero-marquee{margin:2rem -1.25rem 0}
.marquee-track span{font-size:1.15rem;gap:2.5rem}
.marquee-track{gap:2.5rem}
.section{padding:4.5rem 1.25rem}
.trust-strip{padding:3rem 1.25rem}
.trust-stat-num{font-size:2rem}
.services-grid,.cap-grid,.team-grid,.footer-grid{grid-template-columns:1fr}
.cv-modal{padding:.75rem}
.cv-modal-inner{grid-template-columns:1fr}
.cv-photo img{min-height:260px;max-height:280px}
.cv-content{padding:1.5rem}
.cv-details-grid{grid-template-columns:1fr}
.process-track{grid-template-columns:1fr;gap:2.5rem}
.projects-grid{grid-template-columns:1fr}
.why-item{padding:2rem 1.5rem;gap:1rem;grid-template-columns:40px 1fr}
.why-num{font-size:1.8rem}
.clients-row{grid-template-columns:repeat(2,1fr)}
.testimonial{padding:2rem 1.5rem}
.testimonial blockquote{font-size:1.15rem}
.footer{padding:3rem 1.25rem 2rem}
.footer-cta{padding-bottom:3rem;margin-bottom:3rem}
.form-row{grid-template-columns:1fr}
.contact-form{padding:2rem 1.5rem}
.footer-bottom{flex-direction:column;align-items:flex-start}
.footer-bottom>div{display:flex;flex-wrap:wrap;gap:.5rem}
.footer-bottom a{margin-left:0;margin-right:1rem}
.about-text>p:first-child{font-size:1.3rem}
.about-text>p:first-child::first-letter{font-size:2.8em}
}
