/* —————————————————— NEARBLACK · KOTO.COM STYLE —————————————————— */
:root{
  --bg:#000000;
  --bg-2:#0a0a0a;
  --fg:#ffffff;
  --mute:#6a6a6a;
  --mute-2:#999999;
  --line:rgba(255,255,255,.12);
  --line-strong:rgba(255,255,255,.22);
  --display:'Archivo',ui-sans-serif,system-ui,sans-serif;
  --sans:'Inter',ui-sans-serif,system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--fg);font-family:var(--sans);-webkit-font-smoothing:antialiased;font-weight:400;line-height:1.5;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--fg);color:var(--bg)}

/* —————————————————— NAV —————————————————— */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:28px 32px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;background:var(--bg);border-bottom:1px solid var(--line)}
.cta-nav{justify-self:end}
.brand{font-family:var(--display);font-size:20px;font-weight:800;letter-spacing:-.035em;color:var(--fg)}
.brand em{font-style:normal;font-weight:400;color:var(--mute-2)}
.navlinks{display:flex;gap:40px;font-family:var(--display);font-size:14px;font-weight:500;letter-spacing:-.005em}
.navlinks a{color:var(--fg);opacity:.85;transition:opacity .2s}
.navlinks a:hover,.navlinks a.active{opacity:1}
.cta-nav{font-family:var(--display);font-weight:500;font-size:14px;letter-spacing:-.005em;color:var(--fg);border:1px solid var(--line-strong);padding:10px 20px;border-radius:999px;transition:all .2s}
.cta-nav:hover{background:var(--fg);color:var(--bg);border-color:var(--fg)}

/* —————————————————— MOBILE NAV —————————————————— */
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:4px;z-index:110;position:relative}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--fg);transition:transform .3s,opacity .2s;margin:5px 0}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{display:none}

@media (max-width:980px){
  .nav-toggle{display:block!important}
  .cta-nav{display:none!important}
  .mobile-menu{display:none;position:fixed;inset:0;z-index:99;background:var(--bg);flex-direction:column;justify-content:center;align-items:center;gap:0;padding:80px 32px 40px}
  .mobile-menu.open{display:flex!important}
  .mobile-menu a{font-family:var(--display);font-size:clamp(36px,10vw,56px);font-weight:500;letter-spacing:-.02em;color:var(--fg);opacity:.7;padding:16px 0;transition:opacity .2s;text-align:center;border-bottom:1px solid var(--line);width:100%;display:block}
  .mobile-menu a:last-child{border-bottom:none}
  .mobile-menu a:hover,.mobile-menu a.active{opacity:1}
  .mobile-menu .mob-cta{font-size:14px;font-weight:500;letter-spacing:-.005em;margin-top:40px;padding:18px 42px;border:1px solid var(--line-strong);border-radius:999px;opacity:1;width:auto}
}

/* —————————————————— TYPOGRAPHY —————————————————— */
.display{font-family:var(--display);font-weight:500;line-height:1.02;letter-spacing:-.025em;color:var(--fg)}
.display em,.display i{font-style:normal;font-weight:400;color:var(--mute-2)}
.eyebrow{font-family:var(--display);font-size:12px;font-weight:500;letter-spacing:-.005em;color:var(--mute-2);display:inline-flex;align-items:center;gap:14px}
.eyebrow::before{content:"";width:28px;height:1px;background:var(--mute)}

/* —————————————————— HERO (KOTO-STYLE: SMALL, BOTTOM-LEFT) —————————————————— */
.hero{min-height:100vh;padding:120px 32px 48px;display:flex;flex-direction:column;justify-content:flex-end;position:relative;background:var(--bg)}

/* hero with video — video on top, content below */
.hero-video{padding:88px 0 0;justify-content:flex-start;min-height:auto}
.hero-bg{width:100%;height:62vh;object-fit:cover;object-position:center;display:block;background:var(--bg)}
.hero-video .hero-content{padding:48px 32px 16px;display:flex;flex-direction:column;justify-content:flex-end;flex:1}
.hero-video .hero-content .eyebrow{margin-bottom:20px}
.hero-video .hero-content h1{font-family:var(--display);font-weight:500;font-size:clamp(28px,2.6vw,44px);line-height:1.1;letter-spacing:-.018em;max-width:30ch;margin-top:0;color:var(--fg)}
.hero-video .hero-content h1 em,.hero-video .hero-content h1 i{font-style:normal;font-weight:400;color:var(--mute-2)}
.hero .eyebrow{margin-bottom:20px}
.hero h1{font-family:var(--display);font-weight:500;font-size:clamp(28px,2.6vw,44px);line-height:1.1;letter-spacing:-.018em;max-width:30ch;margin-top:0}
.hero h1 em,.hero h1 i{font-style:normal;font-weight:400;color:var(--mute-2)}
.hero-bottom{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-top:48px;padding-top:32px;border-top:1px solid var(--line)}
.hero-bottom p{max-width:46ch;font-size:14px;line-height:1.55;color:var(--mute-2)}
.hero-bottom p strong{font-weight:500;color:var(--fg)}
.hero-meta{display:flex;gap:56px;font-family:var(--display);font-size:11px;font-weight:500;color:var(--mute-2);letter-spacing:-.005em;text-transform:uppercase}
.hero-meta div strong{display:block;font-family:var(--display);font-weight:500;color:var(--fg);font-size:22px;letter-spacing:-.022em;margin-bottom:4px;text-transform:none}

