/* ============================================================
   MORCHEA — home / shared page styles
   ============================================================ */

/* ---- logo mark color variants ---- */
.mark--ink  { color: var(--ink); }
.mark--soft { color: var(--sage-deep); }

/* ============================================================ HERO */
.hero {
  position: relative;
  overflow: hidden;
  padding-block: clamp(76px, 13vw, 168px) clamp(64px, 10vw, 130px);
  background:
    radial-gradient(120% 90% at 50% -10%, #FCFAF4 0%, var(--cream) 55%);
}
.hero-net { position: absolute; inset: 0; width: 100%; height: 100%; z-index: 0; opacity: 1; }
.hero-fade {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: radial-gradient(70% 64% at 50% 44%, transparent 0%, color-mix(in srgb, var(--cream) 28%, transparent) 60%, color-mix(in srgb, var(--cream) 58%, transparent) 100%);
}
.hero-inner { position: relative; z-index: 2; max-width: 920px; text-align: center; display: flex; flex-direction: column; align-items: center; }
.hero .pill { margin-bottom: 30px; }
.hero h1 { margin-bottom: 26px; }
.hero-sub { max-width: 660px; margin-bottom: 38px; }
.hero-cta { display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; }
.hero-meta {
  margin-top: 34px; font-size: 0.92rem; color: var(--ink-3);
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap; justify-content: center;
  max-width: 620px;
}
.hero-meta .phon { color: var(--taupe); font-size: 1.05rem; }
.hero-meta .sep { color: var(--sage-deep); }

/* ============================================================ alt section bg */
.section-pad.alt { background: var(--cream-deep); }

/* ============================================================ POSITIONING */
.pos-grid { margin-top: 8px; }
.pos-card { padding: 4px 2px; }
.pos-ix {
  font-family: var(--mono); font-size: 0.8rem; color: var(--gold-deep);
  display: inline-block; margin-bottom: 16px; letter-spacing: 0.05em;
}
.pos-card h3 { font-size: 1.28rem; margin-bottom: 10px; }
.pos-card p { color: var(--ink-2); font-size: 0.98rem; }
.pos-card { border-top: 1.5px solid var(--line); padding-top: 22px; }

/* ============================================================ STEPS */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.step { text-align: left; }
.step-art {
  width: 84px; height: 84px; border-radius: 20px;
  background: var(--cream-card); border: 1px solid var(--line-soft);
  display: flex; align-items: center; justify-content: center; margin-bottom: 22px;
  box-shadow: var(--shadow-sm);
}
.step-art .ico { width: 50px; height: 50px; }
.step-n { font-family: var(--mono); font-size: 0.74rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold-deep); }
.step h3 { font-size: 1.4rem; margin: 8px 0 12px; }
.step p { color: var(--ink-2); }
.how-foot { margin-top: 52px; display: flex; justify-content: center; }

/* ---- animated process strip ---- */
.process {
  max-width: 940px; margin: 4px auto clamp(48px, 7vw, 76px);
}
.process-stage {
  position: relative; border-radius: var(--radius-lg);
  background: linear-gradient(180deg, var(--cream-card), color-mix(in srgb, var(--sage-tint) 40%, var(--cream-card)));
  border: 1px solid var(--line-soft); box-shadow: var(--shadow);
  aspect-ratio: 24 / 9; overflow: hidden;
}
.process-canvas { width: 100%; height: 100%; display: block; }
.process-legend {
  position: absolute; top: 14px; right: 16px; display: flex; gap: 14px;
  font-family: var(--mono); font-size: 0.64rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink-3);
}
.process-legend .leg { display: inline-flex; align-items: center; gap: 6px; }
.process-legend .ld { width: 7px; height: 7px; border-radius: 50%; }
.process-legend .ld.sig  { background: var(--gold); }
.process-legend .ld.fib  { background: var(--sage-deep); }
.process-legend .ld.burn { background: var(--gold-deep); box-shadow: 0 0 0 2px color-mix(in srgb, var(--gold) 35%, transparent); }
.process-legend .ld.ver  { background: #6fae7e; }
.process-rail {
  display: flex; justify-content: center; flex-wrap: wrap; gap: 8px 6px; margin-top: 22px;
}
.process-rail span {
  position: relative; font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--ink-3); padding: 6px 14px; border-radius: 999px;
  border: 1px solid transparent; transition: color .35s var(--ease), background .35s var(--ease), border-color .35s var(--ease);
}
.process-rail span.on { color: var(--gold-deep); background: color-mix(in srgb, var(--gold) 14%, var(--cream-card)); border-color: color-mix(in srgb, var(--gold-deep) 32%, transparent); }
.process-desc {
  text-align: center; margin-top: 16px; color: var(--ink-2); font-size: 1.02rem; min-height: 1.6em;
  max-width: 560px; margin-inline: auto;
}
.process-desc .pc-term { color: var(--gold-deep); font-weight: 600; }
@media (max-width: 700px) {
  .process-stage { aspect-ratio: 16 / 11; }
  .process-legend { font-size: 0.58rem; gap: 9px; top: 10px; right: 11px; }
  .process-rail span { font-size: 0.64rem; padding: 5px 10px; }
}

