﻿/* ===== RESET & BASE ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --color-bg:#fffdf8;
  --color-paper:#f7f6e4;
  --color-primary:#36443e;
  --color-primary-deep:#202d27;
  --color-text:#36443e;
  --color-text-muted:#4d5854;
  --color-accent:#36443e;
  --color-accent2:#202d27;
  --color-sage:#b8d4c2;
  --color-coral:#e39f8e;
  --color-gold:#e9b753;
  --color-red:#c02b0a;
  --color-bg-dark:#36443e;
  --color-text-light:#fffdf8;
  --color-quiz-bg:#b8d4c2;
  --border-soft:var(--border-soft);
  --border-medium:var(--border-medium);
  --border-strong:var(--border-strong);
  --font-heading:'Spectral',serif;
  --font-body:'Satoshi',system-ui,sans-serif;
  --container:1440px;
  --container-narrow:1200px;
  --header-h:120px;
  --radius:2px;
  --radius-lg:8px;
  --ease:cubic-bezier(.25,.46,.45,.94);
  --ease-radius:cubic-bezier(.4,0,.2,1);
}
html{font-size:16px;color:var(--color-primary);background:var(--color-bg);overflow-x:hidden;max-width:100%}
body{font-family:var(--font-body);color:var(--color-text);background:var(--color-bg);line-height:1.5;overflow-x:hidden;max-width:100%;position:relative;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:clamp(1rem,1.1vw,1.125rem)}
::selection{background:var(--color-sage);color:var(--color-primary)}
::-moz-selection{background:var(--color-sage);color:var(--color-primary)}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
img{max-width:100%;display:block}
h1,h2,h3,h4,h5{font-family:var(--font-heading);font-weight:500;line-height:1.1;color:var(--color-primary);letter-spacing:-.01em}
h1{font-size:clamp(2.75rem,6.5vw,6.25rem);line-height:1;letter-spacing:-.02em;font-weight:500}
h2{font-size:clamp(2rem,4vw,3.5rem);line-height:1.05;letter-spacing:-.015em;text-wrap:balance}
h3{font-size:clamp(1.5rem,2.6vw,2.25rem);line-height:1.15}
h4{font-size:.8125rem;font-family:var(--font-body);font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--color-primary)}
p{font-size:clamp(1rem,1.1vw,1.125rem);max-width:62ch;color:var(--color-text);font-weight:400;line-height:1.5}
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 clamp(1.25rem,3vw,2.5rem)}
.container-narrow{width:100%;max-width:var(--container-narrow);margin:0 auto;padding:0 clamp(1.25rem,3vw,2.5rem)}
.kicker{font-family:var(--font-body);font-weight:700;font-size:.75rem;text-transform:uppercase;letter-spacing:.18em;color:var(--color-primary);display:inline-block;margin-bottom:1rem}

/* Global keyboard focus ring. Component overrides cascade. */
:where(a,button,[role="button"],input,select,textarea,summary):focus-visible{outline:2px solid var(--color-primary);outline-offset:3px;border-radius:2px}
.site-footer :where(a,button):focus-visible{outline-color:var(--color-text-light)}

/* Skip to content. Hidden offscreen until keyboard-focused, then appears at top-left. */
.skip-link{position:absolute;top:.75rem;left:.75rem;z-index:2000;background:var(--color-primary);color:var(--color-text-light);font-family:var(--font-body);font-weight:600;font-size:.875rem;padding:.75rem 1.125rem;border-radius:var(--radius);text-decoration:none;transform:translateY(-150%);transition:transform .25s cubic-bezier(.22,.61,.36,1)}
.skip-link:focus,.skip-link:focus-visible{transform:translateY(0);outline:2px solid var(--color-gold);outline-offset:2px}
:focus-visible{scroll-margin-top:calc(var(--header-h) + 1rem)}

/* ===== BUTTONS - Murmur-style: small radius, animated radius transition ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.625rem;border-radius:var(--radius);font-family:var(--font-body);font-weight:600;font-size:clamp(.875rem,1vw,.9375rem);line-height:1.4;border:1.5px solid transparent;cursor:pointer;transition:border-radius .5s var(--ease-radius),background-color .3s var(--ease),color .3s var(--ease),transform .3s var(--ease);letter-spacing:.01em;text-transform:none}
.btn-primary{background:var(--color-primary);color:var(--color-text-light);border-color:var(--color-primary)}
.btn-primary:hover{border-radius:24px;background:var(--color-primary-deep);border-color:var(--color-primary-deep)}
.btn-outline{background:transparent;border-color:var(--color-primary);color:var(--color-primary)}
.btn-outline:hover{border-radius:24px;background:var(--color-primary);color:var(--color-text-light)}
.btn-accent{background:var(--color-primary);color:var(--color-text-light);border-color:var(--color-primary)}
.btn-accent:hover{border-radius:24px;background:var(--color-primary-deep);border-color:var(--color-primary-deep)}
.btn-light{background:transparent;border-color:var(--color-text-light);color:var(--color-text-light)}
.btn-light:hover{border-radius:24px;background:var(--color-text-light);color:var(--color-primary)}

.explore-link{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-body);font-weight:600;font-size:.9375rem;color:var(--color-primary);transition:gap .3s var(--ease);border-bottom:1.5px solid var(--color-primary);padding-bottom:2px;align-self:flex-start}
.explore-link::after{content:'\2192';transition:transform .3s var(--ease);display:inline-block}
.explore-link:hover{gap:.875rem}
.explore-link:hover::after{transform:translateX(2px)}

/* ===== IMAGE PLACEHOLDERS ===== */
.img-placeholder{background:var(--color-sage);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}
.img-placeholder::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 30% 30%,rgba(255,253,248,.35),transparent 55%),radial-gradient(circle at 75% 70%,rgba(32,45,39,.08),transparent 60%);pointer-events:none}
.img-placeholder::after{content:'';position:absolute;width:56px;height:56px;border-radius:50%;background:rgba(255,253,248,.55);border:1.5px solid var(--border-strong);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%2336443e' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='3' width='18' height='18' rx='2'/%3E%3Ccircle cx='8.5' cy='8.5' r='1.5'/%3E%3Cpath d='m21 15-5-5L5 21'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:22px 22px}
.img-placeholder.no-label::after{display:none}
.img-placeholder.no-label::before{opacity:.6}
.img-placeholder.ph-sage{background:var(--color-sage)}
.img-placeholder.ph-coral{background:var(--color-coral)}
.img-placeholder.ph-gold{background:var(--color-gold)}
.img-placeholder.ph-cream{background:var(--color-paper)}
.img-placeholder.ph-green{background:var(--color-primary)}
.img-placeholder.ph-green::after{background-color:rgba(255,253,248,.15);border-color:rgba(255,253,248,.35);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' viewBox='0 0 24 24' fill='none' stroke='%23fffdf8' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='3' width='18' height='18' rx='2'/%3E%3Ccircle cx='8.5' cy='8.5' r='1.5'/%3E%3Cpath d='m21 15-5-5L5 21'/%3E%3C/svg%3E")}
.img-placeholder.ph-green::before{background-image:radial-gradient(circle at 30% 30%,rgba(184,212,194,.25),transparent 55%),radial-gradient(circle at 75% 70%,rgba(0,0,0,.18),transparent 60%)}

/* ===== HEADER ===== */
.site-header{position:fixed;top:0;left:0;width:100%;z-index:1000;background:var(--color-bg);padding:2rem 0;transition:padding .4s var(--ease),transform .5s var(--ease),box-shadow .4s var(--ease)}
.site-header.scrolled{padding:1rem 0;box-shadow:0 1px 0 var(--border-soft)}
.site-header.header-hidden{transform:translateY(-100%)}
.header-inner{display:flex;align-items:center;justify-content:flex-start;gap:2rem;position:relative}
.logo img{height:36px;width:auto;transition:height .3s var(--ease)}
.site-header.scrolled .logo img{height:30px}
.main-nav{position:absolute;left:0;right:0;display:flex;justify-content:center;margin-left:0;pointer-events:none}
.nav-list{display:flex;gap:2rem;align-items:center;pointer-events:auto}
.nav-link{font-family:var(--font-body);font-weight:600;font-size:.9375rem;color:var(--color-primary);background:none;border:none;cursor:pointer;padding:.25rem 0;position:relative;transition:opacity .25s var(--ease);letter-spacing:.01em}
.nav-link::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1.5px;background:var(--color-primary);transition:width .35s var(--ease)}
.nav-link:hover::after{width:100%}
.nav-dropdown-trigger{display:inline-flex;align-items:center;gap:.4rem}
.dropdown-arrow{transition:transform .3s var(--ease)}
.nav-dropdown-trigger[aria-expanded="true"] .dropdown-arrow{transform:rotate(180deg)}
.header-cta{padding:.625rem 1.25rem;font-size:.8125rem;font-weight:700;letter-spacing:.04em}
.language-switcher + .header-cta{margin-left:-1rem}
.language-switcher{position:relative;margin-left:auto;font-family:var(--font-body);font-size:.75rem;font-weight:700;letter-spacing:.08em;line-height:1}
.language-trigger{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;min-height:40px;padding:.625rem .35rem;border:0;border-radius:var(--radius);background:transparent;color:var(--color-primary);font:inherit;cursor:pointer;transition:color .25s var(--ease),opacity .25s var(--ease)}
.language-trigger:hover,.language-switcher.is-open .language-trigger{color:var(--color-primary-deep);opacity:.82}
.language-icon{width:19px;height:19px;flex-shrink:0;color:currentColor;opacity:.95}
.language-current{min-width:1.4rem;text-align:left}
.language-menu{position:absolute;top:calc(100% + .5rem);right:0;min-width:150px;padding:.45rem;background:var(--color-primary);border:1px solid rgba(255,253,248,.16);border-radius:var(--radius-lg);box-shadow:0 18px 40px -28px rgba(32,45,39,.6);opacity:0;visibility:hidden;transform:translateY(-4px);transition:opacity .2s var(--ease),visibility .2s var(--ease),transform .2s var(--ease);z-index:1002}
.language-switcher.is-open .language-menu{opacity:1;visibility:visible;transform:translateY(0)}
.language-option{appearance:none;width:100%;border:0;background:transparent;color:var(--color-text-light);font:inherit;letter-spacing:.04em;cursor:pointer;padding:.7rem .75rem;border-radius:6px;line-height:1;display:flex;align-items:center;justify-content:space-between;gap:1rem;transition:background-color .25s var(--ease),color .25s var(--ease)}
.language-option:hover,.language-option.is-active{background:var(--color-sage);color:var(--color-primary)}
.language-option:focus-visible,.language-trigger:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px}

/* ===== MEGA MENU - Murmur-style polish ===== */
.mega-menu{position:fixed;top:100px;left:0;right:0;width:100%;z-index:1000;background:var(--color-paper);border-top:1px solid var(--border-soft);padding:3.5rem 0 4.25rem;opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .35s var(--ease),visibility .35s var(--ease),transform .35s var(--ease);--mx:50%;--my:50%;overflow:hidden;pointer-events:none}
.site-header.scrolled .mega-menu{top:62px}
.mega-menu.active{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto}
.mega-menu::before{content:"";position:absolute;inset:0;background:radial-gradient(circle 320px at var(--mx) var(--my),rgba(233,183,83,.18),rgba(233,183,83,0) 70%);pointer-events:none;opacity:0;transition:opacity .5s var(--ease);z-index:0}
.mega-menu.active::before{opacity:1}
.mega-menu-inner{display:grid;grid-template-columns:repeat(3,1fr);gap:4rem;position:relative;z-index:1}
.mega-heading{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:0 0 1rem;margin:0 0 1.125rem;border-bottom:1px solid var(--border-strong);font-family:var(--font-body);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.22em;color:var(--color-primary);transition:color .25s var(--ease),border-color .25s var(--ease)}
.mega-heading:hover{color:var(--color-primary-deep);border-bottom-color:var(--color-primary)}
.mega-heading-icon{width:22px;height:22px;flex-shrink:0;color:var(--color-primary);opacity:.7;transition:opacity .25s var(--ease),transform .45s var(--ease)}
.mega-heading:hover .mega-heading-icon{opacity:1;transform:rotate(-8deg) scale(1.08)}
.mega-col ul{display:flex;flex-direction:column;gap:.125rem}
.mega-col li a{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem .9rem;margin:0 -.9rem;font-family:var(--font-body);font-size:1rem;font-weight:500;color:var(--color-primary);border-radius:2px;transition:border-radius .45s var(--ease-radius),background-color .35s var(--ease),color .25s var(--ease);position:relative}
.mega-col li a::after{content:"\203A";font-family:var(--font-heading);font-size:1.5rem;line-height:1;color:var(--color-primary);opacity:.3;transition:opacity .25s var(--ease),transform .3s var(--ease);display:inline-block}
.mega-col li a:hover{border-radius:20px}
.mega-col li a:hover::after{opacity:1;transform:translateX(5px)}
.mega-col:nth-child(1) li a:hover{background:var(--color-coral)}
.mega-col:nth-child(2) li a:hover{background:var(--color-sage)}
.mega-col:nth-child(3) li a:hover{background:var(--color-gold)}

