/*
Theme Name: Morpho
Theme URI: https://morpho.co
Author: MORPHO Studio
Author URI: https://morpho.co
Description: Bespoke furniture, carpentry and joinery — crafted to the millimetre for the way you live. A premium, cinematic WordPress theme for interior designers, furniture makers, and bespoke craftspeople.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: morpho
Tags: custom-menu, custom-logo, featured-images, full-width-template, portfolio, rtl-language-support, translation-ready
*/

/* ============================================================
   MORPHO — Foundations: Color & Type
   ============================================================ */

@font-face {
  font-family: 'Condor';
  src: url('fonts/Condor-Regular.otf') format('opentype');
  font-weight: 400;
  font-display: swap;
}
@font-face {
  font-family: 'Poppins';
  src: url('fonts/Poppins-Regular.ttf') format('truetype');
  font-weight: 400;
  font-display: swap;
}

:root {
  --morpho-white:  #FFFFFF;
  --morpho-sand:   #D6D2C4;
  --morpho-slate:  #707372;
  --morpho-black:  #000000;

  --sand-100: #F7F6F2;
  --sand-200: #EFEDE6;
  --sand-300: #E5E2D8;
  --sand-400: #D6D2C4;
  --sand-500: #C2BDAB;
  --sand-600: #A9A491;

  --stone-100: #ECEDED;
  --stone-200: #D2D4D3;
  --stone-300: #AEB1B0;
  --stone-400: #8C8F8E;
  --stone-500: #707372;
  --stone-600: #565958;
  --stone-700: #3C3E3D;

  --ink-900: #000000;
  --ink-800: #161616;
  --ink-700: #232423;
  --ink-600: #333534;

  --bg:            var(--morpho-white);
  --bg-alt:        var(--sand-100);
  --bg-sand:       var(--sand-400);
  --bg-ink:        var(--ink-900);

  --fg:            var(--ink-900);
  --fg-muted:      var(--stone-500);
  --fg-faint:      var(--stone-400);
  --fg-on-dark:    var(--morpho-white);
  --fg-on-dark-muted: #A9ABAA;

  --line:          #E2E0D9;
  --line-strong:   #C9C6BC;
  --line-on-dark:  rgba(255,255,255,.16);

  --accent:        var(--ink-900);
  --accent-warm:   var(--sand-500);

  --focus-ring:    #707372;

  --success: #4F6F52;
  --error:   #8A4B3B;
  --error-bg:#F6ECE8;

  --font-display: 'Condor', 'Times New Roman', serif;
  --font-body:    'Poppins', -apple-system, 'Helvetica Neue', Arial, sans-serif;

  --fs-display:  clamp(3.5rem, 1.5rem + 8vw, 8rem);
  --fs-h1:       clamp(2.75rem, 1.6rem + 4.6vw, 5rem);
  --fs-h2:       clamp(2rem, 1.4rem + 2.6vw, 3.25rem);
  --fs-h3:       clamp(1.5rem, 1.2rem + 1.3vw, 2.125rem);
  --fs-h4:       clamp(1.25rem, 1.05rem + 0.8vw, 1.5rem);
  --fs-lead:     clamp(1.125rem, 1rem + 0.6vw, 1.4rem);
  --fs-body:     1.0625rem;
  --fs-small:    0.9375rem;
  --fs-caption:  0.8125rem;
  --fs-eyebrow:  0.75rem;

  --lh-tight:   1.02;
  --lh-snug:    1.12;
  --lh-normal:  1.5;
  --lh-relaxed: 1.7;

  --ls-display: -0.01em;
  --ls-tight:   -0.02em;
  --ls-normal:   0;
  --ls-wide:    0.08em;
  --ls-eyebrow: 0.22em;
  --ls-logo:    0.18em;

  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 48px;
  --space-8: 64px;
  --space-9: 96px;
  --space-10: 128px;
  --space-11: 160px;
  --space-12: 200px;
  --section-y: clamp(64px, 10vw, 160px);
  --gutter:    clamp(20px, 5vw, 80px);
  --maxw:      1440px;

  --radius-0: 0px;
  --radius-sm: 2px;
  --radius-md: 4px;
  --radius-lg: 8px;
  --radius-pill: 999px;

  --shadow-xs: 0 1px 2px rgba(28,26,22,.05);
  --shadow-sm: 0 2px 8px rgba(28,26,22,.06);
  --shadow-md: 0 10px 30px rgba(28,26,22,.08);
  --shadow-lg: 0 24px 60px rgba(28,26,22,.12);
  --shadow-xl: 0 40px 100px rgba(28,26,22,.16);

  --ease-out:   cubic-bezier(0.16, 1, 0.3, 1);
  --ease-inout: cubic-bezier(0.65, 0, 0.35, 1);
  --ease-std:   cubic-bezier(0.4, 0, 0.2, 1);
  --dur-fast:   180ms;
  --dur-base:   320ms;
  --dur-slow:   600ms;
  --dur-reveal: 900ms;

  /* Cinematic motion vars */
  --reveal-y: 24px;
  --reveal-dur: 0.95s;
  --grid-cols: 6;
  --grid-line: rgba(28,26,22,.055);
}

