:root{
    --ink:      #0B0D3B;
    --plum:     #280740;
    --aqua:     #008FD5;
    --paper:    #FAF9F7;
    --stone:    #EAE6DF;
    --ink-soft: #55536E;
    --white:    #FFFFFF;

    --font-display: 'Inter', sans-serif;
    --font-body:    'Inter', sans-serif;
    --font-mono:    'Inter', sans-serif;

    --max: 1280px;
    --gutter: clamp(1.25rem, 4.5vw, 4.5rem);
  }

*,*::before,*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }

@media (prefers-reduced-motion: reduce){
    *,*::before,*::after{ animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important; }
  }

body{ margin:0; background:var(--paper); color:var(--ink); font-family:var(--font-body); font-size:16px; line-height:1.65; -webkit-font-smoothing:antialiased; }
a{ color:inherit; text-decoration:none; }
.label{ font-family:var(--font-body); font-weight:600; font-size:0.72rem; letter-spacing:0.14em; text-transform:uppercase; color:var(--ink-soft); }

header{ position:fixed; top:0; left:0; right:0; z-index:100; padding:1.4rem 0; transition:background .4s ease, padding .4s ease, box-shadow .4s ease; }
.nav-links a:not(.btn){ font-size:0.92rem; font-weight:500; color:var(--white); transition:color .4s ease, opacity .2s ease; }
.nav-links a:not(.btn):hover{ opacity:0.7; }
.nav-links .btn{ background:var(--plum); color:var(--white); padding:0.7em 1.4em; font-size:0.85rem; border-radius:0; }
.nav-links .btn:hover{ background:var(--aqua); color:var(--white); }
.nav-toggle span{ width:22px; height:2px; background:var(--white); transition:background .4s ease; }

.footer-col a{ font-size:0.92rem; color:rgba(255,255,255,0.85); transition:color .2s ease; }
.socials a{ width:34px; height:34px; border-radius:50%; border:1px solid rgba(255,255,255,0.25); display:flex; align-items:center; justify-content:center; transition:border-color .2s ease; }
.footer-bottom{ margin-top:3.4rem; padding-top:1.6rem; border-top:1px solid rgba(255,255,255,0.15); display:flex; justify-content:space-between; flex-wrap:wrap; gap:0.8rem; font-size:0.72rem; color:rgba(255,255,255,0.42); }




h1,h2,h3{ font-family:var(--font-display); color:var(--ink); margin:0; font-weight:700; letter-spacing:-0.025em; }

p{ margin:0; }



img{ max-width:100%; display:block; }

button{ font:inherit; background:none; border:0; cursor:pointer; color:inherit; }

a:focus-visible, button:focus-visible{ outline:2px solid var(--aqua); outline-offset:3px; }

.wrap{ max-width:var(--max); margin:0 auto; padding-left:var(--gutter); padding-right:var(--gutter); }

section{ padding:clamp(4rem,9vw,7.5rem) 0; }

.skip-link{ position:absolute; left:-999px; background:var(--ink); color:var(--white); padding:0.9em 1.4em; z-index:200; font-size:0.85rem; }

.skip-link:focus{ left:1rem; top:1rem; }

.caption{ font-family:var(--font-mono); font-size:0.68rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-soft); }



.section-head{ max-width:820px; margin-bottom:3rem; }

.nowrap-d{ white-space:nowrap; }

@media (max-width:700px){ .nowrap-d{ white-space:normal; } }

.section-head h2{ font-size:clamp(1.9rem,3.6vw,2.75rem); }

.section-head .sub{ color:var(--ink-soft); font-size:1.02rem; margin-top:1rem; max-width:52ch; }

.btn{
    display:inline-flex; align-items:center; gap:0.6em; font-weight:600; font-size:0.95rem;
    padding:0.9em 1.8em; transition:transform .25s ease, background .25s ease, color .25s ease;
  }

.btn-solid{ background:var(--plum); color:var(--white); }

.btn-solid:hover{ background:var(--aqua); }

.btn-outline{ border:1.5px solid rgba(255,255,255,0.7); color:var(--white); }

.btn-outline:hover{ background:rgba(255,255,255,0.12); }

