/* =========================================================================
   Primetime Painting — Design A (North Light, slot-scoped [data-design="a"])
   Atelier register: linen primer, studio pigments, light-rake + pigment-bloom.
   ========================================================================= */

@import url('https://fonts.googleapis.com/css2?family=Newsreader:ital,opsz,wght@0,6..72,400;0,6..72,500;0,6..72,600;1,6..72,400;1,6..72,500&family=Outfit:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap');

/* ---- Token system (scoped to the slice) ---- */
[data-design="a"] {
  --nl-linen         : #F4F2EC;
  --nl-linen-warm    : #E5E1D6;
  --nl-linen-dark    : #1C1813;
  --nl-ink           : #1C1813;
  --nl-ink-soft      : #3F362C;
  --nl-muted         : #807767;
  --nl-rule          : #C9C2B0;
  --nl-rule-strong   : #6E6655;

  --nl-chip-01       : #E8E4D4;  /* Lead White */
  --nl-chip-02       : #6B5645;  /* Raw Umber */
  --nl-chip-03       : #B9914A;  /* Yellow Ochre */
  --nl-chip-04       : #1B3A52;  /* Prussian Blue — house anchor */

  --nl-chip-01-wet   : #DDD9C8;
  --nl-chip-02-wet   : #7C6650;
  --nl-chip-03-wet   : #C99C52;
  --nl-chip-04-wet   : #224862;

  --nl-light-warm    : #F1D7A0;
  --nl-light-cool    : #C7CFD6;

  --nl-pigment-bloom : rgba(105,80,55,0.18);
  --nl-critical      : #B23A1F;
  --nl-success       : #6F7A3A;

  --nl-surface       : var(--nl-linen);
  --nl-surface-sunk  : var(--nl-linen-warm);
  --nl-text          : var(--nl-ink);
  --nl-text-soft     : var(--nl-ink-soft);
  --nl-text-mute     : var(--nl-muted);
  --nl-brand         : var(--nl-chip-04);
  --nl-brand-wet     : var(--nl-chip-04-wet);
  --nl-accent        : var(--nl-chip-03);
  --nl-accent-warm   : var(--nl-chip-01);
  --nl-accent-deep   : var(--nl-chip-02);

  /* Required: expose the design's primary on the slice block */
  --design-a-primary : var(--nl-chip-04);

  --nl-font-display : 'Newsreader', 'Source Serif 4', 'Georgia', serif;
  --nl-font-body    : 'Outfit', -apple-system, 'Helvetica Neue', sans-serif;
  --nl-font-mono    : 'JetBrains Mono', 'SFMono-Regular', 'Menlo', monospace;

  --nl-type-spread   : clamp(40px, 7vw, 84px);
  --nl-type-display  : clamp(32px, 5vw, 60px);
  --nl-type-headline : clamp(24px, 3vw, 32px);
  --nl-type-body-lg  : clamp(18px, 1.6vw, 21px);
  --nl-type-body     : clamp(16px, 1.4vw, 18px);
  --nl-type-caption  : 14px;
  --nl-type-stamp    : 12px;

  --nl-hairline : 1px;
  --nl-thread   : 4px;
  --nl-grain    : 8px;
  --nl-stroke   : 16px;
  --nl-coat     : 24px;
  --nl-canvas   : 40px;
  --nl-wall     : 64px;
  --nl-room     : 96px;
  --nl-atelier  : 160px;

  --nl-dur-touch    : 220ms;
  --nl-dur-settle   : 380ms;
  --nl-dur-bloom    : 900ms;
  --nl-dur-load     : 1400ms;
  --nl-dur-cure     : 1800ms;
  --nl-dur-light    : 24000ms;
  --nl-dur-light-b  : 17000ms;
  --nl-dur-breath   : 6400ms;
  --nl-dur-pointer  : 8000ms;
  --nl-dur-wash     : 5200ms;

  --nl-ease-light   : cubic-bezier(.45, .15, .35, 1);
  --nl-ease-bloom   : cubic-bezier(.22, .61, .36, 1);
  --nl-ease-settle  : cubic-bezier(.16, 1, .3, 1);

  --nl-radius-chip   : 0;
  --nl-radius-tag    : 2px;
  --nl-radius-btn    : 4px;

  --nl-elev-bloom    : 0 0 0 1px var(--nl-pigment-bloom), 0 0 32px -8px var(--nl-pigment-bloom);
}

