/* ============================================================================
   Lumen — shared design system
   Medical-grade, high-contrast, WCAG 2.1 AA. Deep-indigo / teal accent.
   This file is the canonical theme; it is copied verbatim into each app folder
   (reader/, portal/, review/) so every app deploys as a self-contained Pages
   project. Edit shared/lumen.css and re-run scripts/sync-theme.sh to propagate.
   ============================================================================ */

:root {
  /* Palette — calm deep indigo primary, teal accent, warm-neutral surfaces */
  --lm-bg:            #f6f7fb;
  --lm-surface:       #ffffff;
  --lm-surface-2:     #f0f2f8;
  --lm-surface-3:     #e7eaf3;
  --lm-border:        #d4d9e6;
  --lm-border-strong: #b6bed3;

  --lm-ink:           #161a2b;   /* body text — ~16:1 on bg */
  --lm-ink-2:         #3a4055;   /* secondary text — ~9:1 */
  --lm-ink-3:         #5a6075;   /* muted/meta — ~5.4:1, AA for normal text */

  --lm-primary:       #3a3f9e;   /* deep indigo */
  --lm-primary-700:   #2c3080;
  --lm-primary-600:   #353a93;
  --lm-primary-050:   #ecedfb;
  --lm-on-primary:    #ffffff;

  --lm-accent:        #0f7c8c;   /* teal — used sparingly */
  --lm-accent-700:    #0a5f6c;
  --lm-accent-050:    #e2f3f5;

  /* Status / risk */
  --lm-ok:            #1d7a4d;
  --lm-ok-bg:         #e3f4ea;
  --lm-warn:          #9a5b00;
  --lm-warn-bg:       #fbedd6;
  --lm-danger:        #b3261e;
  --lm-danger-bg:     #fbe6e4;
  --lm-info:          #2c3080;
  --lm-info-bg:       #e8e9f8;

  --lm-radius:        12px;
  --lm-radius-sm:     8px;
  --lm-radius-lg:     18px;
  --lm-shadow-sm:     0 1px 2px rgba(22,26,43,.06), 0 1px 3px rgba(22,26,43,.08);
  --lm-shadow-md:     0 2px 8px rgba(22,26,43,.07), 0 8px 24px rgba(22,26,43,.08);
  --lm-shadow-lg:     0 8px 30px rgba(22,26,43,.12);

  --lm-font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
             Helvetica, Arial, sans-serif;
  --lm-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, Consolas,
             monospace;

  --lm-maxw:   1140px;
  --lm-maxw-rd: 760px;   /* reading measure for leaflet body */
}

@media (prefers-color-scheme: dark) {
  :root {
    --lm-bg:            #0f1220;
    --lm-surface:       #171a2b;
    --lm-surface-2:     #1d2136;
    --lm-surface-3:     #252a44;
    --lm-border:        #313760;
    --lm-border-strong: #424978;

    --lm-ink:           #eef0fa;
    --lm-ink-2:         #c2c7dd;
    --lm-ink-3:         #9aa0bd;

    --lm-primary:       #a9adf5;
    --lm-primary-700:   #c3c6fb;
    --lm-primary-600:   #b6b9f8;
    --lm-primary-050:   #23264a;
    --lm-on-primary:    #11132a;

    --lm-accent:        #4cc6d6;
    --lm-accent-700:    #74d6e2;
    --lm-accent-050:    #133038;

    --lm-ok:            #57d39a;  --lm-ok-bg:     #133225;
    --lm-warn:          #e3a857;  --lm-warn-bg:   #34280f;
    --lm-danger:        #f0918a;  --lm-danger-bg: #3a1816;
    --lm-info:          #b6b9f8;  --lm-info-bg:   #20234a;

    --lm-shadow-sm: 0 1px 2px rgba(0,0,0,.4);
    --lm-shadow-md: 0 2px 8px rgba(0,0,0,.4), 0 8px 24px rgba(0,0,0,.45);
    --lm-shadow-lg: 0 8px 30px rgba(0,0,0,.55);
  }
}

