/* ==========================================================================
   pages.css — page-level layouts (legal docs, content pages, page header)
   ========================================================================== */

/* --- Generic page header (non-home) --------------------------------------- */
.page-head {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 88% -10%, rgba(226, 45, 73, 0.22) 0, transparent 48%),
    linear-gradient(180deg, #160b10, var(--bg));
  padding-block: var(--sp-8) var(--sp-6);
  border-bottom: 1px solid var(--line);
}
.page-head .eyebrow { margin-bottom: var(--sp-2); }
.page-head h1 { font-size: clamp(2rem, 4.5vw, var(--fs-800)); }
.page-head p { margin-top: var(--sp-3); max-width: 65ch; }
.page-head .ring.r1 { width: 280px; height: 280px; top: -90px; right: -60px; border-color: var(--red-200); }
.page-head .ring.r2 { width: 160px; height: 160px; top: -30px; right: 40px; border-color: var(--red-300); border-style: dashed; }

/* --- Breadcrumb ----------------------------------------------------------- */
.crumbs { font-size: var(--fs-300); color: var(--text-mute); margin-bottom: var(--sp-3); }
.crumbs a { color: var(--accent-strong); text-decoration: none; }
.crumbs a:hover { text-decoration: underline; }

/* --- Legal / long-form document ------------------------------------------- */
.legal-doc { padding-block: var(--sp-7); }
.legal-doc .doc-grid { display: grid; grid-template-columns: 230px 1fr; gap: var(--sp-7); align-items: start; }
.legal-doc .toc {
  position: sticky; top: calc(var(--header-h) + 52px);
  font-size: 0.9rem;
}
.legal-doc .toc h4 { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.12em; color: var(--text-mute); margin-bottom: var(--sp-2); }
.legal-doc .toc ul { display: flex; flex-direction: column; gap: var(--sp-1); }
.legal-doc .toc a { color: var(--text-soft); text-decoration: none; }
.legal-doc .toc a:hover { color: var(--accent-strong); }

.legal-body h2 { margin-top: var(--sp-7); margin-bottom: var(--sp-3); font-size: var(--fs-600); scroll-margin-top: calc(var(--header-h) + 52px); }
.legal-body h2:first-child { margin-top: 0; }
.legal-body h3 { margin-top: var(--sp-5); margin-bottom: var(--sp-2); font-size: var(--fs-500); }
.legal-body p { margin-bottom: var(--sp-3); }
.legal-body ul:not(.toc ul) { list-style: disc; padding-left: 1.3em; margin-bottom: var(--sp-4); display: flex; flex-direction: column; gap: var(--sp-2); }
.legal-body ol { list-style: decimal; padding-left: 1.4em; margin-bottom: var(--sp-4); display: flex; flex-direction: column; gap: var(--sp-2); }
.legal-body li { color: var(--text-soft); }
.legal-body .version-line { margin-top: var(--sp-6); padding-top: var(--sp-4); border-top: 1px solid var(--line); font-size: var(--fs-300); color: var(--text-mute); }

.cite { font-style: italic; }

@media (max-width: 860px) {
  .legal-doc .doc-grid { grid-template-columns: 1fr; }
  .legal-doc .toc { position: static; }
}

/* --- Service / contact lists ---------------------------------------------- */
.svc-list { display: flex; flex-direction: column; gap: var(--sp-2); }
.svc-list li { padding: var(--sp-3) 0; border-bottom: 1px solid var(--line); }
.svc-list strong { color: var(--accent-strong); }

/* --- Definition rows ------------------------------------------------------ */
.deflist { display: grid; grid-template-columns: max-content 1fr; gap: var(--sp-2) var(--sp-5); }
.deflist dt { font-weight: 700; color: var(--text); }
.deflist dd { color: var(--text-soft); }
@media (max-width: 560px) { .deflist { grid-template-columns: 1fr; gap: var(--sp-1); } .deflist dd { margin-bottom: var(--sp-3); } }