/* ============================================================
   TYPE STYLES
   ============================================================ */
.morpho-display {
  font-family: var(--font-display);
  font-size: var(--fs-display);
  line-height: var(--lh-tight);
  letter-spacing: var(--ls-display);
  font-weight: 400;
}
h1, .h1 { font-family: var(--font-display); font-size: var(--fs-h1); line-height: var(--lh-tight); letter-spacing: var(--ls-tight); font-weight: 400; }
h2, .h2 { font-family: var(--font-display); font-size: var(--fs-h2); line-height: var(--lh-snug); letter-spacing: var(--ls-tight); font-weight: 400; }
h3, .h3 { font-family: var(--font-display); font-size: var(--fs-h3); line-height: var(--lh-snug); font-weight: 400; }
h4, .h4 { font-family: var(--font-display); font-size: var(--fs-h4); line-height: var(--lh-snug); font-weight: 400; }
.lead { font-family: var(--font-body); font-size: var(--fs-lead); line-height: var(--lh-relaxed); color: var(--fg-muted); font-weight: 300; }
body, p, .body { font-family: var(--font-body); font-size: var(--fs-body); line-height: var(--lh-relaxed); font-weight: 400; color: var(--fg); }
.small  { font-size: var(--fs-small); line-height: var(--lh-normal); }
.caption { font-size: var(--fs-caption); color: var(--fg-faint); line-height: var(--lh-normal); }
.eyebrow { font-family: var(--font-body); font-size: var(--fs-eyebrow); letter-spacing: var(--ls-eyebrow); text-transform: uppercase; font-weight: 500; color: var(--fg-muted); }
.wordmark { font-family: var(--font-display); letter-spacing: var(--ls-logo); text-transform: uppercase; font-weight: 400; }

/* ============================================================
   RESET / BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-body);
  font-size: var(--fs-body);
  line-height: var(--lh-relaxed);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: clip;
}
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: 0; background: none; color: inherit; }
img { display: block; max-width: 100%; }
::selection { background: var(--sand-400); color: var(--ink-900); }
:focus-visible { outline: 2px solid var(--focus-ring); outline-offset: 3px; }

/* ============================================================
   LAYOUT PRIMITIVES
   ============================================================ */
.wrap { max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }
.section { padding-block: var(--section-y); }
.section--tight { padding-block: clamp(48px, 7vw, 110px); }

/* Eyebrow */
.eyebrow { display: inline-block; font-family: var(--font-body); font-size: var(--fs-eyebrow); letter-spacing: var(--ls-eyebrow); text-transform: uppercase; font-weight: 500; color: var(--fg-muted); }
.eyebrow--dark { color: var(--fg-on-dark-muted); }