/* smaller page sub-heros */
.hero-sm{min-height:56vh;padding:180px 32px 80px;position:relative;display:flex;flex-direction:column;justify-content:flex-end;border-bottom:1px solid var(--line);background:var(--bg)}
.hero-sm .eyebrow{margin-bottom:20px}
.hero-sm h1{font-family:var(--display);font-weight:500;font-size:clamp(32px,3.6vw,64px);line-height:1.02;letter-spacing:-.022em;max-width:22ch;color:var(--fg)}
.hero-sm h1 em,.hero-sm h1 i{font-style:normal;font-weight:400;color:var(--mute-2)}
.hero-sm .lede{margin-top:36px;max-width:60ch;font-size:15px;line-height:1.65;color:var(--mute-2)}

/* —————————————————— MARQUEE —————————————————— */
.marquee{overflow:hidden;padding:24px 0;background:var(--bg);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.marquee-inner{display:flex;gap:32px;white-space:nowrap;animation:scroll 44s linear infinite;font-family:var(--display);font-size:clamp(20px,2.2vw,36px);font-weight:500;letter-spacing:-.02em;width:max-content;line-height:1;color:var(--fg)}
.marquee-inner span{display:inline-flex;align-items:center;gap:48px}
.marquee-inner i{font-style:normal;font-weight:300;color:var(--mute-2)}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* —————————————————— SECTIONS —————————————————— */
section{padding:140px 32px;border-bottom:1px solid var(--line);position:relative;background:var(--bg)}
.wrap{max-width:1440px;margin:0 auto}
.wrap-sm{max-width:1120px;margin:0 auto}
.section-label{margin-bottom:32px}
.section-title{font-family:var(--display);font-weight:500;font-size:clamp(22px,2.2vw,36px);line-height:1.2;letter-spacing:-.015em;max-width:72ch;margin-bottom:56px;color:var(--fg)}
.section-title em,.section-title i{font-style:normal;font-weight:400;color:var(--mute-2)}

/* —————————————————— MANIFESTO GRID —————————————————— */
.manifesto-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px 100px;margin-top:32px}
.manifesto-grid p{font-family:var(--display);font-size:clamp(18px,1.6vw,26px);font-weight:500;line-height:1.35;letter-spacing:-.012em;color:var(--fg)}
.manifesto-grid p em{font-style:normal;font-weight:400;color:var(--mute-2)}

/* —————————————————— WORK GRID (KOTO-STYLE) —————————————————— */
.work-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:32px 24px;margin-top:40px}
.project{grid-column:span 6;display:block;cursor:pointer;position:relative}
.project.wide{grid-column:span 12}
.project.third{grid-column:span 4}
.project.tall{grid-column:span 6}
.project-tile,.project-img{position:relative;overflow:hidden;aspect-ratio:4/3;background:var(--bg-2);border:1px solid var(--line)}
.project.wide .project-tile,.project.wide .project-img{aspect-ratio:21/9}
.project.tall .project-tile,.project.tall .project-img{aspect-ratio:3/4}
.project-tile img,.project-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.8,.2,1),filter .5s}
.project:hover .project-tile img,.project:hover .project-img img{transform:scale(1.04)}
.project-meta{display:grid;grid-template-columns:1fr 2fr;gap:48px;margin-top:20px;align-items:flex-start}
.project-meta>div:first-child{display:flex;flex-direction:column;gap:6px}
.project-name{font-family:var(--display);font-weight:500;font-size:14px;line-height:1.3;letter-spacing:-.005em;color:var(--fg)}
.project-name em,.project-name i{font-style:normal;font-weight:400;color:var(--mute-2)}
.project-desc{font-size:13px;color:var(--mute-2);line-height:1.55;max-width:52ch;margin-top:0}
.project-tag{font-family:var(--display);font-weight:500;font-size:11px;letter-spacing:-.005em;color:var(--mute-2);text-transform:uppercase;white-space:nowrap;margin-top:2px}
.project-info{flex:1}

/* —————————————————— STATEMENT —————————————————— */
.statement{padding:200px 32px;border-bottom:1px solid var(--line)}
.statement-title{font-family:var(--display);font-weight:500;font-size:clamp(64px,10vw,200px);line-height:.92;letter-spacing:-.04em;max-width:24ch;margin:0 auto;color:var(--fg)}
.statement-title em{font-style:normal;font-weight:300;color:var(--mute-2)}

/* —————————————————— PRICING TIERS —————————————————— */
.tier{display:grid;grid-template-columns:60px 1fr 1.5fr 220px;gap:40px;padding:48px 0;border-top:1px solid var(--line);align-items:flex-start;transition:padding .3s}
.tier:last-child{border-bottom:1px solid var(--line)}
.tier:hover{padding-left:24px}
.tier-num{font-family:var(--display);font-size:13px;font-weight:500;color:var(--mute-2);letter-spacing:-.005em}
.tier-name{font-family:var(--display);font-size:clamp(28px,3vw,48px);font-weight:500;line-height:1.02;letter-spacing:-.02em;color:var(--fg)}
.tier-name em{font-style:normal;font-weight:400;color:var(--mute-2)}
.tier-desc{font-size:14px;line-height:1.7;max-width:42ch;color:var(--mute-2)}
.tier-desc b{display:block;margin-bottom:14px;font-family:var(--display);font-weight:500;font-size:13px;color:var(--fg);letter-spacing:-.005em;text-transform:uppercase}
.tier-desc ul{margin-top:14px;list-style:none;display:flex;flex-direction:column;gap:6px}
.tier-desc ul li{color:var(--mute-2)}
.tier-desc ul li::before{content:"— ";color:var(--fg)}
.tier-meta{text-align:right}
.tier-price{font-family:var(--display);font-size:clamp(32px,3.2vw,52px);font-weight:500;letter-spacing:-.022em;line-height:1;color:var(--fg)}
.tier-delivery{font-family:var(--display);font-weight:500;font-size:11px;color:var(--mute-2);text-transform:uppercase;letter-spacing:-.005em;margin-top:14px}

