/* Lookbook UI kit styles — mirrors lookbook/src/components/ and Layout.astro */

.nm-deck {
  max-width: 920px;
  margin: 0 auto;
  padding: 0 32px 72px;
  counter-reset: section;
  font-family: var(--font-serif);
  font-size: 17px;
  line-height: 1.75;
  color: var(--dark-green);
}

.nm-deck p { margin: 0 0 16px; color: var(--dark-slate); }
.nm-deck strong { color: var(--dark-green); font-weight: 600; }
.nm-deck em { font-style: italic; color: var(--dark-green); }
.nm-deck > ul, .nm-deck > ol { color: var(--dark-slate); padding-left: 20px; }
.nm-deck > ul li::marker { color: var(--medium-green); }
.nm-deck a { color: var(--medium-green); text-decoration: underline; text-underline-offset: 3px; }
.nm-deck code { font-family: var(--font-mono); font-size: 0.88em; background: rgba(74, 161, 107, 0.1); color: var(--dark-green); padding: 1px 6px; border-radius: 4px; }

/* Chrome */
.nm-hero { padding: 56px 0 40px; margin-bottom: 40px; border-bottom: 2px solid var(--dark-green); }
.nm-hero-logos { display: flex; align-items: center; justify-content: space-between; margin-bottom: 56px; gap: 24px; }
.nm-logo { width: auto; display: block; }
.nm-logo-native { height: 30px; }
.nm-logo-partner { height: 25px; }
.nm-hero-title { font-family: var(--font-serif); font-size: clamp(38px, 6vw, 64px); font-weight: 400; line-height: 1.1; margin: 0; letter-spacing: -0.025em; color: var(--dark-green); }

.nm-confidential { font-family: var(--font-sans); font-size: 11px; font-weight: 400; letter-spacing: 0.12em; text-transform: uppercase; color: var(--brown); margin: 0; }
.nm-confidential-top { margin: 16px 0 0; }
.nm-confidential-footer { display: flex; align-items: center; justify-content: space-between; padding: 56px 0 16px; border-top: 2px solid var(--dark-green); margin-top: 64px; }
.nm-footer-logo { height: 20px; width: auto; opacity: 0.35; }

.nm-h2 { font-family: var(--font-serif); font-size: clamp(26px, 4vw, 36px); font-weight: 400; margin: 80px 0 20px; letter-spacing: -0.015em; color: var(--dark-green); line-height: 1.2; }
.nm-h2-counter { display: block; font-family: var(--font-sans); font-size: 12px; font-weight: 700; letter-spacing: 0.08em; color: var(--brown); margin-bottom: 8px; }

/* Stats */
.nm-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 2px; margin: 32px 0; border-radius: 10px; overflow: hidden; }
.nm-stat { background: var(--dark-green); padding: 28px 24px; display: flex; flex-direction: column; gap: 4px; }
.nm-stat-value { font-family: var(--font-serif); font-size: clamp(28px, 4vw, 40px); font-weight: 400; letter-spacing: -0.02em; color: var(--cream); line-height: 1; }
.nm-stat-unit { font-size: 0.6em; color: var(--brown); }
.nm-stat-label { font-family: var(--font-sans); font-size: 12px; text-transform: uppercase; letter-spacing: 0.06em; color: var(--brown); line-height: 1.3; }

/* FeatureGrid */
.nm-feature-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 20px; margin: 32px 0; }
.nm-feature-card { background: var(--white-card); border-radius: 10px; padding: 28px 24px; border-left: 3px solid var(--medium-green); box-shadow: 0 1px 3px rgba(27, 49, 35, 0.06); display: flex; flex-direction: column; }
.nm-feature-title { font-family: var(--font-sans); font-size: 18px; font-weight: 700; margin: 0 0 6px; color: var(--dark-green); }
.nm-feature-tagline { font-size: 14px; font-style: italic; color: var(--dark-slate); margin: 0 0 14px; }
.nm-feature-bullets { margin: 0; padding-left: 18px; font-size: 14px; margin-top: auto; padding-top: 14px; }
.nm-feature-bullets li { margin-bottom: 6px; color: var(--dark-slate); line-height: 1.55; }
.nm-feature-bullets li::marker { color: var(--medium-green); }

/* ProportionBar */
.nm-proportion { margin: 32px 0; display: flex; justify-content: center; }
.nm-bar { width: 100%; max-width: 360px; height: 420px; display: flex; flex-direction: column; border-radius: 10px; overflow: hidden; box-shadow: 0 1px 3px rgba(27,49,35,0.06); }
.nm-segment { display: flex; align-items: center; padding: 14px 20px; color: var(--cream); min-height: 42px; }
.nm-segment-0 { background: var(--dark-green); }
.nm-segment-1 { background: var(--medium-green); }
.nm-segment-2 { background: var(--brown); color: var(--dark-green); }
.nm-segment-inner { display: flex; align-items: baseline; justify-content: space-between; width: 100%; gap: 12px; }
.nm-segment-label { font-family: var(--font-sans); font-size: 13px; font-weight: 600; }
.nm-segment-value { font-family: var(--font-sans); font-size: 12px; letter-spacing: 0.04em; opacity: 0.85; }

