/*
Theme Name: Digital Muse
Theme URI: https://digitalmuse.agency/
Author: Digital Muse Agency
Author URI: https://digitalmuse.agency/
Description: Custom WordPress theme for Digital Muse Agency. Performance-budgeted, ACF-driven, SEO-optimized. WordPress, web apps, brand identity, and SEO. v1.1 adds dedicated project case study pages with per-project accent palettes.
Version: 1.1.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: Proprietary
Text Domain: digital-muse
Tags: agency, portfolio, custom-colors, custom-logo, custom-menu, featured-images
*/

    /* ─── Design tokens ────────────────────────────────────────────── */
    :root {
      --bg: #0A0A0F;
      --bg-elev: #11111B;
      --bg-panel: #16161F;
      --border: #1F1F2E;
      --border-strong: #2A2A3D;
      --text: #F5F5F7;
      --text-2: #A5A5B5;
      --text-3: #6B6B7A;
      --purple: #8E2DB6;
      --purple-bright: #B14FD8;
      --cyan: #29B6F6;
      --cyan-bright: #4FC3F7;
      --grad: linear-gradient(135deg, #8E2DB6 0%, #29B6F6 100%);
      --grad-soft: linear-gradient(135deg, rgba(142,45,182,0.12), rgba(41,182,246,0.12));
      --max: 1320px;
      --pad: clamp(20px, 4vw, 48px);
      --radius: 14px;
      --radius-lg: 24px;
      --t-fast: 180ms cubic-bezier(.4,0,.2,1);
      --t: 320ms cubic-bezier(.4,0,.2,1);
      --t-slow: 600ms cubic-bezier(.4,0,.2,1);
    }

    /* ─── Reset ────────────────────────────────────────────────────── */
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
    body {
      background: var(--bg);
      color: var(--text);
      font-family: 'Inter', system-ui, -apple-system, sans-serif;
      font-size: 16px;
      line-height: 1.6;
      font-feature-settings: 'ss01', 'cv11';
      -webkit-font-smoothing: antialiased;
      overflow-x: hidden;
    }
    img { max-width: 100%; display: block; }
    a { color: inherit; text-decoration: none; }
    button { font: inherit; cursor: pointer; background: none; border: 0; color: inherit; }
    ::selection { background: var(--purple); color: var(--text); }

    /* ─── Ambient background ───────────────────────────────────────── */
    .ambient {
      position: fixed; inset: 0; z-index: 0; pointer-events: none; overflow: hidden;
    }
    .ambient::before, .ambient::after {
      content: ''; position: absolute; width: 60vmax; height: 60vmax; border-radius: 50%;
      filter: blur(120px); opacity: 0.22; will-change: transform;
    }
    .ambient::before { background: var(--purple); top: -20vmax; left: -20vmax; animation: drift1 28s ease-in-out infinite alternate; }
    .ambient::after  { background: var(--cyan);   bottom: -20vmax; right: -20vmax; animation: drift2 34s ease-in-out infinite alternate; }
    @keyframes drift1 { to { transform: translate(15vmax, 10vmax); } }
    @keyframes drift2 { to { transform: translate(-15vmax, -8vmax); } }

    .grid-overlay {
      position: fixed; inset: 0; z-index: 1; pointer-events: none;
      background-image:
        linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
      background-size: 64px 64px;
      mask-image: radial-gradient(ellipse at center, black 30%, transparent 75%);
    }

    /* ─── Layout primitives ────────────────────────────────────────── */
    .wrap { max-width: var(--max); margin: 0 auto; padding: 0 var(--pad); position: relative; z-index: 2; }
    section { position: relative; padding: clamp(40px, 4.5vw, 64px) 0; z-index: 2; }
    .eyebrow {
      display: inline-flex; align-items: center; gap: 10px;
      font: 500 12px/1 'JetBrains Mono', monospace;
      letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-2);
    }
    .eyebrow::before {
      content: ''; width: 24px; height: 1px; background: var(--grad);
    }

    /* ─── Status bar ───────────────────────────────────────────────── */
    .status-bar {
      position: sticky; top: 0; z-index: 50;
      background: rgba(10,10,15,0.7);
      backdrop-filter: blur(20px) saturate(140%);
      -webkit-backdrop-filter: blur(20px) saturate(140%);
      border-bottom: 1px solid var(--border);
    }
    .status-bar-inner {
      max-width: var(--max); margin: 0 auto; padding: 12px var(--pad);
      display: flex; align-items: center; justify-content: space-between; gap: 24px;
      font: 500 12px/1 'JetBrains Mono', monospace; letter-spacing: 0.06em;
    }
    .status-left, .status-right { display: flex; align-items: center; gap: 18px; color: var(--text-2); }
    .status-pip {
      display: inline-flex; align-items: center; gap: 8px;
    }
    .status-pip .dot {
      width: 7px; height: 7px; border-radius: 50%; background: #4ADE80;
      box-shadow: 0 0 10px #4ADE80, 0 0 18px rgba(74,222,128,0.5);
      animation: pulse 1.8s ease-in-out infinite;
    }
    @keyframes pulse { 50% { opacity: 0.55; transform: scale(0.85); } }
    .status-divider { width: 1px; height: 12px; background: var(--border-strong); }
    @media (max-width: 720px) {
      .status-bar-inner { font-size: 11px; gap: 12px; }
      .status-right .hide-sm { display: none; }
    }

    /* ─── Nav ──────────────────────────────────────────────────────── */
    .nav {
      position: sticky; top: 42px; z-index: 40;
      background: rgba(10,10,15,0.55);
      backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px);
      border-bottom: 1px solid var(--border);
    }
    .nav-inner {
      max-width: var(--max); margin: 0 auto; padding: 18px var(--pad);
      display: flex; align-items: center; justify-content: space-between; gap: 24px;
    }
    .brand { display: flex; align-items: center; gap: 12px; }
    .brand img { width: 38px; height: 38px; object-fit: contain; }
    .brand-text {
      font: 700 17px/1 'Syne', sans-serif; letter-spacing: -0.01em;
    }
    .brand-text span {
      background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent;
    }
    .nav-links { display: flex; gap: 32px; align-items: center; }
    .nav-links a {
      font: 500 14px/1 'Inter', sans-serif; color: var(--text-2);
      transition: color var(--t-fast); position: relative;
    }
    .nav-links a:hover { color: var(--text); }
    .nav-links a::after {
      content: ''; position: absolute; left: 0; bottom: -6px; width: 0; height: 1px;
      background: var(--grad); transition: width var(--t);
    }
    .nav-links a:hover::after { width: 100%; }
    .nav-cta {
      padding: 10px 18px; border-radius: 100px; background: var(--text); color: var(--bg);
      font: 600 13px/1 'Inter', sans-serif; transition: transform var(--t-fast);
    }
    .nav-cta:hover { transform: translateY(-1px); }
    @media (max-width: 820px) {
      .nav-links { display: none; }
    }

    /* ─── Hero ─────────────────────────────────────────────────────── */
    .hero { padding: clamp(28px, 3vw, 48px) 0 clamp(32px, 4vw, 56px); }
    .hero-grid {
      display: grid; grid-template-columns: 1fr; gap: 56px; align-items: end;
    }
    @media (min-width: 980px) {
      .hero-grid { grid-template-columns: 1.6fr 1fr; gap: 80px; }
    }
    .hero h1 {
      font: 700 clamp(40px, 6.5vw, 88px)/1.0 'Syne', sans-serif;
      letter-spacing: -0.03em;
      margin: 22px 0 26px;
    }
    .hero h1 .line { display: block; }
    .hero h1 .gradient-word {
      background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent;
      position: relative;
    }
    .hero h1 .cycler {
      display: inline-block; min-width: 4ch;
      background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent;
      transition: opacity 220ms ease;
    }
    .hero h1 .cycler.swap { opacity: 0; }
    .hero h1 .cursor {
      display: inline-block; width: 0.08em; height: 0.85em; vertical-align: text-bottom;
      background: var(--cyan); margin-left: 0.05em; animation: blink 1s steps(2) infinite;
    }
    @keyframes blink { 50% { opacity: 0; } }

    .hero-sub {
      font: 400 clamp(17px, 1.7vw, 21px)/1.55 'Inter', sans-serif;
      color: var(--text-2); max-width: 56ch; margin-bottom: 40px;
    }
    .hero-ctas { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }
    .btn {
      display: inline-flex; align-items: center; gap: 10px;
      padding: 16px 26px; border-radius: 100px;
      font: 600 15px/1 'Inter', sans-serif;
      transition: transform var(--t-fast), box-shadow var(--t);
    }
    .btn-primary {
      background: var(--grad); color: white; position: relative;
      box-shadow: 0 8px 30px -8px rgba(142,45,182,0.5), 0 4px 16px -6px rgba(41,182,246,0.4);
    }
    .btn-primary:hover { transform: translateY(-2px); box-shadow: 0 12px 36px -8px rgba(142,45,182,0.7), 0 6px 22px -6px rgba(41,182,246,0.5); }
    .btn-primary .arrow { transition: transform var(--t); }
    .btn-primary:hover .arrow { transform: translateX(4px); }
    .btn-ghost {
      color: var(--text); border: 1px solid var(--border-strong);
    }
    .btn-ghost:hover { border-color: var(--cyan); color: var(--cyan); }

    /* Hero side card: spec sheet */
    .spec-card {
      background: linear-gradient(180deg, var(--bg-elev), var(--bg-panel));
      border: 1px solid var(--border);
      border-radius: var(--radius-lg);
      padding: 28px;
      position: relative;
    }
    .spec-card::before {
      content: ''; position: absolute; inset: 0; border-radius: var(--radius-lg);
      padding: 1px; background: var(--grad);
      -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
      -webkit-mask-composite: xor; mask-composite: exclude;
      opacity: 0.35; pointer-events: none;
    }
    .spec-row {
      display: flex; justify-content: space-between; align-items: baseline;
      padding: 14px 0; border-bottom: 1px dashed var(--border-strong);
      font: 500 13px/1.3 'JetBrains Mono', monospace;
    }
    .spec-row:last-child { border-bottom: 0; padding-bottom: 0; }
    .spec-row:first-child { padding-top: 0; }
    .spec-row .k { color: var(--text-3); letter-spacing: 0.06em; text-transform: uppercase; font-size: 11px; }
    .spec-row .v { color: var(--text); text-align: right; }
    .spec-row .v.accent { background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent; font-weight: 600; }
    .spec-title {
      font: 500 11px/1 'JetBrains Mono', monospace; letter-spacing: 0.2em; text-transform: uppercase;
      color: var(--text-3); margin-bottom: 20px;
    }

    /* ─── Section heading ──────────────────────────────────────────── */
    .section-head { max-width: 800px; margin-bottom: 36px; }
    .section-head h2 {
      font: 600 clamp(36px, 5.5vw, 64px)/1.05 'Syne', sans-serif;
      letter-spacing: -0.025em; margin-top: 18px;
    }
    .section-head h2 .accent {
      background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent;
    }
    .section-head p {
      font: 400 clamp(16px, 1.4vw, 18px)/1.55 'Inter', sans-serif;
      color: var(--text-2); margin-top: 18px; max-width: 60ch;
    }

    /* ─── Services ─────────────────────────────────────────────────── */
    .services-grid {
      display: grid; grid-template-columns: 1fr; gap: 18px;
    }
    @media (min-width: 720px) { .services-grid { grid-template-columns: 1fr 1fr; } }

    .service {
      position: relative; padding: 36px;
      background: var(--bg-elev); border: 1px solid var(--border);
      border-radius: var(--radius-lg); overflow: hidden;
      transition: transform var(--t), border-color var(--t);
    }
    .service::before {
      content: ''; position: absolute; inset: 0; border-radius: var(--radius-lg);
      padding: 1px; background: var(--grad);
      -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
      -webkit-mask-composite: xor; mask-composite: exclude;
      opacity: 0; transition: opacity var(--t); pointer-events: none;
    }
    .service:hover { transform: translateY(-4px); border-color: transparent; }
    .service:hover::before { opacity: 1; }
    .service-inner { position: relative; z-index: 1; }
    .service-no {
      font: 500 12px/1 'JetBrains Mono', monospace; letter-spacing: 0.1em;
      color: var(--text-3); margin-bottom: 24px;
    }
    .service h3 {
      font: 600 28px/1.15 'Syne', sans-serif; letter-spacing: -0.015em; margin-bottom: 12px;
    }
    .service p {
      color: var(--text-2); font-size: 15px; line-height: 1.65; margin-bottom: 22px;
    }
    .service-tags {
      display: flex; flex-wrap: wrap; gap: 8px;
    }
    .tag {
      padding: 6px 12px; border-radius: 100px;
      background: rgba(255,255,255,0.04); border: 1px solid var(--border-strong);
      font: 500 11px/1 'JetBrains Mono', monospace; letter-spacing: 0.04em; color: var(--text-2);
    }
    .service .glyph {
      position: absolute; top: 36px; right: 36px; width: 36px; height: 36px;
      display: flex; align-items: center; justify-content: center;
      border-radius: 10px; background: var(--grad-soft); color: var(--cyan);
    }
    .service .glyph svg { width: 18px; height: 18px; }

    /* ─── Process ──────────────────────────────────────────────────── */
    .process {
      display: grid; grid-template-columns: 1fr; gap: 1px;
      background: var(--border); border: 1px solid var(--border);
      border-radius: var(--radius-lg); overflow: hidden;
    }
    @media (min-width: 720px) { .process { grid-template-columns: repeat(4, 1fr); } }
    .stage { background: var(--bg); padding: 36px 28px; transition: background var(--t); }
    .stage:hover { background: var(--bg-elev); }
    .stage-no {
      font: 600 13px/1 'JetBrains Mono', monospace; letter-spacing: 0.1em;
      background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent;
      margin-bottom: 16px;
    }
    .stage h4 { font: 600 20px/1.2 'Syne', sans-serif; margin-bottom: 10px; letter-spacing: -0.01em; }
    .stage p { color: var(--text-2); font-size: 14px; line-height: 1.6; }

    /* ─── Work ─────────────────────────────────────────────────────── */
    /* Featured project (case-study card) */
    .work-featured {
      display: grid; grid-template-columns: 1fr; gap: 0;
      background: var(--bg-elev); border: 1px solid var(--border);
      border-radius: var(--radius-lg); overflow: hidden; margin-bottom: 18px;
      transition: transform var(--t), border-color var(--t);
    }
    @media (min-width: 920px) { .work-featured { grid-template-columns: 1.35fr 1fr; } }
    .work-featured:hover { transform: translateY(-4px); border-color: var(--border-strong); }
    .work-featured-art {
      position: relative; min-height: 360px; overflow: hidden;
      background: radial-gradient(circle at 25% 20%, rgba(142,45,182,0.35), transparent 60%),
                  radial-gradient(circle at 85% 90%, rgba(41,182,246,0.28), transparent 60%),
                  #0E0B1A;
    }
    .work-featured-content {
      padding: clamp(28px, 3.5vw, 44px);
      display: flex; flex-direction: column; gap: 24px; justify-content: space-between;
    }
    .work-featured h3 {
      font: 600 clamp(26px, 2.6vw, 32px)/1.1 'Syne', sans-serif;
      letter-spacing: -0.02em; margin: 14px 0 10px;
    }
    .work-featured-content > div > p {
      color: var(--text-2); font-size: 15px; line-height: 1.65;
    }
    .work-tags { display: flex; flex-wrap: wrap; gap: 6px; }
    .work-metrics {
      display: grid; grid-template-columns: 1fr 1fr; gap: 1px;
      background: var(--border-strong); border: 1px solid var(--border-strong);
      border-radius: 12px; overflow: hidden;
    }
    .work-metric { background: var(--bg-elev); padding: 14px 16px; }
    .work-metric .v {
      font: 600 20px/1 'Syne', sans-serif; letter-spacing: -0.015em;
      background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent;
      margin-bottom: 5px;
    }
    .work-metric .k {
      font: 500 10px/1.3 'JetBrains Mono', monospace; letter-spacing: 0.06em;
      text-transform: uppercase; color: var(--text-3);
    }
    .work-cta-link {
      display: inline-flex; align-items: center; gap: 10px;
      font: 500 13px/1 'JetBrains Mono', monospace; letter-spacing: 0.08em;
      text-transform: uppercase; color: var(--cyan); transition: gap var(--t);
    }
    .work-featured:hover .work-cta-link,
    .work-card-v2:hover .work-cta-link { gap: 16px; }

    /* Browser mockup (inside featured-art) */
    .browser-mockup {
      position: absolute; left: 32px; top: 32px; right: -36px; bottom: -36px;
      background: #14141F; border-radius: 10px;
      box-shadow: 0 24px 60px rgba(0,0,0,0.55);
      border: 1px solid var(--border-strong); overflow: hidden;
    }
    .browser-bar {
      display: flex; align-items: center; gap: 6px;
      padding: 10px 14px; background: #1A1A26; border-bottom: 1px solid var(--border);
    }
    .browser-bar .dot { width: 10px; height: 10px; border-radius: 50%; }
    .browser-bar .d1 { background: #FF5F57; }
    .browser-bar .d2 { background: #FEBC2E; }
    .browser-bar .d3 { background: #28C840; }
    .browser-bar .url {
      flex: 1; height: 22px; background: #0A0A0F; border-radius: 6px; margin-left: 12px;
      display: flex; align-items: center; padding: 0 12px;
      font: 500 10px/1 'JetBrains Mono', monospace; color: var(--text-3);
    }
    .browser-body { padding: 26px 22px; }
    .browser-nav {
      display: flex; justify-content: space-between; align-items: center;
      padding-bottom: 14px; margin-bottom: 22px; border-bottom: 1px solid var(--border);
    }
    .bn-logo { width: 64px; height: 12px; background: var(--grad); border-radius: 3px; }
    .bn-items { display: flex; gap: 12px; }
    .bn-items span { width: 28px; height: 5px; background: var(--border-strong); border-radius: 2px; display: block; }
    .bn-h1 { height: 18px; width: 78%; background: var(--text); opacity: 0.9; border-radius: 5px; margin-bottom: 8px; }
    .bn-h1.sm { width: 48%; margin-bottom: 16px; }
    .bn-p { height: 5px; background: var(--border-strong); border-radius: 3px; margin-bottom: 6px; }
    .bn-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; margin-top: 20px; }
    .bn-card {
      aspect-ratio: 1; border-radius: 8px;
      background: linear-gradient(135deg, rgba(142,45,182,0.32), rgba(41,182,246,0.32));
      border: 1px solid rgba(255,255,255,0.06);
    }

    /* Secondary work grid */
    .work-grid {
      display: grid; grid-template-columns: 1fr; gap: 18px;
    }
    @media (min-width: 720px) { .work-grid { grid-template-columns: 1fr 1fr; } }
    .work-card-v2 {
      position: relative; overflow: hidden;
      background: var(--bg-elev); border: 1px solid var(--border);
      border-radius: var(--radius-lg);
      display: grid; grid-template-rows: 220px 1fr;
      transition: transform var(--t), border-color var(--t);
    }
    .work-card-v2:hover { transform: translateY(-4px); border-color: var(--border-strong); }
    .work-card-art { position: relative; overflow: hidden; }
    .work-card-meta { padding: 26px; display: flex; flex-direction: column; gap: 12px; }
    .work-card-meta h4 { font: 600 22px/1.15 'Syne', sans-serif; letter-spacing: -0.015em; margin-top: 4px; }
    .work-card-meta > p { color: var(--text-2); font-size: 14px; line-height: 1.6; flex-grow: 1; }
    .work-card-metric {
      display: flex; align-items: baseline; gap: 10px; padding-top: 14px;
      border-top: 1px solid var(--border-strong); margin-top: 4px;
      justify-content: space-between;
    }
    .work-card-metric .m-row { display: flex; align-items: baseline; gap: 10px; }
    .work-card-metric .m-v {
      font: 600 22px/1 'Syne', sans-serif; letter-spacing: -0.015em;
      background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent;
    }
    .work-card-metric .m-k {
      font: 500 11px/1.3 'JetBrains Mono', monospace;
      letter-spacing: 0.04em; text-transform: uppercase; color: var(--text-3);
    }

    /* Mock visuals: Dashboard */
    .mock-dashboard {
      background: radial-gradient(circle at 75% 25%, rgba(41,182,246,0.32), transparent 60%), #0E0B1A;
      padding: 22px; position: relative;
      display: flex; flex-direction: column; justify-content: flex-end; gap: 8px;
    }
    .mock-dashboard svg { position: absolute; top: 22px; left: 22px; right: 22px; height: 90px; overflow: visible; }
    .mock-dashboard .tiles { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 6px; }
    .mock-dashboard .tile {
      background: rgba(255,255,255,0.04); border: 1px solid var(--border-strong);
      border-radius: 7px; padding: 9px;
    }
    .mock-dashboard .tile .v { height: 12px; width: 65%; background: var(--text); opacity: 0.75; border-radius: 3px; margin-bottom: 5px; }
    .mock-dashboard .tile .k { height: 4px; width: 75%; background: var(--border-strong); border-radius: 2px; }

    /* Mock visuals: Brand wordmark */
    .mock-brand {
      background: linear-gradient(135deg, #1A0F2E 0%, #0E0B1A 100%);
      display: flex; align-items: center; justify-content: center; position: relative;
    }
    .mock-brand .wm {
      font: 800 56px/1 'Syne', sans-serif; letter-spacing: -0.045em;
      background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent;
    }
    .mock-brand .palette { position: absolute; bottom: 18px; left: 18px; display: flex; gap: 6px; }
    .mock-brand .swatch { width: 18px; height: 18px; border-radius: 50%; border: 1px solid rgba(255,255,255,0.08); }
    .mock-brand .label {
      position: absolute; top: 18px; left: 18px;
      font: 500 10px/1 'JetBrains Mono', monospace; letter-spacing: 0.15em;
      color: var(--text-3); text-transform: uppercase;
    }

    /* Mock visuals: Identity (geometric) */
    .mock-identity {
      background: linear-gradient(135deg, #0E1A26 0%, #0A0F1A 100%);
      position: relative; overflow: hidden;
    }
    .mock-identity .shape {
      position: absolute; mix-blend-mode: screen; opacity: 0.85;
    }
    .mock-identity .s1 { width: 120px; height: 120px; background: var(--purple); border-radius: 50%; top: 30px; left: 40px; }
    .mock-identity .s2 { width: 100px; height: 100px; background: var(--cyan); border-radius: 50%; top: 60px; left: 110px; }
    .mock-identity .s3 {
      width: 0; height: 0; top: 50px; right: 30px;
      border-left: 40px solid transparent; border-right: 40px solid transparent;
      border-bottom: 70px solid rgba(255,255,255,0.15);
    }
    .mock-identity .label {
      position: absolute; bottom: 18px; left: 18px;
      font: 500 10px/1 'JetBrains Mono', monospace; letter-spacing: 0.15em;
      color: var(--text-3); text-transform: uppercase;
    }

    /* Mock visuals: Code editor */
    .mock-code {
      background: #0A0A14; padding: 20px 22px; position: relative; overflow: hidden;
      display: flex; flex-direction: column; gap: 7px;
    }
    .mock-code::before {
      content: ''; position: absolute; top: 0; right: 0; width: 50%; height: 100%;
      background: radial-gradient(circle at 100% 50%, rgba(142,45,182,0.18), transparent 65%);
      pointer-events: none;
    }
    .mock-code .line { display: flex; gap: 12px; align-items: center; position: relative; z-index: 1; }
    .mock-code .ln { color: var(--text-3); width: 14px; text-align: right; font: 500 10px/1 'JetBrains Mono', monospace; flex-shrink: 0; }
    .mock-code .tokens { display: flex; gap: 5px; align-items: center; flex-wrap: wrap; }
    .mock-code .tok { height: 7px; border-radius: 2px; }
    .mock-code .kw { background: #B14FD8; }
    .mock-code .fn { background: #4FC3F7; }
    .mock-code .str { background: #5CDB95; }
    .mock-code .var { background: var(--text-2); }
    .mock-code .pn { background: var(--text-3); }
    .mock-code .indent { width: 14px; flex-shrink: 0; }

    /* CTA row below grid */
    .work-cta-row { display: flex; justify-content: center; margin-top: 36px; }

    /* ─── Numbers ──────────────────────────────────────────────────── */
    .numbers {
      display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px;
      background: var(--border); border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden;
    }
    @media (min-width: 720px) { .numbers { grid-template-columns: repeat(4, 1fr); } }
    .number { background: var(--bg); padding: 40px 28px; }
    .number .figure {
      font: 700 clamp(40px, 5.5vw, 64px)/1 'Syne', sans-serif; letter-spacing: -0.025em;
      background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent;
      margin-bottom: 10px;
    }
    .number .label {
      font: 500 12px/1.4 'JetBrains Mono', monospace; letter-spacing: 0.1em;
      text-transform: uppercase; color: var(--text-2);
    }

    /* ─── FAQ ──────────────────────────────────────────────────────── */
    .faq { max-width: 880px; margin: 0 auto; }
    details {
      border-top: 1px solid var(--border-strong); padding: 28px 0;
      transition: border-color var(--t);
    }
    details:last-of-type { border-bottom: 1px solid var(--border-strong); }
    details[open] { border-color: var(--purple); }
    summary {
      list-style: none; cursor: pointer; display: flex; justify-content: space-between;
      align-items: center; gap: 24px;
      font: 600 19px/1.3 'Syne', sans-serif; letter-spacing: -0.01em;
    }
    summary::-webkit-details-marker { display: none; }
    summary .icon {
      flex-shrink: 0; width: 32px; height: 32px; border-radius: 50%;
      border: 1px solid var(--border-strong); display: flex; align-items: center; justify-content: center;
      transition: transform var(--t), border-color var(--t), background var(--t);
    }
    details[open] summary .icon { transform: rotate(45deg); background: var(--grad); border-color: transparent; }
    summary .icon svg { width: 14px; height: 14px; }
    details p {
      color: var(--text-2); font-size: 16px; line-height: 1.7; margin-top: 16px; padding-right: 56px;
    }

    /* ─── Contact ──────────────────────────────────────────────────── */
    .contact-card {
      position: relative; padding: clamp(40px, 6vw, 72px);
      background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--radius-lg);
      overflow: hidden;
    }
    .contact-card::before {
      content: ''; position: absolute; inset: 0;
      background: radial-gradient(circle at 0% 100%, rgba(142,45,182,0.18), transparent 50%),
                  radial-gradient(circle at 100% 0%, rgba(41,182,246,0.18), transparent 50%);
      pointer-events: none;
    }
    .contact-inner { position: relative; z-index: 1; }
    .contact-card h2 {
      font: 600 clamp(36px, 5.5vw, 64px)/1.05 'Syne', sans-serif;
      letter-spacing: -0.025em; margin-bottom: 24px; max-width: 18ch;
    }
    .contact-card h2 .accent {
      background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent;
    }
    .contact-meta {
      display: grid; grid-template-columns: 1fr; gap: 32px; margin-top: 48px;
      padding-top: 32px; border-top: 1px solid var(--border-strong);
    }
    @media (min-width: 720px) { .contact-meta { grid-template-columns: repeat(3, 1fr); } }
    .meta-block .meta-k {
      font: 500 11px/1 'JetBrains Mono', monospace; letter-spacing: 0.15em;
      text-transform: uppercase; color: var(--text-3); margin-bottom: 10px;
    }
    .meta-block .meta-v {
      font: 500 17px/1.4 'Inter', sans-serif; color: var(--text);
    }
    .meta-block a:hover { color: var(--cyan); }

    /* ─── Footer ───────────────────────────────────────────────────── */
    footer {
      border-top: 1px solid var(--border); padding: 48px 0 32px; position: relative; z-index: 2;
    }
    .foot-inner {
      max-width: var(--max); margin: 0 auto; padding: 0 var(--pad);
      display: flex; flex-wrap: wrap; justify-content: space-between; gap: 24px; align-items: center;
      font: 500 13px/1.4 'JetBrains Mono', monospace; color: var(--text-3); letter-spacing: 0.04em;
    }
    .foot-inner a { color: var(--text-2); transition: color var(--t-fast); }
    .foot-inner a:hover { color: var(--cyan); }
    .foot-links { display: flex; gap: 24px; flex-wrap: wrap; }

    /* ─── Reveal animation ────────────────────────────────────────── */
    .reveal { opacity: 0; transform: translateY(24px); transition: opacity var(--t-slow), transform var(--t-slow); }
    .reveal.in { opacity: 1; transform: translateY(0); }

    @media (prefers-reduced-motion: reduce) {
      *, *::before, *::after {
        animation-duration: 0.01ms !important;
        transition-duration: 0.01ms !important;
      }
      .reveal { opacity: 1; transform: none; }
    }

    /* ─── Focus styles for accessibility ───────────────────────────── */
    a:focus-visible, button:focus-visible, summary:focus-visible {
      outline: 2px solid var(--cyan); outline-offset: 4px; border-radius: 4px;
    }

    .work-card-art img,
    .work-featured-art img {
      width: 100%; height: 100%; object-fit: cover; display: block;
    }


/* ═══════════════════════════════════════════════════════════════════════
   DIGITAL MUSE — v1.1 PROJECT PAGES
   Append these styles to the END of style.css.
   Uses per-project accent CSS variables set inline in single-project.php.
   ═══════════════════════════════════════════════════════════════════════ */

/* ── 1. PROJECT HERO ──────────────────────────────────────────────── */
.project-page {
	--accent: #8E2DB6;
	--accent-2: #29B6F6;
}

.project-hero {
	padding: clamp(7rem, 12vw, 11rem) 0 clamp(3rem, 6vw, 5rem);
	border-bottom: 1px solid rgba(255,255,255,0.06);
}

.project-hero__inner {
	max-width: 1200px;
}

.project-hero__back {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-family: 'JetBrains Mono', monospace;
	font-size: 0.8125rem;
	color: rgba(255,255,255,0.55);
	text-decoration: none;
	margin-bottom: 2.5rem;
	transition: color 0.2s;
	letter-spacing: 0.03em;
}
.project-hero__back:hover { color: var(--accent); }
.project-hero__back .arrow-back { transition: transform 0.2s; }
.project-hero__back:hover .arrow-back { transform: translateX(-3px); }

.project-hero__meta {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1.5rem;
	margin-bottom: 1.5rem;
	flex-wrap: wrap;
}
.project-hero__tags {
	display: flex;
	gap: 0.5rem;
	flex-wrap: wrap;
}
.tag {
	display: inline-block;
	padding: 0.375rem 0.75rem;
	font-family: 'JetBrains Mono', monospace;
	font-size: 0.6875rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	border: 1px solid rgba(255,255,255,0.12);
	border-radius: 999px;
	color: rgba(255,255,255,0.7);
}
.tag--accent {
	border-color: color-mix(in srgb, var(--accent) 60%, transparent);
	color: var(--accent);
	background: color-mix(in srgb, var(--accent) 8%, transparent);
}
.project-hero__year {
	font-family: 'JetBrains Mono', monospace;
	font-size: 0.8125rem;
	color: rgba(255,255,255,0.4);
	letter-spacing: 0.05em;
}

.project-hero__title {
	font-family: 'Syne', sans-serif;
	font-weight: 700;
	font-size: clamp(2.75rem, 7vw, 5.5rem);
	line-height: 0.95;
	letter-spacing: -0.025em;
	margin: 0 0 1.25rem;
	color: #fff;
}

.project-hero__tagline {
	font-size: clamp(1.125rem, 1.7vw, 1.5rem);
	line-height: 1.4;
	color: rgba(255,255,255,0.7);
	max-width: 36ch;
	margin: 0 0 3.5rem;
}

.project-hero__details {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 2rem;
	padding-top: 2rem;
	border-top: 1px solid rgba(255,255,255,0.08);
	margin: 0;
}
.project-hero__details > div { margin: 0; }
.project-hero__details dt {
	font-family: 'JetBrains Mono', monospace;
	font-size: 0.6875rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(255,255,255,0.4);
	margin-bottom: 0.5rem;
}
.project-hero__details dd {
	font-size: 0.9375rem;
	color: rgba(255,255,255,0.9);
	margin: 0;
}
.project-hero__details dd a {
	color: var(--accent);
	text-decoration: none;
	border-bottom: 1px solid color-mix(in srgb, var(--accent) 40%, transparent);
}
.project-hero__details dd a:hover { border-bottom-color: var(--accent); }

.project-hero__image-wrap {
	margin-top: clamp(3rem, 6vw, 5rem);
	max-width: 1400px;
	margin-left: auto;
	margin-right: auto;
	padding: 0 clamp(1rem, 4vw, 3rem);
}
.project-hero__image {
	width: 100%;
	height: auto;
	display: block;
	border-radius: 16px;
	box-shadow: 0 30px 80px -20px color-mix(in srgb, var(--accent) 25%, transparent),
	            0 0 0 1px rgba(255,255,255,0.04);
}

/* ── 2. PROJECT SECTIONS — SHARED ─────────────────────────────────── */
.project-section {
	padding: clamp(4rem, 8vw, 7rem) 0;
}

.project-section__grid {
	display: grid;
	grid-template-columns: minmax(160px, 1fr) 4fr;
	gap: clamp(2rem, 6vw, 5rem);
	max-width: 1200px;
}

@media (max-width: 768px) {
	.project-section__grid {
		grid-template-columns: 1fr;
		gap: 1.5rem;
	}
}

.project-section__label {
	position: sticky;
	top: 6rem;
	align-self: start;
	height: max-content;
}
@media (max-width: 768px) {
	.project-section__label { position: static; }
}

.eyebrow {
	display: block;
	font-family: 'JetBrains Mono', monospace;
	font-size: 0.75rem;
	letter-spacing: 0.12em;
	color: var(--accent);
	margin-bottom: 0.5rem;
}
.eyebrow-text {
	display: block;
	font-family: 'Syne', sans-serif;
	font-weight: 600;
	font-size: 1.125rem;
	color: #fff;
	letter-spacing: -0.01em;
}

.project-section__body {
	color: rgba(255,255,255,0.78);
	font-size: clamp(1.0625rem, 1.2vw, 1.1875rem);
	line-height: 1.65;
}
.project-section__body--prose p {
	margin: 0 0 1.25rem;
}
.project-section__body--prose p:last-child { margin-bottom: 0; }
.project-section__intro {
	font-size: clamp(1.125rem, 1.4vw, 1.375rem);
	color: rgba(255,255,255,0.92);
	font-weight: 500;
	margin: 0 0 2.5rem;
	max-width: 48ch;
	line-height: 1.45;
}

/* ── 3. APPROACH STEPS ────────────────────────────────────────────── */
.approach-steps {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0;
}
.approach-step {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 1.5rem;
	padding: 2rem 0;
	border-top: 1px solid rgba(255,255,255,0.08);
	align-items: start;
}
.approach-step:first-child { border-top: none; padding-top: 0; }
.approach-step__num {
	font-family: 'JetBrains Mono', monospace;
	font-size: 0.875rem;
	color: var(--accent);
	letter-spacing: 0.05em;
	padding-top: 0.25rem;
	min-width: 2.5rem;
}
.approach-step__title {
	font-family: 'Syne', sans-serif;
	font-weight: 600;
	font-size: 1.25rem;
	margin: 0 0 0.5rem;
	color: #fff;
	letter-spacing: -0.005em;
}
.approach-step__desc {
	margin: 0;
	color: rgba(255,255,255,0.65);
	font-size: 1rem;
	line-height: 1.6;
}

/* ── 4. SHOWCASE ──────────────────────────────────────────────────── */
.project-section--showcase {
	padding: clamp(2rem, 4vw, 4rem) 0 clamp(4rem, 8vw, 7rem);
}
.showcase-frame {
	max-width: 1400px;
	margin: 0 auto;
	border-radius: 20px;
	overflow: hidden;
	box-shadow: 0 40px 100px -30px color-mix(in srgb, var(--accent) 20%, transparent),
	            0 0 0 1px rgba(255,255,255,0.06);
}
.showcase-frame img {
	width: 100%;
	height: auto;
	display: block;
}

/* ── 5. RESULTS GRID ──────────────────────────────────────────────── */
.results-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
	gap: 1.5rem;
}
.result-card {
	padding: 2rem 1.5rem;
	background: rgba(255,255,255,0.02);
	border: 1px solid rgba(255,255,255,0.08);
	border-radius: 14px;
	transition: all 0.3s;
	position: relative;
	overflow: hidden;
}
.result-card::before {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 8%, transparent), transparent 60%);
	opacity: 0;
	transition: opacity 0.3s;
}
.result-card:hover {
	transform: translateY(-3px);
	border-color: color-mix(in srgb, var(--accent) 40%, transparent);
}
.result-card:hover::before { opacity: 1; }
.result-card__value {
	display: block;
	font-family: 'Syne', sans-serif;
	font-weight: 700;
	font-size: clamp(2rem, 3.5vw, 2.75rem);
	line-height: 1;
	color: var(--accent);
	letter-spacing: -0.02em;
	margin-bottom: 0.5rem;
	position: relative;
}
.result-card__label {
	display: block;
	font-size: 0.875rem;
	color: rgba(255,255,255,0.6);
	line-height: 1.4;
	position: relative;
}

/* ── 6. STACK LIST ────────────────────────────────────────────────── */
.stack-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}
.stack-item {
	padding: 0.625rem 1.125rem;
	font-family: 'JetBrains Mono', monospace;
	font-size: 0.8125rem;
	border: 1px solid rgba(255,255,255,0.12);
	border-radius: 999px;
	color: rgba(255,255,255,0.85);
	background: rgba(255,255,255,0.02);
	transition: all 0.2s;
}
.stack-item:hover {
	border-color: color-mix(in srgb, var(--accent) 50%, transparent);
	color: var(--accent);
}

/* ── 7. TESTIMONIAL ───────────────────────────────────────────────── */
.project-section--testimonial {
	background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--accent) 4%, transparent), transparent);
}
.testimonial {
	max-width: 900px;
	margin: 0 auto;
	padding: 0;
	text-align: center;
}
.testimonial__quote {
	font-family: 'Syne', sans-serif;
	font-weight: 500;
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	line-height: 1.3;
	color: #fff;
	letter-spacing: -0.015em;
	margin: 0 0 2rem;
}
.testimonial__attribution {
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
	font-style: normal;
}
.testimonial__attribution cite {
	font-style: normal;
	font-weight: 600;
	color: rgba(255,255,255,0.9);
	font-size: 0.9375rem;
}
.testimonial__attribution span {
	font-family: 'JetBrains Mono', monospace;
	font-size: 0.75rem;
	color: var(--accent);
	letter-spacing: 0.05em;
}