/* ===== HAMBURGER ===== */
.hamburger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;background:none;border:none;cursor:pointer;min-width:44px;min-height:44px;padding:10px;z-index:1001}
.hamburger-line{width:24px;height:2px;background:var(--color-primary);transition:all .3s var(--ease);border-radius:2px}
.hamburger.active .hamburger-line:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.active .hamburger-line:nth-child(2){opacity:0}
.hamburger.active .hamburger-line:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ===== MOBILE MENU ===== */
.mobile-menu{position:fixed;top:0;right:0;width:100%;height:100vh;height:100dvh;background:var(--color-bg);z-index:999;transform:translateX(100%);transition:transform .5s var(--ease);padding:calc(var(--header-h) + 1rem) 1.5rem 2rem;overflow-y:auto}
.mobile-menu.active{transform:translateX(0)}
.mobile-nav-list{display:flex;flex-direction:column;gap:.125rem}
.mobile-nav-link{display:flex;align-items:center;justify-content:space-between;font-family:var(--font-body);font-size:.9375rem;font-weight:600;color:var(--color-primary);padding:.95rem 0;border-bottom:1px solid rgba(54,68,62,.1);background:none;border-top:none;border-left:none;border-right:none;width:100%;cursor:pointer;text-align:left;letter-spacing:.01em}
.mobile-dropdown{max-height:0;overflow:hidden;transition:max-height .55s var(--ease);background:var(--color-paper);margin:.75rem -.5rem 0;border-radius:var(--radius-lg)}
.mobile-dropdown.active{max-height:1800px}
.mobile-dropdown-section{padding:1rem 1rem 1.125rem}
.mobile-dropdown-section + .mobile-dropdown-section{border-top:1px solid rgba(54,68,62,.12)}
.mobile-dropdown-heading{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:0 0 .7rem;margin:0 0 .35rem;border-bottom:1px solid var(--border-strong);font-family:var(--font-body);font-weight:700;font-size:.7rem;text-transform:uppercase;letter-spacing:.18em;color:var(--color-primary);opacity:1}
.mobile-dropdown-heading-icon{width:18px;height:18px;color:var(--color-primary);opacity:.75;flex-shrink:0}
.mobile-dropdown-section a{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.625rem .75rem;margin:0 -.75rem;font-family:var(--font-body);font-size:.9375rem;font-weight:600;color:var(--color-primary);border-radius:2px;transition:border-radius .4s var(--ease-radius),background-color .3s var(--ease)}
.mobile-dropdown-section a::after{content:"\203A";font-family:var(--font-heading);font-size:1.2rem;line-height:1;opacity:.35;transition:opacity .25s var(--ease),transform .3s var(--ease)}
.mobile-dropdown-section a:hover,.mobile-dropdown-section a:active{border-radius:18px;background:var(--color-bg)}
.mobile-dropdown-section a:hover::after,.mobile-dropdown-section a:active::after{opacity:1;transform:translateX(4px)}
.mobile-language-switcher{display:block;width:max-content;margin-top:1.5rem;margin-left:0}
.mobile-language-switcher .language-menu{left:0;right:auto}
.mobile-cta{margin-top:2rem;width:100%}

/* ===== HERO - large, centered, editorial ===== */
.hero{min-height:85vh;display:flex;align-items:center;justify-content:center;padding-top:calc(var(--header-h) + 1rem);padding-bottom:3rem;position:relative;text-align:center}
.hero .container{display:flex;justify-content:center;align-items:center}
.hero-content{max-width:900px;display:flex;flex-direction:column;align-items:center;margin:0 auto}
.hero-image{max-width:240px;margin:0 auto 1.75rem;width:100%}
.hero-image img,.hero-image video{width:100%;height:auto;display:block}
.hero h1{margin-bottom:1.5rem;font-size:clamp(3rem,8.5vw,7.5rem);line-height:.98;letter-spacing:-.03em;font-weight:500;max-width:15ch}
.hero-subtitle{font-size:clamp(1.0625rem,1.25vw,1.25rem);color:var(--color-text-muted);max-width:600px;line-height:1.55;margin-bottom:2.25rem;margin-left:auto;margin-right:auto;font-weight:400}
.hero-cta{margin-top:0}

/* ===== WORK SHOWCASE (HOME) - EDGE-TO-EDGE ALTERNATING ===== */
.work-showcase{padding:5rem 0 2rem}
.work-item{display:grid;grid-template-columns:3fr 2fr;gap:0;align-items:center;margin-bottom:6rem}
.work-item:nth-child(odd){grid-template-columns:2fr 3fr}
.work-item:nth-child(odd) .work-item-image{order:2}
.work-item:nth-child(odd) .work-item-content{order:1;padding-left:clamp(1.5rem,4vw,4rem);padding-right:clamp(1.5rem,4vw,4rem)}
.work-item-image{overflow:hidden;aspect-ratio:1280/881;border-radius:4px}
.work-item:nth-child(even) .work-item-image{border-top-left-radius:0;border-bottom-left-radius:0}
.work-item:nth-child(odd) .work-item-image{border-top-right-radius:0;border-bottom-right-radius:0}
.work-item-image img,.work-item-image video{width:100%;height:100%;object-fit:cover;display:block}
.work-item-image .img-placeholder{width:100%;height:100%;border-radius:0}
.work-item-triptych{display:flex;align-items:center;justify-content:center;gap:clamp(.5rem,1.2vw,1rem);padding:clamp(.75rem,1.5vw,1.25rem);background-color:var(--color-paper);background-image:url('../assets/portfolio-background-cream.webp');background-size:cover;background-position:center}
.work-item-triptych.is-green{background-image:url('../assets/portfolio-background-green.webp')}
.work-item-triptych video{width:calc((100% - clamp(1rem,2.4vw,2rem))/3);height:auto;aspect-ratio:9/16;border-radius:var(--radius-lg);object-fit:cover;background:var(--color-primary-deep)}
.work-item-triptych.social-triptych img{width:calc((100% - clamp(1rem,2.4vw,2rem))/3);height:auto;aspect-ratio:1;object-fit:cover;border-radius:var(--radius-lg);background:var(--color-bg)}
.work-item-triptych.social-diptych img{width:calc((100% - clamp(.5rem,1.2vw,1rem))/2);height:auto;aspect-ratio:4/5;object-fit:cover;border-radius:var(--radius-lg);background:var(--color-bg)}
.work-item-content{padding:clamp(2rem,4vw,3.5rem) clamp(1.5rem,4vw,4rem);display:flex;flex-direction:column;gap:1rem;align-items:flex-start}
.work-item-content h2{margin-bottom:.25rem;font-size:clamp(1.75rem,3.2vw,2.75rem);line-height:1.05}
.work-item-content p{margin-bottom:.5rem;color:var(--color-text-muted);font-size:clamp(1rem,1.15vw,1.125rem);line-height:1.55;font-weight:400;max-width:48ch}
.work-item-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin:0 0 .1rem;max-width:100%}
.work-item-meta span{display:inline-flex;align-items:center;border:1px solid var(--border-medium);border-radius:999px;padding:.4rem .7rem;font-family:var(--font-body);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--color-primary);line-height:1;white-space:nowrap}
.work-item-meta span.is-video{background:var(--color-coral)}
.work-item-meta span.is-web{background:var(--color-sage)}
.work-item-meta span.is-social{background:var(--color-gold)}
.work-item:last-child{margin-bottom:0}

/* ===== SECTION SPACING ===== */
.work-showcase + .quiz-cta,
.quiz-cta + .values-section,
.values-section + .cta-section,
.work-showcase + .cta-section{margin-top:6rem}

/* ===== QUIZ / SECONDARY CTA ===== */
.quiz-cta{background:var(--color-sage);padding:7rem 0;margin:0;text-align:center;position:relative;overflow:hidden}
.quiz-cta-inner{max-width:var(--container);margin:0 auto;padding:0 clamp(1.25rem,3vw,2.5rem)}
.quiz-cta-content h2{color:var(--color-primary);margin-bottom:.75rem;font-size:clamp(2.25rem,5vw,4rem);font-weight:500;letter-spacing:-.02em}
.quiz-cta-content p{margin:0 auto 2rem;color:var(--color-primary);opacity:.75;font-size:clamp(1.0625rem,1.2vw,1.1875rem)}
.quiz-cta-content .btn{background:var(--color-primary);color:var(--color-text-light);border-color:var(--color-primary);padding:.875rem 2rem}
.quiz-cta-content .btn:hover{border-radius:24px;background:var(--color-primary-deep);border-color:var(--color-primary-deep)}

/* ===== VALUES / CARDS ===== */
.values-section{padding:7rem 0}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem;align-items:stretch}
.value-card{background:transparent;border:none;border-radius:0;overflow:visible;transition:transform .8s cubic-bezier(.22,.61,.36,1);position:relative;display:flex;flex-direction:column;gap:1.25rem;height:100%}
.value-card:hover{transform:translateY(-8px)}
.value-card-image{width:100%;aspect-ratio:16/10;overflow:hidden;border-radius:var(--radius-lg);position:relative}
.value-card-image::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,var(--border-strong) 100%);opacity:0;transition:opacity .8s cubic-bezier(.22,.61,.36,1);pointer-events:none;border-radius:var(--radius-lg)}
.value-card:hover .value-card-image::after{opacity:1}
.value-card-image img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.1s cubic-bezier(.22,.61,.36,1),filter .8s cubic-bezier(.22,.61,.36,1)}
.value-card:hover .value-card-image img{transform:scale(1.06);filter:brightness(1.02)}
.value-card-image .img-placeholder{width:100%;height:100%;border-radius:var(--radius-lg);transition:transform 1.1s cubic-bezier(.22,.61,.36,1)}
.value-card:hover .value-card-image .img-placeholder{transform:scale(1.06)}
.value-card-body{padding:0;display:flex;flex-direction:column;gap:.75rem;align-items:flex-start;flex:1}
.value-card h3{margin-bottom:.25rem;font-size:clamp(1.375rem,2vw,1.75rem);transition:color .5s cubic-bezier(.22,.61,.36,1)}
.value-card:hover h3{color:var(--color-primary-deep)}
.value-card p{font-size:clamp(.9375rem,1.05vw,1.0625rem);color:var(--color-text-muted);margin-bottom:.5rem;font-weight:400;line-height:1.5}
.value-card-body .explore-link{margin-top:auto;transition:gap .5s cubic-bezier(.22,.61,.36,1),border-color .5s cubic-bezier(.22,.61,.36,1)}
.value-card:hover .explore-link{gap:.875rem}
.value-card:hover .explore-link::after{transform:translateX(2px)}

/* ===== CTA SECTION - Murmur-style cream ===== */
.cta-section{padding:clamp(5rem,12vw,10rem) 0;text-align:center;background:var(--color-paper);color:var(--color-primary)}
.cta-section .container{max-width:960px;display:flex;flex-direction:column;align-items:center;gap:0}
.cta-icon{width:clamp(90px,10vw,140px);height:clamp(90px,10vw,140px);margin:0 auto 2rem;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;flex-shrink:0;overflow:hidden}
.cta-icon svg{width:48%;height:48%;fill:var(--color-bg);animation:cta-beat 1.6s var(--ease) infinite}
.cta-icon video{width:100%;height:100%;object-fit:cover;display:block}
@keyframes cta-beat{0%,100%{transform:scale(1)}20%{transform:scale(1.08)}40%{transform:scale(.96)}60%{transform:scale(1.04)}}
.cta-section h2{margin:0 0 1rem;color:var(--color-primary);font-size:clamp(2.5rem,6vw,5rem);font-weight:500;letter-spacing:-.02em;line-height:1}
.cta-section .cta-sub{font-size:clamp(1.125rem,1.4vw,1.375rem);color:var(--color-text-muted);max-width:640px;margin:0 auto 2.5rem;line-height:1.5}
.cta-section .btn{background:var(--color-primary);color:var(--color-text-light);border-color:var(--color-primary);padding:.875rem 2rem}
.cta-section .btn:hover{border-radius:24px;background:var(--color-primary-deep);border-color:var(--color-primary-deep);color:var(--color-text-light)}