/* ---- Base ---- */
[data-design="a"].dq-design,
[data-design="a"] .dq-design { background: var(--nl-linen); color: var(--nl-text); font-family: var(--nl-font-body); }
[data-design="a"] *, [data-design="a"] *::before, [data-design="a"] *::after { box-sizing: border-box; }
[data-design="a"] h1, [data-design="a"] h2, [data-design="a"] h3, [data-design="a"] p, [data-design="a"] ol, [data-design="a"] ul, [data-design="a"] dl, [data-design="a"] dd, [data-design="a"] figure, [data-design="a"] blockquote { margin: 0; }
[data-design="a"] .nl-tag { font-family: var(--nl-font-mono); font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--nl-text-mute); }

/* ===== E1 — Header ===== */
[data-design="a"] .nl-header { position: sticky; top: 0; z-index: 50; background: var(--nl-linen); }
[data-design="a"] .nl-header__bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--nl-stroke) clamp(var(--nl-stroke), 4vw, var(--nl-canvas));
  min-height: 68px;
}
[data-design="a"] .nl-header__logo { text-decoration: none; color: var(--nl-ink); }
[data-design="a"] .nl-header__mark {
  font-family: var(--nl-font-display); font-style: italic; font-weight: 500; font-size: 26px;
  letter-spacing: -0.005em; line-height: 1; font-feature-settings: "ss01";
}
[data-design="a"] .nl-header__menu {
  appearance: none; background: transparent; border: 1px solid var(--nl-rule);
  border-radius: var(--nl-radius-btn); width: 44px; height: 44px;
  display: grid; place-content: center; gap: 5px; cursor: pointer; padding: 0 10px;
}
[data-design="a"] .nl-header__menu-bar { display: block; width: 22px; height: 1px; background: var(--nl-ink); }
[data-design="a"] .nl-header__menu:hover { border-color: var(--nl-ink); }

[data-design="a"] .nl-header__rule { position: relative; height: 1px; background: var(--nl-rule); overflow: visible; }
[data-design="a"] .nl-header__rake {
  position: absolute; left: -10%; right: -10%; top: -8px; height: 16px;
  background: linear-gradient(90deg, transparent 0%, var(--nl-light-warm) 30%, var(--nl-light-cool) 70%, transparent 100%);
  opacity: 0.32; filter: blur(8px);
  animation: nl-header-rake 17s var(--nl-ease-light) infinite;
}
@keyframes nl-header-rake {
  0%, 100% { transform: translateX(-12%); opacity: 0.20; }
  50%      { transform: translateX(12%);  opacity: 0.40; }
}

/* Curtain (focus-trapped drawer) */
[data-design="a"] .nl-curtain { position: fixed; inset: 0; z-index: 60; background: rgba(28,24,19,0.36); }
[data-design="a"] .nl-curtain[hidden] { display: none; }
[data-design="a"] .nl-curtain__panel {
  position: absolute; left: 0; right: 0; top: 0;
  background: var(--nl-linen); border-bottom: 1px solid var(--nl-brand);
  padding: var(--nl-coat) clamp(var(--nl-stroke), 4vw, var(--nl-canvas)) var(--nl-canvas);
  display: flex; flex-direction: column; gap: var(--nl-canvas);
  transform: translateY(-100%); transition: transform 760ms var(--nl-ease-light);
}
[data-design="a"] .nl-curtain.is-open .nl-curtain__panel { transform: translateY(0); }
[data-design="a"] .nl-curtain__close {
  appearance: none; background: transparent; border: 0;
  font-family: var(--nl-font-mono); font-size: 28px; color: var(--nl-ink); cursor: pointer;
  align-self: flex-end; width: 44px; height: 44px;
}
[data-design="a"] .nl-curtain__nav { display: flex; flex-direction: column; gap: var(--nl-grain); }
[data-design="a"] .nl-curtain__nav a {
  font-family: var(--nl-font-display); font-style: italic; font-size: 30px; font-weight: 500;
  color: var(--nl-ink); text-decoration: none; padding: 12px 0;
  border-bottom: 1px solid var(--nl-rule); letter-spacing: -0.005em; font-feature-settings: "ss01";
}
[data-design="a"] .nl-curtain__nav a:hover { color: var(--nl-brand); }
[data-design="a"] .nl-curtain__nav a:last-child { color: var(--nl-brand); }
[data-design="a"] .nl-curtain__foot { margin-top: auto; display: grid; gap: var(--nl-grain); }
[data-design="a"] .nl-curtain__phone {
  font-family: var(--nl-font-display); font-style: italic; font-size: 24px; font-weight: 500;
  color: var(--nl-ink); text-decoration: none; font-feature-settings: "ss01";
}