/* ── 8. NEXT PROJECT ──────────────────────────────────────────────── */
.project-section--next {
	background: color-mix(in srgb, var(--next-accent) 4%, transparent);
	border-top: 1px solid rgba(255,255,255,0.06);
	border-bottom: 1px solid rgba(255,255,255,0.06);
	padding: clamp(3rem, 6vw, 5rem) 0;
}
.next-project {
	display: block;
	text-decoration: none;
	color: inherit;
	max-width: 800px;
	margin: 0 auto;
	text-align: center;
	transition: transform 0.3s;
}
.next-project:hover { transform: translateY(-4px); }
.next-project__eyebrow {
	display: block;
	font-family: 'JetBrains Mono', monospace;
	font-size: 0.8125rem;
	color: var(--next-accent);
	letter-spacing: 0.08em;
	margin-bottom: 1rem;
}
.next-project__title {
	font-family: 'Syne', sans-serif;
	font-weight: 700;
	font-size: clamp(2.25rem, 5vw, 3.75rem);
	line-height: 1;
	letter-spacing: -0.025em;
	margin: 0 0 1rem;
	color: #fff;
}
.next-project__tagline {
	color: rgba(255,255,255,0.65);
	font-size: 1.0625rem;
	margin: 0;
}

/* ── 9. CTA SECTION ───────────────────────────────────────────────── */
.project-section--cta {
	text-align: center;
	padding: clamp(4rem, 8vw, 7rem) 0;
}
.project-cta__title {
	font-family: 'Syne', sans-serif;
	font-weight: 700;
	font-size: clamp(2rem, 4vw, 3.25rem);
	margin: 0 0 1rem;
	color: #fff;
	letter-spacing: -0.02em;
}
.project-cta__lede {
	color: rgba(255,255,255,0.65);
	font-size: 1.125rem;
	margin: 0 0 2.5rem;
}