/* ===== BREADCRUMB ===== */
.breadcrumb{padding:calc(var(--header-h) + 1.5rem) 0 1.5rem;font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em}
.breadcrumb a{color:var(--color-primary);opacity:.6;transition:opacity .2s}
.breadcrumb a:hover{opacity:1}
.breadcrumb span{opacity:.35;margin:0 .5rem}

/* ===== ABOUT PAGE ===== */
.about-intro{padding:1.5rem 0 5rem;max-width:960px}
.about-intro .container{display:flex;flex-direction:column;gap:1rem;align-items:flex-start}
.about-intro h1{max-width:14ch;margin-bottom:.5rem}
.about-intro p{font-size:clamp(1.125rem,1.4vw,1.375rem);max-width:720px;color:var(--color-text-muted);line-height:1.5}
.about-hero{padding:1.5rem 0 5rem}
.about-hero h1{max-width:14ch}
.about-cards{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.about-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:3/2;display:flex;flex-direction:column;justify-content:flex-end;padding:2.5rem;cursor:pointer;transition:transform .5s var(--ease)}
.about-card:hover{transform:translateY(-4px)}
.about-card .img-placeholder{position:absolute;inset:0;z-index:0;border-radius:0;background:var(--color-sage)}
.about-card-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(32,45,39,.85),rgba(32,45,39,.15) 60%,transparent);z-index:1}
.about-card-content{position:relative;z-index:2;color:var(--color-text-light);display:flex;flex-direction:column;gap:.75rem;align-items:flex-start}
.about-card-label{font-family:var(--font-body);font-size:.75rem;text-transform:uppercase;letter-spacing:.16em;font-weight:700;color:rgba(255,253,248,.85);display:inline-block}
.about-card h2{color:var(--color-text-light);margin-bottom:.5rem;font-size:clamp(1.5rem,2.5vw,2.25rem)}
.about-card .explore-link{color:var(--color-text-light);border-bottom-color:var(--color-text-light)}
.bcorp-section{padding:7rem 0}
.bcorp-layout{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.bcorp-image{border-radius:var(--radius-lg);overflow:hidden}
.bcorp-image img,.bcorp-image video{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.bcorp-content{display:flex;flex-direction:column;gap:1rem;align-items:flex-start}
.bcorp-content h2{margin-bottom:.25rem;font-size:clamp(2rem,3.75vw,3rem)}
.bcorp-content p{margin-bottom:.75rem;color:var(--color-text-muted);font-size:clamp(1rem,1.15vw,1.125rem);line-height:1.55;max-width:48ch}

/* ===== WORK PAGE - header w/ filters (Murmur-style) ===== */
.work-hero{padding:calc(var(--header-h) + 1.5rem) 0 3.5rem}
.work-hero .container{display:flex;flex-direction:column;align-items:stretch;gap:1.75rem}
.work-hero-kicker{display:inline-flex;align-self:flex-start;font-family:var(--font-body);font-weight:700;font-size:.8125rem;text-transform:uppercase;letter-spacing:.18em;color:var(--color-primary);padding:0 0 .625rem;border-bottom:1px solid var(--color-primary)}
.work-hero-mark{width:clamp(96px,12vw,160px)}
.work-hero-mark video{width:100%;height:auto;display:block}
.work-hero-row{display:grid;grid-template-columns:1fr auto;gap:2.5rem;align-items:end}
.work-hero h1{font-size:clamp(2.25rem,4.75vw,4.25rem);line-height:1.02;letter-spacing:-.02em;max-width:16ch;margin:0}
.work-filters{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.work-select{appearance:none;-webkit-appearance:none;padding:.875rem 2.75rem .875rem 1.25rem;border:1px solid rgba(54,68,62,.25);border-radius:2px;background-color:var(--color-bg);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6' fill='none'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%2336443e' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;font-family:var(--font-body);font-size:.9375rem;font-weight:500;color:var(--color-primary);cursor:pointer;min-width:190px;transition:border-color .25s var(--ease),border-radius .4s var(--ease-radius),background-color .25s var(--ease)}
.work-select:hover{border-color:var(--color-primary);border-radius:18px}
.work-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px color-mix(in oklab,var(--color-sage) 60%,transparent);border-radius:18px}
.work-search-btn{padding:.875rem 1.5rem;gap:.6rem}
.work-search-btn svg{opacity:.9}
.work-empty{text-align:center;padding:4rem 0 5rem;font-size:1.0625rem;color:var(--color-text-muted)}
.work-reset{background:none;border:none;color:var(--color-primary);font-family:var(--font-body);font-weight:600;font-size:1rem;cursor:pointer;border-bottom:1.5px solid var(--color-primary);padding-bottom:2px;margin-left:.25rem;transition:opacity .25s}
.work-reset:hover{opacity:.7}
.project-card.is-hidden{display:none}

@media(max-width:900px){
  .work-hero-row{grid-template-columns:1fr;gap:1.5rem;align-items:flex-start}
  .work-filters{justify-content:flex-start;width:100%}
  .work-select{flex:1 1 160px;min-width:0}
  .work-search-btn{flex:0 0 auto}
}
.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2.5rem 2rem;padding-bottom:5rem}
.project-card{border-radius:0;overflow:visible;background:transparent;border:none;transition:transform .4s var(--ease);display:flex;flex-direction:column;gap:1rem}
.project-card:hover{transform:translateY(-4px);box-shadow:none}
.project-card-image{aspect-ratio:16/10;overflow:hidden;border-radius:var(--radius-lg)}
.project-card-image img,.project-card-image video{width:100%;height:100%;object-fit:cover;display:block}
.project-card-image .img-placeholder{width:100%;height:100%;border-radius:var(--radius-lg)}
.project-card-triptych video{width:calc((100% - clamp(1rem,2.4vw,2rem))/3);height:auto;aspect-ratio:9/16}
.project-card-content{padding:0}
.project-card h3{margin-bottom:.25rem;font-size:clamp(1.25rem,1.8vw,1.5rem)}
.project-card-tags{font-family:var(--font-body);font-size:.6875rem;text-transform:uppercase;letter-spacing:.16em;font-weight:700;color:var(--color-primary);opacity:.55;margin-bottom:0}
.work-pagination{display:flex;justify-content:center;gap:.5rem;padding:0 0 6rem}
.work-pagination a,.work-pagination span{width:40px;height:40px;border-radius:2px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;border:1.5px solid rgba(54,68,62,.2);transition:all .35s var(--ease-radius)}
.work-pagination .active{background:var(--color-primary);color:var(--color-text-light);border-color:var(--color-primary)}
.work-pagination a:hover{border-radius:20px;border-color:var(--color-primary);color:var(--color-primary)}

/* ===== RETAINER EXAMPLE ===== */
.retainer-example{padding:clamp(5rem,9vw,8rem) 0;background:var(--color-paper);color:var(--color-primary)}
.retainer-example .container{display:flex;flex-direction:column;gap:clamp(2rem,4vw,3.5rem)}
.retainer-example-head{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(280px,.85fr);gap:clamp(2rem,5vw,5rem);align-items:end}
.retainer-example-head h2{font-size:clamp(2.4rem,5vw,4.75rem);line-height:.98;letter-spacing:-.025em;max-width:24ch;margin:0}
.retainer-example-head p{font-size:clamp(1.0625rem,1.25vw,1.25rem);line-height:1.55;color:var(--color-text-muted);margin:0;max-width:46ch}
.retainer-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));border-top:1px solid rgba(54,68,62,.16);border-bottom:1px solid rgba(54,68,62,.16)}
.retainer-stats div{padding:clamp(1.25rem,2.4vw,2rem);border-right:1px solid rgba(54,68,62,.16);display:flex;flex-direction:column;gap:.35rem}
.retainer-stats div:last-child{border-right:none}
.retainer-stats strong{font-family:var(--font-heading);font-size:clamp(2.4rem,5vw,4.75rem);font-weight:500;line-height:.9;letter-spacing:-.035em;color:var(--color-primary-deep)}
.retainer-stats span{font-family:var(--font-body);font-size:.8125rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--color-text-muted)}
.retainer-pillars{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(1rem,2vw,1.5rem)}
.retainer-pillars.is-four{grid-template-columns:repeat(4,minmax(0,1fr))}
.retainer-pillar{position:relative;overflow:hidden;padding:clamp(1.35rem,2.4vw,2rem);background:var(--color-coral);border:1px solid rgba(54,68,62,.1);border-radius:14px;display:flex;flex-direction:column;gap:.75rem;min-height:100%;color:var(--color-primary)}
.retainer-pillar:nth-child(2){background:var(--color-sage)}
.retainer-pillar:nth-child(3){background:var(--color-gold)}
.retainer-pillar::after{position:absolute;right:1.1rem;bottom:-.5rem;font-family:var(--font-heading);font-size:clamp(4.5rem,7vw,7rem);line-height:.8;letter-spacing:-.05em;opacity:.09;pointer-events:none}
.retainer-pillar:nth-child(1)::after{content:'01'}
.retainer-pillar:nth-child(2)::after{content:'02'}
.retainer-pillar:nth-child(3)::after{content:'03'}
.retainer-pillar:nth-child(4)::after{content:'04'}
.retainer-pillar span{font-family:var(--font-body);font-size:.6875rem;font-weight:700;letter-spacing:.18em;color:rgba(32,45,39,.62)}
.retainer-pillar h3{font-size:clamp(1.45rem,2.1vw,2rem);line-height:1.05;margin:0;max-width:11ch}
.retainer-pillar p{font-size:.9875rem;line-height:1.55;color:var(--color-primary);opacity:.82;margin:0}
.retainer-timeline{display:grid;grid-template-columns:minmax(220px,.58fr) minmax(0,1.42fr);gap:clamp(1.5rem,4vw,3rem);align-items:start;padding-top:clamp(1rem,2vw,1.5rem);border-top:1px solid rgba(54,68,62,.16)}
.retainer-timeline-head{position:sticky;top:calc(var(--header-h) + 1.5rem);display:flex;flex-direction:column;gap:.75rem}
.retainer-timeline-head h3,.retainer-rhythm h3{font-size:clamp(1.75rem,3vw,2.6rem);line-height:1.02;margin:0;letter-spacing:-.018em}
.retainer-timeline-head p{font-size:1rem;line-height:1.55;color:var(--color-text-muted);margin:0;max-width:34ch}
.retainer-month-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}
.retainer-month-grid article{padding:1.25rem 0;border-top:1px solid rgba(54,68,62,.16);display:flex;flex-direction:column;gap:.45rem}
.retainer-month-grid article:nth-child(-n+2){border-top:none;padding-top:0}
.retainer-month-grid span{font-family:var(--font-body);font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.16em;color:var(--color-text-muted)}
.retainer-month-grid h4{font-family:var(--font-body);font-size:1rem;font-weight:700;letter-spacing:0;margin:0;color:var(--color-primary)}
.retainer-month-grid p{font-size:.95rem;line-height:1.45;color:var(--color-primary);margin:0}
.retainer-month-grid small{font-size:.875rem;line-height:1.4;color:var(--color-text-muted)}
.retainer-rhythm{display:grid;grid-template-columns:minmax(220px,.55fr) minmax(0,1fr) auto;gap:clamp(1.5rem,3vw,2.5rem);align-items:start;padding:clamp(1.5rem,3vw,2.25rem);background:var(--color-sage);border-radius:14px}
.retainer-rhythm ol{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem 1.25rem;margin:0;padding:0;list-style:none}
.retainer-rhythm li{font-size:.95rem;line-height:1.5;color:var(--color-primary)}
.retainer-rhythm li span{display:block;margin-bottom:.25rem;font-family:var(--font-body);font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.16em;color:rgba(32,45,39,.62)}
.retainer-rhythm .btn{align-self:center;white-space:nowrap;background:var(--color-primary);color:var(--color-text-light);border-color:var(--color-primary)}
.retainer-rhythm .btn:hover{background:var(--color-primary-deep);border-color:var(--color-primary-deep);color:var(--color-text-light)}
.retainer-example-dark{background:var(--color-primary);color:var(--color-text-light)}
.retainer-example-dark .kicker,
.retainer-example-dark h2,
.retainer-example-dark h3,
.retainer-example-dark h4,
.retainer-example-dark p,
.retainer-example-dark small,
.retainer-example-dark .retainer-stats strong,
.retainer-example-dark .retainer-stats span,
.retainer-example-dark .retainer-month-grid span{color:var(--color-text-light)}
.retainer-example-dark .retainer-example-head p,
.retainer-example-dark .retainer-timeline-head p,
.retainer-example-dark .retainer-month-grid small{color:rgba(255,253,248,.72)}
.retainer-example-dark .retainer-stats,
.retainer-example-dark .retainer-timeline{border-color:rgba(255,253,248,.22)}
.retainer-example-dark .retainer-stats div,
.retainer-example-dark .retainer-month-grid article{border-color:rgba(255,253,248,.22)}
.retainer-example-dark .retainer-pillar{background:rgba(255,253,248,.08);border-color:rgba(255,253,248,.22);color:var(--color-text-light)}
.retainer-example-dark .retainer-pillar span{color:rgba(255,253,248,.62)}
.retainer-example-dark .retainer-pillar p{color:rgba(255,253,248,.78)}
.retainer-example-dark .retainer-pillar::after{color:var(--color-text-light);opacity:.08}
.retainer-example-dark .retainer-rhythm{background:rgba(255,253,248,.09);border:1px solid rgba(255,253,248,.2)}
.retainer-example-dark .retainer-rhythm li{color:rgba(255,253,248,.82)}
.retainer-example-dark .retainer-rhythm li span{color:rgba(255,253,248,.62)}
.retainer-example-dark .retainer-rhythm .btn{background:var(--color-text-light);border-color:var(--color-text-light);color:var(--color-primary)}
.retainer-example-dark .retainer-rhythm .btn:hover{background:var(--color-sage);border-color:var(--color-sage);color:var(--color-primary)}