/* ===== E2 — Loaded Stroke CTA ===== */
[data-design="a"] .nl-cta {
  position: relative; display: inline-flex; align-items: center; gap: 16px;
  padding: 18px 30px; min-height: 56px;
  background: var(--nl-brand);
  background-image: linear-gradient(95deg, var(--nl-brand-wet) 0%, var(--nl-brand) 35%, var(--nl-brand) 70%, var(--nl-brand-wet) 100%);
  background-size: 200% 100%;
  color: var(--nl-linen);
  font-family: var(--nl-font-body); font-weight: 500; font-size: 16px;
  text-decoration: none; border-radius: var(--nl-radius-btn);
  cursor: pointer; border: 0; letter-spacing: 0.01em;
  animation: nl-cta-breath var(--nl-dur-breath) ease-in-out infinite;
  transition: box-shadow var(--nl-dur-settle) var(--nl-ease-bloom), transform var(--nl-dur-touch) var(--nl-ease-settle);
  box-shadow: 0 0 0 0 transparent;
}
[data-design="a"] .nl-cta__arrow { font-family: var(--nl-font-mono); font-size: 18px; line-height: 1; transition: transform var(--nl-dur-settle) var(--nl-ease-settle); }
[data-design="a"] .nl-cta:hover { box-shadow: var(--nl-elev-bloom); }
[data-design="a"] .nl-cta:hover .nl-cta__arrow { transform: translateX(4px); }
[data-design="a"] .nl-cta:focus-visible { outline: 2px solid var(--nl-brand); outline-offset: 4px; box-shadow: var(--nl-elev-bloom); }
[data-design="a"] .nl-cta:active { transform: scale(0.985); box-shadow: 0 0 0 1px var(--nl-pigment-bloom), 0 0 48px -4px var(--nl-pigment-bloom); }
[data-design="a"] .nl-cta--submit { width: 100%; justify-content: center; }
@keyframes nl-cta-breath {
  0%, 100% { background-position: 0% 50%; }
  50%      { background-position: 100% 50%; }
}

/* ===== E3 — Hero (color-wash-fill backdrop, ONE animated layer) ===== */
[data-design="a"] .nl-hero {
  position: relative; overflow: hidden; background: var(--nl-linen);
  padding: clamp(var(--nl-wall), 9vw, var(--nl-atelier)) clamp(var(--nl-stroke), 5vw, var(--nl-canvas));
  border-bottom: 1px solid var(--nl-rule);
}
[data-design="a"] .nl-hero__backdrop { position: absolute; inset: 0; z-index: 0; pointer-events: none; }
/* the ONE moving layer: a low-chroma color-wash that fills the surface on arrival, then breathes */
[data-design="a"] .nl-hero__wash {
  position: absolute; inset: -10%;
  background:
    radial-gradient(120% 90% at 18% 8%, var(--nl-chip-03-wet) 0%, transparent 46%),
    linear-gradient(160deg, var(--nl-chip-04) 0%, var(--nl-chip-02) 42%, var(--nl-linen-warm) 100%);
  opacity: 0; transform: translateY(8%) scale(1.04);
  transform-origin: 20% 0%;
  animation: nl-hero-fill var(--nl-dur-cure) var(--nl-ease-light) forwards;
}
/* static (non-animated) raking sheen sits beneath the wash — not a second MOVING layer */
[data-design="a"] .nl-hero__rake {
  position: absolute; inset: -20%;
  background: linear-gradient(118deg, transparent 34%, var(--nl-light-warm) 47%, var(--nl-light-cool) 56%, transparent 70%);
  opacity: 0.22; mix-blend-mode: soft-light;
}
@keyframes nl-hero-fill {
  0%   { opacity: 0;    transform: translateY(8%) scale(1.04); }
  100% { opacity: 0.30; transform: translateY(0)  scale(1); }
}
[data-design="a"] .nl-hero__inner { position: relative; z-index: 1; max-width: 1180px; margin: 0 auto; display: grid; gap: var(--nl-stroke); }
[data-design="a"] .nl-hero__plate { width: max-content; }
/* hero text MUST be visible at first paint — opacity:1, never reveal-gated */
[data-design="a"] .nl-hero__title {
  font-family: var(--nl-font-display); font-style: italic; font-weight: 500;
  font-size: var(--nl-type-spread); line-height: 1.04; letter-spacing: -0.018em;
  color: var(--nl-text); max-width: 18ch; opacity: 1; font-feature-settings: "ss01";
}
[data-design="a"] .nl-hero__sub { font-size: var(--nl-type-body-lg); line-height: 1.5; color: var(--nl-text-soft); max-width: 52ch; opacity: 1; }
[data-design="a"] .nl-hero__proof { font-family: var(--nl-font-mono); font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--nl-text-mute); opacity: 1; }
[data-design="a"] .nl-hero__actions { display: flex; flex-wrap: wrap; gap: var(--nl-stroke); align-items: center; margin-top: var(--nl-grain); }
[data-design="a"] .nl-hero__chip { padding: 8px 12px; border: 1px solid var(--nl-rule); border-radius: var(--nl-radius-tag); background: var(--nl-linen-warm); }