/* ═══════════════════════════════════════════════════════════════════════
   WORK ARCHIVE PAGE (/work/)
   ═══════════════════════════════════════════════════════════════════════ */

.work-archive__hero {
	padding: clamp(7rem, 12vw, 11rem) 0 clamp(3rem, 6vw, 5rem);
}
.work-archive__title {
	font-family: 'Syne', sans-serif;
	font-weight: 700;
	font-size: clamp(2.5rem, 6vw, 4.5rem);
	line-height: 0.98;
	letter-spacing: -0.025em;
	margin: 1rem 0 1.5rem;
	max-width: 14ch;
	color: #fff;
}
.work-archive__title .accent { color: #8E2DB6; }
.work-archive__lede {
	color: rgba(255,255,255,0.65);
	font-size: clamp(1.0625rem, 1.4vw, 1.25rem);
	line-height: 1.5;
	max-width: 52ch;
	margin: 0;
}

.work-archive__filter {
	padding: 1rem 0 2rem;
	border-bottom: 1px solid rgba(255,255,255,0.06);
}
.filter-pills {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}
.filter-pill {
	display: inline-block;
	padding: 0.625rem 1.25rem;
	font-family: 'JetBrains Mono', monospace;
	font-size: 0.8125rem;
	letter-spacing: 0.03em;
	border: 1px solid rgba(255,255,255,0.12);
	border-radius: 999px;
	color: rgba(255,255,255,0.75);
	text-decoration: none;
	transition: all 0.2s;
}
.filter-pill:hover {
	border-color: rgba(255,255,255,0.3);
	color: #fff;
}
.filter-pill.is-active {
	background: #8E2DB6;
	border-color: #8E2DB6;
	color: #fff;
}

.work-archive__grid-wrap {
	padding: clamp(2rem, 5vw, 4rem) 0 clamp(5rem, 10vw, 8rem);
}

.work-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
	gap: clamp(1.5rem, 3vw, 2.5rem);
}