/* ---------- reset / base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--lm-font);
  font-size: 16px;
  line-height: 1.6;
  color: var(--lm-ink);
  background: var(--lm-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
h1, h2, h3, h4 { line-height: 1.25; color: var(--lm-ink); margin: 0 0 .4em; }
p { margin: 0 0 1em; }
a { color: var(--lm-primary); text-underline-offset: 2px; }
a:hover { color: var(--lm-primary-700); }
img, svg { max-width: 100%; }

/* Visible, generous focus ring everywhere (AA 2.4.7) */
:focus-visible {
  outline: 3px solid var(--lm-accent);
  outline-offset: 2px;
  border-radius: 4px;
}

/* Skip link */
.lm-skip {
  position: absolute;
  left: 12px;
  top: -48px;
  z-index: 1000;
  background: var(--lm-primary);
  color: var(--lm-on-primary);
  padding: 10px 16px;
  border-radius: var(--lm-radius-sm);
  font-weight: 600;
  transition: top .15s ease;
}
.lm-skip:focus { top: 12px; color: var(--lm-on-primary); }

/* ---------- layout ---------- */
.lm-container { max-width: var(--lm-maxw); margin: 0 auto; padding: 0 20px; }

.lm-header {
  background: var(--lm-surface);
  border-bottom: 1px solid var(--lm-border);
  position: sticky; top: 0; z-index: 50;
  backdrop-filter: saturate(1.1);
}
.lm-header-inner {
  max-width: var(--lm-maxw); margin: 0 auto; padding: 14px 20px;
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
}
.lm-brand { display: flex; align-items: center; gap: 11px; text-decoration: none; }
.lm-brand:hover { color: inherit; }
.lm-logo {
  width: 32px; height: 32px; flex: none;
  display: grid; place-items: center;
}
.lm-wordmark { display: flex; flex-direction: column; line-height: 1.05; }
.lm-wordmark b {
  font-size: 1.18rem; font-weight: 800; letter-spacing: -.02em; color: var(--lm-ink);
}
.lm-wordmark span {
  font-size: .68rem; font-weight: 600; letter-spacing: .12em;
  text-transform: uppercase; color: var(--lm-ink-3);
}
.lm-header-nav { margin-left: auto; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.lm-header-nav a {
  text-decoration: none; color: var(--lm-ink-2); font-weight: 600; font-size: .9rem;
  padding: 7px 11px; border-radius: var(--lm-radius-sm);
}
.lm-header-nav a:hover { background: var(--lm-surface-2); color: var(--lm-ink); }
.lm-header-nav a[aria-current="page"] { background: var(--lm-primary-050); color: var(--lm-primary-700); }

main { padding: 28px 0 64px; }

/* ---------- cards / surfaces ---------- */
.lm-card {
  background: var(--lm-surface);
  border: 1px solid var(--lm-border);
  border-radius: var(--lm-radius);
  box-shadow: var(--lm-shadow-sm);
}
.lm-card-pad { padding: 22px 24px; }

/* ---------- buttons ---------- */
.lm-btn {
  --b: var(--lm-primary);
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font: inherit; font-weight: 600; font-size: .94rem;
  padding: 10px 16px; border-radius: var(--lm-radius-sm);
  border: 1px solid transparent; background: var(--b); color: var(--lm-on-primary);
  cursor: pointer; text-decoration: none; transition: background .12s, box-shadow .12s, transform .05s;
}
.lm-btn:hover { background: var(--lm-primary-700); color: var(--lm-on-primary); }
.lm-btn:active { transform: translateY(1px); }
.lm-btn[disabled], .lm-btn[aria-disabled="true"] { opacity: .55; cursor: not-allowed; }
.lm-btn-ghost {
  background: var(--lm-surface); color: var(--lm-primary-700);
  border-color: var(--lm-border-strong);
}
.lm-btn-ghost:hover { background: var(--lm-surface-2); color: var(--lm-primary-700); }
.lm-btn-ok    { background: var(--lm-ok); }   .lm-btn-ok:hover    { background: #15623d; color:#fff; }
.lm-btn-danger{ background: var(--lm-danger);} .lm-btn-danger:hover{ background: #8f1d17; color:#fff; }
.lm-btn-sm { padding: 7px 12px; font-size: .86rem; }

/* ---------- inputs ---------- */
.lm-input, .lm-textarea, .lm-select {
  width: 100%; font: inherit; color: var(--lm-ink);
  background: var(--lm-surface); border: 1px solid var(--lm-border-strong);
  border-radius: var(--lm-radius-sm); padding: 11px 13px;
}
.lm-input::placeholder { color: var(--lm-ink-3); }
.lm-input:focus, .lm-textarea:focus, .lm-select:focus {
  border-color: var(--lm-primary); box-shadow: 0 0 0 3px var(--lm-primary-050);
  outline: none;
}
.lm-textarea { min-height: 160px; font-family: var(--lm-mono); font-size: .85rem; line-height: 1.5; resize: vertical; }
.lm-label { display: block; font-weight: 600; font-size: .85rem; color: var(--lm-ink-2); margin-bottom: 6px; }

/* ---------- badges / chips ---------- */
.lm-badge {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: .72rem; font-weight: 700; letter-spacing: .02em;
  padding: 3px 9px; border-radius: 999px; border: 1px solid transparent;
  text-transform: uppercase;
}
.lm-badge-official { background: var(--lm-ok-bg);   color: var(--lm-ok);     border-color: color-mix(in srgb, var(--lm-ok) 30%, transparent); }
.lm-badge-unofficial{ background: var(--lm-warn-bg); color: var(--lm-warn);   border-color: color-mix(in srgb, var(--lm-warn) 30%, transparent); }
.lm-badge-review   { background: var(--lm-warn-bg); color: var(--lm-warn);   border-color: color-mix(in srgb, var(--lm-warn) 30%, transparent); }
.lm-badge-none     { background: var(--lm-surface-2); color: var(--lm-ink-3); border-color: var(--lm-border); }
.lm-badge-info     { background: var(--lm-info-bg);  color: var(--lm-info);   border-color: color-mix(in srgb, var(--lm-info) 28%, transparent); }
.lm-badge-danger   { background: var(--lm-danger-bg);color: var(--lm-danger); border-color: color-mix(in srgb, var(--lm-danger) 30%, transparent); }
.lm-badge-en, .lm-badge-es { background: var(--lm-primary-050); color: var(--lm-primary-700); border-color: color-mix(in srgb, var(--lm-primary) 24%, transparent); }

/* ---------- callouts ---------- */
.lm-callout {
  border: 1px solid var(--lm-border); border-left-width: 4px;
  border-radius: var(--lm-radius-sm); padding: 14px 16px; margin: 0 0 18px;
  background: var(--lm-surface);
}
.lm-callout-warn   { border-left-color: var(--lm-warn);   background: var(--lm-warn-bg); }
.lm-callout-info   { border-left-color: var(--lm-info);   background: var(--lm-info-bg); }
.lm-callout-danger { border-left-color: var(--lm-danger); background: var(--lm-danger-bg); }
.lm-callout-ok     { border-left-color: var(--lm-ok);     background: var(--lm-ok-bg); }
.lm-callout h3, .lm-callout strong { color: inherit; }
.lm-callout-title { font-weight: 800; margin: 0 0 4px; display: flex; align-items: center; gap: 8px; }

/* ---------- misc ---------- */
.lm-muted { color: var(--lm-ink-3); }
.lm-mono  { font-family: var(--lm-mono); }
.lm-visually-hidden {
  position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}
.lm-spinner {
  width: 20px; height: 20px; border-radius: 50%;
  border: 3px solid var(--lm-border-strong); border-top-color: var(--lm-primary);
  animation: lm-spin .7s linear infinite; display: inline-block;
}
@keyframes lm-spin { to { transform: rotate(360deg); } }

.lm-footer {
  border-top: 1px solid var(--lm-border); margin-top: 48px;
  padding: 24px 0; color: var(--lm-ink-3); font-size: .85rem;
}
.lm-footer a { color: var(--lm-ink-2); }

/* table inside leaflet/json */
.lm-prose table { border-collapse: collapse; width: 100%; margin: 12px 0; font-size: .95em; }
.lm-prose th, .lm-prose td { border: 1px solid var(--lm-border); padding: 7px 10px; text-align: left; vertical-align: top; }
.lm-prose th { background: var(--lm-surface-2); }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
}
