/* ============================================================
   SCG — Service / inner pages (Nocturne)
   Loads after tokens.css + site.css + themes.css; pages use data-dir="d"
   ============================================================ */

.spage { padding-top: 0; }

/* ---- Service hero ---- */
.svc-hero { position: relative; padding: clamp(54px, 8vw, 104px) 0 clamp(40px, 5vw, 64px); border-bottom: 1px solid var(--line); overflow: hidden; }
.svc-hero__frame { position: relative; }
.svc-hero__frame::before, .svc-hero__frame::after { content: ""; position: absolute; top: -20px; bottom: -40px; width: 1px; background: var(--line); }
.svc-hero__frame::before { left: 0; }
.svc-hero__frame::after { right: 0; }
.svc-hero__mark { position: absolute; right: 2vw; top: 50%; transform: translateY(-50%); font-family: var(--font-display); font-weight: 300; font-size: clamp(150px, 24vw, 360px); line-height: 0.7; color: var(--ink); opacity: 0.04; pointer-events: none; letter-spacing: -0.05em; }
.svc-hero h1 { font-family: var(--font-display); font-weight: 300; font-size: clamp(40px, 6.4vw, 92px); line-height: 1; letter-spacing: -0.025em; margin-top: 22px; max-width: 16ch; }
.svc-hero h1 em { font-style: italic; color: var(--accent); }
.svc-hero__sub { margin-top: 26px; max-width: 52ch; font-size: clamp(17px, 1.7vw, 21px); color: var(--ink-soft); }
.svc-hero__row { display: flex; align-items: center; gap: 22px; margin-top: 34px; flex-wrap: wrap; }
.price-chip { display: inline-flex; align-items: baseline; gap: 7px; font-family: var(--font-mono); font-size: 13px; letter-spacing: 0.04em; color: var(--accent); border: 1px solid var(--copper-wash-2); background: var(--copper-wash); padding: 9px 15px; border-radius: 100px; }
.price-chip b { font-family: var(--font-display); font-size: 19px; font-weight: 400; }

/* ---- Section heading reuse via .shead (site.css). Extra: ---- */
.svc-block { padding: clamp(56px, 8vw, 104px) 0; }
.svc-block + .svc-block { border-top: 1px solid var(--line); }

/* ---- Features ---- */
.feat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(20px, 3vw, 36px); margin-top: clamp(36px, 5vw, 56px); }
.featcard { padding-top: 24px; border-top: 1px solid var(--ink); }
.featcard__i { font-family: var(--font-mono); font-size: 12px; color: var(--accent); }
.featcard h3 { font-size: 21px; margin-top: 12px; }
.featcard p { margin-top: 12px; color: var(--ink-soft); font-size: 15px; }