.work-card {
	--card-accent: #8E2DB6;
	display: block;
	text-decoration: none;
	color: inherit;
	background: rgba(255,255,255,0.02);
	border: 1px solid rgba(255,255,255,0.06);
	border-radius: 16px;
	overflow: hidden;
	transition: all 0.35s cubic-bezier(0.2, 0.8, 0.2, 1);
	position: relative;
}
.work-card:hover {
	transform: translateY(-6px);
	border-color: color-mix(in srgb, var(--card-accent) 50%, transparent);
	box-shadow: 0 30px 60px -20px color-mix(in srgb, var(--card-accent) 25%, transparent);
}
.work-card__image-wrap {
	aspect-ratio: 16 / 11;
	overflow: hidden;
	background: rgba(0,0,0,0.3);
}
.work-card__image-wrap img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s;
}
.work-card:hover .work-card__image-wrap img {
	transform: scale(1.04);
}
.work-card__body {
	padding: 1.75rem 1.75rem 2rem;
}
.work-card__meta {
	margin-bottom: 0.75rem;
	display: flex;
	gap: 0.75rem;
	align-items: center;
}
.work-card__svc {
	font-family: 'JetBrains Mono', monospace;
	font-size: 0.6875rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--card-accent);
}
.work-card__title {
	font-family: 'Syne', sans-serif;
	font-weight: 600;
	font-size: 1.5rem;
	line-height: 1.15;
	letter-spacing: -0.015em;
	margin: 0 0 0.5rem;
	color: #fff;
}
.work-card__tagline {
	color: rgba(255,255,255,0.6);
	font-size: 0.9375rem;
	line-height: 1.5;
	margin: 0 0 1.25rem;
}
.work-card__cta {
	font-family: 'JetBrains Mono', monospace;
	font-size: 0.8125rem;
	color: var(--card-accent);
	letter-spacing: 0.03em;
}
.work-card__badge {
	display: inline-block;
	padding: 0.25rem 0.625rem;
	font-family: 'JetBrains Mono', monospace;
	font-size: 0.625rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	background: color-mix(in srgb, var(--card-accent) 15%, transparent);
	color: var(--card-accent);
	border-radius: 4px;
}