/* SimpleList */
.nm-simplelist-wrap { overflow-x: auto; margin: 28px 0; border-radius: 10px; background: var(--white-card); box-shadow: 0 1px 3px rgba(27,49,35,0.06); }
.nm-simplelist { width: 100%; border-collapse: collapse; font-size: 14px; }
.nm-simplelist th { background: var(--dark-green); font-family: var(--font-sans); font-weight: 600; font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; text-align: left; padding: 14px 20px; color: var(--cream); white-space: nowrap; vertical-align: top; border-bottom: 1px solid rgba(242,236,228,0.08); }
.nm-simplelist td { padding: 16px 20px; border-bottom: 1px solid rgba(191,171,147,0.2); color: var(--dark-slate); vertical-align: top; line-height: 1.55; font-size: 13.5px; }
.nm-simplelist tr:last-child th, .nm-simplelist tr:last-child td { border-bottom: none; }

/* Table */
.nm-table-wrap { overflow-x: auto; margin: 28px 0; border-radius: 10px; background: var(--white-card); box-shadow: 0 1px 3px rgba(27,49,35,0.06); }
.nm-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.nm-table thead { background: var(--dark-green); }
.nm-table th { font-family: var(--font-sans); font-weight: 600; font-size: 11px; text-transform: uppercase; letter-spacing: 0.06em; text-align: left; padding: 14px 20px; color: var(--cream); white-space: nowrap; }
.nm-table .nm-th-hi { color: var(--medium-green); }
.nm-table td { padding: 16px 20px; border-bottom: 1px solid rgba(191,171,147,0.2); color: var(--dark-slate); vertical-align: top; line-height: 1.55; font-size: 13.5px; }
.nm-table .nm-td-hi { background: rgba(74,161,107,0.05); }
.nm-table tr:last-child td { border-bottom: none; }

/* Matrix */
.nm-matrix { display: grid; grid-template-columns: auto minmax(0, 520px) auto; grid-template-rows: auto auto auto; gap: 12px 14px; margin: 32px auto; max-width: 100%; align-items: center; justify-items: center; }
.nm-axis { font-family: var(--font-sans); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--brown); text-align: center; }
.nm-axis-y-top { grid-column: 2; grid-row: 1; }
.nm-axis-y-bottom { grid-column: 2; grid-row: 3; }
.nm-axis-x-left { grid-column: 1; grid-row: 2; writing-mode: vertical-rl; transform: rotate(180deg); }
.nm-axis-x-right { grid-column: 3; grid-row: 2; writing-mode: vertical-rl; }
.nm-matrix-grid { grid-column: 2; grid-row: 2; display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; gap: 2px; background: var(--brown); border-radius: 10px; overflow: hidden; width: 100%; aspect-ratio: 1 / 1; }
.nm-quadrant { background: var(--white-card); padding: 24px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; gap: 8px; }
.nm-quadrant-label { font-family: var(--font-sans); font-size: 14px; font-weight: 700; color: var(--dark-green); line-height: 1.3; }
.nm-quadrant-desc { font-size: 13px; color: var(--dark-slate); line-height: 1.5; }

/* Timeline */
.nm-timeline { margin: 32px 0; position: relative; padding-left: 28px; border-left: 2px solid var(--brown); }
.nm-timeline-phase { margin-bottom: 20px; margin-left: -28px; padding-left: 28px; }
.nm-timeline-phase:not(:first-child) { margin-top: 32px; }
.nm-timeline-phase-label { font-family: var(--font-sans); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--medium-green); background: var(--cream); display: inline-block; padding: 4px 12px; border-radius: 4px; border: 1px solid var(--brown); }
.nm-timeline-item { display: grid; grid-template-columns: 80px 1fr; gap: 16px; margin-bottom: 20px; position: relative; }
.nm-timeline-dot { position: absolute; left: -34px; top: 4px; width: 10px; height: 10px; border-radius: 50%; background: var(--cream); border: 2px solid var(--brown); }
.nm-timeline-dot-final { background: var(--medium-green); border-color: var(--medium-green); }
.nm-timeline-date { font-family: var(--font-sans); font-size: 13px; font-weight: 600; color: var(--dark-green); padding-top: 1px; }
.nm-timeline-content { display: flex; flex-direction: column; gap: 2px; }
.nm-timeline-content strong { font-family: var(--font-sans); font-size: 14px; color: var(--dark-green); }
.nm-timeline-content span { font-size: 14px; color: var(--dark-slate); line-height: 1.55; }