/* --- Auth pages ----------------------------------------------------------- */
.auth-wrap { display: grid; place-items: center; padding-block: var(--sp-8); }
.auth-card { width: min(100%, 460px); }
.auth-card .card { padding: var(--sp-6); }
.auth-card h1 { font-size: var(--fs-700); }
.auth-aside { font-size: var(--fs-300); color: var(--text-mute); margin-top: var(--sp-4); }

/* --- Flash messages ------------------------------------------------------- */
.flash { padding: var(--sp-3) var(--sp-4); border-radius: var(--r-sm); margin-bottom: var(--sp-3); font-weight: 600; border: 1px solid; }
.flash--success { background: var(--accent-soft); border-color: #2fae6a; color: #8be0ad; }
.flash--error { background: #2c131c; border-color: var(--red-600); color: var(--red-200); }

/* --- Account dashboard ---------------------------------------------------- */
.acct { display: grid; grid-template-columns: 230px 1fr; gap: var(--sp-6); align-items: start; }
.acct__nav { display: flex; flex-direction: column; gap: var(--sp-1); position: sticky; top: calc(var(--header-h) + var(--sp-4)); }
.acct__navlink { display: block; padding: var(--sp-3) var(--sp-4); border-radius: var(--r-sm); color: var(--text-soft); font-weight: 600; border: 1px solid transparent; }
.acct__navlink:hover { background: var(--surface-2); color: var(--text); }
.acct__navlink.is-active { background: var(--accent-soft); color: var(--accent); border-color: var(--line-strong); }
.acct__main > .card { padding: var(--sp-5); }

.stat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-4); }
.stat { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-md); padding: var(--sp-4) var(--sp-5); display: flex; flex-direction: column; gap: var(--sp-2); }
.stat__label { font-size: var(--fs-300); text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-mute); }
.stat__value { font-size: var(--fs-600); font-weight: 700; color: var(--text); }
.stat__link { font-size: var(--fs-300); color: var(--accent); }

.badge { display: inline-block; padding: 2px var(--sp-3); border-radius: var(--r-pill); font-size: var(--fs-300); font-weight: 700; }
.badge--ok { background: rgba(47,174,106,0.15); color: #6fd69b; }
.badge--warn { background: rgba(226,45,73,0.15); color: var(--red-300); }

.kv { display: grid; gap: var(--sp-2); margin-top: var(--sp-3); }
.kv > div { display: grid; grid-template-columns: 160px 1fr; gap: var(--sp-3); padding: var(--sp-2) 0; border-bottom: 1px solid var(--line); }
.kv dt { color: var(--text-mute); font-weight: 600; }
.kv dd { color: var(--text); }

.txn { width: 100%; border-collapse: collapse; margin-top: var(--sp-3); font-size: var(--fs-300); }
.txn th, .txn td { text-align: left; padding: var(--sp-3) var(--sp-3); border-bottom: 1px solid var(--line); }
.txn thead th { color: var(--text-mute); text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.72rem; }
.txn .num { text-align: right; }
.txn td.pos { color: #6fd69b; }
.txn td.neg { color: var(--red-300); }

@media (max-width: 860px) {
  .acct { grid-template-columns: 1fr; }
  .acct__nav { position: static; flex-direction: row; flex-wrap: wrap; }
  .acct__navlink { flex: 1 1 auto; text-align: center; }
  .stat-grid { grid-template-columns: 1fr; }
  .kv > div { grid-template-columns: 1fr; gap: 0; }
}

/* --- Section heading block ------------------------------------------------ */
.section-head { max-width: 60ch; margin-bottom: var(--sp-6); }
.section-head .eyebrow { display: block; margin-bottom: var(--sp-2); }

/* --- Not-available / 404 -------------------------------------------------- */
.notice-page { min-height: 60vh; display: grid; place-items: center; text-align: center; padding-block: var(--sp-8); }
.notice-page .ring.r1 { width: 320px; height: 320px; border-color: var(--red-200); }
.notice-page__inner { position: relative; }