/* ═══════════════════════════════════════════════════════════════════════
   HOMEPAGE — FEATURED + SECONDARY GRID
   ═══════════════════════════════════════════════════════════════════════ */

.work-featured {
	--card-accent: #8E2DB6;
	display: grid;
	grid-template-columns: 1.2fr 1fr;
	gap: clamp(2rem, 4vw, 4rem);
	align-items: center;
	background: rgba(255,255,255,0.02);
	border: 1px solid rgba(255,255,255,0.06);
	border-radius: 24px;
	padding: clamp(1.5rem, 3vw, 2.5rem);
	margin-bottom: clamp(2rem, 4vw, 3rem);
	text-decoration: none;
	color: inherit;
	transition: all 0.4s cubic-bezier(0.2, 0.8, 0.2, 1);
}
@media (max-width: 900px) {
	.work-featured { grid-template-columns: 1fr; }
}
.work-featured:hover {
	transform: translateY(-4px);
	border-color: color-mix(in srgb, var(--card-accent) 40%, transparent);
	box-shadow: 0 40px 80px -25px color-mix(in srgb, var(--card-accent) 25%, transparent);
}
.work-featured__image {
	border-radius: 14px;
	overflow: hidden;
	aspect-ratio: 4 / 3;
	background: rgba(0,0,0,0.4);
}
.work-featured__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s;
}
.work-featured:hover .work-featured__image img { transform: scale(1.03); }

