@import "https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&display=swap";:root{--bg:#fff;--bg-light:#f9f9f9;--ink:#1c1510;--ink-muted:#8a8a8a;--accent:#d63d47;--accent-secondary:#2d7a9f;--accent-tertiary:gold;--accent-hover:#a83347;--border:#e5e5e5;--sans:"DM Sans", system-ui, sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;margin:0;padding:0;font-size:16px;font-weight:400;line-height:1.6;overflow-x:hidden}.page-transition{animation:.4s ease-out fadeIn}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}h1,h2,h3,h4,h5,h6{margin:0;font-weight:700}p{margin:0}a{color:inherit;text-decoration:none}.visually-hidden{clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (prefers-reduced-motion:reduce){*{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}main{flex:1;margin-top:70px}section{max-width:1000px;margin:0 auto;padding:5rem 2.5rem}footer{background:var(--bg-light);border-top:1px solid var(--border);text-align:center;color:var(--ink-muted);padding:3rem 2.5rem;font-size:.875rem}nav{z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);background:#fffffff2;position:fixed;top:0;left:0;right:0}.nav-container{justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;padding:1.25rem 2.5rem;display:flex}.nav-logo{color:var(--ink);letter-spacing:.02em;cursor:pointer;font-size:1rem;font-weight:600;text-decoration:none;transition:opacity .2s}.nav-logo:hover{opacity:.7}.nav-links{gap:2.5rem;margin:0;padding:0;list-style:none;display:flex}.nav-links a{color:var(--ink-muted);letter-spacing:.04em;text-transform:uppercase;font-size:.875rem;font-weight:500;text-decoration:none;transition:color .2s}.nav-links a:hover{color:var(--accent)}.nav-links a.active{color:var(--accent);font-weight:600}.breadcrumb{color:var(--ink-muted);letter-spacing:.06em;text-transform:uppercase;margin-top:.5rem;font-size:.75rem;display:none}.breadcrumb.visible{display:block}.breadcrumb a{color:var(--accent);text-decoration:none}@media (width<=768px){.nav-container{padding:1rem 1.5rem}.nav-links{display:none}}footer{background:var(--bg-light);border-top:1px solid var(--border);text-align:center;color:var(--ink-muted);margin-top:auto;padding:3rem 2.5rem;font-size:.875rem}footer p{max-width:1000px;margin:0 auto}@media (width<=768px){footer{padding:2rem 1.5rem}}.case-studies-grid-section{background:var(--bg);width:100%;padding:5rem 0 7rem;max-width:none!important}.case-studies-header{margin:0 auto 2rem;padding:0 2.5rem;max-width:none!important}.case-studies-header h2{color:var(--ink);font-size:clamp(2.2rem,6vw,3rem);font-weight:700;line-height:1.2}.case-studies-grid-wrapper{justify-content:center;width:100%;padding:0 2.5rem;display:flex;max-width:none!important}.case-studies-grid-container{grid-template-columns:repeat(3,1fr);gap:2rem;width:100%;display:grid;max-width:none!important}.case-studies-grid-container>:nth-child(4){grid-column:1/2}.case-studies-grid-container>:nth-child(5){grid-column:2/3}.case-study-grid-card{background:var(--bg);border:2px solid var(--border);cursor:pointer;border-radius:12px;flex-direction:column;gap:1.25rem;padding:2.5rem;transition:all .3s;display:flex}.case-study-grid-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 8px 24px #d63d4714}.grid-card-header{flex-direction:column;gap:.5rem;display:flex}.grid-card-header h3{color:var(--ink);margin:0;font-size:1.3rem;font-weight:700;line-height:1.3}.grid-card-category{letter-spacing:.1em;text-transform:uppercase;color:var(--accent);align-self:flex-start;font-size:.8rem;font-weight:700}.grid-card-description{color:var(--ink-muted);flex-grow:1;margin:0;font-size:1.05rem;line-height:1.6}.grid-card-meta{border-top:1px solid var(--border);flex-direction:column;gap:.75rem;padding-top:1rem;display:flex}.grid-card-meta .meta-item{flex-direction:column;gap:.25rem;display:flex}.grid-card-meta .meta-label{text-transform:uppercase;letter-spacing:.05em;color:var(--ink-muted);font-size:.8rem;font-weight:600}.grid-card-meta .meta-value{color:var(--ink-muted);font-size:1rem;line-height:1.5}.grid-card-cta{color:var(--accent);margin-top:.5rem;font-size:1rem;font-weight:600;transition:color .2s}.case-study-grid-card:hover .grid-card-cta{color:var(--accent-hover)}@media (width<=1024px){.case-studies-grid-container{grid-template-columns:repeat(2,1fr)}.case-studies-grid-container>:nth-child(4){grid-column:1/2}.case-studies-grid-container>:nth-child(5){grid-column:2/3}}@media (width<=768px){.case-studies-grid-section{padding:3rem 1.5rem 4rem}.case-studies-grid-wrapper{padding:0 1.5rem}.case-studies-grid-container{grid-template-columns:1fr;gap:1.5rem}.case-study-grid-card{padding:1.5rem}.grid-card-header h3{font-size:1.15rem}.case-studies-grid-container>:nth-child(4),.case-studies-grid-container>:nth-child(5){grid-column:1}}.other-work-carousel-section{background:var(--bg-light);border-top:1px solid var(--border);padding:4rem 2.5rem 6rem;position:relative;width:100vw!important;max-width:none!important;margin-left:calc(50% - 50vw)!important;margin-right:0!important}.other-work-carousel-section:before,.other-work-carousel-section:after{content:"";pointer-events:none;z-index:5;width:200px;height:100%;position:absolute;top:0}.other-work-carousel-section:before{background:linear-gradient(90deg,#f9f9f9,#f9f9f900);left:0}.other-work-carousel-section:after{background:linear-gradient(270deg,#f9f9f9,#f9f9f900);right:0}.carousel-header{z-index:1;max-width:1400px;margin:0 auto 2rem;padding:0 2.5rem;position:relative}.carousel-header h2{color:var(--ink);margin-bottom:.5rem;font-size:clamp(2rem,5vw,2.5rem);font-weight:700;line-height:1.2}.carousel-header p{color:var(--ink-muted);max-width:600px;font-size:1rem;line-height:1.6}.carousel-container{z-index:2;align-items:center;max-width:100%;margin:0;padding:0 2.5rem;display:flex;position:relative}.carousel-scroll-wrapper{scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex:1;overflow:auto hidden}.carousel-scroll-wrapper::-webkit-scrollbar{display:none}.carousel-grid{gap:1.5rem;min-width:min-content;padding:1rem 0;display:flex}.carousel-card{background:var(--bg);border:1px solid var(--border);border-radius:8px;flex-direction:column;flex-shrink:0;gap:1rem;width:360px;padding:2rem;transition:all .3s;display:flex}.carousel-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 8px 24px #d63d4714}.card-top{flex-direction:column;gap:.5rem;display:flex}.card-badges{flex-wrap:wrap;align-items:flex-start;gap:.5rem;display:flex}.card-top h3{color:var(--ink);margin:0;font-size:1.1rem;font-weight:700;line-height:1.3}.work-type-badge{background:var(--accent);color:#fff;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;border-radius:4px;padding:.35rem .75rem;font-size:.7rem;font-weight:600;display:inline-block}.work-tag-badge{background:var(--ink-muted);color:#fff;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;border-radius:4px;padding:.35rem .75rem;font-size:.7rem;font-weight:600;display:inline-block}.card-description{color:var(--ink-muted);flex-grow:1;margin:0;font-size:.9rem;line-height:1.6}.carousel-card .meta-label{color:#999}.card-footer{flex-direction:column;gap:1rem;padding-top:1rem;display:flex}.meta{flex-direction:column;gap:.75rem;display:flex}.meta-item{flex-direction:column;gap:.25rem;display:flex}.meta-label{text-transform:uppercase;letter-spacing:.05em;color:var(--ink);font-size:.7rem;font-weight:600}.meta-value{color:var(--ink-muted);font-size:.85rem;line-height:1.5}.card-link{color:var(--accent);align-self:flex-start;font-size:.85rem;font-weight:600;text-decoration:none;transition:color .2s}.card-link:hover{color:var(--accent-hover)}@media (width<=768px){.other-work-carousel-section{padding:3rem 1.5rem 4rem}.carousel-header,.carousel-container{padding:0 1.5rem}.carousel-card{width:320px;padding:1.5rem}.card-top h3{font-size:1rem}}.speaking-grid-section{background:var(--bg);border-top:1px solid var(--border);padding:4rem 2.5rem 6rem}.speaking-grid-header{max-width:1400px;margin:0 auto 3rem}.speaking-grid-header h2{color:var(--ink);margin-bottom:.5rem;font-size:clamp(2rem,5vw,2.5rem);font-weight:700;line-height:1.2}.speaking-grid-header p{color:var(--ink-muted);max-width:600px;font-size:1rem;line-height:1.6}.speaking-grid-container{grid-template-columns:repeat(3,1fr);gap:2rem;max-width:1400px;margin:0 auto;display:grid}.speaking-grid-card{background:var(--bg-light);border:1px solid var(--border);cursor:default;border-radius:8px;flex-direction:column;gap:.75rem;padding:1.5rem;transition:all .3s;display:flex}.speaking-grid-card:hover{border-color:var(--accent-secondary);transform:translateY(-4px);box-shadow:0 8px 24px #2d7a9f14}.talk-header{flex-wrap:wrap;align-items:center;gap:1rem;display:flex}.talk-type-badge{background:var(--accent-secondary);color:#fff;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;border-radius:4px;padding:.35rem .75rem;font-size:.7rem;font-weight:600;display:inline-block}.talk-date{color:var(--ink-muted);letter-spacing:.05em;font-size:.85rem;font-weight:500}.talk-title{color:var(--ink);margin:0;font-size:1rem;font-weight:700;line-height:1.2}.talk-description{color:var(--ink-muted);flex-grow:1;margin:0;font-size:.85rem;line-height:1.5}.talk-meta{border-top:1px solid var(--border);flex-direction:column;gap:.25rem;padding-top:.75rem;display:flex}.talk-meta .meta-label{text-transform:uppercase;letter-spacing:.05em;color:var(--ink);font-size:.65rem;font-weight:600}.talk-meta .meta-value{color:var(--ink-muted);font-size:.85rem;line-height:1.4}.talk-card-link{color:var(--accent-secondary);align-self:flex-start;font-size:.85rem;font-weight:600;text-decoration:none;transition:color .2s}.talk-card-link:hover{color:var(--accent)}@media (width<=768px){.speaking-grid-section{padding:3rem 1.5rem 4rem}.speaking-grid-container{grid-template-columns:1fr;gap:1.5rem}.speaking-grid-card{padding:1.5rem}.talk-title{font-size:1rem}}.hero{text-align:left;flex-direction:column;justify-content:center;min-height:calc(100vh - 70px);padding:3rem 2.5rem;display:flex}.hero h1{letter-spacing:-.03em;max-width:90%;margin-bottom:2rem;font-size:clamp(3rem,10vw,6.5rem);font-weight:700;line-height:1}.hero h1 em{color:var(--accent);font-style:italic}.hero .subtitle{color:var(--ink-muted);max-width:650px;margin-bottom:3rem;font-size:1.15rem;font-weight:400;line-height:1.8}.cta-button{background:var(--accent);color:#fff;letter-spacing:.04em;text-transform:uppercase;cursor:pointer;border:none;border-radius:4px;padding:1rem 2rem;font-size:.875rem;font-weight:600;text-decoration:none;transition:background .2s;display:inline-block}.cta-button:hover{background:var(--accent-hover)}.statement-section{background:var(--accent);color:#fff;text-align:left;border:none;padding:6rem 2.5rem;position:relative;overflow:hidden}.statement-section:before{content:"";background:var(--accent-tertiary);opacity:.15;pointer-events:none;border-radius:50%;width:500px;height:500px;position:absolute;top:50%;right:0;transform:translate(100px,-50%)}.statement-container{z-index:1;grid-template-columns:1fr 1fr;align-items:flex-start;gap:5rem;max-width:1200px;margin:0 auto;display:grid;position:relative}.statement-section h2{letter-spacing:-.02em;color:#fff;margin:0;font-size:clamp(2.5rem,7vw,4.5rem);font-weight:700;line-height:1.1}.statement-section em{color:#fff;text-decoration:underline;-webkit-text-decoration-color:var(--accent-tertiary);text-decoration-color:var(--accent-tertiary);text-underline-offset:.2em;font-style:italic;font-weight:700;text-decoration-thickness:3px}.statement-section p{color:#fff;margin:0;font-size:1.05rem;font-weight:400;line-height:1.9}.statement-list{margin:2rem 0 0;padding:0;list-style:none}.statement-list li{color:#fff;align-items:flex-start;margin-bottom:1.5rem;padding-left:0;font-size:1rem;font-weight:500;line-height:1.8;display:flex}.statement-list li:before{content:"→";color:var(--accent-tertiary);flex-shrink:0;margin-right:1rem;font-size:1.25rem;font-weight:700}.contact-section{text-align:center;background:var(--bg-light);border-top:1px solid var(--border);padding:8rem 2.5rem;width:100vw!important;max-width:none!important;margin:0 0 0 calc(50% - 50vw)!important}.contact-container{max-width:700px;margin:0 auto}.contact-section h2{color:var(--ink);margin-bottom:1rem;font-size:2.5rem;font-weight:700;line-height:1.2}.contact-section p{color:var(--ink-muted);margin-bottom:2.5rem;font-size:1.05rem;line-height:1.8}.featured-section-header{max-width:1000px;margin:0 auto;padding:3rem 2.5rem 0}.featured-section-header h2{margin-bottom:.5rem;font-size:2.2rem;font-weight:700}.featured-projects{grid-template-columns:1fr 1fr;gap:2.5rem;max-width:1200px;margin:0 auto;padding:3rem 2.5rem;display:grid}.projects-grid{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.5rem;max-width:1200px;margin-top:3rem;margin-left:auto;margin-right:auto;padding:3rem 2.5rem;display:grid}.project-card{background:var(--bg);border:2px solid var(--border);cursor:pointer;border-radius:8px;flex-direction:column;padding:3rem;transition:all .3s;display:flex;position:relative;overflow:hidden}.project-card:before{content:"";background:var(--accent);transform-origin:0;height:4px;transition:transform .3s;position:absolute;top:0;left:0;right:0;transform:scaleX(0)}.project-card:hover:before{transform:scaleX(1)}.project-card:hover{border-color:var(--accent);transform:translateY(-6px);box-shadow:0 16px 40px #d63d471f}.project-category{letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem;font-size:.7rem;font-weight:700}.project-card h3{color:var(--ink);margin-bottom:1.25rem;font-size:1.6rem;font-weight:700;line-height:1.3}.project-card p{color:var(--ink-muted);flex-grow:1;margin-bottom:2rem;font-size:.95rem;line-height:1.8}.project-meta{flex-direction:column;gap:.75rem;display:flex}.meta-item-small{color:var(--ink-muted);letter-spacing:.03em;font-size:.8rem}.meta-label-small{color:var(--ink);font-weight:600}@media (width<=768px){main{margin-top:60px}section{padding:3rem 1.5rem}.hero{padding:1.5rem}.hero h1{max-width:100%;font-size:clamp(1.75rem,7vw,3rem)}.featured-projects{grid-template-columns:1fr;padding:2rem 1.5rem}.projects-grid{grid-template-columns:1fr;padding:0 1.5rem}.contact-section{width:100vw;margin-left:calc(50% - 50vw);padding:3rem 1.5rem}.contact-section h2{font-size:1.8rem}.statement-section{padding:4rem 1.5rem}.statement-container{grid-template-columns:1fr;gap:2rem}.statement-section h2{font-size:clamp(1.75rem,6vw,2.5rem)}.featured-section-header{padding:2rem 1.5rem 0}}.base-infographic-wrapper{width:100%;max-width:100%;padding:4rem 2.5rem}.infographic-title{color:var(--ink);letter-spacing:-.5px;margin-bottom:1rem;font-size:1.6rem;font-weight:700}.infographic-description{color:var(--ink-muted);max-width:600px;margin-bottom:3rem;font-size:1.05rem;line-height:1.7}.infographic-container{border:1px solid var(--border);background:var(--bg);border-radius:12px;justify-content:center;align-items:center;width:100%;min-height:420px;padding:4rem 3rem;display:flex}.infographic-container svg{width:100%;height:auto;min-height:320px;margin:0 auto;display:block}@media (width<=768px){.base-infographic-wrapper{padding:2.5rem 1.5rem}.infographic-title{margin-bottom:.75rem;font-size:1.4rem}.infographic-description{margin-bottom:2rem;font-size:1rem}.infographic-container{min-height:350px;padding:2.5rem 1.5rem}}.diagram-svg{width:100%;height:auto;display:block}.diagram-svg text{-webkit-user-select:none;user-select:none;pointer-events:none}.diagram-svg{font-family:var(--sans)}@media (width<=768px){.diagram-svg{min-height:300px}}.principles-container{background:var(--bg);width:100%;padding:3rem 2.5rem}.principles-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;width:100%;max-width:1200px;margin:0 auto;display:grid}.principle-card{background:var(--bg-light);border:1px solid var(--border);border-radius:8px;padding:2rem;transition:all .3s}.principle-card:hover{border-color:var(--ink-muted);box-shadow:0 4px 12px #0000000f}.principle-number{margin-bottom:.5rem;font-size:2.5rem;font-weight:700;line-height:1;display:block}.principle-title{color:var(--ink);margin:0 0 .75rem;font-size:1.25rem;font-weight:700;line-height:1.3}.principle-description{color:var(--ink-muted);margin:0;font-size:1rem;line-height:1.5}@media (width<=768px){.principles-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.principle-card{padding:1.5rem}.principle-number{font-size:2rem}.principle-title{font-size:1.1rem}.principles-container{padding:2rem 1.5rem}}@media (width<=480px){.principles-grid{grid-template-columns:1fr;gap:1rem}.principle-card{padding:1.25rem}.principle-number{font-size:1.75rem}.principle-title{font-size:1rem}.principle-description{font-size:.9rem}.principles-container{padding:1.5rem 1rem}}.photo-gallery-wrapper{width:100%;padding:3rem 2.5rem}.gallery-container{max-width:1200px;margin:0 auto}.gallery-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;width:100%;display:grid}.gallery-item{aspect-ratio:3/4;background:var(--bg-light);border-radius:8px;transition:box-shadow .3s;position:relative;overflow:hidden;box-shadow:0 2px 8px #00000014}.gallery-item:hover{box-shadow:0 8px 24px #0000001f}.gallery-item img{object-fit:cover;width:100%;height:100%;display:block}@media (width<=768px){.gallery-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.photo-gallery-wrapper{padding:2rem 1.5rem}}@media (width<=480px){.gallery-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.75rem}.photo-gallery-wrapper{padding:1.5rem 1rem}}.screenshots-wrapper{width:100%;padding:4rem 2.5rem}.screenshots-grid{grid-template-columns:repeat(2,1fr);align-items:start;gap:3.5rem 3rem;width:100%;max-width:900px;margin:0 auto;display:grid}.screenshot-item{flex-direction:column;gap:1.5rem;display:flex}.screenshot-container{border:1px solid var(--border);background:var(--bg-light);aspect-ratio:16/9;border-radius:8px;position:relative;overflow:hidden}.screenshot-container img{object-fit:contain;width:100%;height:100%;display:block}.screenshot-caption{color:var(--ink-muted);text-align:center;font-size:.95rem;line-height:1.5}@media (width<=1024px){.screenshots-wrapper{padding:3.5rem 2rem}.screenshots-grid{gap:3rem 2.5rem;max-width:100%}}@media (width<=768px){.screenshots-wrapper{max-width:100%;padding:3rem 1.5rem}.screenshots-grid{grid-template-columns:1fr;gap:2rem 1.5rem}.screenshot-container{max-height:600px}}.project-hero{background:var(--bg);padding:3rem 2.5rem}.project-hero h1{max-width:90%;margin-bottom:1.5rem;font-size:clamp(2rem,6vw,4rem);font-weight:700;line-height:1.2}.project-tagline{color:var(--ink-muted);max-width:700px;margin-bottom:2rem;font-size:1.25rem}.project-meta-row{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:3.5rem;margin:2.5rem 0;display:grid}.meta-item{flex-direction:column;padding-left:0;display:flex}.meta-label{letter-spacing:.12em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:.75rem;font-size:.7rem;font-weight:700}.meta-value{color:var(--ink);font-size:1.05rem;font-weight:600;line-height:1.4}.section{max-width:1000px;margin:0 auto;padding:3rem 2.5rem}.section h2{margin-bottom:1.5rem;font-size:2.2rem;font-weight:700;line-height:1.2}.section h3{margin-top:2rem;margin-bottom:1rem;font-size:1.5rem;font-weight:600}.section p{color:var(--ink-muted);max-width:700px;margin-bottom:1rem;font-size:1.15rem;line-height:1.8}.section ul{color:var(--ink-muted);padding:0;font-size:1.15rem;line-height:1.8;list-style:none}.section ul li{margin-bottom:.75rem;padding-left:1.5rem;position:relative}.section ul li:before{content:"—";color:var(--accent);opacity:.6;position:absolute;left:0}.project-nav{border-top:1px solid var(--border);justify-content:space-between;align-items:center;max-width:1000px;margin:0 auto;padding:2rem 2.5rem;display:flex}.nav-button{color:var(--accent);letter-spacing:.04em;cursor:pointer;text-transform:uppercase;background:0 0;border:none;padding:0;font-size:.875rem;font-weight:600;transition:color .2s}.nav-button:hover:not(:disabled){color:var(--accent-hover)}.nav-button:disabled{opacity:.3;cursor:not-allowed}.infographic-section{border-top:none;width:100%;max-width:100%;padding:4rem 0}.infographic-section:first-of-type{border-top:1px solid var(--border)}@media (width<=768px){.project-hero{padding:2rem 1.5rem}.project-hero h1{max-width:100%}.section{padding:2rem 1.5rem}.infographic-section{padding-top:2rem;padding-bottom:2rem}.project-nav{flex-wrap:wrap;gap:1rem;padding:1.5rem}}#root{flex-direction:column;width:100%;min-height:100vh;display:flex}main{flex:1;width:100%}