/* —————————————————— PROCESS STEPS —————————————————— */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:40px;margin-top:40px}
.step{border-top:1px solid var(--line);padding-top:32px}
.step-num{font-family:var(--display);font-size:13px;font-weight:500;color:var(--mute-2);margin-bottom:32px;letter-spacing:-.005em}
.step h3{font-family:var(--display);font-size:clamp(20px,1.7vw,28px);font-weight:500;line-height:1.1;letter-spacing:-.015em;margin-bottom:18px;color:var(--fg)}
.step h3 em{font-style:normal;font-weight:400;color:var(--mute-2)}
.step p{font-size:14px;line-height:1.65;color:var(--mute-2)}

/* —————————————————— ADD-ONS —————————————————— */
.addon-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:40px}
.addon{background:var(--bg);padding:48px 36px;display:flex;flex-direction:column;gap:14px;min-height:220px;justify-content:space-between;transition:background .3s}
.addon:hover{background:var(--bg-2)}
.addon-name{font-family:var(--display);font-size:18px;font-weight:500;letter-spacing:-.015em;line-height:1.1;color:var(--fg)}
.addon-desc{font-size:13px;line-height:1.6;color:var(--mute-2)}
.addon-price{font-family:var(--display);font-size:16px;font-weight:500;letter-spacing:-.015em;margin-top:auto;color:var(--fg)}

/* —————————————————— QUOTE —————————————————— */
.quote{padding:140px 32px;text-align:center;border-bottom:1px solid var(--line);background:var(--bg)}
.quote blockquote{font-family:var(--display);font-weight:500;font-size:clamp(28px,3vw,44px);line-height:1.15;letter-spacing:-.018em;max-width:36ch;margin:0 auto;color:var(--fg)}
.quote blockquote em{font-style:normal;font-weight:400;color:var(--mute-2)}
.quote cite{display:block;margin-top:40px;font-family:var(--display);font-size:12px;font-weight:500;letter-spacing:-.005em;text-transform:uppercase;color:var(--mute-2);font-style:normal}

/* —————————————————— STATS —————————————————— */
.stats{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stat{padding:48px 32px;border-right:1px solid var(--line)}
.stat:last-child{border-right:none}
.stat-num{font-family:var(--display);font-size:clamp(32px,3.4vw,52px);font-weight:500;line-height:1;letter-spacing:-.022em;color:var(--fg)}
.stat-num em{font-style:normal;font-weight:400;color:var(--mute-2)}
.stat-label{font-family:var(--display);font-size:11px;font-weight:500;letter-spacing:-.005em;text-transform:uppercase;color:var(--mute-2);margin-top:16px}

/* —————————————————— CASE STUDY —————————————————— */
.cs-hero{padding:180px 32px 80px;border-bottom:1px solid var(--line)}
.cs-hero h1{font-family:var(--display);font-weight:500;font-size:clamp(36px,4.5vw,72px);line-height:1.05;letter-spacing:-.022em;margin-top:24px;color:var(--fg);overflow-wrap:anywhere;word-break:break-word}
.cs-hero h1 em{font-style:normal;font-weight:400;color:var(--mute-2)}
.cs-hero h1 em.h1-sub{display:inline-block}
.cs-meta{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;margin-top:88px;padding-top:48px;border-top:1px solid var(--line)}
.cs-meta div{display:flex;flex-direction:column;gap:10px}
.cs-meta dt{font-family:var(--display);font-size:12px;font-weight:500;letter-spacing:-.005em;text-transform:uppercase;color:var(--mute-2)}
.cs-meta dd{font-family:var(--display);font-size:20px;font-weight:500;letter-spacing:-.02em;color:var(--fg)}
.cs-hero-image{aspect-ratio:16/9;overflow:hidden}
.cs-hero-image img{width:100%;height:100%;object-fit:cover}
.cs-body{padding:140px 32px;border-bottom:1px solid var(--line)}
.cs-body-grid{display:grid;grid-template-columns:1fr 2fr;gap:100px;max-width:1320px;margin:0 auto}
.cs-body h2{font-family:var(--display);font-weight:500;font-size:clamp(24px,2.4vw,36px);letter-spacing:-.015em;line-height:1.1;color:var(--fg)}
.cs-body h2 em{font-style:normal;font-weight:400;color:var(--mute-2)}
.cs-body p{font-size:15px;line-height:1.75;margin-bottom:18px;color:var(--mute-2)}
.cs-body p:last-child{margin-bottom:0}
.cs-gallery{display:grid;grid-template-columns:1fr 1fr;gap:24px;padding:0 32px 140px;max-width:1600px;margin:0 auto;background:var(--bg)}
.cs-gallery img{width:100%;aspect-ratio:4/3;object-fit:cover;border:1px solid var(--line)}
.cs-gallery img:first-child{grid-column:span 2;aspect-ratio:21/9}

/* —————————————————— FEATURE IMAGE —————————————————— */
.feature-image{aspect-ratio:21/8;overflow:hidden;background:var(--bg-2)}
.feature-image img{width:100%;height:100%;object-fit:cover}

/* —————————————————— SPLIT —————————————————— */
.split{display:grid;grid-template-columns:1fr 1fr;gap:96px;align-items:center}
.split-img{aspect-ratio:4/5;overflow:hidden;background:var(--bg-2);border:1px solid var(--line)}
.split-img img{width:100%;height:100%;object-fit:cover}
.split h2{font-family:var(--display);font-weight:500;font-size:clamp(28px,3vw,44px);line-height:1.05;letter-spacing:-.018em;color:var(--fg)}
.split h2 em{font-style:normal;font-weight:400;color:var(--mute-2)}
.split p{font-size:15px;line-height:1.7;margin-top:24px;max-width:46ch;color:var(--mute-2)}

/* —————————————————— JOURNAL —————————————————— */
.journal-list{margin-top:40px}
.journal-entry{display:grid;grid-template-columns:140px 1fr 1fr 180px;gap:40px;padding:56px 0;border-top:1px solid var(--line);align-items:flex-start;transition:padding .3s}
.journal-entry:last-child{border-bottom:1px solid var(--line)}
.journal-entry:hover{padding-left:24px}
.journal-date{font-family:var(--display);font-size:13px;font-weight:500;color:var(--mute-2);letter-spacing:-.005em;text-transform:uppercase}
.journal-title{font-family:var(--display);font-size:clamp(18px,1.5vw,24px);font-weight:500;line-height:1.25;letter-spacing:-.01em;color:var(--fg)}
.journal-title em{font-style:normal;font-weight:400;color:var(--mute-2)}
.journal-excerpt{font-size:15px;line-height:1.7;max-width:48ch;color:var(--mute-2)}
.journal-cat{font-family:var(--display);font-size:12px;font-weight:500;letter-spacing:-.005em;text-transform:uppercase;color:var(--mute-2);text-align:right}

/* —————————————————— CONTACT —————————————————— */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:120px;max-width:1320px;margin:0 auto}
.contact-info h2{font-family:var(--display);font-weight:500;font-size:clamp(32px,3.4vw,52px);line-height:1.02;letter-spacing:-.022em;color:var(--fg)}
.contact-info h2 em{font-style:normal;font-weight:400;color:var(--mute-2)}
.contact-info p{font-family:var(--sans);font-size:18px;line-height:1.6;margin-top:40px;max-width:38ch;color:var(--mute-2)}
.contact-info .details{margin-top:64px;display:flex;flex-direction:column;gap:32px}
.contact-info .details a{font-family:var(--display);font-size:20px;font-weight:500;letter-spacing:-.015em;transition:opacity .2s;color:var(--fg);display:inline-block}
.contact-info .details a:hover{opacity:.7}
.contact-info .details .label{font-family:var(--display);font-size:12px;font-weight:500;letter-spacing:-.005em;text-transform:uppercase;color:var(--mute-2);margin-bottom:10px}
.form-field{display:flex;flex-direction:column;gap:14px;padding-bottom:32px;margin-bottom:32px;border-bottom:1px solid var(--line)}
.form-field label{font-family:var(--display);font-size:12px;font-weight:500;letter-spacing:-.005em;text-transform:uppercase;color:var(--mute-2)}
.form-field input,.form-field select,.form-field textarea{background:transparent;border:none;outline:none;color:var(--fg);font-family:var(--display);font-size:18px;font-weight:500;letter-spacing:-.012em;padding:0;resize:none;width:100%}
.form-field textarea{min-height:80px;line-height:1.5;font-size:16px}
.form-field input::placeholder,.form-field textarea::placeholder{color:var(--mute);font-weight:400}
.form-submit{display:inline-block;margin-top:24px;padding:22px 48px;background:var(--fg);color:var(--bg);font-family:var(--display);font-size:13px;font-weight:500;letter-spacing:-.005em;text-transform:uppercase;border-radius:999px;transition:opacity .2s}
.form-submit:hover{opacity:.85}