/* ===== E6 — Pointer (Sash of Light) ===== */
[data-design="a"] .nl-pointer {
  display: grid; gap: 12px; place-items: center; width: 100%; padding: var(--nl-canvas) 0;
  color: var(--nl-text-soft); text-decoration: none; background: var(--nl-linen);
}
[data-design="a"] .nl-pointer__field { position: relative; width: 56px; height: 220px; }
[data-design="a"] .nl-pointer__sash {
  position: absolute; left: 50%; top: -40px; width: 14px; height: 80px; transform: translateX(-50%);
  background: linear-gradient(180deg, transparent 0%, var(--nl-light-warm) 30%, var(--nl-light-cool) 70%, transparent 100%);
  filter: blur(8px); opacity: 0.85;
  animation: nl-pointer-sash var(--nl-dur-pointer) var(--nl-ease-light) infinite;
}
[data-design="a"] .nl-pointer__bloom {
  position: absolute; left: 50%; bottom: 0; width: 56px; height: 56px; border-radius: 999px;
  transform: translate(-50%, 50%) scale(0.4);
  background: radial-gradient(closest-side, var(--nl-chip-02) 0%, transparent 70%);
  opacity: 0; mix-blend-mode: multiply;
  animation: nl-pointer-bloom var(--nl-dur-pointer) var(--nl-ease-bloom) infinite;
}
[data-design="a"] .nl-pointer__label { font-family: var(--nl-font-display); font-style: italic; font-weight: 500; font-size: 16px; color: var(--nl-text-soft); font-feature-settings: "ss01"; letter-spacing: -0.005em; }
@keyframes nl-pointer-sash {
  0%   { transform: translateX(-50%) translateY(0);    opacity: 0;   }
  10%  {                                                opacity: 0.85; }
  85%  { transform: translateX(-50%) translateY(240px); opacity: 0.85; }
  100% { transform: translateX(-50%) translateY(240px); opacity: 0;   }
}
@keyframes nl-pointer-bloom {
  0%, 70% { opacity: 0; transform: translate(-50%, 50%) scale(0.4); }
  85%     { opacity: 0.6; transform: translate(-50%, 50%) scale(1); }
  100%    { opacity: 0; transform: translate(-50%, 50%) scale(2); }
}

