/* ============================================================
   Salasel Babel — inner-page components
   Loaded after styles.css on every page except Home.
   ============================================================ */

/* active nav */
.nav-list [data-nav].active { opacity: 1; }
.nav-list [data-nav].active::after,
.nav-item.has-mega [data-nav].active::after { content: ""; }
.site-header .nav-list a.active { color: var(--brass-200); }
.site-header.is-scrolled .nav-list a.active { color: var(--lapis-700); }

/* ---------- PAGE HERO (shorter than home hero) ---------- */
.page-hero {
  position: relative; background: var(--lapis-900); color: var(--limestone-50);
  padding-block: calc(var(--header-h) + clamp(48px, 6vw, 84px)) clamp(48px, 6vw, 84px);
  overflow: hidden;
}
.page-hero .hero-glow { position: absolute; inset-block-start: -40%; inset-inline-end: -10%; width: 55%; height: 130%;
  background: radial-gradient(closest-side, rgba(46,111,176,.4), transparent 70%); }
.page-hero-inner { position: relative; z-index: 1; }
.page-hero.split .page-hero-inner { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(32px,5vw,72px); align-items: center; }
.page-hero h1 { font-size: clamp(2rem, 4.4vw, 3.1rem); margin-bottom: 20px; max-width: 18ch; }
.page-hero h1 .hl { color: var(--brass-200); }
.page-hero .ph-sub { font-size: 1.15rem; color: #D6DEEA; max-width: 46ch; margin-bottom: 28px; }
.page-hero .hero-ctas { display: flex; flex-wrap: wrap; gap: 14px; }

/* breadcrumb */
.breadcrumb { display: flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: .08em; color: var(--lapis-400); margin-bottom: 22px; }
.breadcrumb a { color: var(--lapis-400); }
.breadcrumb a:hover { color: var(--brass-200); }
.breadcrumb .sep { opacity: .5; }
.breadcrumb .current { color: var(--limestone-100); }

/* section variants */
.section.alt { background: var(--limestone-50); }
.section.dark { background: var(--lapis-900); color: var(--limestone-50); }
.section.dark .section-head h2 { color: var(--limestone-50); }
.section-head.center { margin-inline: auto; text-align: center; }
.section-head.center .eyebrow { justify-content: center; }

/* ---------- PROSE / narrative ---------- */
.prose { max-width: 70ch; }
.prose p { color: var(--ink-600); margin-bottom: 18px; font-size: 1.08rem; }
.prose p.big { font-family: var(--font-display); font-size: clamp(1.3rem,2.4vw,1.7rem); color: var(--ink-900); line-height: 1.5; }
.on-dark .prose p { color: var(--lapis-400); }
.on-dark .prose p.big { color: var(--limestone-50); }

/* two-column */
.two-col { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px,5vw,72px); align-items: center; }
.two-col.narrow-right { grid-template-columns: 1.2fr 0.8fr; }