/* —————————————————— FINAL CTA —————————————————— */
.final{padding:140px 32px;text-align:center;background:var(--bg);border-bottom:1px solid var(--line)}
.final-title{font-family:var(--display);font-weight:500;font-size:clamp(32px,3.6vw,56px);line-height:1.08;letter-spacing:-.02em;margin-bottom:40px;color:var(--fg);max-width:24ch;margin-left:auto;margin-right:auto}
.final-title em{font-style:normal;font-weight:400;color:var(--mute-2)}
.cta-btn{display:inline-block;padding:18px 42px;background:var(--fg);color:var(--bg);font-family:var(--display);font-size:12px;font-weight:500;letter-spacing:-.005em;text-transform:uppercase;border-radius:999px;transition:opacity .2s,transform .2s}
.cta-btn:hover{opacity:.85;transform:translateY(-2px)}

/* —————————————————— FOOTER —————————————————— */
footer{padding:100px 32px 40px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:56px;background:var(--bg);border-top:1px solid var(--line)}
footer h4{font-family:var(--display);font-size:12px;font-weight:500;letter-spacing:-.005em;text-transform:uppercase;color:var(--mute-2);margin-bottom:24px}
footer ul{list-style:none;display:flex;flex-direction:column;gap:14px;font-family:var(--display);font-size:15px;font-weight:500;letter-spacing:-.01em}
footer ul a{color:var(--fg);opacity:.75;transition:opacity .2s}
footer ul a:hover{opacity:1}
.foot-brand{font-family:var(--display);font-size:clamp(32px,3.6vw,52px);font-weight:500;letter-spacing:-.02em;line-height:1;color:var(--fg)}
.foot-brand em{font-style:normal;font-weight:400;color:var(--mute-2)}
.foot-tag{font-size:14px;margin-top:24px;max-width:34ch;line-height:1.6;color:var(--mute-2)}
.foot-bottom{grid-column:1/-1;display:flex;justify-content:space-between;padding-top:56px;margin-top:40px;border-top:1px solid var(--line);font-family:var(--display);font-size:12px;font-weight:500;color:var(--mute-2);letter-spacing:-.005em;text-transform:uppercase}