/* ===== SERVICES PAGE ===== */
.services-intro{padding:1.5rem 0 4rem}
.services-intro .container{display:flex;flex-direction:column;align-items:flex-start;gap:1rem}
.services-intro h1{max-width:14ch;margin-bottom:.25rem}
.services-intro p{font-size:clamp(1.125rem,1.4vw,1.375rem);max-width:720px;color:var(--color-text-muted);line-height:1.5}
.service-cards{padding-bottom:6rem;display:flex;flex-direction:column;gap:4rem}
.service-card{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center;padding:0;border-radius:0;background:transparent;border:none;transition:none}
.service-card:hover{box-shadow:none}
.service-card:nth-child(even){direction:rtl}
.service-card:nth-child(even)>*{direction:ltr}
.service-card-image{aspect-ratio:4/3;border-radius:var(--radius-lg);overflow:hidden}
.service-card-image-wide{aspect-ratio:16/10}
.service-card-image img,.service-card-image video{width:100%;height:100%;object-fit:cover;display:block}
.service-card-image .img-placeholder{width:100%;height:100%;border-radius:var(--radius-lg)}
.service-card-content{display:flex;flex-direction:column;gap:1rem;align-items:flex-start}
.service-card h2{margin-bottom:.25rem;font-size:clamp(1.875rem,3vw,2.75rem)}
.service-card p{margin-bottom:.5rem;color:var(--color-text-muted);font-style:normal;font-size:clamp(1rem,1.15vw,1.125rem);font-weight:400;line-height:1.55;max-width:46ch}

/* ===== FAQ / AEO SUPPORT ===== */
.faq-section{padding:1rem 0 6rem}
.faq-section .section-heading{padding-bottom:2rem}
.faq-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.25rem 2rem}
.faq-item{padding:1.5rem 0;border-top:1px solid rgba(54,68,62,.16)}
.faq-item h3{font-family:var(--font-body);font-size:1rem;font-weight:700;letter-spacing:0;margin:0 0 .625rem;color:var(--color-primary)}
.faq-item p{font-size:clamp(.9375rem,1.05vw,1.0625rem);line-height:1.55;color:var(--color-text-muted);max-width:52ch;margin:0}

/* ===== CONTACT PAGE ===== */
.contact-section{padding:calc(var(--header-h) + 3rem) 0 6rem}
.contact-section h1{max-width:13ch;margin-bottom:1.25rem}
.contact-intro{margin-bottom:3rem;max-width:640px;font-size:clamp(1.125rem,1.4vw,1.375rem);color:var(--color-text-muted)}
.contact-layout{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(360px,.92fr);gap:clamp(3rem,6vw,6rem);align-items:stretch}
.contact-form{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;padding:clamp(1.5rem,2.5vw,2.25rem);background:var(--color-paper);border:1px solid rgba(54,68,62,.1);border-radius:var(--radius-lg)}
.form-group{display:flex;flex-direction:column;gap:.625rem}
.form-group:nth-of-type(7),.form-group:nth-of-type(8){grid-column:1/-1}
.form-group label{font-family:var(--font-body);font-weight:700;font-size:.6875rem;text-transform:uppercase;letter-spacing:.16em;color:var(--color-primary)}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:1rem 1.1rem;border:1.5px solid rgba(54,68,62,.16);border-radius:var(--radius);font-family:var(--font-body);font-size:1rem;background:var(--color-bg);color:var(--color-primary);transition:border-color .3s var(--ease),box-shadow .3s var(--ease),border-radius .45s var(--ease-radius),background-color .3s var(--ease);outline:none;resize:vertical}
.form-group select{appearance:none;-webkit-appearance:none;padding-right:3.25rem;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6' fill='none'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%2336443e' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1.25rem center;background-size:10px 6px}
.form-group input:hover,.form-group textarea:hover,.form-group select:hover{border-color:rgba(54,68,62,.35)}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--color-primary);border-radius:18px;box-shadow:0 0 0 3px color-mix(in oklab,var(--color-sage) 65%,transparent);background:color-mix(in oklab,var(--color-bg) 92%,var(--color-paper))}
.form-group textarea{min-height:180px;line-height:1.55}
.contact-form .btn{grid-column:1/-1;justify-self:start;margin-top:.25rem;padding:1rem 2rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.contact-notes{display:grid;grid-template-rows:repeat(3,1fr);gap:1rem;position:sticky;top:calc(var(--header-h) + 1.5rem);height:100%}
.contact-note{position:relative;overflow:hidden;min-height:0;padding:clamp(1.75rem,2.4vw,2.5rem);border-radius:var(--radius-lg);color:var(--color-primary);display:flex;flex-direction:column;align-items:flex-start;gap:.875rem;border:1px solid rgba(54,68,62,.1)}
.contact-note::after{position:absolute;right:1.25rem;bottom:-.45rem;font-family:var(--font-heading);font-size:clamp(5rem,9vw,8rem);line-height:.8;letter-spacing:-.05em;opacity:.09;pointer-events:none}
.contact-note-coral{background:var(--color-coral)}
.contact-note-coral::after{content:'01'}
.contact-note-coral h2,.contact-note-coral ol{margin-left:0}
.contact-note-coral ol{padding-left:0;list-style-position:inside}
.contact-note-sage{background:var(--color-sage)}
.contact-note-sage::after{content:'02'}
.contact-note-gold{background:var(--color-gold)}
.contact-note-gold::after{content:'03'}
.contact-note h2{font-size:clamp(1.5rem,2.2vw,2rem);line-height:1.08;letter-spacing:-.012em;max-width:18ch;margin:0}
.contact-note p,.contact-note li{font-size:.9875rem;line-height:1.55;color:var(--color-primary);opacity:.82}
.contact-note ol{margin:auto 0 0;padding-left:1.2rem}
.contact-note a{margin-top:auto;font-family:var(--font-body);font-weight:700;color:var(--color-primary);text-decoration:underline;text-underline-offset:4px}

/* ===== FOOTER - Murmur-style ===== */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.site-footer{background:var(--color-primary);color:var(--color-text-light);padding:clamp(2.5rem,5vw,4rem) 0 1.5rem}
.site-footer .container{display:flex;flex-direction:column;gap:clamp(2.5rem,5vw,4rem)}
.footer-brand-row{padding:0}
.footer-logo img{height:32px;filter:brightness(0) invert(1);transition:opacity .25s var(--ease)}
.footer-logo:hover img{opacity:.85}
.footer-grid{display:grid;grid-template-columns:repeat(3,1fr) 1.4fr;gap:2rem 3rem;align-items:start}
.footer-nav{display:flex;flex-direction:column}
.footer-nav-heading{display:inline-block;font-family:var(--font-body);font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.2em;color:var(--color-sage);padding:.75rem 0;margin-bottom:.5rem;transition:border-radius .4s var(--ease-radius),background-color .3s;border-radius:2px;align-self:flex-start;padding-left:.5rem;padding-right:.5rem;margin-left:-.5rem}
.footer-nav-heading:hover{border-radius:16px;background:rgba(255,253,248,.06)}
.footer-nav ul{display:flex;flex-direction:column;gap:.125rem}
.footer-nav ul a{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.625rem .75rem;margin-left:-.75rem;font-family:var(--font-body);font-size:.9375rem;font-weight:500;color:var(--color-text-light);opacity:.9;border-radius:2px;transition:border-radius .4s var(--ease-radius),background-color .3s var(--ease),opacity .25s}
.footer-nav ul a:hover{opacity:1;border-radius:16px;background:rgba(32,45,39,.55)}
.footer-nav ul a svg{flex-shrink:0;opacity:.7;transition:transform .25s var(--ease),opacity .25s}
.footer-nav ul a:hover svg{transform:translateX(3px);opacity:1}
.footer-promo{display:flex;flex-direction:column;align-items:flex-start;gap:1rem;padding:1.5rem;background:rgba(255,253,248,.05);border-radius:var(--radius-lg)}
.footer-promo h3{font-family:var(--font-body);font-size:.8125rem;text-transform:uppercase;letter-spacing:.18em;font-weight:700;color:var(--color-sage);margin:0}
.footer-promo-title{font-family:var(--font-heading);font-size:clamp(1.5rem,2.25vw,2rem);font-weight:500;color:var(--color-text-light);line-height:1.05;letter-spacing:-.01em;margin:0}
.footer-promo p{font-size:.9375rem;color:rgba(255,253,248,.75);margin:0;line-height:1.5}
.footer-promo .btn{background:var(--color-bg);color:var(--color-primary);border-color:var(--color-bg);padding:.75rem 1.5rem;font-size:.875rem;margin-top:.25rem}
.footer-promo .btn:hover{border-radius:24px;background:var(--color-sage);border-color:var(--color-sage);color:var(--color-primary)}
.footer-signup{display:grid;grid-template-columns:1fr 1.2fr;gap:2.5rem;align-items:end;padding-top:clamp(2rem,4vw,3rem);border-top:1px solid rgba(255,253,248,.12)}
.footer-signup-text h3{font-family:var(--font-heading);font-size:clamp(1.75rem,2.75vw,2.25rem);font-weight:500;color:var(--color-text-light);margin-bottom:.375rem;letter-spacing:-.01em;line-height:1.05}
.footer-signup-text p{opacity:.7;margin:0;font-size:.9375rem;color:var(--color-text-light)}
.newsletter-form{position:relative;width:100%;max-width:520px}
.newsletter-form input{width:100%;padding:.875rem 3rem .875rem 0;border:none;border-bottom:1.5px solid rgba(255,253,248,.35);border-radius:0;background:transparent;color:var(--color-text-light);font-family:var(--font-body);font-size:1rem;outline:none;transition:border-color .3s}
.newsletter-form input::placeholder{color:rgba(255,253,248,.5)}
.newsletter-form input:focus{border-bottom-color:var(--color-text-light)}
.newsletter-form button{position:absolute;top:50%;right:0;transform:translateY(-50%);min-width:44px;min-height:44px;background:transparent;border:none;color:var(--color-text-light);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .25s var(--ease)}
.newsletter-form button:hover{transform:translateY(-50%) translateX(3px)}
.newsletter-form button:focus-visible{outline:2px solid var(--color-text-light);outline-offset:2px;border-radius:4px}
.newsletter-form input{padding-right:3.5rem}
.footer-meta{display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap;padding-top:clamp(1.5rem,3vw,2rem);border-top:1px solid rgba(255,253,248,.12)}
.footer-address{font-family:var(--font-body);font-size:.875rem;color:rgba(255,253,248,.6);font-weight:500}
.footer-social{display:flex;align-items:center;gap:.75rem}
.footer-social .social-link{display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;border-radius:50%;background:rgba(255,253,248,.08);border:none;color:var(--color-text-light);transition:border-radius .4s var(--ease-radius),background-color .3s var(--ease)}
.footer-social .social-link:hover{border-radius:12px;background:var(--color-sage);color:var(--color-primary)}
.footer-social .social-link svg{width:16px;height:16px}
.footer-social .social-link:focus-visible{outline:2px solid var(--color-text-light);outline-offset:3px}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding-top:1.5rem;font-size:.8125rem;color:rgba(255,253,248,.5);flex-wrap:wrap}
.footer-legal{display:flex;gap:1.5rem}
.footer-legal a{transition:color .2s;color:rgba(255,253,248,.82)}
.footer-legal a:hover{color:var(--color-text-light)}