/* ===== E5 — Funnel (room-walk grammar repurposed) ===== */
[data-design="a"] .nl-room { padding: var(--nl-room) clamp(var(--nl-stroke), 5vw, var(--nl-canvas)); background: var(--nl-linen); border-top: 1px solid var(--nl-rule); }
[data-design="a"] .nl-room__head { max-width: 1180px; margin: 0 auto var(--nl-canvas); display: grid; gap: var(--nl-stroke); }
[data-design="a"] .nl-light__title { font-family: var(--nl-font-display); font-style: italic; font-weight: 500; font-size: var(--nl-type-display); line-height: 1.04; letter-spacing: -0.015em; color: var(--nl-text); max-width: 22ch; font-feature-settings: "ss01"; }
[data-design="a"] .nl-room__lede { color: var(--nl-text-soft); max-width: 60ch; line-height: 1.6; font-size: var(--nl-type-body); }
[data-design="a"] .nl-room__stage { max-width: 760px; margin: 0 auto; }
[data-design="a"] .nl-room__panels { position: relative; min-height: 440px; background: var(--nl-linen-warm); border: 1px solid var(--nl-rule); padding: var(--nl-coat); }
[data-design="a"] .nl-room__step { border: 0; padding: 0; margin: 0; position: absolute; inset: var(--nl-coat); opacity: 0; pointer-events: none; transition: opacity var(--nl-dur-load) var(--nl-ease-light); }
[data-design="a"] .nl-room__step.is-current { opacity: 1; pointer-events: auto; }
[data-design="a"] .nl-room__step legend { font-family: var(--nl-font-display); font-style: italic; font-weight: 500; font-size: clamp(22px, 3.4vw, 28px); color: var(--nl-text); padding: 0; margin-bottom: var(--nl-stroke); letter-spacing: -0.005em; font-feature-settings: "ss01"; }
[data-design="a"] .nl-room__options { display: grid; gap: var(--nl-grain); }
[data-design="a"] .nl-room__opt {
  appearance: none; text-align: left; cursor: pointer;
  background: var(--nl-linen); border: 1px solid var(--nl-rule); border-radius: var(--nl-radius-btn);
  padding: 12px var(--nl-stroke); min-height: 64px;
  display: grid; grid-template-columns: 44px 1fr; gap: var(--nl-stroke); align-items: center;
  font-family: var(--nl-font-body); color: var(--nl-text);
  transition: border-color var(--nl-dur-settle) var(--nl-ease-settle), background-color var(--nl-dur-settle) var(--nl-ease-settle), box-shadow var(--nl-dur-settle) var(--nl-ease-bloom);
}
[data-design="a"] .nl-room__opt:hover { border-color: var(--nl-rule-strong); }
[data-design="a"] .nl-room__opt:focus-visible { outline: 2px solid var(--nl-brand); outline-offset: 2px; }
[data-design="a"] .nl-room__opt.is-picked { border-color: var(--nl-brand); box-shadow: var(--nl-elev-bloom); }
[data-design="a"] .nl-room__opt-swatch { display: block; width: 44px; height: 44px; border: 1px solid var(--nl-rule); }
[data-design="a"] .nl-room__opt-text { display: grid; gap: 2px; }
[data-design="a"] .nl-room__opt-name { font-family: var(--nl-font-display); font-style: italic; font-weight: 500; font-size: 20px; line-height: 1.1; font-feature-settings: "ss01"; }
[data-design="a"] .nl-room__opt-meta { font-family: var(--nl-font-mono); font-size: 12px; letter-spacing: 0.06em; color: var(--nl-text-mute); text-transform: uppercase; }