/* —————————————————— WALKTHROUGH / BEFORE / AFTER —————————————————— */
.ba{padding:140px 32px;background:var(--bg);border-bottom:1px solid var(--line)}
.ba-wrap{max-width:1760px;margin:0 auto}
.ba-label{font-family:var(--display);font-size:12px;font-weight:500;letter-spacing:-.005em;text-transform:uppercase;color:var(--mute-2);margin-bottom:20px;text-align:center}
.ba-title{font-family:var(--display);font-weight:500;font-size:clamp(32px,3.6vw,56px);line-height:1.06;letter-spacing:-.022em;color:var(--fg);text-align:center;max-width:24ch;margin:0 auto 72px}
.ba-title em{font-style:normal;font-weight:400;color:var(--mute-2)}

/* Walkthrough gallery — the beautiful parts */
.walk{display:grid;grid-template-columns:1fr;gap:80px;margin-bottom:120px}
.walk-row{display:grid;grid-template-columns:1fr 2fr;gap:64px;align-items:center}
.walk-row.flip{grid-template-columns:2fr 1fr}
.walk-row.flip .walk-copy{order:2}
.walk-row.flip .walk-img{order:1}
.walk-copy .ba-tag{margin-bottom:18px}
.walk-copy h3{font-family:var(--display);font-weight:500;font-size:clamp(24px,2.2vw,36px);letter-spacing:-.018em;line-height:1.1;color:var(--fg);margin-bottom:20px}
.walk-copy h3 em{font-style:normal;font-weight:400;color:var(--mute-2)}
.walk-copy p{font-family:var(--body);font-size:15px;line-height:1.75;color:var(--mute-2);max-width:44ch}
.walk-img{aspect-ratio:16/10;overflow:hidden;border:1px solid var(--line);background:#111}
.walk-img img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block}

/* Before / after pair */
.ba-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.ba-card{display:flex;flex-direction:column;gap:20px}
.ba-tag{display:inline-flex;align-items:center;gap:10px;font-family:var(--display);font-size:11px;font-weight:500;letter-spacing:-.005em;text-transform:uppercase;color:var(--mute-2)}
.ba-tag .dot{width:8px;height:8px;border-radius:999px;background:var(--mute-2)}
.ba-card.after .ba-tag .dot{background:var(--fg)}
.ba-card.after .ba-tag{color:var(--fg)}
.ba-img{aspect-ratio:16/11;overflow:hidden;border:1px solid var(--line);background:#111}
.ba-img img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block}
.ba-caption{font-family:var(--body);font-size:14px;line-height:1.65;color:var(--mute-2);max-width:48ch}
.ba-caption strong{color:var(--fg);font-weight:500}

/* —————————————————— LEGAL / PROSE —————————————————— */
.legal{padding:120px 32px 160px;background:var(--bg)}
.legal-wrap{max-width:780px;margin:0 auto}
.legal-meta{display:flex;justify-content:space-between;padding-bottom:40px;margin-bottom:64px;border-bottom:1px solid var(--line);font-family:var(--display);font-size:12px;font-weight:500;letter-spacing:-.005em;text-transform:uppercase;color:var(--mute-2)}
.legal h2{font-family:var(--display);font-weight:500;font-size:clamp(22px,2.2vw,30px);line-height:1.15;letter-spacing:-.015em;color:var(--fg);margin-top:72px;margin-bottom:24px}
.legal h2:first-of-type{margin-top:0}
.legal h2 em{font-style:normal;font-weight:400;color:var(--mute-2)}
.legal h2 .num{display:block;font-family:var(--display);font-size:12px;font-weight:500;letter-spacing:-.005em;text-transform:uppercase;color:var(--mute-2);margin-bottom:14px}
.legal p{font-family:var(--body);font-size:16px;line-height:1.75;color:var(--mute-2);margin-bottom:20px;max-width:68ch}
.legal p strong{color:var(--fg);font-weight:500}
.legal p em{color:var(--fg);font-style:italic}
.legal ul{list-style:none;padding:0;margin:0 0 24px}
.legal ul li{position:relative;padding-left:24px;margin-bottom:12px;font-family:var(--body);font-size:16px;line-height:1.7;color:var(--mute-2)}
.legal ul li:before{content:"·";position:absolute;left:8px;color:var(--mute-2)}
.legal a{color:var(--fg);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px}
.legal a:hover{opacity:.7}