/* ===== LEGAL PAGES ===== */
.legal-shell{min-height:100vh;background:var(--color-bg);display:flex;flex-direction:column}
.legal-nav{padding:1.5rem 0;border-bottom:1px solid rgba(54,68,62,.1);background:var(--color-bg)}
.legal-nav .container{display:flex;align-items:center;justify-content:space-between;gap:2rem}
.legal-nav-logo img{height:34px;width:auto}
.legal-nav-links{display:flex;align-items:center;gap:1.5rem;font-family:var(--font-body);font-size:.9375rem;font-weight:600;color:var(--color-primary)}
.legal-nav-links a{position:relative}
.legal-nav-links a::after{content:'';position:absolute;left:0;bottom:-3px;width:0;height:1.5px;background:var(--color-primary);transition:width .25s var(--ease)}
.legal-nav-links a:hover::after{width:100%}
.legal-main{flex:1;padding:clamp(4rem,8vw,7rem) 0}
.legal-main .container{max-width:880px;display:flex;flex-direction:column;align-items:flex-start;text-align:left}
.legal-eyebrow{font-family:var(--font-body);font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;color:var(--color-text-muted);margin-bottom:1rem}
.legal-main h1{font-size:clamp(2.75rem,6vw,5.5rem);max-width:12ch;margin:0 0 1rem}
.legal-updated{color:var(--color-text-muted);margin:0 0 3rem}
.legal-content{display:flex;flex-direction:column;gap:2rem;width:100%}
.legal-content section{display:flex;flex-direction:column;gap:.75rem}
.legal-content h2{font-size:clamp(1.5rem,2.4vw,2.25rem);margin:0}
.legal-content p,.legal-content li{color:var(--color-text-muted);font-size:1rem;line-height:1.65;max-width:72ch}
.legal-content ul{list-style:disc;padding-left:1.25rem;display:flex;flex-direction:column;gap:.5rem}
.legal-footer{padding:2rem 0;background:var(--color-primary);color:var(--color-text-light)}
.legal-footer .container{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.legal-footer p{font-size:.875rem;color:rgba(255,253,248,.65);margin:0}
.legal-footer-links{display:flex;gap:1.25rem;font-size:.875rem;color:rgba(255,253,248,.75)}
.legal-footer-links a:hover{color:var(--color-text-light)}
@media(max-width:640px){
  .legal-nav .container{align-items:flex-start;flex-direction:column;gap:1rem}
  .legal-nav-links{flex-wrap:wrap;gap:.75rem 1rem}
  .legal-main{padding:3rem 0}
  .legal-footer .container{flex-direction:column;align-items:flex-start}
}

/* =============================================
   SERVICE DETAIL + CASE STUDY COMPONENTS
   Senior-UX polish: editorial hierarchy, bento
   features, numbered process, pricing tiers,
   ideal/not-for split, case study layout.
   ============================================= */

/* ---- Service detail hero ---- */
.service-hero{padding:calc(var(--header-h) + .75rem) 0 2rem;position:relative}
.service-hero .container{display:flex;flex-direction:column;gap:1rem;align-items:flex-start;max-width:1180px}
.service-hero .kicker{font-size:.6875rem;letter-spacing:.16em;margin-bottom:.25rem;color:var(--color-text-muted)}
.service-hero .service-index{font-family:var(--font-body);font-size:1rem;line-height:1.2;color:var(--color-primary);font-weight:500;letter-spacing:0;margin:0 .15rem .25rem 0;max-width:none;overflow-wrap:normal;border-bottom:0;padding-bottom:0}
.service-hero h1{font-size:clamp(2.45rem,4.2vw,4.25rem);line-height:1.05;letter-spacing:-.018em;max-width:780px;margin:0}
.service-hero .lead{font-family:var(--font-body);font-style:normal;font-size:clamp(1rem,1.15vw,1.125rem);line-height:1.6;max-width:720px;color:var(--color-text);margin-top:.25rem}
.service-detail-hero{padding:calc(var(--header-h) + .75rem) 0 2rem}
.service-detail-hero .container{max-width:1180px;gap:1rem}
.service-detail-hero .kicker{font-size:.6875rem;letter-spacing:.16em;margin-bottom:.25rem;color:var(--color-text-muted)}
.service-detail-hero .service-index{font-family:var(--font-body);font-size:1rem;line-height:1.2;color:var(--color-primary);font-weight:500;letter-spacing:0;margin:0 .15rem .25rem 0;max-width:none;overflow-wrap:normal;border-bottom:0;padding-bottom:0}
.service-detail-hero h1{font-size:clamp(2.45rem,4.2vw,4.25rem);line-height:1.05;letter-spacing:-.018em;max-width:780px}
.service-detail-hero .lead{font-family:var(--font-body);font-style:normal;font-size:clamp(1rem,1.15vw,1.125rem);line-height:1.6;max-width:720px;color:var(--color-text);margin-top:.25rem}
.service-detail-hero .btn{margin-top:.75rem}
.recipe-video-hero{overflow:hidden}
.recipe-video-hero .container{display:grid;grid-template-columns:minmax(0,.85fr) minmax(360px,1fr);align-items:center;gap:clamp(2rem,4vw,4.5rem);max-width:var(--container)}
.recipe-video-hero-copy{display:flex;flex-direction:column;align-items:flex-start;gap:1rem}
.recipe-video-marquee{position:relative;width:100%;min-width:0;overflow:hidden;padding:.75rem 0;mask-image:linear-gradient(to right,transparent 0,#000 10%,#000 90%,transparent 100%);-webkit-mask-image:linear-gradient(to right,transparent 0,#000 10%,#000 90%,transparent 100%)}
.recipe-video-marquee-track{display:flex;width:max-content;animation:recipe-video-scroll 72s linear infinite;will-change:transform}
.recipe-video-marquee-list{display:flex;align-items:center;gap:clamp(.75rem,1.25vw,1.125rem);padding-right:clamp(.75rem,1.25vw,1.125rem);flex-shrink:0}
.recipe-video-marquee-list li{flex:0 0 auto;width:clamp(112px,9vw,150px);aspect-ratio:9/16;border-radius:var(--radius-lg);overflow:hidden;background:var(--color-primary-deep);box-shadow:0 18px 42px rgba(32,45,39,.14)}
.recipe-video-marquee-list video,.recipe-video-marquee-list img{width:100%;height:100%;object-fit:cover;display:block}
.hero-line{display:block}
.social-photo-hero .recipe-video-marquee{display:flex;flex-direction:column;gap:clamp(.75rem,1.25vw,1.125rem);padding:0}
.social-photo-hero .container{grid-template-columns:minmax(0,1.05fr) minmax(360px,.95fr);gap:clamp(1.75rem,3vw,3.5rem)}
.social-photo-hero h1{max-width:760px}
.social-photo-hero h1 .hero-line{white-space:nowrap}
.social-photo-hero .recipe-video-marquee-list li{width:clamp(140px,13vw,210px);aspect-ratio:1;background:var(--color-paper)}
.social-photo-hero .recipe-video-marquee-track{animation-duration:58s}
.social-photo-hero .social-marquee-row-alt{animation-direction:reverse;animation-duration:64s}
@keyframes recipe-video-scroll{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}
.service-detail-visual{padding:0}
.service-detail-visual .container{max-width:none;padding:0}
.service-detail-visual .img-placeholder{width:100%;aspect-ratio:3.1/1;min-height:300px;border-radius:0;background-size:cover;background-position:center}
.service-detail-visual .img-placeholder::before{background:linear-gradient(90deg,rgba(32,45,39,.18),rgba(255,253,248,.04) 42%,rgba(32,45,39,.12)),radial-gradient(circle at 20% 30%,rgba(255,253,248,.16),transparent 34%);mix-blend-mode:multiply}
.service-detail-visual .ph-sage,.service-detail-visual .ph-cream,.service-detail-visual .ph-green{background-image:url('../assets/portfolio-background-green.webp')}
.service-detail-visual .ph-coral,.service-detail-visual .ph-gold{background-image:url('../assets/pizza.webp')}
.service-visual-media{width:100%;aspect-ratio:3.1/1;min-height:300px;border-radius:0;overflow:hidden;background:var(--color-paper)}
.service-visual-media img,.service-visual-media>video{width:100%;height:100%;object-fit:cover;display:block}
.service-visual-media.website-preview-crop img{object-position:center top}
.service-visual-media.work-item-triptych{height:auto;border-radius:0}
.service-visual-media.work-item-triptych video{width:auto;height:88%;max-height:520px}
.service-story{padding-top:5rem}
.retainer-hero{padding:calc(var(--header-h) + 2.5rem) 0 clamp(4rem,7vw,6rem)}
.retainer-hero .container{display:grid;grid-template-columns:minmax(0,.92fr) minmax(360px,.78fr);gap:clamp(2.5rem,6vw,5rem);align-items:center;max-width:var(--container)}
.retainer-hero-copy{display:flex;flex-direction:column;align-items:flex-start;gap:1rem}
.retainer-hero .service-index{margin-bottom:0}
.retainer-hero h1{max-width:18ch}
.retainer-hero .lead{max-width:46ch;margin:0}
.retainer-hero-media{position:relative;overflow:hidden;border-radius:var(--radius-lg);aspect-ratio:4/5;background:var(--color-sage)}
.retainer-hero-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(32,45,39,.05),rgba(32,45,39,.2));pointer-events:none}
.retainer-hero-media img{width:100%;height:100%;object-fit:cover;display:block}

/* ---- Section heading (reusable editorial heading row) ---- */
.section-heading{padding:5rem 0 2.5rem}
.section-heading .container{display:flex;flex-direction:column;gap:.75rem;align-items:flex-start;max-width:960px}
.section-heading h2{max-width:22ch}
.section-heading p{font-size:clamp(1.0625rem,1.25vw,1.1875rem);color:var(--color-text-muted);max-width:640px;line-height:1.5}

/* ---- Feature bento: 6-card grid with warm wash tiles ---- */
.feature-bento{padding:1rem 0 7rem}
.feature-bento .bento-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.bento-card{background:var(--color-paper);border-radius:var(--radius-lg);padding:clamp(1.75rem,2.5vw,2.5rem);display:flex;flex-direction:column;gap:.75rem;transition:transform .5s var(--ease),background-color .4s var(--ease);min-height:220px;position:relative;overflow:hidden}
.bento-card::before{content:'';position:absolute;left:clamp(1.75rem,2.5vw,2.5rem);top:clamp(1.75rem,2.5vw,2.5rem);width:12px;height:12px;border-radius:50%;background:var(--color-gold);opacity:.85;transition:transform .5s var(--ease)}
.bento-card h3{margin:0;padding-top:2.25rem;font-size:clamp(1.25rem,1.8vw,1.625rem);letter-spacing:-.01em}
.bento-card p{margin:0;font-size:clamp(.9375rem,1.05vw,1rem);color:var(--color-text-muted);line-height:1.55;max-width:32ch}
.bento-card:hover{transform:translateY(-4px)}
.bento-card:hover::before{transform:scale(1.25)}
.bento-card.accent-sage{background:var(--color-sage)}
.bento-card.accent-sage::before{background:var(--color-primary)}
.bento-card.accent-sage p{color:var(--color-primary);opacity:.75}
.bento-card.accent-coral{background:var(--color-coral)}
.bento-card.accent-coral::before{background:var(--color-primary)}
.bento-card.accent-coral p{color:var(--color-primary);opacity:.8}
.bento-card.accent-dark{background:var(--color-primary);color:var(--color-text-light)}
.bento-card.accent-dark h3{color:var(--color-text-light)}
.bento-card.accent-dark p{color:var(--color-text-light);opacity:.75}
.bento-card.accent-dark::before{background:var(--color-gold)}

/* ---- Numbered process steps (clean horizontal row) ---- */
.process-steps{padding:1rem 0 7rem}
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2.5rem;position:relative}
.process-grid::before{content:'';position:absolute;top:2.25rem;left:8%;right:8%;height:1px;background:linear-gradient(to right,transparent,rgba(54,68,62,.2) 10%,rgba(54,68,62,.2) 90%,transparent);z-index:0}
.process-step{display:flex;flex-direction:column;gap:1rem;align-items:flex-start;position:relative;z-index:1}
.process-number{width:4.5rem;height:4.5rem;border-radius:50%;background:var(--color-bg);border:1.5px solid rgba(54,68,62,.2);display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:1.75rem;color:var(--color-primary);font-weight:500;transition:background-color .35s var(--ease),color .35s var(--ease),border-color .35s var(--ease),transform .35s var(--ease)}
.process-step:hover .process-number{background:var(--color-primary);color:var(--color-text-light);border-color:var(--color-primary);transform:scale(1.05)}
.process-step h3{font-size:clamp(1.125rem,1.5vw,1.375rem);margin:0;letter-spacing:-.01em}
.process-step p{font-size:clamp(.9375rem,1.05vw,1rem);color:var(--color-text-muted);line-height:1.55;margin:0;max-width:24ch}