[data-design="a"] .nl-room__step--final { display: grid; gap: var(--nl-stroke); overflow-y: auto; }
[data-design="a"] .nl-room__summary { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--nl-stroke); margin: 0; padding: var(--nl-stroke) 0; border-top: 1px solid var(--nl-rule); border-bottom: 1px solid var(--nl-rule); }
[data-design="a"] .nl-room__summary div { display: grid; gap: 4px; }
[data-design="a"] .nl-room__summary dt { color: var(--nl-text-mute); }
[data-design="a"] .nl-room__summary dd { font-family: var(--nl-font-display); font-style: italic; font-size: 17px; line-height: 1.2; color: var(--nl-text); font-feature-settings: "ss01"; }
[data-design="a"] .nl-room__form { display: grid; gap: var(--nl-stroke); }
[data-design="a"] .nl-field { display: grid; gap: 6px; }
[data-design="a"] .nl-field__label { font-family: var(--nl-font-display); font-style: italic; font-size: 17px; color: var(--nl-text); font-feature-settings: "ss01"; }
[data-design="a"] .nl-field__hint { font-family: var(--nl-font-mono); font-style: normal; font-size: 11px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--nl-text-mute); }
[data-design="a"] .nl-field__input {
  font-family: var(--nl-font-body); font-size: 16px; color: var(--nl-text);
  background: var(--nl-linen); border: 0; border-bottom: 1px solid var(--nl-rule); border-radius: 0;
  padding: 10px 4px; min-height: 44px; width: 100%; transition: border-color var(--nl-dur-settle) var(--nl-ease-settle);
}
[data-design="a"] .nl-field__input:focus { outline: 0; border-bottom: 2px solid var(--nl-brand); }
[data-design="a"] .nl-field__area { resize: vertical; min-height: 76px; }
[data-design="a"] .nl-room__confirm { font-family: var(--nl-font-display); font-style: italic; font-size: 18px; line-height: 1.5; color: var(--nl-success); margin: 0; font-feature-settings: "ss01"; }
[data-design="a"] .nl-room__note { font-size: 14px; line-height: 1.55; color: var(--nl-text-soft); }
[data-design="a"] .nl-room__note a { color: var(--nl-brand); }
[data-design="a"] .nl-room__restart { appearance: none; background: transparent; border: 0; color: var(--nl-text-soft); font-family: var(--nl-font-body); font-size: 14px; text-decoration: underline; text-underline-offset: 4px; cursor: pointer; padding: 12px; min-height: 44px; justify-self: start; }

/* ===== Recent work plates (E4 reveal — pigment-bloom) ===== */
[data-design="a"] .nl-recent { padding: var(--nl-room) clamp(var(--nl-stroke), 5vw, var(--nl-canvas)); background: var(--nl-linen-warm); }
[data-design="a"] .nl-recent__head { max-width: 1180px; margin: 0 auto var(--nl-canvas); display: grid; gap: var(--nl-stroke); }
[data-design="a"] .nl-recent__lede { color: var(--nl-text-soft); max-width: 56ch; line-height: 1.6; font-size: var(--nl-type-body); }
[data-design="a"] .nl-recent__grid { list-style: none; padding: 0; margin: 0 auto; max-width: 1180px; display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--nl-canvas) var(--nl-coat); }
[data-design="a"] .nl-recent__plate { display: grid; gap: var(--nl-stroke); }
[data-design="a"] .nl-recent__plate:nth-child(2n) { margin-top: var(--nl-canvas); }
[data-design="a"] .nl-recent__figure { position: relative; margin: 0; aspect-ratio: 4 / 3; background: var(--nl-linen); overflow: hidden; border: 1px solid var(--nl-rule); }
[data-design="a"] .nl-recent__img { width: 100%; height: 100%; object-fit: cover; display: block; opacity: 0; transform: scale(1.03); transition: opacity var(--nl-dur-cure) var(--nl-ease-light), transform var(--nl-dur-cure) var(--nl-ease-light); }
[data-design="a"] .nl-recent__bloom {
  position: absolute; left: 50%; top: 50%; width: 10%; height: 10%; border-radius: 999px;
  background: radial-gradient(closest-side, var(--nl-chip-02) 0%, transparent 70%);
  transform: translate(-50%, -50%) scale(0.4); opacity: 0; mix-blend-mode: multiply;
  transition: transform var(--nl-dur-bloom) var(--nl-ease-bloom), opacity var(--nl-dur-bloom) var(--nl-ease-bloom);
  z-index: 2; pointer-events: none;
}
[data-design="a"] .nl-recent__plate.is-bloomed .nl-recent__img { opacity: 1; transform: scale(1); }
[data-design="a"] .nl-recent__plate.is-bloomed .nl-recent__bloom { transform: translate(-50%, -50%) scale(12); opacity: 0; }
[data-design="a"] .nl-recent__plate.is-bloomed.is-blooming .nl-recent__bloom { opacity: 0.55; transform: translate(-50%, -50%) scale(8); }
[data-design="a"] .nl-recent__meta { display: grid; gap: var(--nl-grain); }
[data-design="a"] .nl-recent__meta h3 { font-family: var(--nl-font-display); font-style: italic; font-weight: 500; font-size: 22px; line-height: 1.2; letter-spacing: -0.005em; color: var(--nl-text); max-width: 28ch; font-feature-settings: "ss01"; }
[data-design="a"] .nl-recent__tags { display: flex; gap: var(--nl-stroke); flex-wrap: wrap; }
[data-design="a"] .nl-recent__cta { max-width: 1180px; margin: var(--nl-canvas) auto 0; display: flex; justify-content: center; }