/* Arrow link */
.alink { display: inline-flex; align-items: center; gap: 10px; font-size: var(--fs-eyebrow); letter-spacing: .14em; text-transform: uppercase; font-weight: 500; color: var(--fg); padding-bottom: 5px; position: relative; width: max-content; }
.alink svg { transition: transform .4s var(--ease-out); }
.alink::after { content: ""; position: absolute; left: 0; bottom: 0; width: 100%; height: 1px; background: currentColor; transform: scaleX(0); transform-origin: left; transition: transform .45s var(--ease-out); }
.alink:hover::after { transform: scaleX(1); }
.alink:hover svg { transform: translateX(5px); }
.alink--dark { color: #fff; }

/* Buttons */
.btn { display: inline-flex; align-items: center; gap: 12px; font-size: var(--fs-eyebrow); letter-spacing: .14em; text-transform: uppercase; font-weight: 500; padding: 17px 30px; border: 1px solid transparent; border-radius: var(--radius-sm); transition: background .35s var(--ease-out), color .35s var(--ease-out), border-color .35s var(--ease-out), transform .2s var(--ease-out); }
.btn svg { transition: transform .4s var(--ease-out); }
.btn:hover svg { transform: translateX(5px); }
.btn:active { transform: scale(.985); }
.btn--ink { background: var(--ink-900); color: #fff; }
.btn--ink:hover { background: var(--sand-500); color: var(--ink-900); }
.btn--invert { background: #fff; color: var(--ink-900); }
.btn--invert:hover { background: var(--sand-400); }
.btn--outline { border-color: var(--ink-900); color: var(--ink-900); }
.btn--outline:hover { background: var(--ink-900); color: #fff; }
.btn--outline-light { border-color: rgba(255,255,255,.55); color: #fff; }
.btn--outline-light:hover { background: #fff; color: var(--ink-900); border-color: #fff; }

/* Media */
.media { position: relative; overflow: hidden; background: var(--sand-300); }
.media > img { width: 100%; height: 100%; object-fit: cover; }
.media__label { position: absolute; left: 16px; bottom: 14px; font-size: 10px; letter-spacing: .16em; text-transform: uppercase; color: rgba(0,0,0,.4); }

/* ============================================================
   CINEMATIC MOTION LAYER
   ============================================================ */
.gridlines { position: absolute; inset: 0; z-index: 0; pointer-events: none; background-image: linear-gradient(90deg, var(--grid-line) 0 1px, transparent 1px); background-size: calc(100% / var(--grid-cols)) 100%; border-right: 1px solid var(--grid-line); }

.section, .hero, .svc, .why, .testi, .cta, .footer { position: relative; }
.hero__inner, .svc > .wrap, .why > .wrap, .testi > .wrap, .cta > .wrap, .section > .wrap, .footer__top, .footer__bot { position: relative; z-index: 1; }

.hero   { --grid-line: rgba(255,255,255,.10); }
.svc    { --grid-line: rgba(28,26,22,.05); }
.why    { --grid-line: rgba(255,255,255,.07); }
.testi  { --grid-line: rgba(28,26,22,.05); }
.cta    { --grid-line: rgba(28,26,22,.06); }
.footer { --grid-line: rgba(255,255,255,.06); }

@media (max-width: 900px) { :root { --grid-cols: 4; } }
@media (max-width: 560px) { :root { --grid-cols: 3; } }

/* Block reveal */
.reveal { opacity: 0; transform: translateY(var(--reveal-y)); transition: opacity var(--reveal-dur) var(--ease-out), transform var(--reveal-dur) var(--ease-out); will-change: opacity, transform; }
.reveal.is-in { opacity: 1; transform: none; }

/* Editorial type reveal */
.tr { display: inline-block; overflow: hidden; vertical-align: top; padding-bottom: .14em; margin-bottom: -.14em; }
.tr > span { display: inline-block; transform: translateY(115%); transition: transform var(--reveal-dur) var(--ease-out); transition-delay: var(--d, 0ms); will-change: transform; }
.tr.is-in > span { transform: translateY(0); }

/* Image wipe */
.reveal-img { clip-path: inset(0 100% 0 0); transition: clip-path calc(var(--reveal-dur) * 1.25) var(--ease-out); }
.reveal-img.is-in { clip-path: inset(0 0 0 0); }
.reveal-img > img, .reveal-img > .media__label { transition: transform calc(var(--reveal-dur) * 1.7) var(--ease-out); }
.reveal-img > img { transform: scale(1.09); }
.reveal-img.is-in > img { transform: scale(1); }

@media (prefers-reduced-motion: reduce) {
  .reveal, .reveal.is-in { opacity: 1 !important; transform: none !important; }
  .tr > span { transform: none !important; }
  .reveal-img { clip-path: none !important; }
  .reveal-img > img { transform: none !important; }
}

/* Hero cinematic */
.hero__media { top: -8%; bottom: -8%; height: auto; will-change: transform; }
.hero__media img { transform: scale(var(--hero-zoom, 1.14)); transform-origin: 58% 45%; }
.hero.is-ready .hero__media img { transform: scale(1); transition: transform 2.6s var(--ease-out); }
@media (prefers-reduced-motion: reduce) { .hero__media img { transform: none !important; } }

.hero__inner > * { opacity: 0; transform: translateY(20px); }
.hero.is-ready .hero__inner > * { opacity: 1; transform: none; transition: opacity 1s var(--ease-out), transform 1s var(--ease-out); }
.hero.is-ready .hero__eyebrow { transition-delay: .15s; }
.hero.is-ready .hero__title   { transition-delay: .25s; }
.hero.is-ready .hero__sub     { transition-delay: .5s; }
.hero.is-ready .hero__actions { transition-delay: .62s; }
.hero.is-ready .hero__bar     { transition-delay: .74s; }
@media (prefers-reduced-motion: reduce) { .hero__inner > * { opacity: 1 !important; transform: none !important; } }

/* Curtain */
#curtain { position: fixed; inset: 0; z-index: 300; background: var(--ink-900); color: #fff; display: flex; align-items: center; justify-content: center; overflow: hidden; }
#curtain .cu-wm { font-family: var(--font-display); font-size: clamp(40px, 8vw, 96px); letter-spacing: var(--ls-logo); text-transform: uppercase; line-height: 1; opacity: 0; transform: translateY(14px); animation: cuIn .8s var(--ease-out) .1s forwards; }
#curtain .cu-wm .dot { margin-left: -.06em; }
@keyframes cuIn { to { opacity: 1; transform: none; } }
#curtain.lift { transform: translateY(-100%); transition: transform 1s var(--ease-inout); }
#curtain.gone { display: none; }

/* Progress bar */
#progress { position: fixed; top: 0; left: 0; height: 2px; width: 0%; z-index: 150; background: var(--sand-500); transition: width .1s linear; pointer-events: none; }

/* ============================================================
   NAVIGATION
   ============================================================ */
.nav { position: fixed; inset: 0 0 auto 0; z-index: 100; display: flex; align-items: center; justify-content: space-between; padding: 24px var(--gutter); color: #fff; transition: background .45s var(--ease-out), padding .45s var(--ease-out), border-color .45s var(--ease-out), color .25s var(--ease-out); border-bottom: 1px solid transparent; }
.nav.is-solid { background: rgba(255,255,255,.82); backdrop-filter: blur(16px) saturate(1.1); -webkit-backdrop-filter: blur(16px) saturate(1.1); border-bottom-color: var(--line); color: var(--ink-900); padding-block: 15px; }
.nav__logo { font-family: var(--font-display); font-size: 25px; letter-spacing: var(--ls-logo); padding-left: var(--ls-logo); text-transform: uppercase; line-height: 1; }
.nav__logo .dot { margin-left: -.06em; }
.nav__links { display: flex; gap: 36px; list-style: none; margin: 0; padding: 0; }
.nav__link { font-size: var(--fs-eyebrow); letter-spacing: .14em; text-transform: uppercase; font-weight: 500; color: inherit; opacity: .68; position: relative; padding: 4px 0; transition: opacity .3s var(--ease-out); }
.nav__link:hover { opacity: 1; }
.nav__link::after { content: ""; position: absolute; left: 0; bottom: -1px; width: 100%; height: 1px; background: currentColor; transform: scaleX(0); transform-origin: left; transition: transform .4s var(--ease-out); }
.nav__link:hover::after { transform: scaleX(1); }
.nav__right { display: flex; align-items: center; gap: 16px; }
.nav__cta { font-size: 11px; letter-spacing: .14em; text-transform: uppercase; font-weight: 500; padding: 11px 22px; border-radius: var(--radius-sm); border: 1px solid currentColor; transition: background .35s var(--ease-out), color .35s var(--ease-out); }
.nav.is-solid .nav__cta { background: var(--ink-900); color: #fff; border-color: var(--ink-900); }
.nav.is-solid .nav__cta:hover { background: var(--sand-500); color: var(--ink-900); border-color: var(--sand-500); }
.nav:not(.is-solid) .nav__cta:hover { background: #fff; color: var(--ink-900); }
.nav__burger { display: none; }

/* WordPress nav menu alignment */
.nav__links .menu-item a { font-size: var(--fs-eyebrow); letter-spacing: .14em; text-transform: uppercase; font-weight: 500; color: inherit; opacity: .68; position: relative; padding: 4px 0; transition: opacity .3s var(--ease-out); display: block; }
.nav__links .menu-item a:hover { opacity: 1; }
.nav__links .menu-item { position: relative; }
.nav__links .menu-item a::after { content: ""; position: absolute; left: 0; bottom: -1px; width: 100%; height: 1px; background: currentColor; transform: scaleX(0); transform-origin: left; transition: transform .4s var(--ease-out); }
.nav__links .menu-item a:hover::after { transform: scaleX(1); }

/* ============================================================
   HERO
   ============================================================ */
.hero { position: relative; min-height: 100svh; display: flex; flex-direction: column; justify-content: flex-end; color: #fff; overflow: hidden; }
.hero__media { position: absolute; inset: 0; background: #262523 center/cover no-repeat; }
.hero__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.hero__scrim { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,.42) 0%, rgba(0,0,0,.08) 26%, rgba(0,0,0,0) 50%, rgba(0,0,0,.62) 100%); }
.hero__inner { position: relative; width: 100%; padding-bottom: clamp(40px, 6vw, 76px); }
.hero__eyebrow { color: rgba(255,255,255,.78); margin-bottom: clamp(18px, 3vw, 30px); }
.hero__title { font-family: var(--font-display); font-weight: 400; font-size: var(--fs-display); line-height: .94; letter-spacing: -.015em; margin: 0; max-width: 16ch; }
.hero__sub { font-size: var(--fs-lead); font-weight: 300; line-height: 1.6; color: rgba(255,255,255,.86); max-width: 44ch; margin: clamp(22px,3vw,32px) 0 0; }
.hero__actions { display: flex; gap: 16px; flex-wrap: wrap; margin-top: clamp(28px, 4vw, 40px); }
.hero__bar { position: relative; width: 100%; border-top: 1px solid rgba(255,255,255,.22); margin-top: clamp(40px, 6vw, 70px); display: grid; grid-template-columns: repeat(3, 1fr) auto; gap: 24px; padding-top: 22px; align-items: center; }
.hero__bar-item { display: flex; flex-direction: column; gap: 6px; }
.hero__bar-k { font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: rgba(255,255,255,.55); }
.hero__bar-v { font-family: var(--font-display); font-size: clamp(17px, 1.6vw, 22px); letter-spacing: -.01em; }
.hero__scroll { display: inline-flex; align-items: center; gap: 12px; justify-self: end; font-size: 10px; letter-spacing: .2em; text-transform: uppercase; color: rgba(255,255,255,.7); }
.hero__scroll .bar { width: 46px; height: 1px; background: rgba(255,255,255,.4); position: relative; overflow: hidden; }
.hero__scroll .bar::after { content: ""; position: absolute; inset: 0; background: #fff; animation: cue 2.4s var(--ease-inout) infinite; }
@keyframes cue { 0% { transform: translateX(-100%); } 60%, 100% { transform: translateX(100%); } }

/* ============================================================
   SECTION HEADER
   ============================================================ */
.sec-head { display: grid; grid-template-columns: 1fr auto; gap: 32px; align-items: end; margin-bottom: clamp(40px, 5vw, 64px); }
.sec-head__title { font-family: var(--font-display); font-size: var(--fs-h2); letter-spacing: -.02em; line-height: 1.04; margin: 16px 0 0; max-width: 20ch; }
.sec-head__lead { font-size: var(--fs-lead); font-weight: 300; color: var(--fg-muted); line-height: 1.6; max-width: 38ch; }

/* ============================================================
   INTRO / MANIFESTO
   ============================================================ */
.intro { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: clamp(40px, 7vw, 110px); align-items: center; }
.intro__title { font-family: var(--font-display); font-size: var(--fs-h2); line-height: 1.08; letter-spacing: -.02em; margin: 18px 0 0; max-width: 16ch; }
.intro__body { color: var(--fg-muted); font-size: var(--fs-lead); font-weight: 300; line-height: 1.7; margin: 26px 0 0; max-width: 46ch; }
.intro__meta { display: flex; gap: clamp(40px, 5.5vw, 84px); margin: 46px 0 0; padding-top: 36px; border-top: 1px solid var(--line); }
.intro__meta-n { font-family: var(--font-display); font-size: clamp(46px, 5.4vw, 76px); font-weight: 500; letter-spacing: -.035em; line-height: .92; }
.intro__meta-l { font-size: var(--fs-caption); color: var(--fg-muted); margin-top: 14px; letter-spacing: .06em; text-transform: uppercase; }
.intro__cta { margin-top: 34px; }
.intro__figure { position: relative; margin: 0; }
.intro__figure .media { aspect-ratio: 4/5; }
.intro__tag { position: absolute; left: -1px; bottom: -1px; background: var(--bg); color: var(--fg); padding: 14px 20px; font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--fg-muted); border-top: 1px solid var(--line); border-right: 1px solid var(--line); }

/* ============================================================
   SERVICES — text index
   ============================================================ */
.svct { background: var(--sand-100); }
.svct__cols { display: grid; grid-template-columns: 1fr 1fr; gap: 0 clamp(40px, 5vw, 84px); margin-top: clamp(34px, 4vw, 56px); border-top: 1px solid var(--line-strong); }
.svct__row { position: relative; display: grid; grid-template-columns: auto 1fr auto; gap: clamp(16px, 1.6vw, 26px); align-items: center; padding: clamp(20px, 2vw, 28px) 8px; border-bottom: 1px solid var(--line); cursor: pointer; transition: padding-left .45s var(--ease-out); }
.svct__row::before { content: ""; position: absolute; inset: 0 -8px; z-index: 0; background: var(--bg); opacity: 0; transition: opacity .4s var(--ease-out); }
.svct__row:hover { padding-left: 22px; }
.svct__row:hover::before { opacity: 1; }
.svct__row > * { position: relative; z-index: 1; }
.svct__n { font-size: var(--fs-caption); letter-spacing: .14em; color: var(--fg-faint); min-width: 28px; }
.svct__main { display: flex; flex-direction: column; gap: 4px; }
.svct__name { font-family: var(--font-display); font-size: clamp(18px, 2.4vw, 32px); letter-spacing: -.01em; line-height: 1.1; }
.svct__desc { font-size: var(--fs-caption); color: var(--fg-muted); line-height: 1.5; }
.svct__go { color: var(--fg-muted); opacity: 0; transform: translateX(-10px); transition: all .4s var(--ease-out); }
.svct__row:hover .svct__go { opacity: 1; transform: none; }
.svct__foot { display: flex; justify-content: space-between; align-items: center; gap: 24px; margin-top: clamp(36px, 4vw, 54px); flex-wrap: wrap; }
.svct__foot p { color: var(--fg-muted); font-weight: 300; font-size: var(--fs-lead); max-width: 40ch; margin: 0; }

/* ============================================================
   PORTFOLIO / WORK
   ============================================================ */
.work__feature { display: grid; grid-template-columns: 1.5fr 1fr; gap: clamp(32px, 5vw, 80px); align-items: end; margin-bottom: clamp(48px, 6vw, 96px); }
.work__feature .media { aspect-ratio: 16/10; }
.work__feature-body { padding-bottom: clamp(8px, 2vw, 28px); }
.work__cat { font-size: var(--fs-eyebrow); letter-spacing: .16em; text-transform: uppercase; color: var(--fg-faint); }
.work__title { font-family: var(--font-display); font-size: clamp(34px, 4.4vw, 60px); letter-spacing: -.02em; line-height: 1.02; margin: 16px 0 0; }
.work__feature-body p { color: var(--fg-muted); font-weight: 300; font-size: var(--fs-lead); line-height: 1.6; margin: 22px 0 30px; max-width: 38ch; }
.work__grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px, 4vw, 56px) clamp(24px, 3vw, 44px); }
.work__card { cursor: pointer; }
.work__card:nth-child(2) { margin-top: clamp(40px, 8vw, 110px); }
.work__card .media { transition: transform 1.1s var(--ease-out); }
.work__card:hover .media { transform: scale(1.02); }
.work__card-cat { font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--fg-faint); margin-top: 20px; }
.work__card-meta { display: flex; justify-content: space-between; align-items: baseline; margin-top: 6px; gap: 16px; }
.work__card-meta .t { font-family: var(--font-display); font-size: clamp(22px, 2.6vw, 32px); letter-spacing: -.01em; }
.work__card-meta .y { font-size: var(--fs-caption); color: var(--fg-faint); letter-spacing: .08em; }

/* ============================================================
   WHY MORPHO — ink
   ============================================================ */
.why { background: var(--bg-ink); color: var(--fg-on-dark); }
.why__head { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 6vw, 90px); align-items: end; }
.why__title { font-family: var(--font-display); font-size: var(--fs-h2); letter-spacing: -.02em; line-height: 1.06; margin: 16px 0 0; max-width: 16ch; }
.why__lead { color: var(--fg-on-dark-muted); font-size: var(--fs-lead); font-weight: 300; line-height: 1.7; max-width: 42ch; }
.why__image { margin: 0; }
.why__image-shift { }
.why__image img { width: 100%; max-height: 75vh; object-fit: cover; }
.why__image figcaption { font-size: var(--fs-caption); color: var(--fg-on-dark-muted); padding: 14px var(--gutter); letter-spacing: .08em; text-transform: uppercase; }

/* ============================================================
   TESTIMONIALS — sand
   ============================================================ */
.testi { background: var(--sand-200); }
.testi__inner { max-width: 1100px; }
.testi__quote { font-family: var(--font-display); font-size: clamp(28px, 4vw, 54px); line-height: 1.18; letter-spacing: -.01em; margin: 26px 0 0; max-width: 24ch; min-height: 3.5em; transition: opacity .5s var(--ease-out); }
.testi__by { display: flex; align-items: center; gap: 16px; margin-top: 44px; transition: opacity .5s var(--ease-out); }
.testi__av { width: 54px; height: 54px; border-radius: 50%; background: var(--sand-500); flex: none; object-fit: cover; }
.testi__nm { font-size: var(--fs-small); }
.testi__rl { font-size: var(--fs-caption); color: var(--fg-muted); margin-top: 3px; }
.testi.is-fading .testi__quote, .testi.is-fading .testi__by { opacity: 0; }
.testi__dots { display: flex; gap: 9px; margin-top: 40px; }
.testi__dot { width: 8px; height: 8px; border-radius: 50%; background: var(--sand-500); transition: background .3s, width .3s; border: 0; cursor: pointer; padding: 0; }
.testi__dot.is-on { background: var(--ink-900); width: 26px; border-radius: 4px; }

/* ============================================================
   CTA BAND
   ============================================================ */
.cta { position: relative; background: var(--ink-900); color: #fff; text-align: center; overflow: hidden; }
.cta__bg { position: absolute; inset: -6% 0; z-index: 0; will-change: transform; }
.cta__bg img { width: 100%; height: 100%; object-fit: cover; }
.cta__bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(18,14,9,.5) 0%, rgba(18,14,9,.66) 100%); }
.cta__title { font-family: var(--font-display); font-size: var(--fs-h1); line-height: 1.02; letter-spacing: -.02em; color: #fff; margin: 18px auto 34px; max-width: 15ch; }
.cta__actions { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

/* ============================================================
   CONTACT FORM
   ============================================================ */
.contact-section { background: var(--sand-100); }
.contact-form { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; max-width: 900px; margin-top: clamp(40px,5vw,64px); }
.contact-form .full { grid-column: 1 / -1; }
.form-group { display: flex; flex-direction: column; gap: 8px; }
.form-group label { font-size: var(--fs-caption); letter-spacing: .14em; text-transform: uppercase; color: var(--fg-muted); }
.form-group input,
.form-group textarea,
.form-group select { width: 100%; padding: 14px 16px; background: var(--bg); border: 1px solid var(--line-strong); border-radius: var(--radius-sm); font-family: var(--font-body); font-size: var(--fs-small); color: var(--fg); transition: border-color .3s; outline: none; }
.form-group input:focus,
.form-group textarea:focus { border-color: var(--ink-900); }
.form-group textarea { resize: vertical; min-height: 140px; }
.form-message { margin-top: 16px; padding: 14px 18px; border-radius: var(--radius-sm); font-size: var(--fs-small); }
.form-message.success { background: #eaf3eb; color: var(--success); border: 1px solid #c4dfc6; }
.form-message.error { background: var(--error-bg); color: var(--error); border: 1px solid #e0bdb5; }

/* ============================================================
   FOOTER — ink
   ============================================================ */
.footer { background: var(--bg-ink); color: var(--fg-on-dark); padding: clamp(64px, 9vw, 120px) var(--gutter) 36px; }
.footer__top { max-width: var(--maxw); margin-inline: auto; display: grid; grid-template-columns: 1.2fr 1fr; gap: clamp(40px,6vw,70px); padding-bottom: clamp(48px, 7vw, 88px); border-bottom: 1px solid var(--line-on-dark); }
.footer__h { font-family: var(--font-display); font-size: clamp(44px, 7vw, 92px); line-height: .98; letter-spacing: -.02em; margin: 16px 0 34px; }
.footer__cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.fcol { display: flex; flex-direction: column; gap: 14px; }
.fcol__t { font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--fg-on-dark-muted); margin-bottom: 4px; }
.fcol a, .fcol span:not(.fcol__t) { font-size: var(--fs-small); color: rgba(255,255,255,.82); line-height: 1.6; transition: color .3s; width: max-content; }
.fcol a:hover { color: #fff; }
.footer__bot { max-width: var(--maxw); margin-inline: auto; display: flex; justify-content: space-between; align-items: center; padding-top: 28px; gap: 20px; flex-wrap: wrap; }
.footer__wm { font-family: var(--font-display); font-size: 22px; letter-spacing: var(--ls-logo); text-transform: uppercase; }
.footer__legal { color: var(--fg-on-dark-muted); font-size: var(--fs-caption); }

/* ============================================================
   MOBILE MENU
   ============================================================ */
.mm { position: fixed; inset: 0; z-index: 200; background: var(--ink-900); color: #fff; display: flex; flex-direction: column; padding: 24px var(--gutter); transform: translateY(-100%); visibility: hidden; transition: transform .6s var(--ease-inout), visibility .6s; }
.mm.is-open { transform: none; visibility: visible; }
.mm__top { display: flex; justify-content: space-between; align-items: center; }
.mm__top .nav__logo { color: #fff; }
.mm__links { flex: 1; display: flex; flex-direction: column; justify-content: center; gap: 6px; list-style: none; margin: 0; padding: 0; }
.mm__link, .mm__links .menu-item a { font-family: var(--font-display); font-size: clamp(40px, 12vw, 72px); text-align: left; letter-spacing: -.01em; color: #fff; opacity: .9; transition: padding-left .4s var(--ease-out); display: block; }
.mm__link:hover, .mm__links .menu-item a:hover { padding-left: 16px; opacity: 1; }
.mm__foot { display: flex; gap: 28px; font-size: var(--fs-caption); color: var(--fg-on-dark-muted); border-top: 1px solid var(--line-on-dark); padding-top: 22px; }

/* ============================================================
   INNER PAGES
   ============================================================ */
.page-hero { padding: clamp(120px,14vw,200px) 0 clamp(48px,7vw,96px); background: var(--sand-100); }
.page-hero__eyebrow { margin-bottom: 16px; }
.page-hero__title { font-family: var(--font-display); font-size: var(--fs-h1); letter-spacing: -.02em; line-height: 1.02; margin: 0 0 24px; max-width: 20ch; }
.page-content { padding-block: clamp(48px,7vw,96px); }
.page-content .entry-content { max-width: 72ch; font-size: var(--fs-lead); font-weight: 300; color: var(--fg-muted); line-height: 1.75; }
.page-content .entry-content h2 { font-family: var(--font-display); font-size: var(--fs-h2); color: var(--fg); margin-bottom: 0.5em; }
.page-content .entry-content h3 { font-family: var(--font-display); font-size: var(--fs-h3); color: var(--fg); margin-bottom: 0.4em; }
.page-content .entry-content p { margin-bottom: 1.4em; }

/* Blog grid */
.archive-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(28px,3vw,44px); padding-block: clamp(48px,7vw,96px); }
.post-card .media { aspect-ratio: 5/4; margin-bottom: 24px; transition: transform 1.1s var(--ease-out); }
.post-card:hover .media { transform: scale(1.02); }
.post-card__meta { display: flex; gap: 14px; align-items: center; font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--fg-faint); }
.post-card__title { font-family: var(--font-display); font-size: clamp(22px,2.2vw,28px); letter-spacing: -.01em; line-height: 1.15; margin: 16px 0 0; max-width: 22ch; }
.post-card__excerpt { font-size: var(--fs-small); color: var(--fg-muted); line-height: 1.6; margin: 14px 0 18px; max-width: 34ch; }

/* Single post */
.single-hero { padding: clamp(120px,14vw,180px) 0 clamp(48px,6vw,80px); }
.single-hero__cat { font-size: var(--fs-eyebrow); letter-spacing: .16em; text-transform: uppercase; color: var(--fg-faint); }
.single-hero__title { font-family: var(--font-display); font-size: var(--fs-h1); letter-spacing: -.02em; line-height: 1.02; margin: 16px 0 0; max-width: 22ch; }
.single-content { padding-block: clamp(48px,6vw,80px); }
.single-content .entry-content { max-width: 72ch; font-size: var(--fs-lead); font-weight: 300; color: var(--fg-muted); line-height: 1.75; }
.single-content .entry-content > * + * { margin-top: 1.4em; }
.single-content .entry-content h2, .single-content .entry-content h3 { color: var(--fg); margin-top: 2em; margin-bottom: .5em; }
.single-content .entry-content figure { margin: 2.5em 0; }
.single-content .entry-content figure img { width: 100%; height: auto; }

/* 404 */
.error-404-section { min-height: 70vh; display: flex; align-items: center; padding-block: clamp(80px,12vw,160px); }
.error-404-section .num { font-family: var(--font-display); font-size: clamp(100px,20vw,220px); line-height: 1; letter-spacing: -.04em; color: var(--sand-300); display: block; margin-bottom: 24px; }
.error-404-section h1 { font-family: var(--font-display); font-size: var(--fs-h2); margin: 0 0 16px; }
.error-404-section p { color: var(--fg-muted); font-size: var(--fs-lead); font-weight: 300; max-width: 44ch; margin-bottom: 32px; }

/* Search form */
.search-form { display: flex; gap: 12px; margin-top: 24px; flex-wrap: wrap; }
.search-form input[type="search"] { flex: 1; min-width: 200px; padding: 14px 18px; border: 1px solid var(--line-strong); border-radius: var(--radius-sm); font-family: var(--font-body); font-size: var(--fs-small); outline: none; }
.search-form input[type="search"]:focus { border-color: var(--ink-900); }
.search-form button { padding: 14px 28px; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1000px) {
  .nav__links, .nav__cta { display: none; }
  .nav__burger { display: inline-flex; }
  .intro, .why__head, .footer__top { grid-template-columns: 1fr; }
  .work__feature { grid-template-columns: 1fr; }
  .contact-form { grid-template-columns: 1fr; }
  .archive-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 680px) {
  .hero__bar { grid-template-columns: 1fr 1fr; gap: 20px; }
  .hero__scroll { display: none; }
  .sec-head { grid-template-columns: 1fr; }
  .sec-head__lead { max-width: none; }
  .svct__cols { grid-template-columns: 1fr; }
  .work__grid, .footer__cols, .archive-grid { grid-template-columns: 1fr; }
  .work__card:nth-child(2) { margin-top: 0; }
  .footer__bot { flex-direction: column; align-items: flex-start; }
  .intro__meta { flex-wrap: wrap; gap: 28px 40px; }
}
@media (max-width: 480px) {
  .archive-grid { grid-template-columns: 1fr; }
}