/* ---- Pricing tiers, editorial scope cards ---- */
.pricing-section{padding:clamp(4.5rem,8vw,7rem) 0;background:var(--color-paper)}
.pricing-section .section-heading{padding-top:0;padding-bottom:clamp(2rem,4vw,3.5rem)}
.pricing-section .section-heading .container{display:grid;grid-template-columns:minmax(0,1fr);gap:1rem;align-items:start;max-width:var(--container)}
.pricing-section .section-heading .kicker{margin:0}
.pricing-section .section-heading h2{max-width:20ch;margin:0}
.pricing-section .section-heading p{max-width:52ch;margin:0;color:var(--color-text-muted);font-size:clamp(1rem,1.2vw,1.125rem);line-height:1.6}
.pricing-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(1rem,2vw,1.75rem);max-width:var(--container);margin:0 auto;padding:0 clamp(1.25rem,3vw,2.5rem);align-items:stretch}
.pricing-card{background:rgba(255,253,248,.64);border-radius:14px;padding:0;display:flex;flex-direction:column;gap:0;transition:transform .7s cubic-bezier(.22,.61,.36,1),box-shadow .7s cubic-bezier(.22,.61,.36,1),background-color .7s cubic-bezier(.22,.61,.36,1);border:1px solid rgba(54,68,62,.12);position:relative;overflow:hidden;height:100%;box-shadow:0 1px 0 rgba(54,68,62,.05)}
.pricing-card::before{content:"";position:absolute;inset:0 0 auto;height:4px;background:var(--color-primary);opacity:.28}
.pricing-card:hover{transform:translateY(-6px);box-shadow:0 24px 70px -42px rgba(32,45,39,.35);background:rgba(255,253,248,.86)}
.pricing-card-head{padding:clamp(1.5rem,2.4vw,2.25rem) clamp(1.35rem,2.2vw,2rem) clamp(1.25rem,2vw,1.75rem);display:flex;flex-direction:column;gap:0;flex:0 0 auto;min-height:310px}
.pricing-card .pricing-label{display:inline-flex;align-self:flex-start;align-items:center;gap:.5rem;margin:0 0 1.2rem;font-family:var(--font-body);font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;color:var(--color-text-muted);line-height:1}
.pricing-card .pricing-label::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--color-gold)}
.pricing-card h3{font-family:var(--font-heading);font-size:clamp(1.65rem,2.35vw,2.25rem);margin:0 0 .75rem;letter-spacing:-.018em;font-weight:500;color:var(--color-primary);line-height:1.04}
.pricing-card .pricing-desc{font-size:clamp(.95rem,1.05vw,1rem);color:var(--color-text-muted);line-height:1.6;margin:0 0 1.75rem;font-family:var(--font-body)}
.pricing-card .pricing-price{font-family:var(--font-heading);font-size:clamp(2.35rem,4.4vw,4.5rem);color:var(--color-primary);letter-spacing:-.035em;line-height:.9;margin:auto 0 .55rem;font-weight:500;display:flex;align-items:baseline;flex-wrap:wrap;gap:.15em}
.pricing-card .pricing-price span{font-size:clamp(.9rem,1vw,1rem);font-family:var(--font-body);color:var(--color-text-muted);font-weight:600;letter-spacing:0}
.pricing-card .pricing-price-note{font-size:.8125rem;color:var(--color-text-muted);margin:0;font-family:var(--font-body);line-height:1.45}
.pricing-card-body{padding:clamp(1.35rem,2vw,1.9rem) clamp(1.35rem,2.2vw,2rem) clamp(1.5rem,2.3vw,2.1rem);display:flex;flex-direction:column;gap:1.4rem;border-top:1px solid var(--border-medium);flex:1 1 auto}
.pricing-features{display:flex;flex-direction:column;gap:.82rem;margin:0 0 auto;padding:0;border:none;list-style:none}
.pricing-features li{position:relative;padding-left:1.35rem;font-size:.9375rem;line-height:1.5;color:var(--color-primary);font-family:var(--font-body)}
.pricing-features li::before{content:"";position:absolute;left:0;top:.62em;width:6px;height:6px;border-radius:50%;background:var(--color-primary);opacity:.54}
.pricing-cta-wrap{margin-top:auto;display:flex;flex-direction:column;align-items:stretch;gap:.85rem;text-align:center}
.pricing-card .pricing-cta.btn{width:100%;justify-content:center;border-radius:999px;padding:1rem 1.35rem;font-size:.9375rem}
.pricing-card .pricing-cta.btn:hover{border-radius:999px;transform:translateY(-1px)}
.pricing-card .pricing-cta.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px}
.pricing-booklink{align-self:center;font-size:.875rem;color:var(--color-primary);text-decoration:underline;text-underline-offset:4px;text-decoration-thickness:1px;font-weight:600;transition:color .3s var(--ease)}
.pricing-booklink:hover{color:var(--color-primary-deep)}
.pricing-booklink:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px;border-radius:2px}

/* Featured tier, confident but still restrained. */
.pricing-card.pricing-featured{background:var(--color-sage);border-color:rgba(32,45,39,.18);box-shadow:0 22px 70px -46px rgba(32,45,39,.55)}
.pricing-card.pricing-featured::before{opacity:1;background:var(--color-primary-deep)}
.pricing-card.pricing-featured:hover{background:color-mix(in oklab,var(--color-sage) 88%,var(--color-bg))}
.pricing-card.pricing-featured .pricing-card-body{border-top-color:rgba(32,45,39,.2)}
.pricing-card.pricing-featured .pricing-label,.pricing-card.pricing-featured .pricing-price span,.pricing-card.pricing-featured .pricing-price-note{color:rgba(32,45,39,.72)}
.pricing-card.pricing-featured h3,.pricing-card.pricing-featured .pricing-price{color:var(--color-primary-deep)}
.pricing-card.pricing-featured .pricing-features li{font-weight:600;color:var(--color-primary-deep)}
.pricing-card.pricing-featured .pricing-features li::before{background:var(--color-primary-deep);opacity:.8}
.pricing-badge{position:absolute;top:1.35rem;right:1.35rem;background:var(--color-primary-deep);color:var(--color-text-light);font-family:var(--font-body);font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;padding:.48rem .82rem;border-radius:999px;line-height:1;z-index:2}
.pricing-card.pricing-featured .pricing-card-head{padding-top:2.6rem}
.pricing-card.pricing-featured .pricing-cta{background:var(--color-primary-deep);border-color:var(--color-primary-deep)}
.pricing-card.pricing-featured .pricing-cta:hover{background:color-mix(in oklab,var(--color-primary-deep) 88%,var(--color-bg));border-color:color-mix(in oklab,var(--color-primary-deep) 88%,var(--color-bg))}
.aftercare-pricing{width:calc(100% - clamp(2.5rem,6vw,5rem));max-width:calc(var(--container) - clamp(2.5rem,6vw,5rem));margin:clamp(1rem,2vw,1.75rem) auto 0;padding:clamp(1.35rem,2.4vw,2.1rem);display:grid;grid-template-columns:minmax(220px,.8fr) minmax(0,1.9fr);gap:clamp(1rem,2vw,1.5rem);align-items:stretch;border:1px solid rgba(54,68,62,.12);border-radius:14px;background:rgba(255,253,248,.72);box-shadow:0 1px 0 rgba(54,68,62,.05)}
.aftercare-heading{display:flex;flex-direction:column;justify-content:center;gap:.65rem;padding-right:clamp(.25rem,1.5vw,1.25rem)}
.aftercare-heading .kicker{margin:0;color:var(--color-primary)}
.aftercare-heading h3{font-family:var(--font-heading);font-size:clamp(1.55rem,2.4vw,2.25rem);line-height:1.05;font-weight:500;color:var(--color-primary);margin:0;letter-spacing:-.018em}
.aftercare-heading p{font-size:.96rem;line-height:1.55;color:var(--color-text-muted);margin:0;max-width:38ch}
.aftercare-options{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem}
.aftercare-option{min-height:188px;padding:1.15rem;border:1px solid rgba(54,68,62,.12);border-radius:10px;background:var(--color-bg);display:flex;flex-direction:column;gap:.5rem}
.aftercare-option span{font-family:var(--font-body);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--color-text-muted);line-height:1}
.aftercare-option strong{font-family:var(--font-heading);font-size:clamp(1.45rem,2vw,2rem);font-weight:500;line-height:1.05;letter-spacing:-.02em;color:var(--color-primary)}
.aftercare-option p{font-size:.9rem;line-height:1.5;color:var(--color-text-muted);margin:0}

/* ---- Best-for service cards ---- */
.ideal-split{padding:7rem 0;background:var(--color-bg);color:var(--color-primary);position:relative;overflow:hidden}
.ideal-split .section-heading{position:relative;z-index:1}
.ideal-split .section-heading .container{display:flex;flex-direction:column;gap:.75rem;align-items:flex-start;max-width:var(--container)}
.ideal-split .kicker{color:var(--color-primary);margin-bottom:0}
.ideal-split h2{color:var(--color-primary);max-width:24ch}
.ideal-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;position:relative;z-index:1}
.ideal-card{min-height:240px;padding:clamp(1.75rem,2.4vw,2.5rem) 24px;border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:.75rem;align-items:flex-start;position:relative;overflow:hidden;color:var(--color-primary);border:1px solid rgba(54,68,62,.1);transition:transform .5s var(--ease)}
.ideal-card:hover{transform:translateY(-4px)}
.ideal-card::after{position:absolute;right:1.25rem;bottom:-.45rem;font-family:var(--font-heading);font-size:clamp(4.75rem,9vw,8rem);line-height:.8;letter-spacing:-.05em;opacity:.09;pointer-events:none}
.ideal-card:nth-child(1){background:var(--color-coral)}
.ideal-card:nth-child(1)::after{content:'01'}
.ideal-card:nth-child(2){background:var(--color-sage)}
.ideal-card:nth-child(2)::after{content:'02'}
.ideal-card:nth-child(3){background:var(--color-gold)}
.ideal-card:nth-child(3)::after{content:'03'}
.ideal-card:nth-child(4){background:var(--color-paper)}
.ideal-card:nth-child(4)::after{content:'04'}
.ideal-card h3{font-size:clamp(1.35rem,2vw,1.875rem);margin:0;letter-spacing:-.012em;max-width:15ch}
.ideal-card p{font-size:clamp(.95rem,1.05vw,1rem);color:inherit;opacity:.78;line-height:1.55;margin:0;max-width:36ch}

