@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;600;700&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,700&display=swap');
:root{--ink:#12345e;--paper:#f5f4ee;--grid:#d4cfc0;--accent:#e89a1e;--teal:#1d5e7a;--blue:#0d2a4a;--highlight:#f0a030;--mono:'JetBrains Mono',monospace;--sans:'DM Sans',sans-serif}
*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--paper);color:var(--ink);line-height:1.65;overflow-x:hidden}
body::before{content:'';position:fixed;inset:0;z-index:-1;background-image:linear-gradient(var(--grid) 1px,transparent 1px),linear-gradient(90deg,var(--grid) 1px,transparent 1px);background-size:24px 24px;opacity:.35}
.container{max-width:1200px;margin:0 auto;padding:0 2rem}
.label{font-family:var(--mono);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--teal);display:inline-block;border:1px solid var(--teal);padding:.15rem .5rem;border-radius:2px}
header{position:sticky;top:0;z-index:100;background:var(--paper);border-bottom:2px solid var(--ink);padding:.75rem 0}
header::after{content:'';position:absolute;bottom:-5px;left:0;right:0;height:1px;background:var(--ink);opacity:.3}
.header-inner{display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:.75rem;text-decoration:none;color:var(--ink)}
.brand img{height:42px}
nav{display:flex;gap:.25rem;align-items:center}
nav a{font-family:var(--mono);font-size:.8rem;text-decoration:none;color:var(--ink);padding:.35rem .75rem;border-radius:3px;transition:all .2s}
nav a:hover{background:var(--ink);color:var(--paper)}
nav a.cta{background:var(--accent);color:#fff;font-weight:600}nav a.cta:hover{background:#c78510}
.hero{padding:6rem 0 5rem}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.hero h1{font-family:var(--sans);font-size:clamp(2.8rem,5vw,4.2rem);font-weight:700;line-height:1.05;letter-spacing:-.03em;margin-bottom:1.5rem}
.hero h1 .accent{color:var(--accent)}
.hero p{font-size:1.15rem;color:#4a4a4a;max-width:440px;margin-bottom:2rem}
.hero-btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--mono);font-size:.85rem;font-weight:600;padding:.75rem 1.5rem;background:var(--ink);color:var(--paper);text-decoration:none;border:2px solid var(--ink);transition:all .25s}
.hero-btn:hover{background:transparent;color:var(--ink)}.hero-btn .arrow{transition:transform .25s}.hero-btn:hover .arrow{transform:translateX(4px)}
.hero-diagram{position:relative;aspect-ratio:1;max-width:420px;justify-self:center}.hero-diagram svg{width:100%;height:100%}
.section{padding:5rem 0}.section-header{margin-bottom:3rem}
.section-header h2{font-family:var(--sans);font-size:clamp(2rem,3.5vw,2.8rem);font-weight:700;letter-spacing:-.02em;margin-top:.5rem}
.section-header h2 .num{font-family:var(--mono);font-size:.6em;color:var(--accent);vertical-align:super;margin-right:.25rem}
.divider{height:2px;background:var(--ink);margin:0 0 5rem;position:relative}
.divider::after{content:'\25CF';position:absolute;right:0;top:-8px;color:var(--accent);font-size:1rem}
.about-grid{display:grid;grid-template-columns:200px 1fr;gap:3rem;align-items:start}
.about-photo-wrap{position:relative}.about-photo-wrap img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:4px;filter:grayscale(30%);border:2px solid var(--ink)}
.about-photo-wrap::after{content:'';position:absolute;inset:6px -6px -6px 6px;border:2px solid var(--accent);border-radius:4px;z-index:-1}
.about-content p{font-size:1.05rem;margin-bottom:1rem;max-width:600px}
.about-links{display:flex;gap:1rem;margin-top:1.5rem}
.about-links a{font-family:var(--mono);font-size:.8rem;color:var(--teal);text-decoration:none;border-bottom:1px dashed var(--teal);padding-bottom:2px;transition:color .2s}
.about-links a:hover{color:var(--accent);border-color:var(--accent)}
.services-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem}
.service-card{background:#fff;border:1.5px solid var(--ink);padding:1.75rem;position:relative;transition:transform .2s,box-shadow .2s}
.service-card:hover{transform:translateY(-3px);box-shadow:4px 4px 0 var(--ink)}
.service-card .service-num{font-family:var(--mono);font-size:2rem;font-weight:700;color:var(--accent);opacity:.3;position:absolute;top:.75rem;right:1rem}
.service-card h3{font-family:var(--mono);font-size:.95rem;font-weight:700;margin-bottom:.75rem;padding-right:2rem}
.service-card p{font-size:.9rem;color:#555;line-height:1.6}
.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.25rem}
.portfolio-card{background:#fff;border:1.5px solid var(--ink);display:grid;grid-template-rows:auto 1fr auto;transition:transform .2s,box-shadow .2s;overflow:hidden}
.portfolio-card:hover{transform:translateY(-3px);box-shadow:5px 5px 0 var(--ink)}
.portfolio-card-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.25rem .75rem;border-bottom:1px solid #eee}
.portfolio-card-header h3{font-family:var(--mono);font-size:.85rem;font-weight:700}
.portfolio-card-header h3 a{color:var(--ink);text-decoration:none;border-bottom:1.5px solid var(--accent);transition:color .2s}
.portfolio-card-header h3 a:hover{color:var(--accent)}
.portfolio-card-header img{max-height:32px;max-width:80px;object-fit:contain;filter:grayscale(100%);opacity:.6;transition:all .3s}
.portfolio-card:hover .portfolio-card-header img{filter:grayscale(0%);opacity:1}
.portfolio-card-body{padding:1rem 1.25rem}.portfolio-card-body p{font-size:.88rem;color:#555;line-height:1.55}
.portfolio-card-footer{padding:.75rem 1.25rem;background:#faf9f2;border-top:1px solid #eee;display:flex;flex-wrap:wrap;gap:.5rem}
.person-tag{font-family:var(--mono);font-size:.7rem;background:var(--paper);border:1px solid var(--grid);padding:.15rem .45rem;border-radius:2px;text-decoration:none;color:var(--ink);transition:all .2s}
.person-tag:hover{border-color:var(--teal);color:var(--teal)}
.contact-box{background:var(--ink);color:var(--paper);padding:3.5rem;position:relative;overflow:hidden}
.contact-box::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:24px 24px}
.contact-box h2{font-size:2rem;margin-bottom:1.5rem;position:relative}
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;position:relative}
.contact-item .contact-label{font-family:var(--mono);font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--highlight);margin-bottom:.35rem}
.contact-item p,.contact-item a{font-size:.95rem;color:var(--paper)}
.contact-item a{text-decoration:none;border-bottom:1px solid rgba(255,255,255,.3);transition:border-color .2s}
.contact-item a:hover{border-color:var(--highlight)}
.careers-roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.25rem}
.role-card{display:block;background:#fff;border:1.5px solid var(--ink);padding:1.75rem;text-decoration:none;color:var(--ink);transition:transform .2s,box-shadow .2s;position:relative}
.role-card:hover{transform:translateY(-3px);box-shadow:4px 4px 0 var(--ink)}
.role-type{font-family:var(--mono);font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;color:var(--teal);border:1px solid var(--teal);padding:.1rem .4rem;border-radius:2px;display:inline-block;margin-bottom:.75rem}
.role-card h3{font-family:var(--mono);font-size:.95rem;font-weight:700;margin-bottom:.75rem}
.role-card p{font-size:.9rem;color:#555;line-height:1.6;margin-bottom:1rem}
.role-link{font-family:var(--mono);font-size:.8rem;color:var(--accent);font-weight:600}
.role-card:hover .role-link{text-decoration:underline}
.careers-empty{font-size:.95rem;color:#777;font-style:italic;padding:1.5rem 0}
.careers-callout{background:var(--ink);padding:2.5rem 3rem;position:relative;overflow:hidden}.careers-callout::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:24px 24px}.careers-callout-inner{display:flex;align-items:center;justify-content:space-between;gap:2rem;position:relative;flex-wrap:wrap}.careers-callout p strong{color:var(--paper)}.careers-btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--mono);font-size:.85rem;font-weight:600;padding:.75rem 1.5rem;background:var(--accent);color:#fff;text-decoration:none;border:2px solid var(--accent);white-space:nowrap;transition:all .25s;flex-shrink:0}.careers-btn:hover{background:transparent;color:var(--accent)}.careers-btn .arrow{transition:transform .25s}.careers-btn:hover .arrow{transform:translateX(4px)}@media(max-width:768px){.careers-callout{padding:1.75rem}.careers-callout-inner{flex-direction:column;align-items:flex-start}}
footer{text-align:center;padding:2rem 0;font-family:var(--mono);font-size:.75rem;color:#888;border-top:1px solid var(--grid)}
@media(max-width:768px){.hero-grid{grid-template-columns:1fr;gap:2rem}.hero-diagram{max-width:280px}.about-grid{grid-template-columns:140px 1fr;gap:1.5rem}.portfolio-grid{grid-template-columns:1fr}.contact-box{padding:2rem}nav{gap:0}nav a{font-size:.7rem;padding:.3rem .5rem}}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.animate-in{animation:fadeUp .6s ease forwards;opacity:0}.delay-1{animation-delay:.1s}.delay-2{animation-delay:.2s}.delay-3{animation-delay:.3s}
@keyframes dash{to{stroke-dashoffset:0}}
.draw-line{stroke-dasharray:1000;stroke-dashoffset:1000;animation:dash 2s ease forwards}
.draw-line.d2{animation-delay:.3s}.draw-line.d3{animation-delay:.6s}.draw-line.d4{animation-delay:.9s}
@keyframes pulse-dot{0%,100%{r:4;opacity:.8}50%{r:6;opacity:1}}.pulse-dot{animation:pulse-dot 2s ease-in-out infinite}