/* ===== Services ===== */
[data-design="a"] .nl-services { padding: var(--nl-room) clamp(var(--nl-stroke), 5vw, var(--nl-canvas)); background: var(--nl-linen); border-top: 1px solid var(--nl-rule); }
[data-design="a"] .nl-services__head { max-width: 1180px; margin: 0 auto var(--nl-canvas); display: grid; gap: var(--nl-stroke); }
[data-design="a"] .nl-services__list { list-style: none; padding: 0; margin: 0 auto; max-width: 1180px; display: grid; gap: 0; }
[data-design="a"] .nl-svc { padding: var(--nl-coat) 0; border-top: 1px solid var(--nl-rule); display: grid; gap: var(--nl-grain); }
[data-design="a"] .nl-svc:last-child { border-bottom: 1px solid var(--nl-rule); }
[data-design="a"] .nl-svc__name { font-family: var(--nl-font-display); font-style: italic; font-weight: 500; font-size: var(--nl-type-headline); line-height: 1.1; color: var(--nl-text); letter-spacing: -0.01em; font-feature-settings: "ss01"; }
[data-design="a"] .nl-svc__note { color: var(--nl-text-soft); line-height: 1.6; max-width: 68ch; font-size: var(--nl-type-body); }

/* ===== Process ===== */
[data-design="a"] .nl-process { padding: var(--nl-room) clamp(var(--nl-stroke), 5vw, var(--nl-canvas)); background: var(--nl-linen-warm); }
[data-design="a"] .nl-process__head { max-width: 1180px; margin: 0 auto var(--nl-canvas); display: grid; gap: var(--nl-stroke); }
[data-design="a"] .nl-process__track { list-style: none; padding: 0; margin: 0 auto; max-width: 1180px; display: grid; grid-template-columns: repeat(5, 1fr); gap: var(--nl-coat); }
[data-design="a"] .nl-phase { display: grid; gap: var(--nl-grain); align-content: start; padding-top: var(--nl-stroke); border-top: 2px solid var(--nl-brand); }
[data-design="a"] .nl-phase__name { font-family: var(--nl-font-display); font-style: italic; font-weight: 500; font-size: 21px; line-height: 1.15; color: var(--nl-text); font-feature-settings: "ss01"; }
[data-design="a"] .nl-phase__note { color: var(--nl-text-soft); line-height: 1.55; font-size: 15px; }

/* ===== About ===== */
[data-design="a"] .nl-about { padding: var(--nl-room) clamp(var(--nl-stroke), 5vw, var(--nl-canvas)); background: var(--nl-linen); border-top: 1px solid var(--nl-rule); }
[data-design="a"] .nl-about__inner { max-width: 1180px; margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: var(--nl-canvas); align-items: start; }
[data-design="a"] .nl-about__quote { font-family: var(--nl-font-display); font-style: italic; font-weight: 400; font-size: var(--nl-type-display); line-height: 1.1; color: var(--nl-text); letter-spacing: -0.015em; font-feature-settings: "ss01"; }
[data-design="a"] .nl-about__title { font-family: var(--nl-font-display); font-style: italic; font-weight: 500; font-size: var(--nl-type-headline); line-height: 1.1; color: var(--nl-text); margin-bottom: var(--nl-stroke); font-feature-settings: "ss01"; }
[data-design="a"] .nl-about__body p { color: var(--nl-text-soft); line-height: 1.65; max-width: 60ch; font-size: var(--nl-type-body); }
[data-design="a"] .nl-about__facts { list-style: none; padding: 0; margin: var(--nl-coat) 0 0; display: grid; gap: var(--nl-grain); }
[data-design="a"] .nl-about__facts li { font-family: var(--nl-font-display); font-style: italic; font-size: 19px; color: var(--nl-text); display: flex; gap: var(--nl-stroke); align-items: baseline; font-feature-settings: "ss01"; }

