:root{--bg:#F3F2EF;--text:#111;--muted:rgba(0,0,0,.62);--card:rgba(255,255,255,.58);--line:rgba(0,0,0,.10);--shadow:0 18px 48px rgba(0,0,0,.12);--max:1180px}[data-theme=dark]{--bg:#101010;--text:#F3F2EF;--muted:rgba(255,255,255,.68);--card:rgba(255,255,255,.08);--line:rgba(255,255,255,.16);--shadow:0 18px 48px rgba(0,0,0,.45)}*{box-sizing:border-box}html{scroll-behavior:smooth}html,body{min-height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;transition:background .25s ease,color .25s ease}body.lightbox-open{overflow:hidden}.topbar{position:sticky;top:0;z-index:40;background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}.topbar__inner{max-width:var(--max);margin:0 auto;padding:18px;display:flex;align-items:center;justify-content:space-between;gap:16px}.topbar__left{display:flex;align-items:center;gap:14px;min-width:0}.topbar__right{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.topbar__logo{height:34px;width:auto;display:block}[data-theme=dark] .topbar__logo{filter:invert(1)}.topbar__logoLink{display:inline-flex;align-items:center;text-decoration:none;color:inherit}.kicker{font-size:14px;letter-spacing:.02em;color:var(--muted)}.nav-link,.icon-btn,.theme-toggle{height:40px;border-radius:999px;border:1px solid var(--line);background:var(--card);color:var(--text);text-decoration:none;display:inline-flex;align-items:center;justify-content:center;transition:transform .2s ease,background .2s ease,border-color .2s ease}.nav-link{padding:0 14px;font-weight:600;font-size:13px}.icon-btn{width:40px;font-weight:700}.theme-toggle{padding:0 14px;font:600 13px Inter,system-ui;cursor:pointer}.nav-link:hover,.icon-btn:hover,.theme-toggle:hover{transform:translateY(-1px);background:color-mix(in srgb,var(--card) 70%,var(--text) 8%)}.icon{font-weight:700;font-family:Space Grotesk,Inter,sans-serif}.page{padding:54px 18px 70px}.intro{max-width:var(--max);margin:0 auto 30px;display:grid;gap:8px}.eyebrow{margin:0;color:var(--muted);font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:700}.intro h1{margin:0;font-family:Space Grotesk,Inter,sans-serif;font-size:clamp(44px,8vw,96px);line-height:.92;letter-spacing:-.05em}.intro p:last-child{max-width:640px;margin:0;color:var(--muted);line-height:1.6}.project-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.project-card{position:relative;border:0;padding:0;min-height:320px;aspect-ratio:4/5;overflow:hidden;border-radius:24px;background:var(--card);box-shadow:var(--shadow);cursor:pointer;color:white}.project-card img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1.01);transition:transform .45s ease,filter .45s ease}.project-card__overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-start;padding:22px;text-align:left;background:linear-gradient(to top,rgba(0,0,0,.72),rgba(0,0,0,.10) 55%,rgba(0,0,0,0));opacity:0;transition:opacity .25s ease}.project-card__name{font-family:Space Grotesk,Inter,sans-serif;font-size:clamp(23px,3vw,34px);line-height:1;font-weight:700;letter-spacing:-.03em}.project-card__type{margin-top:8px;font-size:12px;text-transform:uppercase;letter-spacing:.14em;font-weight:700;opacity:.86}.project-card:hover img,.project-card:focus-visible img{transform:scale(1.06);filter:saturate(1.06) contrast(1.03)}.project-card:hover .project-card__overlay,.project-card:focus-visible .project-card__overlay{opacity:1}.project-card:focus-visible{outline:3px solid currentColor;outline-offset:4px}.lightbox{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:24px;opacity:0;pointer-events:none;transition:opacity .25s ease}.lightbox.is-open{opacity:1;pointer-events:auto}.lightbox__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(8px)}.lightbox__panel{position:relative;width:min(1200px,96vw);max-height:90vh;display:grid;grid-template-columns:minmax(0,1.2fr) minmax(300px,.8fr);background:var(--bg);color:var(--text);border:1px solid var(--line);border-radius:28px;box-shadow:0 28px 90px rgba(0,0,0,.42);overflow:hidden}.lightbox__close{position:absolute;top:14px;right:14px;z-index:2;width:42px;height:42px;border-radius:999px;border:1px solid var(--line);background:var(--card);color:var(--text);font-size:30px;line-height:1;cursor:pointer}.lightbox__media{position:relative;min-height:620px;background:rgba(0,0,0,.06);display:grid;place-items:center;padding:54px}.lightbox__image{max-width:100%;max-height:76vh;width:auto;height:auto;border-radius:18px;box-shadow:var(--shadow);object-fit:contain}.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:999px;border:1px solid var(--line);background:color-mix(in srgb,var(--bg) 85%,transparent);color:var(--text);font-size:34px;cursor:pointer}.lightbox__nav--prev{left:16px}.lightbox__nav--next{right:16px}.lightbox__content{padding:56px 34px 34px;overflow:auto}.lightbox__type{margin:0 0 8px;color:var(--muted);font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:800}.lightbox__title{margin:0 0 18px;font-family:Space Grotesk,Inter,sans-serif;font-size:clamp(34px,5vw,62px);line-height:.95;letter-spacing:-.05em}.lightbox__description p{margin:0 0 15px;color:var(--muted);line-height:1.65}.lightbox__counter{margin-top:18px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:700}.video-section{padding:90px 0 40px}.video-section__inner{max-width:var(--max);margin:0 auto}.video-section__title{font-size:44px;line-height:1.05;margin:0 0 10px;font-family:Space Grotesk,Inter,sans-serif;letter-spacing:-.03em}.video-section__subtitle{margin:0 0 26px;color:var(--muted);max-width:60ch}.video-wrap{width:50%;margin:0 auto;border-radius:22px;overflow:hidden;box-shadow:var(--shadow);background:var(--card)}.video{width:100%;height:auto;display:block}.footer{border-top:1px solid var(--line)}.footer__inner{max-width:var(--max);margin:0 auto;padding:22px 18px;color:var(--muted);font-size:12px}.reveal{opacity:0;transform:translateY(10px);transition:opacity .65s ease,transform .65s ease}.reveal.in-view{opacity:1;transform:translateY(0)}.no-js .reveal{opacity:1;transform:none}@media(max-width:980px){.project-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.lightbox__panel{grid-template-columns:1fr;overflow:auto}.lightbox__media{min-height:460px;padding:54px 44px 32px}.lightbox__content{padding:32px}.video-wrap{width:75%}}@media(max-width:640px){.topbar__inner{align-items:flex-start;flex-direction:column}.project-grid{grid-template-columns:1fr}.project-card{min-height:260px;aspect-ratio:1.12/1}.project-card__overlay{opacity:1}.lightbox{padding:12px}.lightbox__panel{width:100%;max-height:92vh;border-radius:22px}.lightbox__media{min-height:330px;padding:58px 24px 24px}.lightbox__nav{width:38px;height:38px;font-size:28px}.lightbox__nav--prev{left:8px}.lightbox__nav--next{right:8px}.video-wrap{width:100%}}@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}*,*::before,*::after{transition:none!important;animation:none!important}.reveal{opacity:1;transform:none}}
 /* Case Study Layout Refinement — Mood Harbor */

.cs-detail {
  max-width: 1100px;
  margin: 0 auto;
  padding: 48px 20px 80px;
}

/* HERO */
.cs-detail-hero {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 48px;
  padding: 32px 0 48px;
}

.cs-detail-hero__left {
  flex: 1.1;
}

.cs-detail-hero__right {
  flex: 1;
}

.cs-hero-video,
.cs-detail-hero__right video {
  width: 100%;
  border-radius: 12px;
  display: block;
  box-shadow: var(--shadow);
}

/* TYPOGRAPHY */
.cs-detail h1 {
  font-size: 48px;
  line-height: 1.1;
  margin-bottom: 16px;
}

.cs-lede {
  font-size: 20px;
  line-height: 1.6;
  max-width: 60ch;
  margin-bottom: 24px;
}

.cs-section h2 {
  font-size: 32px;
  margin-bottom: 16px;
  margin-top: 64px;
}

.cs-section p {
  max-width: 70ch;
  line-height: 1.65;
  margin-bottom: 20px;
}

/* FACTS BLOCK */
.cs-facts {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin-top: 24px;
}

.cs-facts span {
  display: block;
  font-size: 13px;
  color: var(--muted);
  margin-bottom: 2px;
}

.cs-facts strong {
  font-size: 16px;
}

/* GALLERY */
.cs-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 32px;
  margin: 48px 0;
}

.cs-gallery figure,
.cs-figure {
  margin: 0;
}

.cs-gallery img,
.cs-gallery video,
.cs-figure img,
.cs-figure video {
  width: 100%;
  border-radius: 12px;
  display: block;
  box-shadow: var(--shadow);
}

/* CAPTIONS */
figcaption {
  font-size: 14px;
  color: var(--muted);
  margin-top: 12px;
  line-height: 1.5;
}

/* SECTION SPACING */
.cs-section {
  margin-top: 64px;
}

/* OUTCOME SECTION */
.cs-outcome {
  border-top: 1px solid var(--line);
  padding-top: 48px;
  margin-top: 80px;
}

.cs-note {
  font-size: 14px;
  color: var(--muted);
  margin-top: 16px;
}

/* RESPONSIVE */
@media (max-width: 900px) {
  .cs-detail-hero {
    flex-direction: column;
  }
}
