:root {
  --navy: #071a3d;
  --navy-soft: #10264f;
  --orange: #ff5017;
  --coral: #ff7547;
  --peach: #ffc09f;
  --cream: #fff7ee;
  --paper: #faf6ef;
  --ink: #0a1d3f;
  --muted: #687083;
  --line: rgba(7, 26, 61, .14);
  --sans: "DM Sans", sans-serif;
  --display: "Manrope", sans-serif;
  --serif: "Playfair Display", Georgia, serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: var(--sans); overflow-x: hidden; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }
button { font: inherit; }
::selection { color: white; background: var(--orange); }

.noise { position: fixed; inset: 0; opacity: .025; z-index: 20; pointer-events: none; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.8'/%3E%3C/svg%3E"); }

.site-header { position: fixed; inset: 0 0 auto; height: 86px; padding: 0 4.5vw; display: flex; align-items: center; justify-content: space-between; z-index: 50; transition: background .3s, box-shadow .3s, height .3s; }
.site-header.scrolled { height: 72px; background: rgba(250, 246, 239, .91); backdrop-filter: blur(16px); box-shadow: 0 1px rgba(7, 26, 61, .08); }
.brand { width: 175px; }
.brand img { width: 100%; }
.site-nav { display: flex; align-items: center; gap: 36px; font-size: 13px; font-weight: 600; }
.site-nav > a:not(.nav-cta) { position: relative; }
.site-nav > a:not(.nav-cta)::after { content: ""; position: absolute; left: 0; bottom: -5px; width: 100%; height: 1px; background: var(--orange); transform: scaleX(0); transform-origin: right; transition: transform .25s; }
.site-nav > a:hover::after { transform: scaleX(1); transform-origin: left; }
.nav-cta { padding: 12px 18px; border-radius: 999px; color: white; background: var(--navy); transition: transform .2s, background .2s; }
.nav-cta:hover { transform: translateY(-2px); background: var(--orange); }
.nav-cta span { margin-left: 8px; }
.menu-toggle { display: none; border: 0; background: none; padding: 8px; }
.icon-arrow { width: 14px; height: 14px; display: inline-block; flex: 0 0 auto; color: inherit; background: currentColor; -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 17 17 7'/%3E%3Cpath d='M7 7h10v10'/%3E%3C/svg%3E") center / contain no-repeat; mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 17 17 7'/%3E%3Cpath d='M7 7h10v10'/%3E%3C/svg%3E") center / contain no-repeat; }

.hero { min-height: 100vh; padding: 150px 6vw 44px; position: relative; display: grid; grid-template-columns: 1.1fr .9fr; grid-template-rows: 1fr auto; align-items: center; overflow: hidden; }
.hero-glow { position: absolute; width: 65vw; height: 65vw; right: -20vw; top: -18vw; background: radial-gradient(circle, rgba(255, 190, 156, .35), transparent 68%); }
.hero-copy { width: 100%; min-width: 0; max-width: 760px; position: relative; z-index: 2; }
.eyebrow { margin: 0 0 30px; font-size: 11px; font-weight: 600; letter-spacing: .19em; text-transform: uppercase; display: flex; align-items: center; gap: 11px; }
.eyebrow span { display: inline-block; width: 27px; height: 1px; background: var(--orange); }
.eyebrow.light { color: rgba(255, 255, 255, .72); }
.hero h1, .section-heading h2, .work-heading h2, .approach h2, .contact h2 { font-family: var(--display); letter-spacing: -.065em; font-weight: 500; margin: 0; }
.hero h1 { font-size: clamp(58px, 7.4vw, 116px); line-height: .91; }
.hero h1.hero-tagline { font-size: clamp(52px, 6vw, 92px); line-height: .95; }
em { font-family: var(--serif); font-weight: 500; color: var(--orange); }
.hero-intro { max-width: 585px; margin: 34px 0 0; padding-left: 2px; font-size: clamp(17px, 1.5vw, 21px); line-height: 1.65; color: #48546a; }
.hero-actions { margin-top: 35px; display: flex; align-items: center; gap: 32px; }
.button { display: inline-flex; align-items: center; justify-content: space-between; gap: 32px; padding: 17px 22px; border-radius: 999px; font-size: 13px; font-weight: 600; transition: transform .2s, box-shadow .2s, background .2s; }
.button:hover { transform: translateY(-3px); }
.button-primary { color: white; background: var(--orange); box-shadow: 0 10px 28px rgba(255, 80, 23, .18); }
.button-primary:hover { background: var(--navy); box-shadow: 0 12px 30px rgba(7, 26, 61, .2); }
.text-link { font-size: 13px; font-weight: 600; padding-bottom: 5px; border-bottom: 1px solid var(--ink); }
.text-link span { margin-left: 12px; color: var(--orange); }

.hero-art { width: min(40vw, 600px); aspect-ratio: 1; position: relative; justify-self: center; display: grid; place-items: center; }
.shell-wrap { position: relative; width: 61%; z-index: 2; animation: float 5s ease-in-out infinite; }
.shell { width: 100%; filter: drop-shadow(0 30px 35px rgba(7, 26, 61, .18)); }
.shell-halo { position: absolute; width: 120%; aspect-ratio: 1; border-radius: 50%; left: -10%; top: 5%; background: radial-gradient(circle, rgba(255, 100, 42, .18), transparent 68%); filter: blur(10px); }
.orbit { position: absolute; border: 1px solid rgba(7, 26, 61, .12); border-radius: 50%; }
.orbit::after { content: ""; position: absolute; width: 8px; height: 8px; background: var(--orange); border-radius: 50%; }
.orbit-one { width: 85%; height: 85%; transform: rotate(24deg); }
.orbit-one::after { top: 15%; right: 12%; }
.orbit-two { width: 65%; height: 95%; transform: rotate(-42deg); }
.orbit-two::after { bottom: 7%; left: 25%; width: 5px; height: 5px; }
.art-note { position: absolute; font-size: 9px; text-transform: uppercase; letter-spacing: .2em; color: #7a8190; }
.art-note-top { right: 0; top: 14%; transform: rotate(90deg) translateX(100%); transform-origin: right top; }
.art-note-bottom { left: 2%; bottom: 9%; }
@keyframes float { 50% { transform: translateY(-13px) rotate(1deg); } }

.hero-foot { grid-column: 1 / -1; margin-top: 55px; display: grid; grid-template-columns: 1fr 1fr 1fr; align-items: end; font-size: 10px; line-height: 1.65; text-transform: uppercase; letter-spacing: .12em; color: #6f7582; }
.hero-foot p { margin: 0; }
.hero-foot-right { text-align: right; }
.scroll-cue { justify-self: center; display: flex; flex-direction: column; align-items: center; gap: 8px; }
.scroll-cue i { width: 34px; height: 34px; display: grid; place-items: center; border: 1px solid var(--line); border-radius: 50%; color: var(--orange); font-style: normal; }

.capability-rail { padding: 0 7vw; display: grid; grid-template-columns: .28fr 1.72fr; align-items: stretch; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); background: #f3ece2; }
.capability-rail > p { margin: 0; padding: 30px 30px 30px 0; display: flex; align-items: center; border-right: 1px solid var(--line); color: var(--orange); font-size: 9px; font-weight: 600; letter-spacing: .16em; text-transform: uppercase; }
.capability-items { display: grid; grid-template-columns: repeat(4, 1fr); }
.capability-items a { min-height: 104px; padding: 24px 22px; display: grid; grid-template-columns: 1fr auto; grid-template-rows: auto 1fr; align-items: end; border-right: 1px solid var(--line); font: 500 15px var(--display); transition: color .25s, background .25s; }
.capability-items a:last-child { border-right: 0; }
.capability-items a > span { grid-column: 1 / -1; align-self: start; color: #9499a3; font: 400 8px var(--sans); letter-spacing: .12em; }
.capability-items i { color: var(--orange); font: normal 12px var(--sans); transition: transform .25s; }
.capability-items a:hover { color: white; background: var(--navy); }
.capability-items a:hover i { transform: translate(3px, -3px); }

.section { padding: 140px 7vw; }
.section-heading { display: grid; grid-template-columns: 1.5fr .65fr; column-gap: 9vw; align-items: end; margin-bottom: 85px; }
.section-heading .eyebrow { grid-column: 1 / -1; }
.section-heading h2, .work-heading h2, .approach h2, .contact h2 { font-size: clamp(47px, 5.4vw, 80px); line-height: 1.02; }
.section-heading > p:last-child, .work-heading > p:last-child { color: var(--muted); line-height: 1.7; margin: 0 0 6px; font-size: 15px; }
.service-list { border-top: 1px solid var(--line); }
.service-card { min-height: 230px; display: grid; grid-template-columns: 9% 1fr auto; gap: 4vw; align-items: center; border-bottom: 1px solid var(--line); transition: padding .3s, background .3s; }
.service-card:hover { background: rgba(255, 255, 255, .48); padding: 0 2vw; }
.service-number { font-size: 10px; letter-spacing: .15em; color: var(--orange); align-self: start; padding-top: 52px; }
.service-content { display: grid; grid-template-columns: minmax(210px, .75fr) 1.2fr .9fr; gap: 4vw; align-items: center; }
.service-content h3 { margin: 0; font-family: var(--display); font-size: clamp(30px, 3vw, 46px); font-weight: 500; letter-spacing: -.05em; }
.service-content p { max-width: 440px; margin: 0; line-height: 1.65; color: var(--muted); font-size: 14px; }
.service-content ul { list-style: none; padding: 0; margin: 0; font-size: 11px; line-height: 2; text-transform: uppercase; letter-spacing: .08em; color: #5d6472; }
.service-icon { width: 47px; height: 47px; display: grid; place-items: center; border: 1px solid var(--line); border-radius: 50%; color: var(--orange); transition: color .25s, background .25s, transform .25s; }
.service-card:hover .service-icon { color: white; background: var(--orange); transform: rotate(45deg); }

.work { color: white; background: var(--navy); }
.work-heading { display: grid; grid-template-columns: 1fr .7fr; align-items: end; gap: 8vw; margin-bottom: 80px; }
.work-heading .eyebrow { grid-column: 1 / -1; }
.work-heading h2 { color: white; }
.work-heading > p:last-child { color: rgba(255,255,255,.58); max-width: 390px; }
.project-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px 3vw; }
.project-large { grid-column: 1 / -1; }
.project-visual { overflow: hidden; position: relative; min-height: 560px; display: grid; place-items: center; }
.project-large .project-visual { min-height: 690px; }
.visual-one { background: linear-gradient(135deg, #efb585, #e47b52); }
.visual-two { background: #d8ab87; }
.visual-three { background: #f0d6c4; }
.mock-browser { width: 79%; height: 74%; padding: 0 0 30px; border-radius: 12px 12px 0 0; color: var(--navy); background: #f8eee0; box-shadow: 0 40px 80px rgba(7, 26, 61, .24); transform: translateY(10%); transition: transform .7s cubic-bezier(.2,.8,.2,1); }
.project:hover .mock-browser { transform: translateY(6%); }
.browser-bar { padding: 13px 17px; display: flex; gap: 6px; border-bottom: 1px solid rgba(7,26,61,.1); }
.browser-bar i { width: 7px; height: 7px; border-radius: 50%; background: #d6c7b6; }
.browser-content { height: calc(100% - 34px); padding: 8%; display: flex; flex-direction: column; align-items: flex-start; justify-content: center; background: radial-gradient(circle at 76% 50%, rgba(43, 110, 88, .18), transparent 25%); }
.browser-content span { font-size: 11px; letter-spacing: .2em; }
.browser-content strong { margin: 35px 0; font: 500 clamp(34px, 5vw, 75px)/1.03 var(--serif); }
.browser-content b { font: 600 10px var(--sans); text-transform: uppercase; letter-spacing: .15em; padding-bottom: 5px; border-bottom: 1px solid; }
.phone { width: 48%; min-width: 240px; height: 78%; color: var(--navy); background: #f8f3ec; border: 7px solid var(--navy); border-radius: 38px 38px 0 0; padding: 55px 24px 25px; transform: translateY(12%); box-shadow: 0 35px 60px rgba(7,26,61,.22); position: relative; transition: transform .7s; }
.project:hover .phone { transform: translateY(8%); }
.phone-notch { position: absolute; top: 13px; left: 50%; transform: translateX(-50%); width: 31%; height: 17px; border-radius: 20px; background: var(--navy); }
.phone > small { font-size: 9px; color: #777; }
.phone > strong { display: block; margin: 12px 0 32px; font: 600 23px/1.2 var(--display); letter-spacing: -.04em; }
.phone-chart { height: 120px; display: flex; align-items: end; gap: 9px; padding: 12px 16px 0; background: #fff; border-radius: 12px; }
.phone-chart i { flex: 1; height: 45%; background: var(--peach); border-radius: 6px 6px 0 0; }
.phone-chart i:nth-child(2) { height: 65%; }.phone-chart i:nth-child(3) { height: 52%; }.phone-chart i:nth-child(4) { height: 82%; background: var(--orange); }.phone-chart i:nth-child(5) { height: 72%; }
.phone-stats { margin-top: 16px; display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.phone-stats span { padding: 13px; border-radius: 9px; background: #fff; font: 600 18px var(--display); }
.phone-stats small { display: block; font: 8px var(--sans); color: #777; margin-top: 4px; }
.search-card { width: 76%; padding: 8%; color: var(--navy); background: rgba(255,255,255,.7); box-shadow: 0 35px 60px rgba(7,26,61,.12); transition: transform .5s; }
.project:hover .search-card { transform: translateY(-8px); }
.search-card > small { font-size: 10px; text-transform: uppercase; letter-spacing: .12em; }
.search-card > strong { display: block; font: 500 clamp(55px, 8vw, 110px) var(--display); letter-spacing: -.07em; color: var(--orange); }
.line-chart { height: 145px; margin: 10px 0; }
.line-chart svg { width: 100%; height: 100%; overflow: visible; }
.line-chart path { fill: none; stroke: var(--navy); stroke-width: 3; vector-effect: non-scaling-stroke; }
.search-card > span { font-size: 10px; color: #777; }
.project-meta { margin-top: 22px; display: flex; justify-content: space-between; align-items: start; }
.project-meta h3 { margin: 0 0 6px; font: 500 24px var(--display); }
.project-meta p, .project-meta > span { margin: 0; font-size: 11px; color: rgba(255,255,255,.55); text-transform: uppercase; letter-spacing: .1em; }
.placeholder-note { margin: 55px 0 0; text-align: center; font-size: 9px; text-transform: uppercase; letter-spacing: .16em; color: rgba(255,255,255,.38); }

.approach { display: grid; grid-template-columns: .65fr 1.35fr; gap: 9vw; align-items: center; overflow: hidden; }
.approach-mark { position: relative; display: grid; place-items: center; }
.approach-mark::before, .approach-mark::after { content: ""; position: absolute; width: 36vw; max-width: 540px; aspect-ratio: 1; border: 1px solid var(--line); border-radius: 50%; }
.approach-mark::after { width: 27vw; max-width: 400px; }
.approach-mark img { width: 54%; position: relative; z-index: 2; filter: drop-shadow(0 24px 30px rgba(7,26,61,.15)); }
.approach-copy > .eyebrow { margin-bottom: 36px; }
.approach-lead { font-size: clamp(18px, 2vw, 25px); line-height: 1.6; color: #4c576b; max-width: 720px; margin: 38px 0 55px; }
.principles { border-top: 1px solid var(--line); }
.principles > div { display: grid; grid-template-columns: 50px .7fr 1fr; gap: 20px; align-items: baseline; padding: 28px 0; border-bottom: 1px solid var(--line); }
.principles span { color: var(--orange); font-size: 10px; }
.principles h3 { font: 500 17px var(--display); margin: 0; }
.principles p { color: var(--muted); font-size: 13px; line-height: 1.6; margin: 0; }

.testimonial { position: relative; min-height: 650px; display: flex; flex-direction: column; justify-content: center; align-items: center; text-align: center; background: #f3e9dc; }
.quote-mark { height: 75px; color: var(--orange); font: 500 115px/1 var(--serif); }
.testimonial blockquote { max-width: 970px; margin: 20px auto 35px; font: 500 clamp(35px, 4.6vw, 68px)/1.18 var(--serif); letter-spacing: -.035em; }
.quote-source { display: flex; gap: 12px; align-items: start; text-align: left; font-size: 11px; line-height: 1.6; text-transform: uppercase; letter-spacing: .08em; }
.quote-source span { color: var(--orange); }
.quote-source p { margin: 0; }
.testimonial .placeholder-note { color: rgba(7,26,61,.4); margin-top: 30px; }

.contact { min-height: 730px; padding: 130px 8vw; position: relative; display: flex; align-items: center; overflow: hidden; color: white; background: var(--navy); }
.contact-inner { position: relative; z-index: 2; }
.contact h2 { color: white; font-size: clamp(52px, 7vw, 102px); }
.contact p:not(.eyebrow) { max-width: 520px; margin: 35px 0; color: rgba(255,255,255,.62); line-height: 1.65; }
.contact-actions { display: flex; gap: 32px; align-items: center; }
.button-light { color: var(--navy); background: white; }
.button-light:hover { background: var(--orange); color: white; }
.light-link { color: white; border-color: rgba(255,255,255,.5); }
.contact-shell { position: absolute; right: -3vw; bottom: -18%; width: min(40vw, 620px); opacity: .75; filter: saturate(.85) drop-shadow(0 20px 60px rgba(0,0,0,.3)); transform: rotate(-12deg); }
.contact-glow { position: absolute; right: -10%; bottom: -30%; width: 65vw; height: 65vw; border-radius: 50%; background: radial-gradient(circle, rgba(255,80,23,.2), transparent 68%); }

footer { min-height: 280px; padding: 65px 7vw 35px; display: grid; grid-template-columns: 1fr 1fr; align-items: start; background: var(--paper); }
.footer-brand { width: 180px; }
.footer-links { display: flex; justify-content: flex-end; gap: 32px; font-size: 12px; font-weight: 600; }
.footer-links a:hover { color: var(--orange); }
.footer-meta { grid-column: 1 / -1; align-self: end; display: flex; justify-content: space-between; padding-top: 25px; border-top: 1px solid var(--line); color: #747b88; font-size: 9px; text-transform: uppercase; letter-spacing: .13em; }

.reveal { opacity: 0; transform: translateY(25px); transition: opacity .8s ease, transform .8s cubic-bezier(.2,.8,.2,1); }
.reveal.visible { opacity: 1; transform: none; }

/* Interior pages */
.site-nav a.active:not(.nav-cta) { color: var(--orange); }
.page-hero { min-height: 760px; padding: 180px 7vw 100px; display: grid; grid-template-columns: 1.45fr .55fr; align-items: end; gap: 9vw; position: relative; overflow: hidden; }
.page-hero::after { content: ""; position: absolute; width: 55vw; height: 55vw; border-radius: 50%; right: -25vw; top: -26vw; border: 1px solid var(--line); box-shadow: 0 0 0 9vw rgba(255, 80, 23, .025), 0 0 0 18vw rgba(255, 80, 23, .018); }
.page-hero-copy { position: relative; z-index: 1; }
.page-hero h1, .about-hero h1, .contact-page-intro h1 { margin: 0; font: 500 clamp(62px, 8vw, 125px)/.93 var(--display); letter-spacing: -.07em; }
.page-hero-copy > p:last-child { max-width: 620px; margin: 38px 0 0; font-size: 18px; line-height: 1.7; color: var(--muted); }
.page-index { padding: 30px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.page-index > span { font-size: 9px; text-transform: uppercase; letter-spacing: .17em; color: var(--orange); }
.page-index ol { list-style: none; counter-reset: item; padding: 0; margin: 20px 0 0; }
.page-index li { counter-increment: item; padding: 8px 0; font: 500 15px var(--display); }
.page-index li::before { content: "0" counter(item); display: inline-block; width: 45px; color: #959aa5; font: 400 9px var(--sans); }

.service-detail { min-height: 770px; padding: 110px 7vw; display: grid; grid-template-columns: .22fr 1.25fr .75fr; gap: 5vw; align-items: center; position: relative; overflow: hidden; }
.detail-aside { align-self: stretch; display: flex; flex-direction: column; justify-content: space-between; border-right: 1px solid currentColor; border-color: rgba(7,26,61,.15); }
.detail-aside span { color: var(--orange); font-size: 10px; }
.detail-aside p { writing-mode: vertical-rl; transform: rotate(180deg); margin: 0 16px 0 0; font-size: 10px; text-transform: uppercase; letter-spacing: .16em; }
.detail-main { position: relative; z-index: 2; }
.detail-main h2 { margin: 0; font: 500 clamp(45px, 5.2vw, 76px)/1.03 var(--display); letter-spacing: -.06em; }
.detail-lead { max-width: 680px; margin: 32px 0 55px; font-size: 18px; line-height: 1.65; color: var(--muted); }
.detail-columns { display: grid; grid-template-columns: 1fr 1fr; gap: 5vw; }
.detail-columns h3 { margin: 0 0 19px; font: 600 10px var(--sans); text-transform: uppercase; letter-spacing: .15em; color: var(--orange); }
.detail-columns ul { padding: 0; margin: 0; list-style: none; font-size: 13px; line-height: 2; }
.detail-columns li::before { content: "—"; margin-right: 12px; color: var(--orange); }
.detail-columns p { margin: 0; font-size: 13px; line-height: 1.75; color: var(--muted); }
.detail-art { aspect-ratio: .85; display: grid; place-items: center; position: relative; }
.orange-detail { background: #fffaf4; }
.navy-detail { color: white; background: var(--navy); }
.navy-detail .detail-aside { border-color: rgba(255,255,255,.18); }
.navy-detail .detail-lead, .navy-detail .detail-columns p { color: rgba(255,255,255,.6); }
.cream-detail { background: #f1e7da; }
.peach-detail { background: #ffd0b5; }
.mini-window { width: 86%; aspect-ratio: .72; padding: 16%; display: flex; flex-direction: column; justify-content: center; background: var(--navy); color: white; box-shadow: 25px 30px 0 var(--peach); transform: rotate(4deg); }
.mini-window span { width: 30px; height: 3px; background: var(--orange); margin-bottom: 45px; }
.mini-window strong { font: 500 clamp(28px, 3vw, 46px)/1.05 var(--serif); }
.mini-window i { margin-top: 48px; font: normal 8px var(--sans); text-transform: uppercase; letter-spacing: .15em; color: rgba(255,255,255,.55); }
.search-art::before, .search-art::after { content: ""; position: absolute; width: 90%; aspect-ratio: 1; border-radius: 50%; border: 1px solid rgba(255,255,255,.18); }
.search-art::after { width: 60%; }
.search-orbit { width: 63%; aspect-ratio: 1; border-radius: 50%; display: flex; flex-direction: column; justify-content: center; align-items: center; background: var(--orange); position: relative; z-index: 1; box-shadow: 0 20px 50px rgba(0,0,0,.2); }
.search-orbit strong { font: 500 clamp(42px, 5vw, 72px) var(--display); letter-spacing: -.07em; }
.search-orbit span { font-size: 8px; text-transform: uppercase; letter-spacing: .15em; }
.app-screen { width: 90%; padding: 12%; color: white; background: var(--navy); box-shadow: 20px 25px 0 rgba(255,255,255,.5); }
.app-screen small { font-size: 8px; text-transform: uppercase; letter-spacing: .15em; color: var(--peach); }
.app-screen b { display: block; margin: 30px 0 50px; font: 500 clamp(28px, 3vw, 44px)/1.08 var(--display); }
.app-screen > div { height: 120px; display: flex; align-items: end; gap: 10px; }
.app-screen i { flex: 1; height: 45%; border-radius: 6px 6px 0 0; background: var(--coral); }
.app-screen i:nth-child(2) { height: 90%; background: var(--orange); }.app-screen i:nth-child(3) { height: 68%; }
.ai-art::before { content: ""; position: absolute; width: 105%; aspect-ratio: 1; border: 1px solid rgba(7,26,61,.18); border-radius: 50%; }
.ai-art img { width: 65%; position: relative; z-index: 1; filter: drop-shadow(0 20px 30px rgba(7,26,61,.18)); }
.process-section { background: var(--paper); }
.process-grid { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.process-grid > div { min-height: 280px; padding: 34px 30px; border-right: 1px solid var(--line); }
.process-grid > div:last-child { border: 0; }
.process-grid span { color: var(--orange); font-size: 10px; }
.process-grid h3 { margin: 75px 0 14px; font: 500 24px var(--display); }
.process-grid p { margin: 0; color: var(--muted); font-size: 13px; line-height: 1.7; }
.mini-cta { min-height: 500px; padding: 90px 7vw; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; color: white; background: var(--orange); }
.mini-cta p { margin: 0 0 20px; font-size: 10px; text-transform: uppercase; letter-spacing: .16em; }
.mini-cta h2 { max-width: 900px; margin: 0 0 40px; font: 500 clamp(42px, 5.5vw, 80px)/1.05 var(--serif); }
.mini-cta .button-light:hover { color: white; background: var(--navy); box-shadow: 0 12px 28px rgba(7, 26, 61, .2); }

/* Work page */
.work-page-hero { min-height: 800px; }
.concept-badge { justify-self: end; width: 145px; height: 145px; border-radius: 50%; display: grid; place-items: center; text-align: center; color: white; background: var(--orange); font-size: 9px; line-height: 1.7; text-transform: uppercase; letter-spacing: .14em; transform: rotate(8deg); }
.case-study { padding: 100px 7vw 130px; }
.case-visual { min-height: 720px; display: grid; place-items: end center; overflow: hidden; }
.case-palm .case-visual { background: linear-gradient(135deg,#f4c79d,#dd7650); }
.case-browser { width: 82%; height: 80%; background: #f8efe2; color: var(--navy); box-shadow: 0 35px 80px rgba(7,26,61,.2); transform: translateY(8%); }
.case-browser nav { height: 65px; padding: 0 5%; display: flex; justify-content: space-between; align-items: center; font-size: 10px; letter-spacing: .13em; }
.case-browser nav span { font-size: 8px; }
.case-browser main { height: calc(100% - 65px); padding: 8%; display: flex; flex-direction: column; justify-content: center; background: radial-gradient(circle at 78% 48%, rgba(68,120,88,.2), transparent 28%); }
.case-browser small { font-size: 8px; letter-spacing: .15em; }
.case-browser h2 { margin: 25px 0 40px; font: 500 clamp(48px, 7vw, 100px)/.95 var(--serif); }
.case-browser h2 i { color: #ae634c; font-weight: 400; }
.case-browser a { align-self: flex-start; padding-bottom: 6px; border-bottom: 1px solid; font-size: 9px; text-transform: uppercase; letter-spacing: .13em; }
.case-copy { padding-top: 34px; display: grid; grid-template-columns: 1fr 1fr; gap: 7vw; }
.case-copy span, .case-copy dt { font-size: 8px; text-transform: uppercase; letter-spacing: .15em; color: var(--orange); }
.case-copy h2 { margin: 8px 0 0; font: 500 38px var(--display); letter-spacing: -.04em; }
.case-copy > p { margin: 0; font-size: 17px; line-height: 1.65; color: var(--muted); }
.case-copy dl { grid-column: 2; display: grid; grid-template-columns: 1fr 1fr; padding-top: 25px; border-top: 1px solid var(--line); }
.case-copy dt { color: #979ba4; }
.case-copy dd { margin: 8px 0 0; font-size: 11px; }
.case-tide { color: white; background: var(--navy); }
.case-tide .case-visual { background: #d3a47d; }
.case-tide .case-copy > p { color: rgba(255,255,255,.58); }
.case-tide .case-copy dl { border-color: rgba(255,255,255,.15); }
.dashboard { width: 85%; height: 76%; padding: 0 6% 5%; color: var(--navy); background: #f7f3ed; box-shadow: 0 35px 75px rgba(7,26,61,.25); transform: translateY(9%); }
.dashboard header { height: 64px; display: flex; justify-content: space-between; align-items: center; border-bottom: 1px solid var(--line); font-size: 10px; }
.dashboard header span { font-size: 8px; color: #777; }
.dash-title { padding: 55px 0 30px; }
.dash-title small, .dash-cards small { font-size: 8px; text-transform: uppercase; letter-spacing: .12em; color: #8b8f97; }
.dash-title h2 { margin: 7px 0 0; font: 500 34px var(--display); }
.dash-cards { display: grid; grid-template-columns: .7fr .7fr 1.6fr; gap: 14px; }
.dash-cards > div { min-height: 150px; padding: 24px; border: 1px solid var(--line); background: white; }
.dash-cards strong { display: block; margin-top: 30px; font: 500 45px var(--display); }
.dash-chart svg { width: 100%; height: 85px; margin-top: 15px; }
.dash-chart path { fill: none; stroke: var(--orange); stroke-width: 3; vector-effect: non-scaling-stroke; }
.case-north .case-visual { background: #f1dac9; }
.growth-panel { width: 75%; padding: 7%; background: rgba(255,255,255,.7); box-shadow: 0 30px 70px rgba(7,26,61,.13); }
.growth-panel small { font-size: 9px; letter-spacing: .15em; }
.growth-panel strong { display: block; margin: 20px 0 0; color: var(--orange); font: 500 clamp(75px, 12vw, 180px)/.9 var(--display); letter-spacing: -.08em; }
.growth-panel span { font-size: 10px; color: var(--muted); }
.growth-panel svg { display: block; width: 100%; height: 190px; margin-top: 20px; }
.growth-panel path { fill: none; stroke: var(--navy); stroke-width: 3; vector-effect: non-scaling-stroke; }
.portfolio-disclaimer { margin: 0; padding: 35px; text-align: center; font-size: 9px; text-transform: uppercase; letter-spacing: .14em; color: #858b95; background: #eee8df; }

/* About page */
.about-hero { min-height: 980px; padding: 175px 7vw 100px; display: grid; grid-template-columns: 1.2fr .8fr; grid-template-rows: 1fr auto; align-items: center; gap: 4vw; overflow: hidden; }
.about-shell { height: 600px; display: grid; place-items: center; position: relative; }
.about-shell div { position: absolute; width: 115%; aspect-ratio: 1; border: 1px solid var(--line); border-radius: 50%; box-shadow: 0 0 0 9vw rgba(255,80,23,.02); }
.about-shell img { width: 59%; position: relative; z-index: 1; filter: drop-shadow(0 28px 35px rgba(7,26,61,.18)); animation: float 5s ease-in-out infinite; }
.about-intro { grid-column: 1 / -1; max-width: 850px; margin: 10px 0 0 12vw; font: 500 clamp(22px,2.5vw,36px)/1.5 var(--serif); }
.manifesto { min-height: 760px; padding: 120px 10vw; display: flex; flex-direction: column; justify-content: center; color: white; background: var(--navy); }
.manifesto > p { margin: 0 0 50px; color: var(--orange); font-size: 10px; text-transform: uppercase; letter-spacing: .16em; }
.manifesto h2 { max-width: 1150px; margin: 0; font: 400 clamp(38px,5.3vw,78px)/1.2 var(--display); letter-spacing: -.055em; }
.values-section { display: grid; grid-template-columns: .7fr 1.3fr; gap: 10vw; }
.values-intro h2, .founder-copy h2 { margin: 0; font: 500 clamp(46px,5vw,73px)/1.02 var(--display); letter-spacing: -.06em; }
.values-list { border-top: 1px solid var(--line); }
.values-list article { display: grid; grid-template-columns: 45px .85fr 1.15fr; gap: 25px; align-items: baseline; padding: 36px 0; border-bottom: 1px solid var(--line); }
.values-list span { font-size: 9px; color: var(--orange); }
.values-list h3 { margin: 0; font: 500 20px var(--display); }
.values-list p { margin: 0; font-size: 13px; line-height: 1.7; color: var(--muted); }
.founder-placeholder { min-height: 850px; padding: 120px 7vw; display: grid; grid-template-columns: .8fr 1.2fr; gap: 10vw; align-items: center; background: #f1e5d7; }
.founder-visual { height: 580px; display: grid; place-items: center; position: relative; background: #e2b697; overflow: hidden; }
.founder-visual img { width: 60%; opacity: .55; filter: saturate(.5); }
.founder-visual span { position: absolute; left: 25px; bottom: 22px; font-size: 8px; text-transform: uppercase; line-height: 1.7; letter-spacing: .14em; }
.founder-copy > p:not(.eyebrow) { max-width: 680px; color: var(--muted); font-size: 16px; line-height: 1.75; }
.founder-copy h2 + p { margin-top: 38px; }

/* Contact page */
.contact-page { background: var(--navy); }
.contact-page .site-header { background: rgba(250,246,239,.94); backdrop-filter: blur(16px); }
.contact-page-main { min-height: 100vh; padding: 170px 7vw 130px; display: grid; grid-template-columns: .85fr 1.15fr; gap: 9vw; color: white; position: relative; overflow: hidden; }
.contact-page-intro { position: relative; z-index: 2; }
.contact-page-intro h1 { font-size: clamp(58px,6.7vw,100px); }
.contact-page-intro > p:not(.eyebrow) { max-width: 490px; margin: 35px 0 55px; line-height: 1.7; color: rgba(255,255,255,.6); }
.direct-contact { display: flex; flex-direction: column; gap: 10px; font-size: 10px; text-transform: uppercase; letter-spacing: .12em; color: rgba(255,255,255,.45); }
.direct-contact a { align-self: flex-start; display: inline-flex; align-items: center; gap: 9px; color: var(--peach); text-transform: none; letter-spacing: 0; font-size: 14px; border-bottom: 1px solid rgba(255,190,156,.35); padding-bottom: 5px; }
.inquiry-wrap { position: relative; z-index: 2; padding: 48px; color: var(--navy); background: var(--paper); box-shadow: 0 30px 80px rgba(0,0,0,.25); }
.inquiry-form { display: flex; flex-direction: column; gap: 28px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.inquiry-form label, .inquiry-form legend { display: flex; flex-direction: column; gap: 9px; font: 600 10px var(--sans); text-transform: uppercase; letter-spacing: .1em; }
.inquiry-form label > span { color: #969ba4; font-size: 8px; }
.inquiry-form input, .inquiry-form textarea, .inquiry-form select { width: 100%; border: 0; border-bottom: 1px solid var(--line); border-radius: 0; padding: 12px 0; color: var(--navy); background: transparent; font: 400 14px var(--sans); outline: none; text-transform: none; letter-spacing: 0; }
.inquiry-form input:focus, .inquiry-form textarea:focus, .inquiry-form select:focus { border-color: var(--orange); }
.inquiry-form textarea { resize: vertical; min-height: 120px; }
.inquiry-form fieldset { padding: 0; margin: 0; border: 0; }
.inquiry-form legend { margin-bottom: 15px; }
.choice-grid { display: flex; flex-wrap: wrap; gap: 8px; }
.choice-grid label { display: block; }
.choice-grid input { position: absolute; opacity: 0; pointer-events: none; }
.choice-grid span { display: block; padding: 11px 14px; border: 1px solid var(--line); border-radius: 999px; color: #535e72; font-size: 9px; transition: color .2s, background .2s, border .2s; cursor: pointer; }
.choice-grid input:checked + span { color: white; border-color: var(--orange); background: var(--orange); }
.form-submit { align-self: flex-start; min-width: 220px; padding: 16px 20px; display: flex; justify-content: space-between; border: 0; border-radius: 999px; color: white; background: var(--orange); font: 600 12px var(--sans); cursor: pointer; transition: transform .2s, background .2s; }
.form-submit:hover { transform: translateY(-2px); background: var(--navy); }
.form-note { margin: -15px 0 0; color: #979ba3; font-size: 8px; line-height: 1.6; }
.form-success { padding: 18px; display: flex; flex-direction: column; gap: 5px; border-left: 3px solid var(--orange); background: #fff0e6; }
.form-success[hidden] { display: none; }
.form-success strong { font: 500 15px var(--display); }
.form-success span { color: var(--muted); font-size: 11px; }
.contact-page-shell { position: absolute; width: 36vw; left: -13vw; bottom: -17vw; opacity: .13; transform: rotate(25deg); }
.dark-footer { color: white; background: #051631; }
.dark-footer .footer-brand { filter: brightness(0) invert(1); opacity: .85; }
.dark-footer .footer-meta { border-color: rgba(255,255,255,.12); color: rgba(255,255,255,.45); }

@media (max-width: 980px) {
  .hero { padding-top: 125px; grid-template-columns: minmax(0, 1fr); }
  .hero-art { position: absolute; right: -9vw; top: 22%; width: 50vw; opacity: .34; }
  .hero-copy { z-index: 3; }
  .hero-intro { max-width: 560px; }
  .section-heading, .work-heading { grid-template-columns: 1fr; }
  .section-heading h2, .work-heading h2 { margin-bottom: 25px; }
  .section-heading > p:last-child, .work-heading > p:last-child { max-width: 580px; }
  .service-content { grid-template-columns: .8fr 1.2fr; }
  .service-content ul { display: none; }
  .project-visual, .project-large .project-visual { min-height: 480px; }
  .approach { grid-template-columns: 1fr; }
  .approach-mark { display: none; }
  .service-detail { grid-template-columns: 45px 1fr; }
  .detail-art { display: none; }
  .process-grid { grid-template-columns: 1fr 1fr; }
  .process-grid > div:nth-child(2) { border-right: 0; }
  .process-grid > div:nth-child(-n+2) { border-bottom: 1px solid var(--line); }
  .case-visual { min-height: 570px; }
  .values-section { grid-template-columns: 1fr; }
  .founder-placeholder { grid-template-columns: .8fr 1.2fr; gap: 6vw; }
  .contact-page-main { grid-template-columns: 1fr; }
  .contact-page-intro { max-width: 750px; }
}

@media (max-width: 720px) {
  .site-header, .site-header.scrolled { inset: 12px 14px auto; width: auto; height: 60px; padding: 0 9px 0 17px; border: 1px solid rgba(7, 26, 61, .1); border-radius: 18px; background: rgba(255, 250, 244, .98); box-shadow: 0 10px 34px rgba(7, 26, 61, .09); backdrop-filter: none; }
  .brand { width: 137px; position: relative; z-index: 3; }
  .menu-toggle { width: 42px; height: 42px; padding: 0; display: grid; place-content: center; gap: 5px; position: relative; z-index: 3; border-radius: 13px; background: var(--orange); cursor: pointer; transition: background .25s, transform .25s; }
  .menu-toggle:active { transform: scale(.94); }
  .menu-toggle span { display: block; width: 19px; height: 1.5px; margin: 0; background: white; transition: transform .25s, background .25s; }
  .menu-toggle.active { background: white; }
  .menu-toggle.active span { background: var(--navy); }
  .menu-toggle.active span:first-child { transform: translateY(3.25px) rotate(45deg); }
  .menu-toggle.active span:last-child { transform: translateY(-3.25px) rotate(-45deg); }
  .site-nav { position: absolute; inset: -13px -15px auto auto; width: 100vw; min-height: 100vh; height: 100dvh; padding: 118px 28px 42px; flex-direction: column; align-items: stretch; justify-content: center; gap: 0; visibility: hidden; color: white; background: var(--navy); font: 500 40px var(--display); transform: translateX(calc(100% + 20px)); transition: transform .4s cubic-bezier(.2,.8,.2,1), visibility 0s .4s; }
  .site-nav.open { visibility: visible; transform: none; transition: transform .4s cubic-bezier(.2,.8,.2,1), visibility 0s; }
  .site-nav > a:not(.nav-cta) { width: 100%; padding: 17px 2px; border-bottom: 1px solid rgba(255,255,255,.16); opacity: 0; transform: translateX(24px); transition: opacity .25s, transform .35s; }
  .site-nav > a:not(.nav-cta)::after { display: none; }
  .site-nav.open > a { opacity: 1; transform: none; }
  .site-nav.open > a:nth-child(1) { transition-delay: .08s; }
  .site-nav.open > a:nth-child(2) { transition-delay: .13s; }
  .site-nav.open > a:nth-child(3) { transition-delay: .18s; }
  .site-nav .nav-cta { width: 100%; margin-top: 30px; padding: 17px 20px; justify-content: center; opacity: 0; transform: translateY(14px); font: 600 13px var(--sans); background: var(--orange); }
  .site-nav.open .nav-cta { opacity: 1; transform: none; transition: opacity .3s .24s, transform .3s .24s, background .2s; }
  .hero { min-height: 920px; padding: 135px 24px 36px; align-items: start; }
  .hero h1 { font-size: clamp(52px, 14vw, 72px); }
  .hero-intro { font-size: 16px; line-height: 1.6; }
  .hero-actions { align-items: flex-start; flex-direction: column; gap: 20px; }
  .hero-art { width: 73vw; top: auto; bottom: 72px; right: -18vw; opacity: .52; }
  .art-note { display: none; }
  .hero-foot { position: absolute; left: 24px; right: 24px; bottom: 30px; grid-template-columns: 1fr 1fr; }
  .hero-foot > p:first-child { display: none; }
  .scroll-cue { justify-self: start; }
  .capability-rail { padding: 0 24px; grid-template-columns: 1fr; }
  .capability-rail > p { padding: 20px 0; border-right: 0; border-bottom: 1px solid var(--line); }
  .capability-items { grid-template-columns: 1fr 1fr; }
  .capability-items a { min-height: 92px; padding: 18px 14px; border-bottom: 1px solid var(--line); }
  .capability-items a:nth-child(2) { border-right: 0; }
  .capability-items a:nth-child(n+3) { border-bottom: 0; }
  .section { padding: 95px 24px; }
  .section-heading { margin-bottom: 55px; }
  .section-heading h2, .work-heading h2, .approach h2 { font-size: 47px; }
  .service-card { min-height: 250px; grid-template-columns: 30px 1fr; gap: 0; padding: 35px 0; }
  .service-card:hover { padding: 35px 10px; }
  .service-number { padding-top: 7px; }
  .service-content { display: block; }
  .service-content h3 { margin-bottom: 18px; }
  .service-icon { display: none; }
  .project-grid { grid-template-columns: 1fr; gap: 60px; }
  .project-large { grid-column: auto; }
  .project-visual, .project-large .project-visual { min-height: 420px; }
  .mock-browser { width: 92%; }
  .browser-content strong { font-size: 39px; }
  .phone { width: 65%; }
  .principles > div { grid-template-columns: 32px 1fr; }
  .principles p { grid-column: 2; }
  .testimonial { min-height: 600px; }
  .testimonial blockquote { font-size: 36px; }
  .contact { min-height: 720px; padding: 100px 24px; align-items: flex-start; }
  .contact h2 { font-size: 55px; }
  .contact-actions { align-items: flex-start; flex-direction: column; gap: 24px; }
  .button-light { gap: 15px; }
  .contact-shell { width: 70vw; right: -14vw; bottom: -8%; opacity: .44; }
  footer { min-height: 320px; padding: 50px 24px 28px; grid-template-columns: 1fr; }
  .footer-links { justify-content: flex-start; flex-wrap: wrap; margin-top: 45px; }
  .footer-meta { gap: 15px; }
  .page-hero { min-height: 760px; padding: 145px 24px 80px; grid-template-columns: 1fr; gap: 55px; }
  .page-hero h1, .about-hero h1 { font-size: 56px; }
  .page-index { max-width: 330px; }
  .service-detail { min-height: auto; padding: 85px 24px; grid-template-columns: 28px 1fr; gap: 20px; }
  .detail-aside p { margin-right: 5px; }
  .detail-main h2 { font-size: 43px; }
  .detail-lead { font-size: 16px; margin-bottom: 38px; }
  .detail-columns { grid-template-columns: 1fr; gap: 32px; }
  .process-grid { grid-template-columns: 1fr; }
  .process-grid > div { min-height: 220px; border-right: 0; border-bottom: 1px solid var(--line); }
  .process-grid > div:nth-child(3) { border-bottom: 1px solid var(--line); }
  .process-grid h3 { margin-top: 45px; }
  .mini-cta { min-height: 480px; padding: 75px 24px; }
  .work-page-hero { min-height: 830px; }
  .concept-badge { justify-self: start; width: 115px; height: 115px; }
  .case-study { padding: 65px 24px 90px; }
  .case-visual { min-height: 430px; }
  .case-browser { width: 92%; height: 82%; }
  .case-browser nav span { display: none; }
  .case-browser h2 { font-size: 43px; }
  .case-copy { grid-template-columns: 1fr; gap: 27px; }
  .case-copy dl { grid-column: 1; }
  .dashboard { width: 94%; height: 82%; padding: 0 5% 4%; }
  .dashboard header span { display: none; }
  .dash-title { padding: 30px 0 20px; }
  .dash-cards { grid-template-columns: 1fr 1fr; }
  .dash-chart { display: none; }
  .growth-panel { width: 90%; }
  .growth-panel svg { height: 120px; }
  .about-hero { min-height: 920px; padding: 145px 24px 75px; grid-template-columns: 1fr; grid-template-rows: auto auto auto; gap: 35px; }
  .about-shell { height: 310px; }
  .about-shell div { width: 90%; }
  .about-shell img { width: 43%; }
  .about-intro { grid-column: 1; margin: 0; font-size: 23px; }
  .manifesto { min-height: 650px; padding: 90px 24px; }
  .manifesto h2 { font-size: 40px; }
  .values-list article { grid-template-columns: 30px 1fr; }
  .values-list p { grid-column: 2; }
  .founder-placeholder { padding: 90px 24px; grid-template-columns: 1fr; }
  .founder-visual { height: 430px; }
  .founder-copy h2 { font-size: 43px; }
  .contact-page-main { padding: 135px 20px 90px; gap: 65px; }
  .contact-page-intro h1 { font-size: 54px; }
  .inquiry-wrap { padding: 32px 22px; }
  .form-row { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}