/* ---------- FEATURE / DETAIL ROWS (modules, system) ---------- */
.feature-row { display: grid; grid-template-columns: 64px 1fr; gap: 22px; padding: 30px 0; border-top: 1px solid var(--limestone-200); }
.feature-row:first-child { border-top: none; }
.feature-ico { width: 56px; height: 56px; border-radius: 12px; background: var(--limestone-50); color: var(--lapis-600); display: flex; align-items: center; justify-content: center; }
.feature-ico .icon { width: 28px; height: 28px; }
.feature-row h3 { font-size: 1.3rem; margin-bottom: 8px; display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.feature-row .spec { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: .08em; color: var(--brass-600); background: #FBF4DF; padding: 3px 8px; border-radius: 4px; }
.feature-row > div > p { color: var(--ink-600); margin-bottom: 14px; max-width: 70ch; }
.cap-list { display: flex; flex-wrap: wrap; gap: 8px; }
.cap-list span { font-size: 0.84rem; color: var(--ink-600); background: var(--limestone-50); border: 1px solid var(--limestone-200); padding: 6px 12px; border-radius: 999px; }
.human-gate { display: inline-flex; align-items: center; gap: 7px; margin-top: 12px; font-size: 0.84rem; color: var(--brass-600); font-weight: 600; }
.human-gate .icon { width: 16px; height: 16px; }

/* feature grid (cards) */
.feature-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.feature-card { padding: 28px 26px; border-radius: var(--radius-card); background: var(--white); border: 1px solid var(--limestone-200); }
.section.alt .feature-card { background: var(--white); }
.feature-card .fc-ico { width: 46px; height: 46px; border-radius: 11px; background: var(--limestone-50); color: var(--lapis-600); display: flex; align-items: center; justify-content: center; margin-bottom: 18px; }
.feature-card .fc-ico .icon { width: 24px; height: 24px; }
.feature-card h3 { font-size: 1.18rem; margin-bottom: 9px; }
.feature-card p { color: var(--ink-600); font-size: 0.95rem; line-height: 1.6; }
.section.dark .feature-card { background: rgba(255,255,255,.04); border-color: rgba(111,160,208,.18); color: var(--limestone-50); }
.section.dark .feature-card .fc-ico { background: rgba(255,255,255,.06); color: var(--brass-200); }
.section.dark .feature-card p { color: var(--lapis-400); }

/* ---------- STEP FLOW (client journeys) ---------- */
.flow { display: grid; gap: 12px; counter-reset: step; }
.flow-step { display: grid; grid-template-columns: 44px 1fr; gap: 16px; align-items: start; padding: 16px 20px; background: var(--white); border: 1px solid var(--limestone-200); border-radius: 10px; }
.section.alt .flow-step { background: var(--white); }
.flow-step .num { width: 40px; height: 40px; border-radius: 50%; background: var(--lapis-600); color: #fff; font-family: var(--font-mono); font-size: 0.85rem; display: flex; align-items: center; justify-content: center; }
.flow-step.is-human .num { background: var(--brass-500); color: #2A2207; }
.flow-step h4 { font-family: var(--font-display); font-size: 1.05rem; margin-bottom: 3px; }
.flow-step p { color: var(--ink-600); font-size: 0.9rem; }

/* ---------- DATA TABLE (alert timing) -> responsive ---------- */
.data-table { width: 100%; border-collapse: collapse; font-size: 0.95rem; }
.data-table th, .data-table td { padding: 14px 18px; text-align: start; border-bottom: 1px solid var(--limestone-200); }
.data-table thead th { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: .1em; text-transform: uppercase; color: var(--brass-600); }
.data-table td:first-child { font-weight: 600; }
.data-table .mono { font-family: var(--font-mono); color: var(--lapis-600); font-size: 0.88rem; }

/* ---------- PRINCIPLES ---------- */
.principle-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.principle { padding: 26px 22px; border-radius: var(--radius-card); border: 1px solid var(--limestone-200); background: var(--white); }
.principle .icon { width: 30px; height: 30px; color: var(--lapis-600); margin-bottom: 16px; }
.principle h4 { font-family: var(--font-display); font-size: 1.1rem; margin-bottom: 7px; }
.principle p { color: var(--ink-600); font-size: 0.9rem; line-height: 1.55; }

/* ---------- TIMELINE ---------- */
.timeline { position: relative; display: grid; gap: 4px; padding-inline-start: 30px; }
.timeline::before { content: ""; position: absolute; inset-block: 8px; inset-inline-start: 5px; width: 2px; background: var(--limestone-200); }
.tl-item { position: relative; padding: 14px 0 22px; }
.tl-item::before { content: ""; position: absolute; inset-inline-start: -30px; inset-block-start: 20px; width: 12px; height: 12px; border-radius: 50%; background: var(--lapis-600); box-shadow: 0 0 0 4px var(--limestone-50); }
.tl-item.gold::before { background: var(--brass-500); }
.tl-item .yr { font-family: var(--font-mono); font-size: 0.78rem; color: var(--brass-600); letter-spacing: .06em; }
.tl-item h4 { font-family: var(--font-display); font-size: 1.15rem; margin: 4px 0 6px; }
.tl-item p { color: var(--ink-600); font-size: 0.95rem; max-width: 60ch; }

/* ---------- FORMS ---------- */
.form-card { background: var(--white); border: 1px solid var(--limestone-200); border-radius: var(--radius-card); padding: clamp(24px, 4vw, 40px); box-shadow: 0 30px 70px -44px rgba(15,42,82,.4); }
.site-form { display: grid; gap: 18px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.field { display: flex; flex-direction: column; gap: 7px; }
.field > label { font-size: 0.88rem; font-weight: 600; color: var(--ink-900); }
.field > label .req { color: var(--clay-500); }
.field input, .field select, .field textarea {
  font-family: var(--font-body); font-size: 1rem; color: var(--ink-900);
  padding: 13px 15px; border: 1px solid var(--limestone-200); border-radius: var(--radius);
  background: var(--limestone-50); transition: border-color .2s, background .2s;
}
.field textarea { resize: vertical; min-height: 120px; }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--lapis-600); background: var(--white); }
.field input::placeholder, .field textarea::placeholder { color: var(--ink-400); }
.field .field-error { display: none; font-size: 0.8rem; color: var(--clay-500); }
.field.has-error input, .field.has-error select, .field.has-error textarea { border-color: var(--clay-500); background: #FBEEE6; }
.field.has-error .field-error { display: block; }
.field-check { flex-direction: row; align-items: flex-start; gap: 11px; }
.field-check input { width: 20px; height: 20px; margin-top: 2px; accent-color: var(--lapis-600); flex: none; padding: 0; }
.field-check label { font-weight: 400; font-size: 0.9rem; color: var(--ink-600); }
.form-note { font-size: 0.82rem; color: var(--ink-400); display: flex; align-items: center; gap: 8px; }
.form-note .icon { width: 15px; height: 15px; color: var(--lapis-600); }
.form-success { display: flex; flex-direction: column; align-items: center; text-align: center; gap: 16px; padding: clamp(32px,5vw,56px); background: var(--white); border: 1px solid var(--limestone-200); border-radius: var(--radius-card); }
.form-success .icon { width: 30px; height: 30px; color: #fff; background: var(--brass-500); border-radius: 50%; padding: 7px; box-sizing: content-box; }
.form-success p { font-family: var(--font-display); font-size: 1.3rem; color: var(--ink-900); max-width: 24ch; }

/* options grid (multi-select chips) */
.chip-select { display: flex; flex-wrap: wrap; gap: 9px; }
.chip-select label { display: inline-flex; align-items: center; gap: 8px; padding: 9px 15px; border: 1px solid var(--limestone-200); border-radius: 999px; font-size: 0.88rem; cursor: pointer; transition: all .18s; background: var(--limestone-50); }
.chip-select input { display: none; }
.chip-select label:has(input:checked) { border-color: var(--lapis-600); background: rgba(46,111,176,.1); color: var(--lapis-700); font-weight: 600; }

/* contact details list */
.contact-list { display: grid; gap: 8px; margin-top: 8px; }
.contact-list a, .contact-list span.ci { display: flex; align-items: center; gap: 14px; padding: 14px 0; border-bottom: 1px solid var(--limestone-200); color: var(--ink-900); }
.contact-list .icon { width: 22px; height: 22px; color: var(--lapis-600); flex: none; }
.contact-list b { display: block; font-size: 0.78rem; font-weight: 600; color: var(--ink-400); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 2px; }
.on-dark .contact-list a, .on-dark .contact-list span.ci { color: var(--limestone-50); border-color: rgba(111,160,208,.2); }
.on-dark .contact-list .icon { color: var(--brass-200); }
.on-dark .contact-list b { color: var(--lapis-400); }

/* "what to expect" list (demo) */
.expect-list { display: grid; gap: 18px; }
.expect-item { display: grid; grid-template-columns: 40px 1fr; gap: 16px; align-items: start; }
.expect-item .icon { width: 26px; height: 26px; color: var(--brass-200); margin-top: 2px; }
.expect-item h4 { font-family: var(--font-display); font-size: 1.1rem; margin-bottom: 4px; }
.expect-item p { color: var(--lapis-400); font-size: 0.95rem; }

/* ---------- PRICING ---------- */
.billing-switch { display: inline-flex; align-items: center; gap: 14px; margin: 0 auto 44px; padding: 8px 8px; }
.billing-switch span { font-size: 0.95rem; font-weight: 600; color: var(--ink-400); transition: color .2s; }
.billing-switch span.on { color: var(--ink-900); }
.switch { position: relative; width: 52px; height: 28px; flex: none; }
.switch input { opacity: 0; width: 0; height: 0; }
.switch .track { position: absolute; inset: 0; background: var(--lapis-600); border-radius: 999px; cursor: pointer; transition: background .2s; }
.switch .track::before { content: ""; position: absolute; inset-block-start: 3px; inset-inline-start: 3px; width: 22px; height: 22px; background: #fff; border-radius: 50%; transition: transform .2s; }
.switch input:checked + .track::before { transform: translateX(24px); }
html[dir="rtl"] .switch input:checked + .track::before { transform: translateX(-24px); }
.save-badge { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: .06em; color: var(--brass-600); background: #FBF4DF; padding: 4px 9px; border-radius: 4px; }

.pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; align-items: stretch; }
.price-card { display: flex; flex-direction: column; padding: 34px 30px; border-radius: var(--radius-card); background: var(--white); border: 1px solid var(--limestone-200); }
.price-card.featured { border-color: var(--lapis-600); box-shadow: 0 30px 70px -40px rgba(46,111,176,.5); position: relative; }
.price-card .tier { font-family: var(--font-display); font-size: 1.3rem; margin-bottom: 6px; }
.price-card .tier-desc { color: var(--ink-600); font-size: 0.9rem; margin-bottom: 22px; min-height: 2.8em; }
.price-card .price { font-family: var(--font-display); font-size: 2.6rem; color: var(--ink-900); line-height: 1; unicode-bidi: plaintext; }
.price-card .price small { font-family: var(--font-body); font-size: 0.9rem; color: var(--ink-400); font-weight: 400; }
.price-card .price-note { font-size: 0.82rem; color: var(--ink-400); margin-top: 8px; min-height: 1.2em; }
.price-card .btn { margin: 24px 0; }
.price-card ul { list-style: none; display: grid; gap: 11px; }
.price-card li { display: flex; align-items: flex-start; gap: 10px; font-size: 0.92rem; color: var(--ink-600); }
.price-card li .icon { width: 17px; height: 17px; color: var(--lapis-600); flex: none; margin-top: 3px; }
.price-card .featured-tag { position: absolute; inset-block-start: -12px; inset-inline-start: 30px; white-space: nowrap; font-family: var(--font-mono); font-size: 0.64rem; letter-spacing: .1em; text-transform: uppercase; color: #2A2207; background: var(--brass-500); padding: 5px 12px; border-radius: 4px; }
.addon-note { margin-top: 28px; padding: 20px 24px; background: var(--limestone-50); border: 1px solid var(--limestone-200); border-radius: 10px; font-size: 0.92rem; color: var(--ink-600); display: flex; gap: 14px; align-items: flex-start; }
.addon-note .icon { width: 20px; height: 20px; color: var(--brass-600); flex: none; margin-top: 2px; }

/* ---------- ACCORDION (instant; robust in all render contexts) ---------- */
.accordion { max-width: 820px; margin-inline: auto; }
.acc-item { border-bottom: 1px solid var(--limestone-200); }
.acc-head { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 22px 4px; text-align: start; font-family: var(--font-display); font-size: 1.12rem; color: var(--ink-900); }
.acc-head .pm { width: 22px; height: 22px; flex: none; position: relative; color: var(--lapis-600); }
.acc-head .pm::before, .acc-head .pm::after { content: ""; position: absolute; inset-inline-start: 3px; inset-block-start: 10px; width: 16px; height: 2px; background: currentColor; border-radius: 2px; }
.acc-head .pm::after { transform: rotate(90deg); transition: opacity .2s; }
.acc-item.open .acc-head .pm::after { opacity: 0; }
.acc-body { height: 0; overflow: hidden; }
.acc-item.open .acc-body { height: auto; }
.acc-body p { padding: 0 4px 24px; color: var(--ink-600); max-width: 68ch; line-height: 1.7; }
.acc-group-label { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: .12em; text-transform: uppercase; color: var(--brass-600); margin: 40px 0 6px; }
.acc-group-label:first-child { margin-top: 0; }

/* ---------- ARTICLE / RESOURCE CARDS ---------- */
.article-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.article-card { display: flex; flex-direction: column; border-radius: var(--radius-card); overflow: hidden; background: var(--white); border: 1px solid var(--limestone-200); transition: transform .22s var(--ease), box-shadow .25s var(--ease); }
.article-card:hover { transform: translateY(-4px); box-shadow: 0 26px 50px -32px rgba(15,42,82,.4); }
.article-thumb { aspect-ratio: 16/9; background: repeating-linear-gradient(135deg, rgba(46,111,176,.09) 0 10px, rgba(46,111,176,.03) 10px 20px), var(--limestone-50); display: flex; align-items: center; justify-content: center; }
.article-thumb .icon { width: 34px; height: 34px; color: var(--lapis-400); }
.article-body { padding: 22px 22px 24px; display: flex; flex-direction: column; flex: 1; }
.article-tag { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: .08em; text-transform: uppercase; color: var(--brass-600); margin-bottom: 10px; }
.article-card h3 { font-size: 1.12rem; margin-bottom: 8px; line-height: 1.35; }
.article-card p { color: var(--ink-600); font-size: 0.9rem; margin-bottom: 16px; }
.article-card .read { margin-top: auto; font-size: 0.86rem; font-weight: 600; color: var(--lapis-600); }

/* gated download band */
.download-band { display: grid; grid-template-columns: 1fr auto; gap: 28px; align-items: center; padding: clamp(28px,4vw,44px); border-radius: var(--radius-card); background: var(--lapis-900); color: var(--limestone-50); }
.download-band h3 { font-size: clamp(1.3rem,2.4vw,1.8rem); margin-bottom: 10px; }
.download-band p { color: var(--lapis-400); max-width: 52ch; }
.download-form { display: flex; gap: 10px; }
.download-form input { padding: 13px 15px; border-radius: var(--radius); border: 1px solid rgba(111,160,208,.3); background: rgba(255,255,255,.05); color: #fff; min-width: 220px; }
.download-form input::placeholder { color: var(--lapis-400); }

/* legal / doc layout */
.doc-layout { display: grid; grid-template-columns: 240px 1fr; gap: clamp(32px,5vw,72px); align-items: start; }
.doc-toc { position: sticky; top: calc(var(--header-h) + 24px); display: grid; gap: 8px; font-size: 0.9rem; }
.doc-toc a { color: var(--ink-600); padding: 5px 0; }
.doc-toc a:hover { color: var(--lapis-600); }
.doc-body h2 { font-size: 1.5rem; margin: 38px 0 14px; }
.doc-body h2:first-child { margin-top: 0; }
.doc-body p { color: var(--ink-600); margin-bottom: 14px; line-height: 1.75; max-width: 72ch; }
.doc-body ul { margin: 0 0 14px; padding-inline-start: 22px; color: var(--ink-600); }
.doc-body li { margin-bottom: 7px; }
.doc-note { padding: 16px 20px; background: var(--limestone-50); border-inline-start: 3px solid var(--brass-500); border-radius: 6px; font-size: 0.9rem; color: var(--ink-600); margin-bottom: 20px; }

/* CTA reuse on inner pages */
.inline-cta { text-align: center; max-width: 620px; margin-inline: auto; }
.inline-cta h2 { font-size: clamp(1.6rem,3vw,2.4rem); margin-bottom: 14px; }
.inline-cta p { color: var(--lapis-400); margin-bottom: 28px; font-size: 1.05rem; }
.section.dark .inline-cta .cta-actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* ---------- RESPONSIVE ---------- */
@media (max-width: 1024px) {
  .page-hero.split .page-hero-inner { grid-template-columns: 1fr; }
  .feature-grid, .article-grid, .pricing-grid { grid-template-columns: repeat(2, 1fr); }
  .principle-grid { grid-template-columns: repeat(2, 1fr); }
  .two-col { grid-template-columns: 1fr; }
  .doc-layout { grid-template-columns: 1fr; }
  .doc-toc { position: static; }
}
@media (max-width: 760px) {
  .feature-grid, .article-grid, .pricing-grid, .principle-grid { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .feature-row { grid-template-columns: 1fr; gap: 14px; }
  .download-band { grid-template-columns: 1fr; }
  .download-form { flex-direction: column; }
  .data-table thead { display: none; }
  .data-table, .data-table tbody, .data-table tr, .data-table td { display: block; width: 100%; }
  .data-table tr { border: 1px solid var(--limestone-200); border-radius: 8px; margin-bottom: 12px; padding: 6px 10px; }
  .data-table td { border: none; padding: 7px 8px; }
  .data-table td::before { content: attr(data-label); display: block; font-family: var(--font-mono); font-size: 0.66rem; text-transform: uppercase; color: var(--brass-600); margin-bottom: 2px; }
}