.link-arrow{ font-weight:600; border-bottom:1.5px solid var(--ink); padding-bottom:0.2em; display:inline-flex; gap:0.5em; }

.link-arrow:hover{ border-color:var(--aqua); color:var(--aqua); }



header .bar{ display:flex; align-items:center; justify-content:space-between; gap:1.5rem; }

header.scrolled{ background:rgba(250,249,247,0.94); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px); padding:0.85rem 0; box-shadow:0 1px 0 rgba(11,13,59,0.08); }

.brand{ display:flex; align-items:center; gap:0.65rem; }

.brand-mark{ width:140px; height:140px; border-radius:50%; background:var(--white); display:flex; align-items:center; justify-content:center; flex:none; }

.brand-mark img{ height:96px; width:96px; object-fit:contain; }

nav.nav-links{ display:flex; align-items:center; gap:2.1rem; }





header.scrolled .nav-links a:not(.btn){ color:var(--ink); }





.nav-toggle{ display:none; flex-direction:column; gap:5px; padding:0.4rem; }



header.scrolled .nav-toggle span{ background:var(--ink); }

@media (max-width:900px){
    .nav-links{
      position:fixed; inset:0 0 0 26%; background:var(--paper);
      flex-direction:column; justify-content:center; align-items:flex-start; gap:1.8rem;
      padding:2rem var(--gutter); transform:translateX(100%); transition:transform .4s ease;
      box-shadow:-6px 0 24px rgba(11,13,59,0.12);
    }
    .nav-links.open{ transform:translateX(0); }
    .nav-links a:not(.btn){ font-size:1.4rem; color:var(--ink); }
    .nav-toggle{ display:flex; }
    .brand-mark{ width:96px; height:96px; }
    .brand-mark img{ height:66px; width:66px; }
  }

.hero{
    position:relative; min-height:100vh; display:flex; align-items:flex-end;
    background-size:cover; background-position:center; padding:0 0 clamp(2.5rem,7vw,5rem);
  }

.hero::after{
    content:""; position:absolute; inset:0;
    background:linear-gradient(0deg, rgba(11,13,59,0.92) 0%, rgba(11,13,59,0.55) 42%, rgba(11,13,59,0.08) 72%);
  }

.hero .wrap{ position:relative; z-index:2; color:var(--white); }

.hero-badge{ font-family:var(--font-mono); font-size:0.72rem; letter-spacing:0.14em; text-transform:uppercase; display:flex; align-items:center; gap:0.6em; margin-bottom:1.3rem; color:rgba(255,255,255,0.85); }

.hero-badge::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--aqua); }

.hero h1{ color:var(--white); font-size:clamp(2.6rem,6vw,4.6rem); line-height:1.03; max-width:15ch; }

.hero h1 em{ font-style:italic; color:#B9E4FF; }

.hero .sub{ color:rgba(255,255,255,0.82); font-size:clamp(1.02rem,1.4vw,1.2rem); max-width:44ch; margin-top:1.4rem; }

.hero .cta-row{ display:flex; gap:1rem; flex-wrap:wrap; margin-top:2.2rem; }

.hero .credit{ position:absolute; right:var(--gutter); bottom:1.5rem; z-index:2; color:rgba(255,255,255,0.55); font-family:var(--font-mono); font-size:0.66rem; letter-spacing:0.08em; text-transform:uppercase; }

.manifesto .wrap{ display:grid; grid-template-columns:1.1fr 0.9fr; gap:clamp(2rem,6vw,5rem); align-items:center; }

.manifesto h2{ font-size:clamp(1.7rem,3.4vw,2.6rem); line-height:1.28; font-weight:400; }

.manifesto .img-frame{ aspect-ratio:4/5; overflow:hidden; }

.manifesto .img-frame img{ width:100%; height:100%; object-fit:cover; }

@media (max-width:900px){ .manifesto .wrap{ grid-template-columns:1fr; } .manifesto .img-frame{ order:-1; max-width:420px; margin:0 auto; } }

.slideshow{ position:relative; aspect-ratio:16/10; overflow:hidden; }

.slide{ position:absolute; inset:0; background-size:cover; background-position:center; opacity:0; transition:opacity 1.1s ease; display:flex; align-items:flex-end; }

.slide.active{ opacity:1; z-index:1; }

.slide::after{ content:""; position:absolute; inset:0; background:linear-gradient(0deg, rgba(11,13,59,0.82) 0%, rgba(11,13,59,0.25) 50%, transparent 75%); }

.slide-text{ position:relative; z-index:2; padding:clamp(1.4rem,4vw,2.6rem); color:var(--white); }

.slide-text h3{ font-size:clamp(1.5rem,3.2vw,2.3rem); color:var(--white); font-weight:700; }

.slide-text p{ margin-top:0.4rem; color:rgba(255,255,255,0.85); font-size:1rem; max-width:42ch; }

.slide-dots{ position:absolute; bottom:1.2rem; right:1.2rem; z-index:3; display:flex; gap:0.5rem; }

.dot{ width:8px; height:8px; border-radius:50%; background:rgba(255,255,255,0.4); padding:0; border:0; cursor:pointer; transition:background .2s ease, transform .2s ease; }

.dot.active{ background:var(--white); transform:scale(1.25); }

@media (max-width:700px){ .slideshow{ aspect-ratio:4/5; } }

.portfolio{ background:var(--stone); }

.work-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(230px, 1fr)); gap:1rem; }

