/* ═════════════════════════════════════════════════════════════════════════
   [2026-05-18] DESIGN-PORT — Solution Landing.html body sections
   Ported from the Claude Design "Solution Landing.html" delivery so the
   page below the hero matches the niche-specific design (restaurant
   palette: warm oklch oranges/reds via .text-grad-warm).
   Class namespace stays separate from .sol-* so existing top-of-fold
   panel is unaffected. Tokens reused: --glass-*, --stroke-*, --ink-*,
   --bg-*, --r-*, --f-*, --grad-primary, --shadow-glow-blue, --cyan,
   --success, --blue-bright, --violet.
   ═════════════════════════════════════════════════════════════════════════ */

/* Section padding rhythm */
.sld-section { position: relative; z-index: 1; padding: 112px 0; }
.sld-section.compact { padding: 72px 0; }
@media (max-width: 768px) {
  .sld-section { padding: 72px 0; }
  .sld-section.compact { padding: 56px 0; }
}

/* Warm text-grad utility (orange→red) — restaurant H1 emphasis */
.text-grad-warm {
  background: linear-gradient(135deg, oklch(0.85 0.16 70), oklch(0.78 0.18 35) 50%, oklch(0.66 0.21 22));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}

/* Section head */
.sld-sec-head { text-align: center; max-width: 720px; margin: 0 auto 56px; }
.sld-sec-head .kicker { margin-bottom: 14px; display: block; }
.sld-sec-head .lead { color: var(--ink-1); font-size: 17px; line-height: 1.55; margin-top: 16px; }

/* ===== START BUILDING ===== */
.sb-card {
  background:
    radial-gradient(70% 60% at 80% 0%, oklch(0.6 0.2 35 / 0.18), transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.015));
  border: 1px solid var(--stroke-2); border-radius: var(--r-xl, 32px);
  padding: 48px 48px; position: relative; overflow: hidden;
}
.sb-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
@media (max-width: 920px) { .sb-grid { grid-template-columns: 1fr; gap: 32px; } .sb-card { padding: 36px 28px; } }
.sb-grid .lead { font-size: 17px; color: var(--ink-1); line-height: 1.55; margin: 16px 0 26px; max-width: 460px; }
.sld-section .btn-lg { padding: 14px 22px; font-size: 15px; }
.seed-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.seed { padding: 16px; background: var(--glass-2); border: 1px solid var(--stroke-1); border-radius: var(--r-md); cursor: pointer; transition: border-color .15s, transform .15s, background .15s; text-align: left; }
.seed:hover { border-color: oklch(0.78 0.18 35 / 0.4); background: var(--glass-3); transform: translateY(-2px); }
.seed .tag { display: inline-flex; align-items: center; gap: 6px; font-family: var(--f-mono); font-size: 9.5px; letter-spacing: 0.08em; color: oklch(0.85 0.16 70); margin-bottom: 8px; text-transform: uppercase; }
.seed .tag::before { content: ""; width: 5px; height: 5px; border-radius: 50%; background: currentColor; }
.seed .ex { font-size: 13.5px; color: var(--ink-0); line-height: 1.45; letter-spacing: -0.005em; }
.seed .ex em { background: var(--grad-primary); -webkit-background-clip: text; background-clip: text; color: transparent; font-style: normal; }