/* ============================================================ COLONY */
.colony-grid { margin-top: 8px; }
.colony-card { display: flex; flex-direction: column; }
.seat-glyph {
  position: relative; width: 50px; height: 50px; border-radius: 14px;
  background: var(--sage-tint); border: 1px solid color-mix(in srgb, var(--sage-deep) 38%, transparent);
  margin-bottom: 20px; flex: none; display: grid; place-items: center;
}
.seat-glyph svg { width: 27px; height: 27px; }
.seat-glyph[data-seat="conductor"] { background: color-mix(in srgb, var(--gold) 20%, var(--cream-card)); border-color: color-mix(in srgb, var(--gold-deep) 45%, transparent); }
.seat-name { font-size: 1.32rem; margin-bottom: 3px; }
.seat-role { font-size: 0.82rem; font-weight: 600; letter-spacing: 0.04em; color: var(--gold-deep); text-transform: uppercase; margin-bottom: 12px; }
.colony-card p { color: var(--ink-2); font-size: 0.97rem; margin-top: auto; }
.colony-note { text-align: center; max-width: 620px; margin: 44px auto 0; color: var(--ink-3); font-size: 1.02rem; }

/* featured Maestro */
.maestro-card {
  display: grid; grid-template-columns: auto 1fr; gap: 28px; align-items: center;
  background: linear-gradient(118deg, color-mix(in srgb, var(--gold) 10%, var(--cream-card)), var(--cream-card) 52%);
  border: 1px solid var(--cream-line); border-radius: var(--radius-lg);
  padding: 30px 36px; margin-bottom: 24px; box-shadow: var(--shadow-sm);
}
.maestro-body .seat-role { margin-bottom: 5px; }
.maestro-body .seat-name { font-size: 1.7rem; margin-bottom: 8px; }
.maestro-body p { color: var(--ink-2); font-size: 1.02rem; max-width: 62ch; }
.seat-glyph.lg { width: 66px; height: 66px; border-radius: 18px; }
.seat-glyph.lg svg { width: 36px; height: 36px; }

/* compact specialist cards */
.seat-card {
  background: var(--cream-card); border: 1px solid var(--line-soft); border-radius: var(--radius);
  padding: 22px; box-shadow: var(--shadow-sm);
  transition: transform .22s var(--ease), box-shadow .22s var(--ease), border-color .22s var(--ease);
}
.seat-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); border-color: var(--line); }
.seat-card .seat-glyph { width: 42px; height: 42px; border-radius: 12px; margin-bottom: 15px; }
.seat-card .seat-glyph svg { width: 23px; height: 23px; }
.seat-card .seat-name { font-size: 1.12rem; margin-bottom: 2px; }
.seat-card .seat-role { font-size: 0.7rem; margin-bottom: 9px; }
.seat-card p { color: var(--ink-3); font-size: 0.88rem; margin: 0; }
@media (max-width: 560px) {
  .maestro-card { grid-template-columns: 1fr; gap: 18px; padding: 26px 24px; }
}