/* —————————————————— EMAIL MOCKUP (process step 1) —————————————————— */
.email-mock{aspect-ratio:4/5;overflow:hidden;border:1px solid var(--line);background:linear-gradient(145deg,#1a1a1a 0%,#0a0a0a 60%,#000 100%);position:relative;padding:48px 40px;display:flex;flex-direction:column;justify-content:center;gap:24px}
.email-mock::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 10%,rgba(255,255,255,.04),transparent 40%),radial-gradient(circle at 85% 90%,rgba(255,255,255,.025),transparent 45%);pointer-events:none}
.em-card{background:#f6f3ec;color:#111;border-radius:10px;padding:22px 24px;font-family:var(--sans);position:relative;z-index:1;box-shadow:0 24px 60px rgba(0,0,0,.45),0 2px 0 rgba(255,255,255,.02)}
.em-card.primary{margin-right:28px}
.em-card.reply{margin-left:56px;margin-top:-8px;background:#ececec;padding:18px 22px}
.em-head{display:flex;align-items:center;gap:12px;padding-bottom:14px;margin-bottom:14px;border-bottom:1px solid rgba(0,0,0,.08)}
.em-avatar{width:30px;height:30px;border-radius:8px;background:#111;color:#f6f3ec;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:600;font-size:13px;flex-shrink:0}
.em-headtext{display:flex;flex-direction:column;gap:2px;min-width:0}
.em-title{font-family:var(--display);font-size:13px;font-weight:600;letter-spacing:-.005em;color:#111}
.em-sub{font-size:11px;color:#777;letter-spacing:-.005em}
.em-row{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}
.em-row:last-child{margin-bottom:0}
.em-label{font-family:var(--display);font-size:10px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:#999}
.em-value{font-family:var(--sans);font-size:13px;line-height:1.45;color:#222}
.em-value.muted{color:#555}
.em-chip{display:inline-flex;align-items:center;gap:6px;background:#111;color:#f6f3ec;padding:3px 9px;border-radius:4px;font-family:var(--display);font-size:10px;font-weight:500;letter-spacing:.01em;margin-right:4px}
.em-chip .dot{width:5px;height:5px;border-radius:999px;background:#f6f3ec}
.em-arrow{position:absolute;left:50%;top:50%;width:2px;height:28px;background:linear-gradient(to bottom,rgba(255,255,255,.2),rgba(255,255,255,0));transform:translate(-50%,-50%)}
.em-reply-head{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.em-reply-dot{width:8px;height:8px;border-radius:999px;background:#0a0a0a}

/* —————————————————— REVIEW MOCK (process step 3) —————————————————— */
.review-mock{aspect-ratio:4/5;overflow:hidden;border:1px solid var(--line);background:linear-gradient(145deg,#1a1a1a 0%,#0a0a0a 60%,#000 100%);position:relative;padding:48px 40px;display:flex;flex-direction:column;justify-content:center;gap:20px}
.review-mock::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 10%,rgba(255,255,255,.04),transparent 40%),radial-gradient(circle at 15% 95%,rgba(255,255,255,.025),transparent 45%);pointer-events:none}
.rv-card{background:#f6f3ec;color:#111;border-radius:10px;padding:22px 24px;font-family:var(--sans);position:relative;z-index:1;box-shadow:0 24px 60px rgba(0,0,0,.45)}
.rv-card.primary{margin-left:20px}
.rv-head{display:flex;align-items:center;justify-content:space-between;padding-bottom:14px;margin-bottom:10px;border-bottom:1px solid rgba(0,0,0,.08)}
.rv-head-left{display:flex;align-items:center;gap:12px}
.rv-avatar{width:30px;height:30px;border-radius:999px;background:#111;color:#f6f3ec;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:600;font-size:13px}
.rv-title{font-family:var(--display);font-size:13px;font-weight:600;color:#111;line-height:1.2}
.rv-sub{font-size:11px;color:#777;margin-top:2px}
.rv-count{font-family:var(--display);font-size:11px;font-weight:500;color:#777}
.rv-item{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid rgba(0,0,0,.06)}
.rv-item:last-child{border-bottom:none}
.rv-check{width:16px;height:16px;border-radius:4px;border:1.5px solid #222;flex-shrink:0;margin-top:1px;position:relative}
.rv-item.done .rv-check{background:#111;border-color:#111}
.rv-item.done .rv-check::after{content:"";position:absolute;left:4px;top:0;width:5px;height:9px;border:solid #f6f3ec;border-width:0 2px 2px 0;transform:rotate(45deg)}
.rv-item.done .rv-text{color:#888;text-decoration:line-through;text-decoration-thickness:1px}
.rv-text{font-size:13px;line-height:1.4;color:#222}
.rv-note{background:#ececec;margin-left:64px;margin-right:-8px;margin-top:-4px;padding:14px 18px;border-radius:10px;font-size:12px;line-height:1.45;color:#444;position:relative;z-index:1;box-shadow:0 10px 30px rgba(0,0,0,.35)}
.rv-note .rv-tag{font-family:var(--display);font-size:10px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:#888;display:block;margin-bottom:4px}

/* —————————————————— LAUNCH MOCK (process step 4) —————————————————— */
.launch-mock{aspect-ratio:4/5;overflow:hidden;border:1px solid var(--line);background:linear-gradient(145deg,#141414 0%,#080808 60%,#000 100%);position:relative;padding:48px 40px;display:flex;flex-direction:column;justify-content:center;gap:18px}
.launch-mock::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 15%,rgba(255,255,255,.05),transparent 45%),radial-gradient(circle at 90% 90%,rgba(27,155,74,.06),transparent 50%);pointer-events:none}
.lc-card{background:#f6f3ec;color:#111;border-radius:10px;padding:22px 24px;font-family:var(--sans);position:relative;z-index:1;box-shadow:0 24px 60px rgba(0,0,0,.45)}
.lc-head{display:flex;align-items:center;justify-content:space-between;padding-bottom:14px;margin-bottom:14px;border-bottom:1px solid rgba(0,0,0,.08)}
.lc-status{display:flex;align-items:center;gap:10px}
.lc-dot{width:8px;height:8px;border-radius:999px;background:#1b9b4a;box-shadow:0 0 0 4px rgba(27,155,74,.15)}
.lc-status-text{font-family:var(--display);font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:#1b9b4a}
.lc-time{font-family:var(--display);font-size:11px;color:#888}
.lc-url{font-family:var(--display);font-size:22px;font-weight:600;letter-spacing:-.015em;color:#111;margin-bottom:4px}
.lc-sub{font-size:12px;color:#666;margin-bottom:16px;line-height:1.4}
.lc-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;padding-top:14px;border-top:1px solid rgba(0,0,0,.08)}
.lc-stat{display:flex;flex-direction:column;gap:3px}
.lc-stat-num{font-family:var(--display);font-size:18px;font-weight:600;letter-spacing:-.015em;color:#111}
.lc-stat-label{font-family:var(--display);font-size:9px;font-weight:500;letter-spacing:.05em;text-transform:uppercase;color:#888}
.lc-invoice{background:#ececec;margin-top:-4px;margin-right:28px;padding:14px 18px;border-radius:10px;color:#444;position:relative;z-index:1;box-shadow:0 10px 30px rgba(0,0,0,.35)}
.lc-invoice-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.lc-invoice-tag{font-family:var(--display);font-size:10px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:#888}
.lc-invoice-amt{font-family:var(--display);font-size:15px;font-weight:600;color:#111;letter-spacing:-.01em}
.lc-invoice-line{font-size:11px;color:#555}

/* —————————————————— INTAKE MOCK (studio: only refreshes) —————————————————— */
.intake-mock{aspect-ratio:4/5;overflow:hidden;border:1px solid var(--line);background:linear-gradient(145deg,#1a1a1a 0%,#0a0a0a 60%,#000 100%);position:relative;padding:48px 40px;display:flex;flex-direction:column;justify-content:center;gap:18px}
.intake-mock::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 15%,rgba(255,255,255,.04),transparent 40%),radial-gradient(circle at 85% 90%,rgba(27,155,74,.05),transparent 50%);pointer-events:none}
.in-card{background:#f6f3ec;color:#111;border-radius:10px;padding:22px 24px;font-family:var(--sans);position:relative;z-index:1;box-shadow:0 24px 60px rgba(0,0,0,.45)}
.in-card.primary{margin-right:20px}
.in-head{padding-bottom:14px;margin-bottom:14px;border-bottom:1px solid rgba(0,0,0,.08)}
.in-tag{font-family:var(--display);font-size:10px;font-weight:500;letter-spacing:.05em;text-transform:uppercase;color:#888;margin-bottom:6px}
.in-title{font-family:var(--display);font-size:15px;font-weight:600;letter-spacing:-.01em;color:#111;line-height:1.25}
.in-field{display:flex;align-items:center;gap:12px;padding:12px 14px;background:#ececec;border-radius:8px;margin-bottom:10px}
.in-field:last-child{margin-bottom:0}
.in-check{width:18px;height:18px;border-radius:999px;background:#1b9b4a;flex-shrink:0;position:relative}
.in-check::after{content:"";position:absolute;left:5px;top:3px;width:5px;height:9px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}
.in-cross{width:18px;height:18px;border-radius:999px;background:#b94a3a;flex-shrink:0;position:relative}
.in-cross::before,.in-cross::after{content:"";position:absolute;left:4px;top:8px;width:10px;height:2px;background:#fff}
.in-cross::before{transform:rotate(45deg)}
.in-cross::after{transform:rotate(-45deg)}
.in-field-text{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1}
.in-field-url{font-family:var(--display);font-size:13px;font-weight:600;color:#111;letter-spacing:-.005em}
.in-field-meta{font-size:11px;color:#777}
.in-footer{display:flex;align-items:center;gap:8px;margin-top:14px;padding-top:12px;border-top:1px solid rgba(0,0,0,.08);font-size:11px;color:#555}
.in-footer b{font-family:var(--display);font-weight:600;color:#111}
.in-reject{background:#ececec;margin-left:40px;margin-top:-4px;padding:14px 18px;border-radius:10px;font-size:12px;line-height:1.45;color:#555;position:relative;z-index:1;box-shadow:0 10px 30px rgba(0,0,0,.35)}
.in-reject .in-tag{margin-bottom:4px}

/* —————————————————— DELIVERABLES MOCK (studio: how we work) —————————————————— */
.deliv-mock{aspect-ratio:4/5;overflow:hidden;border:1px solid var(--line);background:linear-gradient(145deg,#161616 0%,#090909 60%,#000 100%);position:relative;padding:48px 40px;display:flex;flex-direction:column;justify-content:center;gap:18px}
.deliv-mock::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 75% 20%,rgba(255,255,255,.05),transparent 45%),radial-gradient(circle at 10% 90%,rgba(255,255,255,.025),transparent 50%);pointer-events:none}
.dv-card{background:#f6f3ec;color:#111;border-radius:10px;padding:22px 24px;font-family:var(--sans);position:relative;z-index:1;box-shadow:0 24px 60px rgba(0,0,0,.45)}
.dv-head{padding-bottom:14px;margin-bottom:14px;border-bottom:1px solid rgba(0,0,0,.08)}
.dv-tag{font-family:var(--display);font-size:10px;font-weight:500;letter-spacing:.05em;text-transform:uppercase;color:#888;margin-bottom:6px}
.dv-title{font-family:var(--display);font-size:15px;font-weight:600;letter-spacing:-.01em;color:#111}
.dv-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;padding:8px 0 16px;border-bottom:1px solid rgba(0,0,0,.08);margin-bottom:14px}
.dv-stat{display:flex;flex-direction:column;gap:3px;text-align:left}
.dv-stat-num{font-family:var(--display);font-size:22px;font-weight:600;letter-spacing:-.02em;color:#111;line-height:1}
.dv-stat-num em{font-style:normal;font-weight:400;color:#777;font-size:13px}
.dv-stat-label{font-family:var(--display);font-size:9px;font-weight:500;letter-spacing:.05em;text-transform:uppercase;color:#888}
.dv-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.dv-list li{display:flex;align-items:flex-start;gap:10px;font-size:12px;line-height:1.45;color:#333}
.dv-list li::before{content:"";width:14px;height:14px;border-radius:999px;background:#111;flex-shrink:0;margin-top:1px;position:relative;background-image:linear-gradient(#111,#111)}
.dv-list li{position:relative}
.dv-check{width:14px;height:14px;border-radius:999px;background:#111;flex-shrink:0;margin-top:1px;position:relative;display:inline-block}
.dv-check::after{content:"";position:absolute;left:4px;top:2px;width:4px;height:7px;border:solid #f6f3ec;border-width:0 2px 2px 0;transform:rotate(45deg)}
.dv-list li::before{display:none}
.dv-testim{background:#ececec;margin-left:44px;margin-top:-4px;padding:14px 18px;border-radius:10px;position:relative;z-index:1;box-shadow:0 10px 30px rgba(0,0,0,.35)}
.dv-testim-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.dv-testim-stars{font-family:var(--display);font-size:11px;font-weight:600;color:#111;letter-spacing:.02em}
.dv-testim-tag{font-family:var(--display);font-size:10px;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:#888}
.dv-testim-q{font-family:var(--display);font-size:13px;line-height:1.4;color:#222;letter-spacing:-.005em}
.dv-testim-q em{font-style:normal;font-weight:400;color:#777;display:block;font-size:11px;margin-top:4px;letter-spacing:0}

/* —————————————————— RESPONSIVE —————————————————— */
@media (max-width:980px){
  nav{padding:20px}
  .navlinks{display:none}
  .hero,.hero-sm{padding:140px 20px 70px!important;min-height:auto!important}
  section{padding:90px 20px!important}
  .manifesto-grid,.steps{grid-template-columns:1fr!important;gap:40px!important}
  .work-grid{grid-template-columns:1fr!important;gap:32px!important}
  .project,.project.wide,.project.tall,.project.third{grid-column:span 1!important}
  .tier{grid-template-columns:1fr!important;gap:16px!important;padding:40px 0!important}
  .tier-meta{text-align:left!important}
  .tier-name,.tier-price{font-size:48px!important}
  .addon-grid{grid-template-columns:1fr!important}
  footer{grid-template-columns:1fr 1fr!important;gap:40px!important;padding:60px 20px 30px!important}
  .foot-bottom{flex-direction:column!important;gap:12px!important}
  .final{padding:120px 20px!important}
  .stats{grid-template-columns:1fr 1fr!important}
  .stat{border-right:none!important;border-bottom:1px solid var(--line)!important}
  .contact-grid{grid-template-columns:1fr!important;gap:72px!important}
  .cs-body-grid{grid-template-columns:1fr!important;gap:40px!important}
  .cs-gallery{grid-template-columns:1fr!important}
  .cs-gallery img:first-child{grid-column:span 1!important}
  .cs-meta{grid-template-columns:1fr 1fr!important;gap:24px!important}
  .journal-entry{grid-template-columns:1fr!important;gap:12px!important}
  .journal-cat{text-align:left!important}
  .split{grid-template-columns:1fr!important;gap:40px!important}
  .hero-bottom{flex-direction:column!important;align-items:flex-start!important;gap:32px!important}
  .hero-meta{flex-wrap:wrap!important;gap:28px!important}
  .ba{padding:70px 20px!important}
  .ba-grid{grid-template-columns:1fr!important;gap:48px!important}
  .ba-title{margin-bottom:48px!important}
  .legal{padding:70px 20px 110px!important}
  .legal-meta{flex-direction:column!important;gap:8px!important;margin-bottom:48px!important}
  .legal h2{margin-top:56px!important}
  .cs-hero{padding:140px 20px 60px!important}
  .cs-hero h1{font-size:clamp(28px,8vw,40px)!important;line-height:1.1!important}
  .cs-hero h1 em.h1-sub{display:block!important;font-size:.55em!important;margin-top:8px!important}
  .cs-hero-image{aspect-ratio:4/3!important}
  .cs-meta{margin-top:48px!important;padding-top:32px!important}
  .cs-body{padding:70px 20px!important}
  .cs-gallery{padding:0 20px 70px!important;gap:16px!important}
  .hero-video .hero-content{padding:32px 20px 16px!important}
  .hero-video .hero-content h1{font-size:clamp(26px,7vw,34px)!important}
  .hero-bg{height:40vh!important}
  /* brand tagline only on mobile footer */
  footer .foot-tag{max-width:100%!important}
  /* mockups: scale down inner padding */
  .email-mock,.review-mock,.launch-mock,.intake-mock,.deliv-mock{padding:32px 22px!important;aspect-ratio:auto!important;min-height:520px}
  .em-card,.rv-card,.lc-card,.in-card,.dv-card{padding:18px 20px!important}
  .em-card.reply,.rv-note,.lc-invoice,.in-reject,.dv-testim{margin-left:24px!important;margin-right:0!important;padding:12px 16px!important}
  .em-card.primary,.in-card.primary,.rv-card.primary{margin-right:12px!important;margin-left:0!important}
  .em-value,.rv-text,.lc-sub,.in-field-meta,.dv-list li{font-size:12px!important}
  .lc-url{font-size:18px!important}
  .dv-stat-num,.lc-stat-num{font-size:18px!important}
  .dv-stats{gap:8px!important}
  .in-title,.dv-title{font-size:13px!important}
  .em-title,.rv-title{font-size:12px!important}
  /* h1 with long url ems: wrap onto next line */
  h1 em.h1-sub{display:block;font-size:.6em;margin-top:8px}
  /* stack project meta on mobile so tile copy uses full width */
  .project-meta{grid-template-columns:1fr!important;gap:8px!important;margin-top:16px!important}
  .project-tag{margin-top:6px!important}
  /* smaller section title on mobile, smaller hero-sm h1 */
  .hero-sm h1{font-size:clamp(32px,8vw,44px)!important}
  .section-title{font-size:clamp(22px,6vw,28px)!important;margin-bottom:40px!important}
  /* nav brand + cta on mobile: keep compact */
  nav{padding:18px 20px!important}
  .brand{font-size:18px!important}
  .cta-nav{padding:8px 14px!important;font-size:12px!important}
  /* stats numbers smaller at mobile */
  .stat{padding:32px 20px!important}
  .stat-num{font-size:clamp(32px,10vw,44px)!important}
}