/* ---- Pricing tiers ---- */
.tiers { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: clamp(36px, 5vw, 56px); align-items: start; }
.tier { background: var(--white); border: 1px solid var(--line); border-radius: 10px; padding: 30px 26px; display: flex; flex-direction: column; gap: 6px; position: relative; }
.tier--feat { border-color: var(--accent); box-shadow: 0 30px 60px -36px rgba(0,0,0,0.7); }
.tier--single { grid-column: 1 / -1; display: grid; grid-template-columns: 1fr 1.2fr; gap: 36px; align-items: center; }
.tier__badge { position: absolute; top: -11px; left: 26px; background: var(--accent); color: #14110b; font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; padding: 4px 11px; border-radius: 100px; }
.tier__name { font-family: var(--font-display); font-size: 25px; }
.tier__price { font-family: var(--font-display); font-size: clamp(34px, 4vw, 46px); line-height: 1; margin: 8px 0; color: var(--accent); }
.tier__price small { font-family: var(--font-mono); font-size: 14px; color: var(--ink-soft); margin-left: 4px; }
.tier__tagline { font-size: 14px; color: var(--ink-soft); margin-bottom: 8px; }
.tier__list { list-style: none; margin: 14px 0 0; padding: 16px 0 0; border-top: 1px solid var(--line); display: flex; flex-direction: column; gap: 10px; }
.tier__list li { font-size: 14px; padding-left: 20px; position: relative; }
.tier__list li::before { content: "→"; position: absolute; left: 0; color: var(--accent); }
.tier__cta { margin-top: 20px; }
.tier__note { display: block; margin-top: 10px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.04em; color: var(--ink-soft); text-align: center; }
.tier-callout { margin-top: 22px; font-size: 15px; color: var(--ink-soft); }
.tier-callout a { color: var(--accent); border-bottom: 1px solid var(--copper-wash-2); padding-bottom: 1px; }

/* ---- FAQ ---- */
.faqs { margin-top: clamp(32px, 4vw, 48px); border-top: 1px solid var(--line); max-width: 860px; }
.faq { border-bottom: 1px solid var(--line); }
.faq summary { list-style: none; cursor: pointer; padding: 22px 0; display: flex; justify-content: space-between; align-items: center; gap: 20px; font-family: var(--font-display); font-size: clamp(18px, 2vw, 23px); font-weight: 400; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; font-family: var(--font-body); font-size: 24px; color: var(--accent); transition: transform 0.3s var(--ease); flex: 0 0 auto; }
.faq[open] summary::after { transform: rotate(45deg); }
.faq__a { padding: 0 0 22px; color: var(--ink-soft); font-size: 16px; max-width: 62ch; }

/* ---- CTA band ---- */
.svc-cta { padding: clamp(64px, 9vw, 120px) 0; border-top: 1px solid var(--line); text-align: center; }
.svc-cta h2 { font-family: var(--font-display); font-weight: 300; font-size: clamp(32px, 5vw, 60px); line-height: 1.04; max-width: 18ch; margin: 0 auto; }
.svc-cta h2 em { font-style: italic; color: var(--accent); }
.svc-cta p { margin: 22px auto 0; color: var(--ink-soft); max-width: 52ch; font-size: 17px; }
.svc-cta__row { display: flex; gap: 16px; justify-content: center; margin-top: 34px; flex-wrap: wrap; }

@media (max-width: 900px) {
  .feat-grid { grid-template-columns: 1fr 1fr; }
  .tiers { grid-template-columns: 1fr; }
  .tier--single { grid-template-columns: 1fr; gap: 22px; }
}
@media (max-width: 560px) {
  .feat-grid { grid-template-columns: 1fr; }
}

/* ---- Blog index ---- */
.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: clamp(36px, 5vw, 56px); }
.bpost { display: flex; flex-direction: column; gap: 9px; background: var(--white); border: 1px solid var(--line); border-radius: 10px; padding: 26px 24px; min-height: 240px; transition: transform 0.4s var(--ease), box-shadow 0.4s var(--ease), border-color 0.4s; }
.bpost:hover { transform: translateY(-5px); box-shadow: 0 24px 50px rgba(0,0,0,0.42); border-color: var(--line-strong); }
.bpost__tag { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); }
.bpost__title { font-family: var(--font-display); font-weight: 300; font-size: 23px; line-height: 1.14; margin-top: 2px; }
.bpost__desc { font-size: 14px; color: var(--ink-soft); flex: 1; }
.bpost__read { margin-top: 14px; font-size: 14px; font-weight: 500; color: var(--accent); display: inline-flex; align-items: center; gap: 6px; }
.bpost__read .arr { transition: transform 0.3s var(--ease); }
.bpost:hover .bpost__read .arr { transform: translateX(4px); }
@media (max-width: 900px) { .blog-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .blog-grid { grid-template-columns: 1fr; } }

/* ---- Legal / doc pages ---- */
.legal { max-width: 820px; }
.legal h2 { font-family: var(--font-display); font-weight: 400; font-size: clamp(24px, 3vw, 34px); margin: 40px 0 14px; letter-spacing: -0.02em; }
.legal h2:first-child { margin-top: 0; }
.legal p, .legal li { color: var(--ink-soft); font-size: 16px; line-height: 1.7; margin: 0 0 14px; }
.legal ul { margin: 0 0 14px 20px; }
.legal a { color: var(--accent); border-bottom: 1px solid var(--copper-wash-2); }
.legal strong { color: var(--ink); font-weight: 600; }
.legal__updated { font-family: var(--font-mono); font-size: 12px; color: var(--ink-soft); letter-spacing: 0.04em; margin-bottom: 36px; padding-bottom: 24px; border-bottom: 1px solid var(--line); }