/* ConceptualSequence */
.nm-sequence { position: relative; margin: 32px 0; padding-left: 56px; padding-bottom: 40px; }
.nm-sequence-axis { position: absolute; left: 16px; top: -6px; bottom: 0; width: 2px; background: linear-gradient(to bottom, rgba(191,171,147,0) 0%, var(--brown) 15%, var(--brown) 100%); }
.nm-sequence-axis::after { content: ""; position: absolute; left: 50%; bottom: -2px; transform: translateX(-50%); width: 0; height: 0; border-left: 9px solid transparent; border-right: 9px solid transparent; border-top: 14px solid var(--brown); }
.nm-sequence-header { display: grid; grid-template-columns: minmax(0, 1.8fr) minmax(0, 1fr); gap: 36px; margin-bottom: 14px; }
.nm-sequence-outcome-header { grid-column: 2; font-family: var(--font-sans); font-size: 11px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--brown); padding: 0 4px; }
.nm-phase { display: grid; grid-template-columns: 1fr; gap: 36px; align-items: start; margin-bottom: 14px; position: relative; }
.nm-sequence-two-col .nm-phase { grid-template-columns: minmax(0, 1.8fr) minmax(0, 1fr); }
.nm-phase-card { display: grid; grid-template-columns: 170px 1fr; gap: 24px; align-items: start; background: rgba(191,171,147,0.18); border: 1px solid rgba(191,171,147,0.45); border-radius: 10px; padding: 20px 24px; position: relative; }
.nm-phase-card::before { content: ""; position: absolute; left: -46px; top: 50%; transform: translateY(-50%); width: 12px; height: 12px; border-radius: 50%; background: var(--cream); border: 2px solid var(--brown); z-index: 2; }
.nm-phase-title { font-family: var(--font-sans); font-size: 18px; font-weight: 700; color: var(--dark-green); line-height: 1.15; }
.nm-phase-subtitle { font-family: var(--font-serif); font-style: italic; font-size: 13px; color: var(--brown); margin-top: 4px; line-height: 1.3; }
.nm-phase-body { font-family: var(--font-serif); font-size: 14px; color: var(--dark-slate); line-height: 1.55; }
.nm-phase-outcome { font-family: var(--font-serif); font-style: italic; font-size: 14px; color: var(--dark-slate); line-height: 1.55; padding: 20px 4px 0; }

/* Statement / Callout / Summary / Figure */
.nm-statement { margin: 72px auto; max-width: 720px; padding: 0 16px; text-align: center; }
.nm-statement blockquote { margin: 0; font-family: var(--font-serif); font-size: clamp(26px, 4.5vw, 42px); font-weight: 400; line-height: 1.25; letter-spacing: -0.02em; color: var(--dark-green); }
.nm-statement blockquote em { font-style: italic; color: var(--medium-green); }
.nm-attribution { margin: 28px 0 0; font-family: var(--font-sans); font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--brown); }

.nm-callout { background: var(--dark-green); border-radius: 10px; padding: 40px 36px; margin: 32px 0; color: var(--cream); font-size: 18px; line-height: 1.65; }
.nm-callout p { color: var(--cream); margin: 0 0 16px; }
.nm-callout p:last-child { margin-bottom: 0; }
.nm-callout strong, .nm-callout em { color: var(--cream); }
.nm-callout ul { padding-left: 20px; margin: 0; }
.nm-callout li { color: var(--cream); margin-bottom: 10px; line-height: 1.6; }
.nm-callout li::marker { color: var(--medium-green); }

.nm-summary-card { margin: 32px 0; padding: 36px 32px; background: var(--white-card); border-radius: 10px; border-top: 3px solid var(--medium-green); box-shadow: 0 1px 3px rgba(27,49,35,0.06); }
.nm-summary-title { font-family: var(--font-sans); font-size: 11px; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--brown); margin-bottom: 10px; }
.nm-summary-headline { font-family: var(--font-serif); font-size: clamp(20px, 3vw, 26px); font-weight: 400; margin: 0 0 20px; color: var(--dark-green); line-height: 1.3; letter-spacing: -0.015em; }
.nm-summary-points { margin: 0; padding-left: 20px; color: var(--dark-slate); font-size: 15px; line-height: 1.65; }
.nm-summary-points li { margin-bottom: 8px; }
.nm-summary-points li::marker { color: var(--medium-green); }

.nm-figure { margin: 32px 0; padding: 28px; background: var(--white-card); border-radius: 10px; box-shadow: 0 1px 3px rgba(27,49,35,0.06); text-align: center; }
.nm-figure img { max-width: 100%; height: auto; display: block; margin: 0 auto 20px; }
.nm-figure figcaption { font-family: var(--font-sans); font-size: 13px; color: var(--brown); line-height: 1.6; max-width: 540px; margin: 0 auto; }

@media (max-width: 720px) {
  .nm-feature-grid { grid-template-columns: 1fr; }
  .nm-sequence-two-col .nm-phase { grid-template-columns: 1fr; gap: 10px; }
  .nm-phase-card { grid-template-columns: 1fr; gap: 8px; padding: 16px 18px; }
  .nm-phase-card::before { left: -34px; top: 28px; transform: none; }
}