/* ===== FEATURES BENTO ===== */
.bento { display: grid; grid-template-columns: repeat(6, 1fr); grid-auto-rows: 220px; gap: 16px; }
@media (max-width: 900px) { .bento { grid-template-columns: 1fr 1fr; } .bento .b-card { grid-column: span 2 !important; } }
.b-card { padding: 24px; background: var(--glass-1); border: 1px solid var(--stroke-1); border-radius: var(--r-lg); position: relative; overflow: hidden; display: flex; flex-direction: column; }
.b-card .b-head { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.b-card .b-icon { width: 36px; height: 36px; border-radius: 9px; background: var(--glass-3); border: 1px solid var(--stroke-2); display: grid; place-items: center; }
.b-card .b-icon.warm { background: linear-gradient(135deg, oklch(0.78 0.18 35 / 0.2), oklch(0.66 0.21 22 / 0.1)); border-color: oklch(0.78 0.18 35 / 0.35); color: oklch(0.85 0.16 70); }
.b-card .b-icon.green { background: linear-gradient(135deg, oklch(0.78 0.17 158 / 0.2), oklch(0.65 0.15 168 / 0.1)); border-color: oklch(0.78 0.17 158 / 0.35); color: var(--success); }
.b-card .b-icon.blue { background: linear-gradient(135deg, oklch(0.7 0.19 256 / 0.2), oklch(0.66 0.21 295 / 0.1)); border-color: oklch(0.7 0.19 256 / 0.35); color: var(--cyan); }
.b-card .b-icon.violet { background: linear-gradient(135deg, oklch(0.66 0.21 295 / 0.2), oklch(0.7 0.19 256 / 0.1)); border-color: oklch(0.66 0.21 295 / 0.35); color: oklch(0.85 0.13 295); }
.b-card h3 { font-size: 16px; }
.b-card p { color: var(--ink-1); font-size: 13.5px; line-height: 1.5; margin: 0; }
.b-art { margin-top: auto; padding-top: 16px; }
.b-1 { grid-column: span 3; grid-row: span 2; }
.b-2 { grid-column: span 3; }
.b-3 { grid-column: span 2; }
.b-4 { grid-column: span 1; }
.b-5 { grid-column: span 3; }
.b-6 { grid-column: span 3; }

.menu-art { background: linear-gradient(180deg, rgba(0,0,0,0.3), rgba(0,0,0,0.5)); border-radius: var(--r-md); padding: 18px 22px; border: 1px solid var(--stroke-1); }
.menu-art .heading { font-family: "Times New Roman", Georgia, serif; font-style: italic; font-size: 13px; color: oklch(0.85 0.16 70); letter-spacing: 0.04em; margin-bottom: 10px; text-transform: uppercase; font-weight: 600; }
.menu-art .row { display: flex; justify-content: space-between; align-items: baseline; padding: 6px 0; border-bottom: 1px dashed rgba(255,255,255,0.08); font-size: 12px; }
.menu-art .row:last-child { border-bottom: 0; }
.menu-art .row .nm { color: var(--ink-0); font-weight: 500; }
.menu-art .row .px { font-family: var(--f-mono); color: var(--ink-2); }

.schema-art { margin: 0; padding: 14px 16px; background: rgba(0,0,0,0.4); border: 1px solid var(--stroke-1); border-radius: var(--r-md); font-family: var(--f-mono); font-size: 10.5px; line-height: 1.55; color: var(--ink-1); overflow: hidden; white-space: pre; }
.schema-art .k { color: oklch(0.85 0.13 205); }
.schema-art .s { color: oklch(0.78 0.17 158); }
.schema-art .d { color: var(--ink-3); }

.resv-art { display: flex; flex-direction: column; gap: 8px; }
.resv-art .slot { display: flex; align-items: center; justify-content: space-between; padding: 9px 14px; background: var(--glass-2); border: 1px solid var(--stroke-1); border-radius: var(--r-pill); font-size: 12.5px; }
.resv-art .slot.on { background: linear-gradient(180deg, oklch(0.78 0.18 35 / 0.18), oklch(0.66 0.21 22 / 0.06)); border-color: oklch(0.78 0.18 35 / 0.45); }
.resv-art .slot .time { font-family: var(--f-mono); color: var(--ink-0); font-weight: 600; letter-spacing: -0.005em; }
.resv-art .slot .meta { font-size: 11px; color: var(--ink-2); }
.resv-art .slot .pill { padding: 2px 9px; font-family: var(--f-mono); font-size: 9.5px; background: oklch(0.85 0.16 70 / 0.15); border: 1px solid oklch(0.85 0.16 70 / 0.4); border-radius: 999px; color: oklch(0.92 0.18 75); }

.lang-row { display: flex; gap: 6px; flex-wrap: wrap; }
.lang-row .lc { padding: 5px 12px; background: var(--glass-2); border: 1px solid var(--stroke-1); border-radius: 999px; font-family: var(--f-mono); font-size: 11px; color: var(--ink-1); letter-spacing: 0.04em; }
.lang-row .lc.on { background: linear-gradient(180deg, oklch(0.66 0.21 295 / 0.18), oklch(0.7 0.19 256 / 0.06)); border-color: oklch(0.66 0.21 295 / 0.4); color: var(--ink-0); }

/* ===== HOW-TO ===== */
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
@media (max-width: 920px) { .steps { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .steps { grid-template-columns: 1fr; } }
.step { padding: 26px 24px 28px; background: var(--glass-1); border: 1px solid var(--stroke-1); border-radius: var(--r-lg); position: relative; overflow: hidden; min-height: 260px; display: flex; flex-direction: column; }
.step::before { content: ""; position: absolute; inset: 0; background: linear-gradient(135deg, oklch(0.78 0.18 35 / 0.12), oklch(0.66 0.21 22 / 0.04)); opacity: 0; transition: opacity .3s; }
.step:hover::before { opacity: 1; }
.step > * { position: relative; z-index: 1; }
.step-num { font-family: var(--f-mono); font-size: 11px; color: var(--ink-2); letter-spacing: 0.1em; margin-bottom: 16px; display: flex; align-items: center; gap: 8px; }
.step-num::before { content: ""; width: 24px; height: 1px; background: var(--stroke-2); }
.step-icon { width: 44px; height: 44px; border-radius: 12px; background: var(--glass-3); border: 1px solid var(--stroke-2); display: grid; place-items: center; margin-bottom: 18px; color: oklch(0.85 0.16 70); }
.step h3 { font-size: 18px; margin-bottom: 8px; }
.step p { font-size: 14px; color: var(--ink-1); line-height: 1.5; margin: 0; }

/* ===== PROOF ===== */
.proof-grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 32px; }
@media (max-width: 980px) { .proof-grid { grid-template-columns: 1fr; } }
.stats { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.stat { padding: 24px 22px; background: var(--glass-1); border: 1px solid var(--stroke-1); border-radius: var(--r-lg); position: relative; overflow: hidden; }
.stat::before { content: ""; position: absolute; top: -40%; right: -20%; width: 80%; height: 100%; background: radial-gradient(circle, oklch(0.78 0.18 35 / 0.15), transparent 60%); pointer-events: none; }
.stat .v { font-size: 38px; font-weight: 700; letter-spacing: -0.035em; line-height: 1; margin-bottom: 8px; background: linear-gradient(135deg, oklch(0.92 0.18 75), oklch(0.66 0.21 22)); -webkit-background-clip: text; background-clip: text; color: transparent; }
.stat .l { font-size: 13px; color: var(--ink-1); line-height: 1.45; }
.testi { padding: 32px 32px; background: var(--glass-1); border: 1px solid var(--stroke-1); border-radius: var(--r-lg); display: flex; flex-direction: column; gap: 20px; }
.testi .rate { display: flex; gap: 2px; color: oklch(0.85 0.16 70); font-size: 15px; }
.testi .q { font-size: 19px; line-height: 1.45; letter-spacing: -0.015em; color: var(--ink-0); }
.testi .author { display: flex; align-items: center; gap: 14px; padding-top: 18px; border-top: 1px solid var(--stroke-1); }
.testi .av { width: 44px; height: 44px; border-radius: 50%; background: linear-gradient(135deg, oklch(0.85 0.16 70), oklch(0.66 0.21 22)); display: grid; place-items: center; font-weight: 600; color: #2a1607; font-size: 14px; }
.testi .nm { font-size: 14px; font-weight: 500; }
.testi .role { font-size: 12.5px; color: var(--ink-2); }

/* ===== FAQ ===== */
.faq-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 56px; align-items: flex-start; }
@media (max-width: 920px) { .faq-grid { grid-template-columns: 1fr; gap: 32px; } }
.faq-list { display: flex; flex-direction: column; gap: 4px; }
.faq-item { padding: 22px 4px; border-bottom: 1px solid var(--stroke-1); cursor: pointer; }
.faq-item:last-child { border-bottom: 0; }
/* [2026-06-20] FAQ accordion fix: the markup is native <details>/<summary>, so
   drive the open state off the [open] ATTRIBUTE (was .open class, which native
   <details> never sets → answers stayed clipped). Also hide the default marker. */
.faq-q { display: flex; justify-content: space-between; align-items: center; font-size: 16px; font-weight: 500; color: var(--ink-0); gap: 16px; cursor: pointer; list-style: none; }
.faq-q::-webkit-details-marker { display: none; }
.faq-q::marker { content: ""; }
.faq-q .plus { width: 24px; height: 24px; border-radius: 50%; border: 1px solid var(--stroke-2); display: grid; place-items: center; color: var(--ink-1); flex-shrink: 0; transition: all .25s; }
.faq-item[open] .plus { background: linear-gradient(135deg, oklch(0.85 0.16 70), oklch(0.66 0.21 22)); border-color: transparent; color: white; transform: rotate(45deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .35s ease, padding .35s ease; color: var(--ink-1); font-size: 14.5px; line-height: 1.55; }
.faq-item[open] .faq-a { max-height: 640px; padding-top: 12px; }

/* ===== TEMPLATES GRID (replaces #blog "From the journal") =====
   Renders the restaurant templates we ship in the generator's templates
   panel. Each card is a thumbnail + name + page count + CTA. */
.tpls-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 920px) { .tpls-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .tpls-grid { grid-template-columns: 1fr; } }
.tpl-card { padding: 0; background: var(--glass-1); border: 1px solid var(--stroke-1); border-radius: var(--r-lg); display: flex; flex-direction: column; cursor: pointer; transition: border-color .15s, transform .15s; text-decoration: none; overflow: hidden; }
.tpl-card:hover { border-color: var(--stroke-bright); transform: translateY(-2px); }
.tpl-card .thumb { aspect-ratio: 16 / 10; position: relative; overflow: hidden; background: linear-gradient(135deg, #1a0d08, #2a1607); }
.tpl-card .thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.tpl-card .thumb.placeholder.a { background: radial-gradient(60% 80% at 30% 30%, oklch(0.78 0.18 35 / 0.5), transparent 60%), radial-gradient(60% 80% at 80% 80%, oklch(0.66 0.21 22 / 0.5), transparent 60%), linear-gradient(135deg, #2a1607, #0a0503); }
.tpl-card .thumb.placeholder.b { background: radial-gradient(60% 80% at 70% 20%, oklch(0.7 0.19 256 / 0.4), transparent 60%), radial-gradient(60% 80% at 20% 80%, oklch(0.85 0.16 70 / 0.4), transparent 60%), linear-gradient(135deg, #11173a, #0a0503); }
.tpl-card .thumb.placeholder.c { background: radial-gradient(60% 80% at 50% 30%, oklch(0.78 0.17 158 / 0.4), transparent 60%), radial-gradient(60% 80% at 80% 90%, oklch(0.85 0.16 70 / 0.4), transparent 60%), linear-gradient(135deg, #0a1f15, #2a1607); }
.tpl-card .thumb.placeholder.d { background: radial-gradient(60% 80% at 40% 60%, oklch(0.66 0.21 295 / 0.4), transparent 60%), radial-gradient(60% 80% at 90% 20%, oklch(0.85 0.16 70 / 0.4), transparent 60%), linear-gradient(135deg, #1a0728, #0a0503); }
.tpl-card .thumb.placeholder.e { background: radial-gradient(60% 80% at 60% 30%, oklch(0.78 0.18 35 / 0.5), transparent 60%), radial-gradient(60% 80% at 30% 80%, oklch(0.78 0.17 158 / 0.35), transparent 60%), linear-gradient(135deg, #21100a, #050202); }
.tpl-card .thumb.placeholder.f { background: radial-gradient(60% 80% at 20% 30%, oklch(0.85 0.16 70 / 0.5), transparent 60%), radial-gradient(60% 80% at 80% 80%, oklch(0.6 0.18 295 / 0.4), transparent 60%), linear-gradient(135deg, #1a1408, #0a0503); }
.tpl-card .thumb__tag { position: absolute; top: 12px; left: 12px; padding: 4px 10px; background: rgba(8,12,26,0.78); border: 1px solid var(--stroke-2); border-radius: 999px; font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: oklch(0.85 0.16 70); backdrop-filter: blur(8px); }
.tpl-card__body { padding: 18px 20px 20px; display: flex; flex-direction: column; gap: 8px; }
.tpl-card__body h3 { font-size: 17px; line-height: 1.25; letter-spacing: -0.02em; color: var(--ink-0); margin: 0; }
.tpl-card__body p { font-size: 13px; color: var(--ink-2); line-height: 1.5; margin: 0; }
.tpl-card__meta { display: flex; justify-content: space-between; align-items: center; padding-top: 8px; }
.tpl-card__pages { font-family: var(--f-mono); font-size: 10.5px; color: var(--ink-3); letter-spacing: 0.04em; }
.tpl-card__cta { color: oklch(0.85 0.16 70); font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.04em; }

/* ===== MORE BUILDERS (sibling tiles) ===== */
.mb-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
@media (max-width: 820px) { .mb-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .mb-grid { grid-template-columns: 1fr; } }
.mb-tile { display: flex; align-items: center; gap: 14px; padding: 18px 20px; background: var(--glass-1); border: 1px solid var(--stroke-1); border-radius: var(--r-lg); text-decoration: none; cursor: pointer; transition: border-color .15s, transform .15s, background .15s; }
.mb-tile:hover { border-color: var(--stroke-bright); background: var(--glass-2); transform: translateY(-2px); }
.mb-tile .icb { width: 42px; height: 42px; border-radius: 11px; display: grid; place-items: center; color: white; flex-shrink: 0; }
.mb-tile .icb.real-estate { background: linear-gradient(135deg, oklch(0.7 0.19 256), oklch(0.5 0.19 256)); }
.mb-tile .icb.portfolio { background: linear-gradient(135deg, oklch(0.66 0.21 295), oklch(0.5 0.21 295)); }
.mb-tile .icb.hotel { background: linear-gradient(135deg, oklch(0.85 0.13 205), oklch(0.55 0.13 205)); color: #0a1230; }
.mb-tile .icb.saas { background: linear-gradient(135deg, oklch(0.78 0.17 158), oklch(0.5 0.17 158)); }
.mb-tile .icb.agency { background: linear-gradient(135deg, oklch(0.82 0.16 80), oklch(0.62 0.18 50)); color: #1a0a05; }
.mb-tile .icb.photo { background: linear-gradient(135deg, oklch(0.78 0.18 35), oklch(0.45 0.16 35)); }
.mb-tile .icb svg { width: 20px; height: 20px; stroke: currentColor; fill: none; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.mb-tile .info { min-width: 0; flex: 1; }
.mb-tile .nm { font-size: 15px; font-weight: 600; color: var(--ink-0); letter-spacing: -0.015em; }
.mb-tile .cta { font-family: var(--f-mono); font-size: 11px; color: var(--ink-3); letter-spacing: 0.04em; margin-top: 2px; display: flex; align-items: center; gap: 4px; }
.mb-tile:hover .cta { color: var(--ink-1); }
.mb-tile .arr { color: var(--ink-3); transition: transform .15s, color .15s; }
.mb-tile:hover .arr { color: oklch(0.85 0.16 70); transform: translateX(2px); }

/* ===== FINAL CTA ===== */
.final-cta { padding: 80px 56px; text-align: center; border-radius: var(--r-xl, 32px); position: relative; overflow: hidden; background: radial-gradient(800px 400px at 20% 20%, oklch(0.65 0.21 35 / 0.45), transparent 60%), radial-gradient(700px 350px at 90% 80%, oklch(0.55 0.21 22 / 0.4), transparent 60%), linear-gradient(180deg, #1a0d08, #050202); border: 1px solid oklch(0.78 0.18 35 / 0.3); }
.final-cta::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px); background-size: 48px 48px; mask-image: radial-gradient(ellipse 60% 80% at 50% 50%, black, transparent 70%); }
.final-cta > * { position: relative; z-index: 1; }
.final-cta .h-1 { margin-bottom: 18px; }
.final-cta p { font-size: 18px; color: var(--ink-1); max-width: 560px; margin: 0 auto 32px; }
.final-cta .btn-primary { background: linear-gradient(135deg, oklch(0.78 0.18 35), oklch(0.66 0.21 22)); box-shadow: 0 14px 60px -10px oklch(0.7 0.19 22 / 0.6); }

@media (max-width: 768px) {
  .final-cta { padding: 56px 24px; }
}

/* ═════════════════════════════════════════════════════════════════════════
   [2026-05-18] HOW-TO REDESIGN — multi-layer flow
   3 entry paths (L1) → website (L2) → AI refinement (L3).
   Designed to communicate that the platform is multi-layered, the user
   chooses where AI enters the loop, and token cost is per-request.
   ═════════════════════════════════════════════════════════════════════════ */

/* Flow container */
.flow { display: flex; flex-direction: column; gap: 12px; max-width: 1100px; margin: 0 auto; }

/* One layer */
.flow-layer { position: relative; background: linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0.008)); border: 1px solid var(--stroke-1); border-radius: var(--r-xl, 28px); padding: 36px 36px 40px; overflow: hidden; }
.flow-layer__head { max-width: 720px; margin: 0 auto 28px; text-align: center; }
.flow-layer__head h3 { font-size: 24px; line-height: 1.2; letter-spacing: -0.015em; margin: 10px 0 8px; color: var(--ink-0); font-weight: 600; }
.flow-layer__head p { font-size: 14.5px; color: var(--ink-2); line-height: 1.55; margin: 0; }
.flow-badge { display: inline-block; font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.14em; padding: 4px 10px; border-radius: 999px; border: 1px solid var(--stroke-2); background: var(--glass-2); color: var(--ink-2); }

/* Layer-specific border accents to convey progression. */
.flow-l1 { border-left: 3px solid oklch(0.78 0.18 35 / 0.6); }
.flow-l2 { border-left: 3px solid oklch(0.7 0.19 200 / 0.6); }
.flow-l3 { border-left: 3px solid oklch(0.7 0.21 295 / 0.6); }

/* ───── LAYER 1 — three paths ───── */
.paths { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
@media (max-width: 920px) { .paths { grid-template-columns: 1fr; } }
.path { position: relative; padding: 22px 22px 24px; border-radius: var(--r-lg, 20px); border: 1px solid var(--stroke-1); background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01)); transition: border-color .2s ease, transform .2s ease, background .2s ease; }
.path:hover { border-color: var(--stroke-2); transform: translateY(-2px); }
.path-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.path-ic { display: grid; place-items: center; width: 36px; height: 36px; border-radius: 10px; background: var(--glass-2); border: 1px solid var(--stroke-1); color: var(--ink-0); }
.path-token { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.06em; padding: 4px 9px; border-radius: 999px; }
.path-token--zero { background: oklch(0.7 0.18 158 / 0.14); color: oklch(0.78 0.16 158); border: 1px solid oklch(0.7 0.18 158 / 0.3); }
.path-token--ai { background: oklch(0.78 0.18 35 / 0.16); color: oklch(0.82 0.16 70); border: 1px solid oklch(0.78 0.18 35 / 0.35); }
.path h4 { font-size: 17px; letter-spacing: -0.01em; margin: 0 0 8px; color: var(--ink-0); font-weight: 600; }
.path > p { font-size: 13.5px; color: var(--ink-2); line-height: 1.55; margin: 0 0 16px; }
.path-stats { list-style: none; margin: 0; padding: 12px 0 0; border-top: 1px dashed var(--stroke-1); display: flex; flex-direction: column; gap: 6px; }
.path-stats li { display: flex; justify-content: space-between; font-size: 12.5px; }
.path-stats .lbl { font-family: var(--f-mono); font-size: 10.5px; color: var(--ink-3); letter-spacing: 0.06em; text-transform: uppercase; }
.path-stats .val { color: var(--ink-0); font-weight: 500; }

/* Highlight the AI path subtly so it's visually distinct (it's the "new" capability). */
.path.is-feature { background: linear-gradient(180deg, oklch(0.78 0.18 35 / 0.08), rgba(255,255,255,0.01)); border-color: oklch(0.78 0.18 35 / 0.3); }
.path.is-feature .path-ic { background: oklch(0.78 0.18 35 / 0.12); border-color: oklch(0.78 0.18 35 / 0.3); color: oklch(0.85 0.16 70); }

/* Convergence svg arc */
.flow-converge { margin: 18px auto -8px; max-width: 760px; pointer-events: none; }

/* ───── LAYER 2 — website output card ───── */
.output-card { max-width: 760px; margin: 0 auto; background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.012)); border: 1px solid var(--stroke-2); border-radius: var(--r-lg, 20px); overflow: hidden; box-shadow: 0 24px 60px -20px rgba(0,0,0,0.5); }
.output-card__chrome { display: flex; align-items: center; gap: 12px; padding: 11px 14px; background: rgba(255,255,255,0.03); border-bottom: 1px solid var(--stroke-1); }
.chrome-dots { display: flex; gap: 6px; }
.chrome-dots span { width: 10px; height: 10px; border-radius: 50%; background: rgba(255,255,255,0.18); }
.chrome-url { font-family: var(--f-mono); font-size: 11px; color: var(--ink-2); flex: 1; text-align: center; padding: 4px 10px; background: var(--bg-2, rgba(0,0,0,0.3)); border-radius: 6px; border: 1px solid var(--stroke-1); }
.chrome-lock { display: inline-flex; align-items: center; gap: 4px; font-family: var(--f-mono); font-size: 10px; color: oklch(0.78 0.16 158); letter-spacing: 0.06em; }
.output-card__body { padding: 22px 24px 24px; }
.output-pages { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 20px; }
.pg { font-size: 12.5px; padding: 6px 12px; border-radius: 999px; border: 1px solid var(--stroke-1); background: var(--glass-2); color: var(--ink-1); }
.pg.pg--active { background: oklch(0.78 0.18 35 / 0.16); border-color: oklch(0.78 0.18 35 / 0.4); color: oklch(0.85 0.16 70); }
.output-signals { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; padding-top: 18px; border-top: 1px dashed var(--stroke-1); }
@media (max-width: 600px) { .output-signals { grid-template-columns: 1fr; } }
.signal { display: inline-flex; align-items: center; gap: 8px; font-size: 12.5px; color: var(--ink-1); }
.signal .dot { width: 6px; height: 6px; border-radius: 50%; background: oklch(0.7 0.18 158); flex-shrink: 0; }

/* ───── LAYER 3 — AI refinement chat ───── */
.refine-stream { max-width: 760px; margin: 0 auto; display: flex; flex-direction: column; gap: 16px; }
.refine-msg { padding: 16px 18px; border-radius: 16px; border: 1px solid var(--stroke-1); background: linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0.008)); position: relative; }
.refine-user, .refine-bot { font-size: 13.5px; line-height: 1.55; padding: 10px 14px; border-radius: 10px; position: relative; padding-left: 56px; min-height: 40px; }
.refine-user { background: oklch(0.78 0.18 35 / 0.08); color: var(--ink-0); border: 1px solid oklch(0.78 0.18 35 / 0.18); margin-bottom: 8px; }
.refine-bot { background: oklch(0.7 0.21 295 / 0.08); color: var(--ink-1); border: 1px solid oklch(0.7 0.21 295 / 0.18); }
.refine-who { position: absolute; left: 12px; top: 10px; font-family: var(--f-mono); font-size: 9.5px; letter-spacing: 0.08em; padding: 3px 7px; border-radius: 999px; color: var(--ink-2); background: rgba(0,0,0,0.25); border: 1px solid var(--stroke-1); }
.refine-meta { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 12px; padding-left: 12px; }
.refine-chip { font-family: var(--f-mono); font-size: 10.5px; padding: 4px 9px; border-radius: 999px; background: var(--glass-2); color: var(--ink-2); border: 1px solid var(--stroke-1); letter-spacing: 0.04em; }
.refine-chip--diff { background: oklch(0.7 0.18 158 / 0.12); color: oklch(0.78 0.16 158); border-color: oklch(0.7 0.18 158 / 0.3); }

/* Footnote at end of Layer 3 — drives home the token economy message. */
.flow-footnote { max-width: 760px; margin: 32px auto 0; padding: 18px 22px; background: linear-gradient(180deg, oklch(0.7 0.21 295 / 0.06), transparent); border: 1px solid oklch(0.7 0.21 295 / 0.2); border-radius: 14px; font-size: 13.5px; line-height: 1.6; color: var(--ink-1); }
.flow-footnote strong { color: var(--ink-0); font-weight: 600; }

@media (max-width: 768px) {
  .flow-layer { padding: 28px 22px 32px; }
  .flow-layer__head h3 { font-size: 20px; }
  .output-card__body { padding: 18px 18px 20px; }
}

/* Btn variants used inside design sections (don't conflict with existing .btn-primary in landing.css) */
.sld-section .btn { display: inline-flex; align-items: center; gap: 8px; font-family: var(--f-sans); font-weight: 500; font-size: 14px; padding: 10px 16px; border-radius: var(--r-pill); border: 1px solid var(--stroke-1); background: var(--glass-2); color: var(--ink-0); cursor: pointer; text-decoration: none; transition: all .2s ease; }
.sld-section .btn:hover { background: var(--glass-3); border-color: var(--stroke-2); }
.sld-section .btn-primary { background: var(--grad-primary); color: white; border: 0; font-weight: 600; box-shadow: var(--shadow-glow-blue); }
.sld-section .btn-primary:hover { transform: translateY(-1px); filter: brightness(1.05); }
.sld-section .ic { width: 16px; height: 16px; stroke: currentColor; fill: none; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.sld-section .h-1 { font-size: clamp(36px, 4vw, 56px); line-height: 1.04; letter-spacing: -0.035em; font-weight: 600; }
.sld-section .h-2 { font-size: clamp(28px, 2.6vw, 38px); line-height: 1.1; letter-spacing: -0.03em; font-weight: 600; }
.sld-section .text-grad { background: linear-gradient(180deg, #ffffff 0%, #aab0c8 100%); -webkit-background-clip: text; background-clip: text; color: transparent; }
.sld-section .kicker { font-family: var(--f-mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-2); }
.sld-section .kicker-grad { background: var(--grad-primary); -webkit-background-clip: text; background-clip: text; color: transparent; }
</content>
</invoke>
/* ═════════════════════════════════════════════════════════════════════════
   [2026-06-19] NICHE PAGES — additions for page-templates/solution-niche.php
   (how-it-works steps, sub-niches/verticals grid, SEO prose). Reuses the same
   --glass/--stroke/--ink/--r/--f tokens as the sections above.
   ═════════════════════════════════════════════════════════════════════════ */

/* How it works — numbered steps */
.niche-steps { list-style: none; margin: 0 auto; padding: 0; display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; max-width: 940px; }
@media (max-width: 760px) { .niche-steps { grid-template-columns: 1fr; } }
.niche-step { display: flex; gap: 16px; padding: 24px; background: var(--glass-1); border: 1px solid var(--stroke-1); border-radius: var(--r-lg); }
.niche-step__n { flex: 0 0 auto; width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center; font-family: var(--f-mono); font-size: 14px; color: var(--ink-0); background: var(--glass-3); border: 1px solid var(--stroke-2); }
.niche-step h3 { font-size: 16px; margin: 2px 0 6px; color: var(--ink-0); }
.niche-step p { font-size: 14px; line-height: 1.5; color: var(--ink-1); margin: 0; }

/* Sub-niches (verticals) grid */
.vert-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 14px; }
.vert-card { display: flex; flex-direction: column; gap: 6px; padding: 20px; background: var(--glass-1); border: 1px solid var(--stroke-1); border-radius: var(--r-md); text-decoration: none; transition: border-color .15s, transform .15s, background .15s; }
.vert-card:hover { border-color: var(--stroke-bright); background: var(--glass-2); transform: translateY(-2px); }
.vert-name { font-size: 15px; font-weight: 600; color: var(--ink-0); letter-spacing: -0.01em; }
.vert-blurb { font-size: 13px; line-height: 1.45; color: var(--ink-2); }
.vert-go { margin-top: 6px; font-family: var(--f-mono); font-size: 11px; letter-spacing: 0.04em; color: var(--cyan); opacity: 0; transform: translateX(-4px); transition: opacity .15s, transform .15s; }
.vert-card:hover .vert-go { opacity: 1; transform: translateX(0); }

/* SEO prose body */
.niche-seo-body { border-top: 1px solid var(--stroke-1); }
.niche-prose { max-width: 760px; margin: 0 auto; }
.niche-prose h2 { font-size: 26px; line-height: 1.2; letter-spacing: -0.02em; margin: 36px 0 14px; color: var(--ink-0); }
.niche-prose h2:first-child { margin-top: 0; }
.niche-prose p { font-size: 16px; line-height: 1.65; color: var(--ink-1); margin: 0 0 16px; }
.niche-prose ul { margin: 0 0 16px; padding-left: 20px; }
.niche-prose li { font-size: 15.5px; line-height: 1.6; color: var(--ink-1); margin-bottom: 8px; }
.niche-prose strong { color: var(--ink-0); }

/* Related solutions cross-link row */
.related-links { display: flex; gap: 10px; flex-wrap: wrap; justify-content: center; max-width: 820px; margin: 0 auto; }
.related-links .btn { font-size: 13.5px; }

/* ═════════════════════════════════════════════════════════════════════════
   [2026-06-19] SOLUTIONS HUB + NICHE LIBRARY pages
   ═════════════════════════════════════════════════════════════════════════ */

/* Hub — larger industry solution cards (icon on top) */
.vert-card--lg { gap: 8px; }
.vert-ic { width: 38px; height: 38px; border-radius: 10px; background: var(--glass-3); border: 1px solid var(--stroke-2); display: grid; place-items: center; color: var(--cyan); margin-bottom: 6px; }

/* Library — shorter, text-only hero (no chips/form) */
.sol-hero-fullbleed--short { min-height: 58vh; }

/* Library — search toolbar + colour-coded industry groups.
   [2026-06-20] Redesigned from a flat grid into per-industry groups, each with a
   hue accent (--ind-hue set per group), so 140 niches read as 13 industries. */
.lib-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin: 0 0 30px; flex-wrap: wrap; }
.lib-search { display: flex; align-items: center; gap: 10px; flex: 1; min-width: 260px; padding: 12px 16px; background: var(--glass-2); border: 1px solid var(--stroke-1); border-radius: var(--r-pill, 999px); color: var(--ink-2); }
.lib-search input { flex: 1; background: transparent; border: 0; outline: 0; color: var(--ink-0); font-size: 15px; }
.lib-search input::placeholder { color: var(--ink-3); }
.lib-count { font-family: var(--f-mono); font-size: 12px; color: var(--ink-2); white-space: nowrap; }

/* Industry group block */
.lib-group { margin: 0 0 38px; }
.lib-group[hidden] { display: none; }
.lib-group__head { display: flex; align-items: center; gap: 11px; margin: 0 0 16px; padding-bottom: 11px; border-bottom: 1px solid var(--stroke-1); }
.lib-group__dot { width: 11px; height: 11px; flex: none; border-radius: 50%; background: hsl(var(--ind-hue, 210) 72% 58%); box-shadow: 0 0 14px hsl(var(--ind-hue, 210) 80% 58% / .55); }
.lib-group__name { margin: 0; font-size: 18px; font-weight: 700; color: var(--ink-0); letter-spacing: -0.01em; }
.lib-group__count { margin-left: auto; font-family: var(--f-mono); font-size: 11.5px; color: var(--ink-3); }

.lib-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(190px, 1fr)); gap: 12px; }
.lib-card { position: relative; display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 14px 16px; background: var(--glass-1); border: 1px solid var(--stroke-1); border-left: 2px solid hsl(var(--ind-hue, 210) 60% 52% / .45); border-radius: var(--r-md); text-decoration: none; transition: border-color .15s, transform .15s, background .15s; }
.lib-card:hover { border-color: hsl(var(--ind-hue, 210) 72% 60%); border-left-color: hsl(var(--ind-hue, 210) 72% 60%); background: var(--glass-2); transform: translateY(-2px); }
.lib-card[hidden] { display: none; }
.lib-name { font-size: 14px; font-weight: 600; color: var(--ink-0); letter-spacing: -0.01em; }
.lib-go { font-family: var(--f-mono); font-size: 10px; letter-spacing: 0.03em; white-space: nowrap; color: hsl(var(--ind-hue, 210) 72% 66%); opacity: 0; transform: translateX(-4px); transition: opacity .15s, transform .15s; }
.lib-card:hover .lib-go { opacity: 1; transform: translateX(0); }
.lib-empty { text-align: center; color: var(--ink-2); margin-top: 32px; }

/* Solutions hub — first section sits directly under the nav (hero removed) */
.sld-section--hubtop { padding-top: 140px; }
@media (max-width: 768px) { .sld-section--hubtop { padding-top: 104px; } }