.work-featured__meta {
	display: flex;
	gap: 0.75rem;
	align-items: center;
	margin-bottom: 1.5rem;
}
.work-featured__year {
	font-family: 'JetBrains Mono', monospace;
	font-size: 0.75rem;
	color: rgba(255,255,255,0.4);
}
.work-featured__title {
	font-family: 'Syne', sans-serif;
	font-weight: 700;
	font-size: clamp(1.875rem, 3.5vw, 2.75rem);
	line-height: 1.05;
	letter-spacing: -0.02em;
	margin: 0 0 1rem;
	color: #fff;
}
.work-featured__tagline {
	color: rgba(255,255,255,0.7);
	font-size: 1.0625rem;
	line-height: 1.5;
	margin: 0 0 1.5rem;
	max-width: 36ch;
}
.work-featured__tags {
	display: flex;
	gap: 0.5rem;
	flex-wrap: wrap;
	margin-bottom: 1.5rem;
}
.work-featured__cta {
	font-family: 'JetBrains Mono', monospace;
	font-size: 0.875rem;
	color: var(--card-accent);
	letter-spacing: 0.03em;
}

.work-grid--secondary {
	grid-template-columns: repeat(2, 1fr);
}
@media (max-width: 720px) {
	.work-grid--secondary { grid-template-columns: 1fr; }
}
.work-card--small .work-card__image-wrap { aspect-ratio: 16 / 10; }
.work-card--small .work-card__body { padding: 1.25rem 1.5rem 1.5rem; }
.work-card--small .work-card__title { font-size: 1.25rem; }

.section__footer {
	margin-top: clamp(2.5rem, 4vw, 3.5rem);
	text-align: center;
}

/* Section background helpers (keep brand-color section_brief darker than approach) */
.project-section--brief    { background: rgba(255,255,255,0.012); }
.project-section--approach { background: transparent; }
.project-section--results  { background: rgba(255,255,255,0.012); }
.project-section--stack    { background: transparent; }