.work-tile{ position:relative; aspect-ratio:4/5; overflow:hidden; display:block; }

.work-tile img{ width:100%; height:100%; object-fit:cover; transition:transform .45s ease; }

.work-tile:hover img{ transform:scale(1.06); }

.work-tile::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 55%, rgba(11,13,59,0.78) 100%); pointer-events:none; }

.work-tile-text{ position:absolute; left:0; right:0; bottom:0; padding:0.9rem; z-index:2; color:var(--white); }

.work-tile-text .cat{ font-family:var(--font-body); font-size:0.66rem; font-weight:600; letter-spacing:0.09em; text-transform:uppercase; opacity:0.85; }

.work-tile-text h3{ font-size:1.02rem; color:var(--white); margin-top:0.25rem; font-weight:600; }

.portfolio-cta{ margin-top:2rem; }

.video-frame{
    position:relative; aspect-ratio:16/8; overflow:hidden;
    background-size:cover; background-position:center;
    display:flex; align-items:center; justify-content:center;
  }

.video-frame video{ width:100%; height:100%; object-fit:cover; }

.about .wrap{ display:grid; grid-template-columns:0.75fr 1.25fr; gap:clamp(2rem,6vw,5rem); align-items:center; }

.about-photo{ aspect-ratio:1/1; border-radius:50%; overflow:hidden; }

.about-photo img{ width:100%; height:100%; object-fit:cover; }

.about h2{ font-size:clamp(1.7rem,3.2vw,2.3rem); }

.about p.bio{ margin-top:1.3rem; color:var(--ink-soft); font-size:1.03rem; max-width:58ch; }

.about .link-arrow{ margin-top:1.7rem; display:inline-flex; }

@media (max-width:900px){ .about .wrap{ grid-template-columns:1fr; } .about-photo{ max-width:280px; margin:0 auto; } }

.reviews{ text-align:center; }

.reviews .section-head{ margin-left:auto; margin-right:auto; }

.final-cta{ position:relative; background-size:cover; background-position:center; padding:clamp(5rem,12vw,9rem) 0; text-align:center; }

.final-cta::before{ content:""; position:absolute; inset:0; background:rgba(11,13,59,0.82); }

.final-cta .wrap{ position:relative; z-index:2; }

.final-cta h2{ color:var(--white); font-size:clamp(2rem,4.4vw,3.2rem); max-width:16ch; margin:0 auto; }

.final-cta .sub{ color:rgba(255,255,255,0.7); max-width:48ch; margin:1.2rem auto 0; }

.final-cta .cta-row{ margin-top:2.2rem; display:flex; justify-content:center; }

footer{ background:var(--plum); color:rgba(255,255,255,0.8); padding:4.5rem 0 2rem; }

.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:2.5rem; }

.footer-mark{ width:130px; height:130px; border-radius:50%; background:var(--white); display:flex; align-items:center; justify-content:center; margin-bottom:1rem; }

.footer-mark img{ height:88px; width:88px; object-fit:contain; }