/* ---- Case study - hero image full-bleed ---- */
.case-hero-image{padding:0 0 5rem}
.case-hero-image .container{padding:0;max-width:none}
.case-hero-image .case-hero-inner{width:100%;aspect-ratio:16/9;max-height:720px;overflow:hidden;border-radius:0}
.case-hero-image .case-hero-inner img,.case-hero-image .case-hero-inner .img-placeholder{width:100%;height:100%;object-fit:cover;border-radius:0}

/* ---- Case study - header ---- */
.case-header{padding:calc(var(--header-h) + 2rem) 0 4rem}
.case-header .container{display:flex;flex-direction:column;gap:1.5rem;align-items:flex-start;max-width:1100px}
.case-header h1{font-size:clamp(3.25rem,7vw,6rem);max-width:16ch;margin:0;letter-spacing:-.03em;line-height:.98}
.case-header .case-tagline{font-size:clamp(1.25rem,1.75vw,1.625rem);max-width:720px;color:var(--color-text-muted);line-height:1.4;font-family:var(--font-heading);font-style:italic;font-weight:400;margin-top:.5rem}

/* ---- Case meta bar ---- */

/* ---- Case narrative - editorial long-form ---- */
.case-narrative{padding:5rem 0;background:var(--color-bg)}
.case-narrative.has-bg{background:var(--color-paper)}
.case-narrative .container{max-width:1100px}
.narrative-split{display:grid;grid-template-columns:1fr 1.5fr;gap:clamp(2.5rem,5vw,5rem);align-items:start}
.narrative-split .narrative-aside{display:flex;flex-direction:column;gap:1rem;align-items:flex-start;position:sticky;top:calc(var(--header-h) + 2rem)}
.narrative-split .narrative-aside h2{font-size:clamp(2rem,3.25vw,2.75rem);max-width:18ch;margin:0;letter-spacing:-.015em}
.narrative-split .narrative-aside .kicker{margin:0}
.narrative-split .narrative-body{display:flex;flex-direction:column;gap:1.25rem}
.narrative-split .narrative-body p{font-size:clamp(1.0625rem,1.25vw,1.1875rem);line-height:1.6;color:var(--color-primary);max-width:60ch}
.narrative-split .narrative-body p:first-of-type::first-letter{font-family:inherit;font-size:inherit;float:none;line-height:inherit;margin:0;color:inherit;font-weight:inherit}

/* ---- Role cards (3-up role pill cards) ---- */
.role-section{padding:5rem 0}
.role-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.role-card{padding:2rem;background:var(--color-paper);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:.75rem;transition:transform .4s var(--ease)}
.role-card:hover{transform:translateY(-4px)}
.role-card .role-number{font-family:var(--font-heading);font-size:2rem;color:var(--color-gold);font-weight:500;line-height:1;letter-spacing:-.02em}
.role-card h3{font-size:clamp(1.125rem,1.6vw,1.375rem);margin:0;letter-spacing:-.01em}
.role-card p{font-size:.9375rem;color:var(--color-text-muted);line-height:1.55;margin:0}

/* ---- Case pullquote - big editorial stat/quote ---- */

/* ---- Takeaways - 2-col highlighted ---- */
.takeaways{padding:6rem 0}
.takeaways-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.takeaway-card{padding:2.5rem;border-radius:var(--radius-lg);background:var(--color-paper);display:flex;flex-direction:column;gap:1rem;position:relative}
.takeaway-card .takeaway-number{font-family:var(--font-heading);font-size:3.5rem;color:var(--color-gold);line-height:.85;font-weight:500;letter-spacing:-.03em;margin-bottom:.5rem}
.takeaway-card h3{font-size:clamp(1.375rem,2vw,1.625rem);margin:0;max-width:24ch;letter-spacing:-.01em}
.takeaway-card p{font-size:clamp(1rem,1.1vw,1.0625rem);color:var(--color-text-muted);line-height:1.55;margin:0;max-width:42ch}

/* ---- Next-project nav ---- */
.case-next{padding:5rem 0;text-align:center;border-top:1px solid rgba(54,68,62,.1)}
.case-next .kicker{opacity:.6}
.case-next h2{margin:.5rem 0 2rem;font-size:clamp(2rem,3.5vw,3rem)}
.case-next-link{display:inline-flex;align-items:center;gap:.75rem;font-family:var(--font-body);font-weight:600;font-size:1rem;transition:gap .3s var(--ease)}
.case-next-link:hover{gap:1.25rem}

/* ---- Responsive overrides for new components ---- */
@media(max-width:1024px){
  .feature-bento .bento-grid{grid-template-columns:1fr 1fr}
  .process-grid{grid-template-columns:1fr 1fr;gap:3rem}
  .process-grid::before{display:none}
  .pricing-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1.25rem}
  .pricing-section .section-heading .container{grid-template-columns:1fr;gap:1rem;align-items:start}
  .pricing-section .section-heading h2{max-width:18ch}
  .pricing-card-head{min-height:auto}
  .aftercare-pricing{width:auto;max-width:none;grid-template-columns:1fr;margin-left:clamp(1.25rem,3vw,2.5rem);margin-right:clamp(1.25rem,3vw,2.5rem)}
  .aftercare-heading{padding-right:0}
  .retainer-example-head{grid-template-columns:1fr;align-items:start}
  .retainer-stats{grid-template-columns:repeat(2,minmax(0,1fr))}
  .retainer-stats div:nth-child(2){border-right:none}
  .retainer-stats div:nth-child(-n+2){border-bottom:1px solid rgba(54,68,62,.16)}
  .retainer-pillars{grid-template-columns:1fr}
  .retainer-pillars.is-four{grid-template-columns:1fr}
  .retainer-example-dark .retainer-stats div:nth-child(-n+2){border-bottom-color:rgba(255,253,248,.22)}
  .retainer-timeline{grid-template-columns:1fr}
  .retainer-timeline-head{position:static}
  .retainer-rhythm{grid-template-columns:1fr}
  .retainer-rhythm .btn{justify-self:start}
  .retainer-hero .container{grid-template-columns:1fr;gap:2rem}
  .retainer-hero-media{aspect-ratio:16/9}
  .ideal-grid{grid-template-columns:1fr 1fr;gap:1rem}
  .narrative-split{grid-template-columns:1fr;gap:2rem}
  .narrative-split .narrative-aside{position:static}
  .role-grid{grid-template-columns:1fr;gap:1rem}
  .takeaways-grid{grid-template-columns:1fr;gap:1rem}
}
@media(max-width:768px){
  .feature-bento .bento-grid{grid-template-columns:1fr}
  .process-grid{grid-template-columns:1fr;gap:2.25rem}
  .service-hero{padding-top:calc(var(--header-h) + 1rem);padding-bottom:3rem}
  .service-detail-hero{padding-top:calc(var(--header-h) + .75rem);padding-bottom:2rem}
  .service-detail-hero .service-index{font-size:.9375rem;max-width:none}
  .service-detail-hero h1{font-size:clamp(2.35rem,11vw,3.5rem)}
  .retainer-hero{padding-top:calc(var(--header-h) + 1rem);padding-bottom:3rem}
  .retainer-hero h1{max-width:12ch}
  .retainer-hero-media{aspect-ratio:4/3}
  .service-detail-visual{padding-bottom:0}
  .service-detail-visual .img-placeholder{aspect-ratio:4/3;min-height:280px}
  .service-visual-media{aspect-ratio:4/3;min-height:280px}
  .service-visual-media.work-item-triptych video{height:92%;max-width:30%}
  .service-story{padding-top:3.5rem}
  .case-header{padding-top:calc(var(--header-h) + 1rem);padding-bottom:2rem}
  .case-hero-image .case-hero-inner{aspect-ratio:4/3}
  .case-narrative{padding:3.5rem 0}
  .takeaways{padding:3.5rem 0}
  .pricing-section{padding-bottom:3.5rem}
  .pricing-section .section-heading{padding-top:3.5rem}
  .pricing-card .pricing-price{font-size:clamp(2.25rem,13vw,3.25rem)}
  .aftercare-options{grid-template-columns:1fr}
  .pricing-badge{top:1rem;right:1rem}
  .pricing-card.pricing-featured .pricing-card-head{padding-top:1.5rem}
  .retainer-example{padding:3.5rem 0}
  .retainer-month-grid{grid-template-columns:1fr}
  .retainer-month-grid article:nth-child(2){border-top:1px solid rgba(54,68,62,.16);padding-top:1.25rem}
  .retainer-rhythm ol{grid-template-columns:1fr}
  .ideal-split{padding:3.5rem 0}
  .ideal-grid{grid-template-columns:1fr}
  .feature-bento{padding-bottom:3.5rem}
  .process-steps{padding-bottom:3.5rem}
  .role-section{padding:3.5rem 0}
  .bento-card{min-height:auto;padding:1.5rem}
}

/* =============================================
   ABOUT PAGE - editorial layouts
   ============================================= */

/* Full-bleed editorial image row */
.full-image{padding:2rem 0 5rem}
.full-image .container{max-width:none;padding:0}
.full-image .full-image-inner{width:100%;aspect-ratio:21/9;overflow:hidden;position:relative;background:var(--color-sage)}
.full-image .full-image-inner picture{display:block;width:100%;height:100%}
.full-image .full-image-inner img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease);display:block}
.full-image .full-image-inner:hover img{transform:scale(1.03)}
.full-image.contained .container{max-width:var(--container);padding:0 clamp(1.25rem,3vw,2.5rem)}
.full-image.contained .full-image-inner{border-radius:var(--radius-lg);aspect-ratio:16/9}

/* Founder split - large portrait + story */
.founder-split{padding:6rem 0}
.founder-split .container{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(2.5rem,5vw,5rem);align-items:center;max-width:1200px}
.founder-portrait{aspect-ratio:4/5;overflow:hidden;border-radius:var(--radius-lg);position:relative;background:var(--color-coral)}
.founder-portrait img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;transition:transform 1s var(--ease)}
.founder-portrait:hover img{transform:scale(1.03)}
.founder-content{display:flex;flex-direction:column;gap:1.25rem;align-items:flex-start}
.founder-content .kicker{margin:0}
.founder-content h2{margin:0;font-size:clamp(2rem,3.5vw,3rem);max-width:18ch;letter-spacing:-.02em;line-height:1.05}
.founder-content p{font-size:clamp(1.0625rem,1.2vw,1.1875rem);line-height:1.6;color:var(--color-primary);max-width:54ch;margin:0}
.founder-stats{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:1.5rem;padding-top:1.75rem;border-top:1px solid var(--border-strong);width:100%;max-width:480px}
.founder-stat{display:flex;flex-direction:column;gap:.5rem}
.founder-stat .stat-number{font-family:var(--font-heading);font-size:clamp(2.25rem,3.25vw,2.75rem);color:var(--color-gold);line-height:1;letter-spacing:-.02em;font-weight:500}
.founder-stat .stat-label{font-family:var(--font-body);font-size:.75rem;text-transform:uppercase;letter-spacing:.18em;font-weight:700;color:var(--color-text-muted)}

/* Brand wall - 3x2 grid of client marks */
.brand-wall{padding:6rem 0;background:var(--color-paper)}
.brand-wall-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border-medium);border:1px solid var(--border-medium);max-width:var(--container);margin:0 auto}
.brand-mark{background:var(--color-paper);padding:2.75rem 2rem;display:flex;align-items:center;justify-content:center;min-height:160px;font-family:var(--font-heading);font-size:clamp(1.25rem,2vw,1.75rem);font-weight:500;color:var(--color-primary);letter-spacing:-.015em;text-align:center;transition:background-color .35s var(--ease),color .35s var(--ease)}
.brand-mark:hover{background:var(--color-primary);color:var(--color-bg)}
.brand-wall .section-heading{padding-top:0;padding-bottom:3rem}