/* ============================================================ ENGINE (DARK) */
.engine {
  position: relative; overflow: hidden;
  background: var(--dark); color: var(--dark-text);
  padding-block: clamp(80px, 12vw, 150px);
}
.engine::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(90% 70% at 70% 30%, rgba(200,155,75,0.10), transparent 60%);
  pointer-events: none;
}
.engine-net { position: absolute; inset: 0; width: 100%; height: 100%; opacity: 0.5; z-index: 0; }
.engine-inner { position: relative; z-index: 2; }
.engine h2, .engine .h2 { color: var(--dark-text); }
.engine .lead { color: var(--dark-muted); }
.engine .eyebrow-mono { color: var(--gold); }
.engine-grid { display: grid; grid-template-columns: 1.15fr 0.85fr; gap: 56px; align-items: start; margin-top: 8px; }
.engine-points { display: flex; flex-direction: column; gap: 34px; }
.epoint { padding-left: 22px; border-left: 2px solid var(--dark-line); }
.epoint h3 { color: var(--dark-text); font-size: 1.3rem; margin-bottom: 8px; }
.epoint p { color: var(--dark-muted); }

/* signal panel */
.signal-panel {
  background: rgba(255,255,255,0.035); border: 1px solid var(--dark-line);
  border-radius: var(--radius-lg); padding: 22px; backdrop-filter: blur(6px);
}
.sp-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.sp-title { font-family: var(--mono); font-size: 0.82rem; letter-spacing: 0.08em; color: var(--dark-text); text-transform: uppercase; }
.sp-live { background: rgba(255,255,255,0.04); border-color: var(--dark-line); color: var(--dark-muted); padding: 4px 10px; }
.sp-log { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 11px; font-family: var(--mono); font-size: 0.78rem; }
.sp-log li { color: var(--dark-text); display: flex; gap: 9px; align-items: baseline; flex-wrap: wrap; }
.sp-t { color: var(--dark-muted); }
.sp-tag { padding: 1px 8px; border-radius: 6px; font-size: 0.7rem; letter-spacing: 0.04em; }
.sp-tag.scout { background: rgba(184,201,179,0.18); color: var(--sage); }
.sp-tag.forge { background: rgba(184,201,179,0.18); color: var(--sage); }
.sp-tag.burn  { background: rgba(200,155,75,0.2); color: var(--gold); }
.sp-tag.sentinel { background: rgba(184,201,179,0.18); color: var(--sage); }
.sp-tag.toll  { background: rgba(200,155,75,0.2); color: var(--gold); }
.sp-foot { margin-top: 18px; padding-top: 16px; border-top: 1px solid var(--dark-line); font-family: var(--mono); font-size: 0.76rem; color: var(--dark-muted); display: flex; flex-direction: column; gap: 8px; }
.sp-foot strong { color: var(--dark-text); font-weight: 500; }
.sp-bar { height: 5px; border-radius: 99px; background: rgba(255,255,255,0.08); display: block; overflow: hidden; }
.sp-bar i { display: block; height: 100%; background: var(--gold); border-radius: 99px; }

/* ============================================================ MEMORY */
.memory-inner { display: grid; grid-template-columns: 1fr 0.9fr; gap: 60px; align-items: center; }
.memory-copy .eyebrow { display: block; margin-bottom: 16px; }
.memory-copy .lead { margin-top: 18px; }
.voice { margin-top: 24px; font-size: 1.35rem; color: var(--green); line-height: 1.4; }
.mem-stack { display: flex; flex-wrap: wrap; gap: 12px; }
.mem-chip {
  padding: 11px 18px; border-radius: 999px; background: var(--cream-card);
  border: 1px solid var(--line); color: var(--ink-2); font-size: 0.95rem; font-weight: 500;
  box-shadow: var(--shadow-sm);
}
.mem-chip:nth-child(2) { background: var(--sage-tint); border-color: transparent; }
.mem-chip:nth-child(4) { background: var(--sage-tint); border-color: transparent; }

/* ============================================================ CTA BAND
   (.cta-band / .cta-inner / .cta-mark and footer extras now live in styles.css
    so every page — including pricing & how-it-works — shares them.) */

/* ============================================================ RESPONSIVE */
@media (max-width: 960px) {
  .engine-grid { grid-template-columns: 1fr; gap: 40px; }
  .memory-inner { grid-template-columns: 1fr; gap: 36px; }
}
@media (max-width: 900px) {
  .pos-grid { grid-template-columns: 1fr 1fr; gap: 28px 30px; }
  .steps { grid-template-columns: 1fr; gap: 38px; max-width: 480px; margin-inline: auto; }
  .colony-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .pos-grid { grid-template-columns: 1fr; }
  .colony-grid { grid-template-columns: 1fr; }
  .hero-cta .btn { width: 100%; }
}