.footer-brand p{ font-size:0.88rem; max-width:30ch; color:rgba(255,255,255,0.58); }

.footer-col .label{ color:rgba(255,255,255,0.48); margin-bottom:1.1rem; display:block; }

.footer-col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:0.7rem; }



.footer-col a:hover{ color:var(--aqua); }

.socials{ display:flex; gap:0.9rem; }



.socials a:hover{ border-color:var(--aqua); }

.socials svg{ width:15px; height:15px; fill:rgba(255,255,255,0.85); }



@media (max-width:900px){ .footer-grid{ grid-template-columns:1fr 1fr; } }

@media (max-width:560px){ .footer-grid{ grid-template-columns:1fr; } }

.reveal{ opacity:0; transform:translateY(16px); transition:opacity .7s ease, transform .7s ease; }

.reveal.in{ opacity:1; transform:translateY(0); }

:root{
    --ink:      #0B0D3B;
    --plum:     #280740;
    --aqua:     #008FD5;
    --paper:    #FAF9F7;
    --stone:    #EAE6DF;
    --ink-soft: #55536E;
    --white:    #FFFFFF;
    --font-display: 'Inter', sans-serif;
    --font-body:    'Inter', sans-serif;
    --max: 1280px;
    --gutter: clamp(1.25rem, 4.5vw, 4.5rem);
  }

@media (prefers-reduced-motion: reduce){
    *,*::before,*::after{ animation-duration:0.001ms !important; transition-duration:0.001ms !important; scroll-behavior:auto !important; }
  }







.nav-links a.current{ border-bottom:2px solid var(--aqua); padding-bottom:0.3rem; }





@media (max-width:900px){
    .nav-links{ position:fixed; inset:0 0 0 26%; background:var(--paper); flex-direction:column; justify-content:center; align-items:flex-start; gap:1.8rem; padding:2rem var(--gutter); transform:translateX(100%); transition:transform .4s ease; box-shadow:-6px 0 24px rgba(11,13,59,0.12); }
    .nav-links.open{ transform:translateX(0); }
    .nav-links a:not(.btn){ font-size:1.4rem; }
    .nav-toggle{ display:flex; }
    .brand-mark{ width:96px; height:96px; }
    .brand-mark img{ height:66px; width:66px; }
    .filters{ top:141px; }
  }

.folio-hero{ position:relative; min-height:52vh; display:flex; align-items:flex-end; background-size:cover; background-position:center; }

.folio-hero::after{ content:""; position:absolute; inset:0; background:linear-gradient(0deg, rgba(11,13,59,0.88) 0%, rgba(11,13,59,0.5) 55%, rgba(11,13,59,0.12) 100%); }

.folio-hero .wrap{ position:relative; z-index:2; padding:12rem 0 2.6rem; }

.folio-hero .label{ color:rgba(255,255,255,0.8); }

.folio-hero h1{ color:var(--white); font-size:clamp(2.3rem,5.2vw,3.8rem); margin-top:0.8rem; max-width:16ch; }

.folio-hero p{ color:rgba(255,255,255,0.82); font-size:1.02rem; max-width:none; margin-top:1rem; }

.filters{ position:sticky; top:186px; z-index:50; background:rgba(250,249,247,0.96); backdrop-filter:blur(8px); border-bottom:1px solid rgba(11,13,59,0.1); padding:1.1rem 0; }

.filter-row{ display:flex; flex-wrap:wrap; gap:1.9rem; }

.filter-btn{ font-size:0.86rem; font-weight:600; letter-spacing:0.01em; color:var(--ink-soft); padding:0.3em 0; border-bottom:2px solid transparent; transition:color .2s ease, border-color .2s ease; }

.filter-btn:hover{ color:var(--ink); }

.filter-btn.active{ color:var(--ink); border-bottom-color:var(--aqua); }

.cat-group{ padding:clamp(2.6rem,5.5vw,3.6rem) 0; }

.cat-group.alt{ background:var(--stone); }

.cat-title{ font-size:clamp(1.6rem,2.8vw,2.2rem); margin-bottom:2rem; display:flex; align-items:center; gap:0.6em; }