/* Brand marquee - auto-scrolling logo strip (right-to-left) */
.brand-marquee{padding:clamp(3.5rem,6vw,5.5rem) 0;background:var(--color-bg);overflow:hidden;position:relative}
.brand-marquee-heading{text-align:center;margin-bottom:clamp(2rem,3.5vw,3rem);padding:0 clamp(1.25rem,3vw,2.5rem)}
.brand-marquee-heading .kicker{margin-bottom:.875rem}
.brand-marquee-heading h2{font-size:clamp(1.75rem,3vw,2.5rem);margin-bottom:.625rem}
.brand-marquee-heading p{font-size:clamp(.9375rem,1vw,1rem);color:var(--color-text-muted);margin:0 auto;max-width:48ch}
.brand-marquee-viewport{position:relative;width:100%;mask-image:linear-gradient(to right,transparent 0,#000 8%,#000 92%,transparent 100%);-webkit-mask-image:linear-gradient(to right,transparent 0,#000 8%,#000 92%,transparent 100%)}
.brand-marquee-track{display:flex;width:max-content;animation:brand-scroll 55s linear infinite;will-change:transform}
.brand-marquee-list{display:flex;align-items:center;gap:clamp(3rem,6vw,5.5rem);padding-right:clamp(3rem,6vw,5.5rem);flex-shrink:0}
.brand-marquee-item{flex:0 0 auto;display:flex;align-items:center;justify-content:center;height:clamp(40px,5vw,56px);opacity:.7;transition:opacity .35s var(--ease)}
.brand-marquee-item img{height:100%;width:auto;max-width:220px;object-fit:contain;display:block;transition:filter .35s var(--ease)}
.brand-marquee-item:hover{opacity:1}
@keyframes brand-scroll{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}
@media (prefers-reduced-motion:reduce){.brand-marquee-track,.recipe-video-marquee-track{animation-duration:180s}}
@media (max-width:640px){.brand-marquee{padding:3rem 0}.brand-marquee-track{animation-duration:40s}}

/* Principles - numbered list, Murmur-style */
.principles{padding:6rem 0}
.principles-list{display:flex;flex-direction:column;gap:0;max-width:1100px;margin:0 auto}
.principle-row{display:grid;grid-template-columns:auto 1fr 2fr;gap:clamp(2rem,5vw,5rem);align-items:baseline;padding:2rem 0;border-top:1px solid var(--border-medium);transition:transform .45s var(--ease),background-color .45s var(--ease),border-color .45s var(--ease)}
.principle-row:last-child{border-bottom:1px solid var(--border-medium)}
.principle-row:hover{transform:translateX(.75rem);background:rgba(237,245,232,.38);border-color:var(--border-strong)}
.principle-num{font-family:var(--font-heading);font-size:clamp(1.25rem,1.5vw,1.5rem);color:var(--color-gold);font-weight:500;line-height:1;letter-spacing:-.01em}
.principle-title{font-family:var(--font-heading);font-size:clamp(1.5rem,2.5vw,2.25rem);font-weight:500;color:var(--color-primary);line-height:1.1;letter-spacing:-.015em;margin:0}
.principle-body{font-size:clamp(1rem,1.15vw,1.125rem);color:var(--color-text-muted);line-height:1.55;margin:0;max-width:48ch}

/* Responsive */
@media(max-width:900px){
  .founder-split .container{grid-template-columns:1fr;gap:2.5rem}
  .founder-portrait{aspect-ratio:4/5;max-width:420px;margin:0 auto;width:100%}
  .brand-wall-grid{grid-template-columns:repeat(2,1fr)}
  .principle-row{grid-template-columns:auto 1fr;gap:1.25rem 1.5rem;padding:1.5rem 0}
  .principle-body{grid-column:1/-1;padding-top:.25rem}
  .principle-row:hover{transform:translateX(.35rem)}
}
@media(max-width:600px){
  .brand-wall-grid{grid-template-columns:1fr}
  .founder-stats{grid-template-columns:1fr 1fr;gap:1.25rem}
  .founder-split{padding:3.5rem 0}
  .brand-wall{padding:3.5rem 0}
  .principles{padding:3.5rem 0}
  .full-image{padding:1.5rem 0 3rem}
  .full-image .full-image-inner{aspect-ratio:4/5}
  .full-image .full-image-inner img{object-position:center center}
}

/* ===== SCROLL ANIMATIONS ===== */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.active{opacity:1;transform:translateY(0)}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  :root{--header-h:90px}
  .main-nav,.header-cta,.site-header .language-switcher{display:none}
  .hamburger{display:flex;margin-left:auto}
  .work-item,.work-item:nth-child(odd){grid-template-columns:1fr;margin-bottom:4rem}
  .work-item:nth-child(odd) .work-item-image{order:0}
  .work-item:nth-child(odd) .work-item-content{order:0;padding-left:clamp(1.5rem,4vw,3rem);padding-right:clamp(1.5rem,4vw,3rem)}
  .work-item-image,
  .work-item:nth-child(even) .work-item-image,
  .work-item:nth-child(odd) .work-item-image{border-radius:0}
  .work-item-image:not(.work-item-triptych){margin-left:clamp(1.25rem,3vw,2.5rem);margin-right:clamp(1.25rem,3vw,2.5rem);border-radius:var(--radius-lg)}
  .values-grid{grid-template-columns:1fr;gap:3rem}
  .about-cards{grid-template-columns:1fr}
  .service-card{grid-template-columns:1fr;gap:2rem;padding:0}
  .service-card:nth-child(even){direction:ltr}
  .bcorp-layout{grid-template-columns:1fr;gap:2.5rem}
  .contact-layout{grid-template-columns:1fr;gap:3rem}
  .contact-notes{position:static}
  .footer-grid{grid-template-columns:repeat(2,1fr);gap:2rem}
  .footer-promo{grid-column:1/-1}
  .footer-signup{grid-template-columns:1fr;gap:1.5rem;align-items:start}
  .form-row{grid-template-columns:1fr}
}
@media(max-width:768px){
  :root{--header-h:72px}
  .pricing-grid{grid-template-columns:1fr;gap:1rem}
  .hero{min-height:auto;padding-top:calc(var(--header-h) + 2.5rem);padding-bottom:3.5rem}
  .hero-image{max-width:180px;margin-bottom:1.25rem}
  .recipe-video-hero .container{grid-template-columns:1fr;gap:2rem}
  .social-photo-hero h1 .hero-line{white-space:normal}
  .recipe-video-marquee{width:calc(100% + 2.5rem);margin-inline:-1.25rem}
  .recipe-video-marquee-list li{width:116px}
  .recipe-video-marquee-track{animation-duration:55s}
  .work-showcase{padding:3rem 0}
  .work-item-image:not(.work-item-triptych){margin-left:0;margin-right:0;border-radius:0}
  .work-item-triptych{gap:.4rem;padding:.5rem}
  .work-item-triptych video{width:calc((100% - .8rem)/3);border-radius:4px}
  .work-item-triptych.social-triptych img{width:calc((100% - .8rem)/3);border-radius:4px}
  .work-item-triptych.social-diptych img{width:calc((100% - .4rem)/2);border-radius:4px}
  .quiz-cta{padding:4rem 1.5rem}
  .values-section{padding:4rem 0}
  .faq-section{padding:0 0 4rem}
  .faq-grid{grid-template-columns:1fr;gap:.5rem}
  .cta-section{padding:5rem 0}
  .bcorp-section{padding:4rem 0}
  .work-grid{grid-template-columns:1fr;gap:2.5rem}
  .contact-section{padding-top:calc(var(--header-h) + 2rem)}
  .contact-form{grid-template-columns:1fr;padding:1.25rem}
  .form-group{grid-column:1/-1}
  .footer-grid{grid-template-columns:1fr;gap:1.5rem}
  .footer-promo{grid-column:auto}
  .footer-meta{flex-direction:column;align-items:flex-start;gap:1rem}
  .footer-bottom{flex-direction:column;gap:.75rem;text-align:center;align-items:center}
}

/* Compact phones: 320 to 479px. Tighten chrome, full-width primary actions, larger touch zones. */
@media(max-width:479px){
  :root{--header-h:80px}
  .container{padding:0 1.125rem}
  .site-header{padding:1.125rem 0}
  .site-header.scrolled{padding:.625rem 0}

  .hero{padding-top:calc(var(--header-h) + 1rem);padding-bottom:2.5rem}
  .hero h1{font-size:clamp(2.25rem,11vw,3.25rem)}
  .hero-subtitle{font-size:1rem}
  .hero-cta .btn,.hero-cta a{width:100%;justify-content:center}

  .work-showcase{padding:0}
  .work-item{padding:2rem 0}
  .work-item-image:not(.work-item-triptych){margin-left:0;margin-right:0;border-radius:0}
  .work-item-image-contain-mobile{background:var(--color-paper)}
  .work-item-image-contain-mobile img{object-fit:contain}
  .work-item-triptych.social-diptych{padding-left:12px;padding-right:12px}
  .work-item-content{padding:1.25rem 1.125rem 0}
  .work-item h2{font-size:clamp(1.75rem,7vw,2.25rem)}
  .work-item-meta{flex-wrap:nowrap;gap:.35rem;overflow-x:auto;max-width:100%;padding-bottom:.1rem;scrollbar-width:none}
  .work-item-meta::-webkit-scrollbar{display:none}
  .work-item-meta span{font-size:.58rem;letter-spacing:.08em;padding:.32rem .52rem;flex:0 0 auto}

  .pricing-section{padding:1.5rem 0 3rem}
  .pricing-section .section-heading{padding-top:2.5rem;padding-bottom:1.75rem}
  .pricing-grid{gap:.875rem;padding:0 1.125rem}
  .aftercare-pricing{width:auto;max-width:none;margin-left:1.125rem;margin-right:1.125rem;padding:1.125rem}
  .pricing-card-head{padding:1.5rem 1.375rem 1.25rem}
  .pricing-card-body{padding:1.25rem 1.375rem 1.5rem}
  .pricing-card .pricing-cta.btn{padding:.875rem 1.25rem}
  .pricing-card.pricing-featured .pricing-card-head h3{padding-right:5.5rem}
  .pricing-badge{top:1.125rem;right:1.125rem;font-size:.625rem;padding:.35rem .65rem}

  .values-section{padding:3rem 0}
  .values-grid{gap:2rem}

  .cta-section{padding:3rem 0}

  .brand-marquee{padding:2.25rem 0}
  .brand-marquee-heading{margin-bottom:1.5rem;padding:0 1.125rem}
  .brand-marquee-heading h2{font-size:clamp(1.5rem,6.5vw,1.875rem)}
  .brand-marquee-item{height:clamp(32px,8vw,40px)}
  .brand-marquee-list{gap:2.25rem;padding-right:2.25rem}

  .footer-signup{flex-direction:column;align-items:flex-start;gap:1.25rem}
  .newsletter-form{max-width:100%}

  .work-hero{padding:calc(var(--header-h) + 1rem) 0 2rem}
  .work-hero .container{gap:1.25rem}
  .work-filters{display:grid;grid-template-columns:1fr 1fr;width:100%;gap:.5rem}
  .work-select{width:100%;min-width:0;padding:.72rem 2rem .72rem .875rem;background-position:right .75rem center;font-size:.8125rem}
  .work-search-btn{grid-column:1/-1;width:100%;min-height:44px;padding:.72rem 1rem;font-size:.875rem}
}

/* Reduced-motion safety net. Honors user OS preference across the entire site.
   Pairs with the JS lazy-play guard so autoplay videos also stay paused. */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
    scroll-behavior:auto !important;
  }
  .brand-marquee-track{animation:none !important;transform:none !important}
  .hero-image,.hero-content{transform:none !important}
}

/* Landscape phones (height under 480px). Relax hero so headline plus CTA fit without clipping. */
@media (max-height: 480px) and (orientation: landscape){
  .hero{min-height:auto;padding-top:calc(var(--header-h) + .75rem);padding-bottom:1.75rem}
  .hero h1{font-size:clamp(1.875rem,5.5vw,2.75rem);margin-bottom:.875rem}
  .hero-subtitle{font-size:.9375rem;margin-bottom:1.125rem;max-width:50ch}
  .hero-image{max-width:120px;margin-bottom:.75rem}
  .mobile-menu{padding:calc(var(--header-h) + .5rem) 1.5rem 1.5rem}
}