/* ===== Service Area ===== */
[data-design="a"] .nl-area { padding: var(--nl-room) clamp(var(--nl-stroke), 5vw, var(--nl-canvas)); background: var(--nl-linen-warm); }
[data-design="a"] .nl-area__head { max-width: 1180px; margin: 0 auto; display: grid; gap: var(--nl-stroke); }
[data-design="a"] .nl-area__note { color: var(--nl-text-soft); line-height: 1.6; max-width: 60ch; font-size: var(--nl-type-body); }

/* ===== Footer ===== */
[data-design="a"] .nl-footer { background: var(--nl-linen-warm); border-top: 1px solid var(--nl-rule); padding: var(--nl-wall) clamp(var(--nl-stroke), 5vw, var(--nl-canvas)) var(--nl-coat); }
[data-design="a"] .nl-footer__inner { max-width: 1180px; margin: 0 auto; display: flex; flex-wrap: wrap; gap: var(--nl-canvas); justify-content: space-between; }
[data-design="a"] .nl-footer__col { display: grid; gap: var(--nl-grain); align-content: start; }
[data-design="a"] .nl-footer__mark { font-family: var(--nl-font-display); font-style: italic; font-weight: 500; font-size: 24px; color: var(--nl-ink); font-feature-settings: "ss01"; }
[data-design="a"] .nl-footer__line { color: var(--nl-text-soft); font-size: 15px; line-height: 1.5; }
[data-design="a"] .nl-footer__cta { font-family: var(--nl-font-display); font-style: italic; font-size: 22px; color: var(--nl-brand); text-decoration: none; font-feature-settings: "ss01"; }
[data-design="a"] .nl-footer__phone { font-family: var(--nl-font-display); font-style: italic; font-size: 22px; color: var(--nl-ink); text-decoration: none; font-feature-settings: "ss01"; }
[data-design="a"] .nl-footer__legal { gap: 6px; }
[data-design="a"] .nl-footer__base { max-width: 1180px; margin: var(--nl-canvas) auto 0; padding-top: var(--nl-stroke); border-top: 1px solid var(--nl-rule); }

/* ===== Responsive ===== */
@media (max-width: 920px) {
  [data-design="a"] .nl-process__track { grid-template-columns: repeat(2, 1fr); }
  [data-design="a"] .nl-about__inner { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  [data-design="a"] .nl-recent__grid { grid-template-columns: 1fr; }
  [data-design="a"] .nl-recent__plate { margin-top: 0 !important; }
  [data-design="a"] .nl-room__summary { grid-template-columns: 1fr; }
  [data-design="a"] .nl-process__track { grid-template-columns: 1fr; }
  [data-design="a"] .nl-footer__inner { flex-direction: column; }
}
@media (max-width: 380px) {
  [data-design="a"] .nl-header__mark { font-size: 22px; }
}

/* ===== Reduced-motion fallback — every signature interaction ===== */
@media (prefers-reduced-motion: reduce) {
  [data-design="a"] .nl-header__rake { animation: none; opacity: 0.28; }
  [data-design="a"] .nl-curtain__panel { transition: none; }
  [data-design="a"] .nl-cta { animation: none; background-image: none; }
  [data-design="a"] .nl-hero__wash { animation: none; opacity: 0.30; transform: none; }
  [data-design="a"] .nl-pointer__sash { animation: none; transform: translateX(-50%) translateY(100px); opacity: 0.8; }
  [data-design="a"] .nl-pointer__bloom { animation: none; opacity: 0.4; transform: translate(-50%, 50%) scale(1); }
  [data-design="a"] .nl-room__step, [data-design="a"] .nl-field__input { transition: none; }
  [data-design="a"] .nl-recent__img { opacity: 1; transform: none; transition: none; }
  [data-design="a"] .nl-recent__bloom { opacity: 0; transition: none; }
}

/* ===== Mobile overflow guards (MANDATORY — appended at bottom) ===== */
[data-design="a"].dq-design,[data-design="a"] .dq-design{max-width:100%;overflow-x:clip;}
[data-design="a"] *{min-width:0;}
[data-design="a"] img,[data-design="a"] svg:not([data-keep-size]){max-width:100%;height:auto;}

/* Phase-3.4 hero visibility floor (forge_assemble) */
[data-design="a"] [data-mf-role="hero"] :is(h1,h2,p,.headline,.subtitle,.proof,[class*="headline"],[class*="subtitle"],[class*="proof"]),
[data-design="a"] [data-mf-role="cta"] { opacity: 1 !important; }
