/* =========================================================================
   dexwatch — methodology / score transparency page (/methodology/)
   ========================================================================= */
.me-main { padding: 32px 0 80px; }
.me-wrap { width: min(820px, 100% - 44px); margin-inline: auto; }

.me-kicker { font-family: var(--font-mono); font-size: 12px; font-weight: 500; letter-spacing: .14em; text-transform: uppercase; color: color-mix(in oklch, var(--accent) 70%, var(--ink)); }
.me-title { font-size: clamp(28px, 4vw, 44px); font-weight: 800; letter-spacing: -0.03em; line-height: 1.05; margin: 12px 0 14px; }
.me-lead { color: var(--ink-2); font-size: clamp(15px, 1.7vw, 18px); line-height: 1.55; text-wrap: pretty; max-width: 64ch; }

.me-h2 { font-size: clamp(20px, 2.4vw, 26px); letter-spacing: -0.02em; margin: 46px 0 14px; }
.me-p { font-size: 16px; line-height: 1.7; color: var(--ink-2); margin: 0 0 16px; text-wrap: pretty; }
.me-p strong { color: var(--ink); font-weight: 700; }
.me-p a { color: color-mix(in oklch, var(--accent) 78%, var(--ink)); font-weight: 600; text-decoration: underline; text-decoration-color: var(--accent-line); text-underline-offset: 2px; }

/* is / isn't */
.me-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin: 8px 0 4px; }
@media (max-width: 640px){ .me-cols { grid-template-columns: 1fr; } }
.me-card { padding: 18px 20px; border: 1px solid var(--line); border-radius: var(--r-lg); background: var(--bg-elev); }
.me-card h3 { font-size: 14px; display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.me-card ul { display: flex; flex-direction: column; gap: 8px; }
.me-card li { font-size: 14px; line-height: 1.5; color: var(--ink-2); position: relative; padding-left: 22px; list-style: none; }
.me-is h3 { color: var(--up); }
.me-is li::before { content: "\2713"; position: absolute; left: 0; color: var(--up); font-weight: 700; }
.me-isnt h3 { color: var(--down); }
.me-isnt li::before { content: "\2715"; position: absolute; left: 0; color: var(--down); font-weight: 700; }

/* weight bar */
.me-weights { margin: 18px 0 6px; }
.me-bar { display: flex; height: 46px; border-radius: var(--r-md); overflow: hidden; border: 1px solid var(--line); }
.me-bar span { display: grid; place-items: center; font-family: var(--font-mono); font-size: 12px; font-weight: 700; color: #08110d; }
.me-seg-liq { background: var(--accent); }
.me-seg-sec { background: color-mix(in oklch, var(--accent-2) 85%, white); }
.me-seg-cost { background: color-mix(in oklch, var(--accent) 38%, var(--bg-sunken)); color: var(--ink) !important; }
.me-seg-base { background: var(--bg-sunken); color: var(--ink-3) !important; }
.me-legend { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 12px; font-size: 13px; color: var(--ink-3); }
.me-legend i { display: inline-block; width: 11px; height: 11px; border-radius: 3px; margin-right: 7px; vertical-align: -1px; }

/* factor cards */
.me-factors { display: flex; flex-direction: column; gap: 12px; margin-top: 6px; }
.me-factor { padding: 18px 20px; border: 1px solid var(--line); border-radius: var(--r-lg); background: var(--bg-elev); }
.me-factor-h { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; margin-bottom: 8px; }
.me-factor-h .nm { font-weight: 750; font-size: 16px; letter-spacing: -0.01em; }
.me-factor-h .wt { font-family: var(--font-mono); font-size: 12px; font-weight: 700; color: color-mix(in oklch, var(--accent) 60%, var(--ink)); background: var(--accent-wash); border: 1px solid var(--accent-line); border-radius: var(--r-pill); padding: 3px 10px; flex: none; }
.me-factor p { font-size: 14px; line-height: 1.6; color: var(--ink-2); margin: 0; }
.me-factor .lim { font-size: 12.5px; color: var(--ink-faint); margin-top: 8px; }
.me-factor .lim b { color: var(--ink-3); font-weight: 600; }

/* tiers */
.me-tiers { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 10px; margin-top: 6px; }
.me-tier { padding: 14px 16px; border: 1px solid var(--line); border-radius: var(--r-md); background: var(--bg-elev); }
.me-tier .rng { font-family: var(--font-mono); font-size: 12px; color: var(--ink-faint); }
.me-tier .lbl { font-weight: 750; font-size: 15px; margin-top: 4px; }
.me-tier.hi .lbl { color: var(--up); }
.me-tier.mid .lbl { color: var(--accent); }
.me-tier.low .lbl { color: var(--ink); }
.me-tier.warn .lbl { color: var(--down); }

/* worked example */
.me-egs { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 6px; }
@media (max-width: 680px){ .me-egs { grid-template-columns: 1fr; } }
.me-eg { padding: 18px 20px; border: 1px solid var(--line); border-radius: var(--r-lg); background: var(--bg-elev); }
.me-eg-h { display: flex; align-items: center; gap: 11px; margin-bottom: 14px; }
.me-eg-h .nm { font-weight: 750; font-size: 16px; }
.me-eg-h .total { margin-left: auto; font-family: var(--font-mono); font-weight: 800; font-size: 22px; }
.me-eg-rows { display: flex; flex-direction: column; gap: 0; }
.me-eg-row { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; padding: 8px 0; border-bottom: 1px solid var(--line); font-size: 13.5px; }
.me-eg-row:last-child { border-bottom: none; }
.me-eg-row .k { color: var(--ink-3); }
.me-eg-row .k small { color: var(--ink-faint); font-family: var(--font-mono); font-size: 11px; margin-left: 6px; }
.me-eg-row .v { font-family: var(--font-mono); font-variant-numeric: tabular-nums; font-weight: 600; color: var(--ink); flex: none; }
.me-eg-row.pen .v { color: var(--down); }
.me-eg-row.sum { padding-top: 10px; margin-top: 4px; border-top: 2px solid var(--line-strong); border-bottom: none; font-weight: 700; }
.me-eg-row.sum .v { color: color-mix(in oklch, var(--accent) 55%, var(--ink)); }

.me-note { font-size: 13px; color: var(--ink-faint); line-height: 1.55; margin-top: 12px; }

/* cross links */
.me-cross { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 12px; margin-top: 18px; }
.me-cross a { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 16px 18px; border: 1px solid var(--line); border-radius: var(--r-md); background: var(--bg-elev); font-weight: 650; color: var(--ink); transition: border-color .15s, transform .12s; }
.me-cross a:hover { border-color: var(--accent-line); transform: translateY(-1px); }
.me-cross a .arr { color: var(--ink-faint); }
.me-cross a:hover .arr { color: var(--accent); }