.cat-title::before{ content:""; width:9px; height:9px; border-radius:50%; background:var(--aqua); flex:none; }

.project{ margin-bottom:2.8rem; }

.project:last-child{ margin-bottom:0; }

.project-head{ display:flex; justify-content:space-between; align-items:baseline; flex-wrap:wrap; gap:0.5rem 1.5rem; margin-bottom:1.1rem; }

.project-head h3{ font-size:1.4rem; font-weight:700; }

.project-meta{ text-align:right; }

.project-meta .credit{ font-size:0.85rem; color:var(--ink-soft); margin-top:0.25rem; display:block; }

.project-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(230px, 1fr)); grid-auto-rows:150px; gap:0.6rem; }

.project-grid .pg-item:first-child{ grid-column:span 2; grid-row:span 2; }

.project-grid.pair{ grid-template-columns:repeat(2, 1fr); grid-auto-rows:auto; }

.project-grid.pair .pg-item{ aspect-ratio:5/4; }

.project-grid.pair .pg-item:first-child{ grid-column:auto; grid-row:auto; }

.project-grid.hero-stack{ display:grid; grid-template-columns:1.5fr 1fr; gap:0.6rem; }

.project-grid.hero-stack .hero-item{ aspect-ratio:4/5; }

.project-grid.hero-stack .hero-item:first-child{ grid-column:auto; grid-row:auto; }

.project-grid.hero-stack .stack{ display:flex; flex-direction:column; gap:0.6rem; }

.project-grid.hero-stack .stack .pg-item{ aspect-ratio:4/2.35; }

@media (max-width:700px){
    .project-grid.hero-stack{ grid-template-columns:1fr; }
    .project-grid.hero-stack .hero-item{ aspect-ratio:4/3; }
  }

.pg-item{ overflow:hidden; background:var(--stone); }

.cat-group.alt .pg-item{ background:var(--white); }

.pg-item img{ width:100%; height:100%; object-fit:cover; transition:transform .4s ease; }

.pg-item:hover img{ transform:scale(1.045); }

@media (max-width:560px){
    .project-grid{ grid-auto-rows:130px; }
    .project-grid .pg-item:first-child{ grid-column:span 2; grid-row:span 1; }
  }

.video-embed{ position:relative; width:100%; aspect-ratio:16/9; overflow:hidden; margin-top:1rem; background:var(--stone); }

.video-embed iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }

.video-embed-row{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin-top:1rem; }

.video-embed-row .video-embed{ margin-top:0; }

.video-embed-row .video-label{ font-family:var(--font-body); font-size:0.75rem; font-weight:600; letter-spacing:0.06em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:0.5rem; display:block; }

@media (max-width:700px){ .video-embed-row{ grid-template-columns:1fr; } }

.hidden{ display:none !important; }







h1,h2{ font-family:var(--font-display); color:var(--ink); margin:0; font-weight:700; letter-spacing:-0.02em; }



a:hover{ text-decoration:underline; }











@media (max-width:900px){
    .nav-links{ position:fixed; inset:0 0 0 26%; background:var(--paper); flex-direction:column; justify-content:center; align-items:flex-start; gap:1.8rem; padding:2rem var(--gutter); transform:translateX(100%); transition:transform .4s ease; box-shadow:-6px 0 24px rgba(11,13,59,0.12); }
    .nav-links.open{ transform:translateX(0); }
    .nav-links a:not(.btn){ font-size:1.4rem; }
    .nav-toggle{ display:flex; }
    .brand-mark{ width:96px; height:96px; }
    .brand-mark img{ height:66px; width:66px; }
  }

.page-hero{ padding:clamp(11.5rem,17vw,13rem) 0 2.5rem; }

.page-hero h1{ font-size:clamp(2rem,4.4vw,3rem); }

.page-hero p{ color:var(--ink-soft); margin-top:1rem; max-width:none; }

.terms{ padding-bottom:5rem; }

.terms .wrap{ max-width:820px; }

.terms h2{ font-size:1.25rem; margin-top:2.6rem; margin-bottom:0.9rem; }

.terms h2:first-of-type{ margin-top:0; }

.terms p{ color:var(--ink-soft); margin-bottom:1rem; }

.terms p:last-child{ margin-bottom:0; }

