/*
Theme Name: Twenty Twenty-Five — MiraclesFor.me
Theme URI: https://miraclesfor.me
Description: Child theme of Twenty Twenty-Five for miraclesfor.me. Applies the MiraclesFor.me Design System (Bloom palette, Instrument Serif × Manrope) and adds custom block patterns + page templates for the 17 redesigned pages. Built 2026-05-19.
Author: David Cameron Gikandi
Author URI: https://miraclesfor.me
Template: twentytwentyfive
Version: 1.1.0-iris
Text Domain: twentytwentyfive-mfm
*/

/* ──────────────────────────────────────────────────────────────────
   The full MiraclesFor.me design system is loaded via theme.json
   (presets) + this stylesheet (component CSS for patterns).
   ────────────────────────────────────────────────────────────────── */

:root {
  /* Bloom palette tokens (also defined in theme.json as preset colors) */
  --paper:    #FAF8FC;
  --paper-2:  #FFFFFF;
  --paper-3:  #EEE6F7;
  --ink:      #1A1530;
  --ink-2:    #2E2848;
  --pine:     #6E4FE5;
  --pine-2:   #5638C7;
  --ember:    #B14A9A;
  --ember-2:  #983E83;
  --ochre:    #D4A857;
  --mist:     #6B6584;
  --mist-2:   #A8A4BC;
  --hairline: #E5DFEF;
  --moss:     #7E8B7A;

  --bg:       var(--paper);
  --surface:  var(--paper-2);
  --fg:       var(--ink);
  --fg-mute:  var(--mist);
  --rule:     var(--hairline);
  --primary:  var(--pine);
  --accent:   var(--ember);

  --font-display: "Instrument Serif", "Newsreader", Georgia, serif;
  --font-body:    "Manrope", ui-sans-serif, system-ui, -apple-system, sans-serif;
  --font-mono:    "JetBrains Mono", ui-monospace, "SF Mono", monospace;

  --t-xs:  12px;  --t-sm:  14px;  --t-md:  16px;  --t-lg:  18px;
  --t-xl:  22px;  --t-2xl: 28px;  --t-3xl: 38px;
  --t-4xl: 56px;  --t-5xl: 84px;  --t-6xl: 124px;

  --s-1: 4px;  --s-2: 8px;  --s-3: 12px; --s-4: 16px;
  --s-5: 24px; --s-6: 32px; --s-7: 48px; --s-8: 64px;
  --s-9: 96px; --s-10: 128px; --s-11: 192px;

  --r-xs: 2px; --r-sm: 4px; --r-md: 8px; --r-lg: 14px; --r-pill: 999px;

  --shadow-1: 0 1px 0 rgba(24,31,27,.04), 0 1px 2px rgba(24,31,27,.04);
  --shadow-2: 0 1px 0 rgba(24,31,27,.04), 0 6px 18px -8px rgba(24,31,27,.18);
  --shadow-3: 0 30px 60px -30px rgba(24,31,27,.35), 0 12px 24px -16px rgba(24,31,27,.18);

  --maxw: 1240px;
  --maxw-content: 720px;
  --gutter: 32px;
}

/* Base */
body.mfm,
.mfm-page {
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-body);
  font-size: var(--t-md);
  line-height: 1.55;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-feature-settings: "ss01", "ss02", "kern";
}
.mfm-page * { box-sizing: border-box; }
.mfm-page img, .mfm-page svg { display: block; max-width: 100%; }
.mfm-page a { color: inherit; text-underline-offset: 3px; }
.mfm-page hr { border: none; height: 1px; background: var(--hairline); margin: 0; }
.mfm-page ::selection { background: var(--ember); color: var(--paper-2); }

/* Typography helpers */
.mfm .display { font-family: var(--font-display); font-weight: 400; line-height: 1.02; letter-spacing: -0.015em; }
.mfm .italic { font-style: italic; }
.mfm .mono { font-family: var(--font-mono); font-size: var(--t-xs); letter-spacing: 0.01em; }
.mfm .eyebrow { font-family: var(--font-body); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; font-weight: 600; color: var(--mist); }
.mfm .muted { color: var(--mist); }

/* Layout */
.mfm .wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--gutter); }
.mfm .wrap-narrow { max-width: var(--maxw-content); margin: 0 auto; padding: 0 var(--gutter); }
.mfm section { padding: var(--s-9) 0; position: relative; }
.mfm section + section { border-top: 1px solid var(--hairline); }
.mfm .section-band { background: var(--paper-2); }
.mfm .section-petal { background: var(--paper-3); }
.mfm .section-dark { background: var(--ink); color: var(--paper); }
.mfm .section-dark .muted { color: var(--mist-2); }
.mfm .section-dark .eyebrow { color: var(--mist-2); }

.mfm .section-head { display: grid; grid-template-columns: 1fr 2fr; gap: var(--s-7); align-items: end; margin-bottom: var(--s-8); }
.mfm .section-head .index { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em; color: var(--mist); display: flex; align-items: center; gap: var(--s-3); }
.mfm .section-head .index::before { content: ""; display: inline-block; width: 18px; height: 1px; background: currentColor; }
.mfm .section-head h2 { font-family: var(--font-display); font-weight: 400; font-size: clamp(40px, 5.5vw, 72px); line-height: 1.02; letter-spacing: -0.02em; margin: var(--s-4) 0 0; text-wrap: balance; }
.mfm .section-head .kicker { font-family: var(--font-display); font-style: italic; color: var(--ember); }
.mfm .section-head .blurb { font-size: var(--t-lg); line-height: 1.55; color: var(--ink-2); max-width: 56ch; text-wrap: pretty; }
@media (max-width: 800px) { .mfm .section-head { grid-template-columns: 1fr; gap: var(--s-4); align-items: start; } }

/* Topbar */
.mfm-topbar { position: sticky; top: 0; z-index: 50; background: color-mix(in oklab, var(--paper) 88%, transparent); backdrop-filter: saturate(160%) blur(12px); -webkit-backdrop-filter: saturate(160%) blur(12px); border-bottom: 1px solid var(--hairline); }
.mfm-topbar-inner { display: flex; align-items: center; justify-content: space-between; padding: 14px var(--gutter); max-width: var(--maxw); margin: 0 auto; gap: var(--s-5); }
.mfm-topbar .nav { display: flex; gap: 28px; font-size: var(--t-sm); color: var(--ink-2); }
.mfm-topbar .nav a { text-decoration: none; transition: color .15s ease; }
.mfm-topbar .nav a:hover { color: var(--ember); }
.mfm-topbar .nav a.here { color: var(--ember); border-bottom: 1px solid var(--ember); padding-bottom: 2px; }
.mfm-topbar .join-btn { font-family: var(--font-body); font-weight: 600; font-size: var(--t-sm); background: var(--pine); color: var(--paper); padding: 9px 16px; border-radius: var(--r-pill); text-decoration: none; border: 1px solid var(--pine); transition: background .15s ease; }
.mfm-topbar .join-btn:hover { background: var(--ink); border-color: var(--ink); }
@media (max-width: 900px) { .mfm-topbar .nav { display: none; } }

.mfm .wm { display: inline-flex; align-items: baseline; gap: 6px; font-family: var(--font-display); font-style: italic; font-size: 22px; letter-spacing: -0.01em; color: var(--fg); text-decoration: none; }
.mfm .wm .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--ember); align-self: center; }
.mfm .wm .me { font-style: normal; font-family: var(--font-body); font-weight: 500; font-size: 13px; letter-spacing: 0.04em; color: var(--mist); }

/* Buttons */
.mfm .btn { display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-body); font-weight: 600; font-size: var(--t-sm); letter-spacing: 0.01em; padding: 14px 22px; border-radius: var(--r-pill); border: 1px solid transparent; cursor: pointer; transition: transform .15s ease, background .15s ease, color .15s ease, border-color .15s ease; text-decoration: none; line-height: 1; }
.mfm .btn-primary { background: var(--pine); color: var(--paper); }
.mfm .btn-primary:hover { background: var(--ink); }
.mfm .btn-ember { background: var(--ember); color: var(--paper-2); }
.mfm .btn-ember:hover { background: var(--ember-2); }
.mfm .btn-ghost { background: transparent; color: var(--ink); border-color: var(--ink); }
.mfm .btn-ghost:hover { background: var(--ink); color: var(--paper); }
.mfm .btn-ghost-light { background: transparent; color: var(--paper); border-color: var(--paper); }
.mfm .btn-ghost-light:hover { background: var(--paper); color: var(--ink); }
.mfm .btn-link { background: transparent; color: var(--ink); padding-left: 0; padding-right: 0; border-radius: 0; gap: 6px; }
.mfm .btn-link::after { content: "→"; transition: transform .2s ease; }
.mfm .btn-link:hover::after { transform: translateX(4px); }
.mfm .btn-link:hover { color: var(--ember); }
.mfm .btn-small { padding: 9px 14px; font-size: var(--t-xs); }

/* Badges */
.mfm .badge { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-body); font-weight: 600; font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; padding: 5px 10px; border-radius: var(--r-pill); border: 1px solid var(--hairline); color: var(--ink-2); background: var(--paper-2); }
.mfm .badge::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--ember); display: inline-block; }
.mfm .badge.pine { color: var(--pine); }
.mfm .badge.pine::before { background: var(--pine); }

/* Inputs */
.mfm .input, .mfm .textarea { font-family: var(--font-body); font-size: var(--t-md); padding: 14px 16px; border: 1px solid var(--hairline); background: var(--paper-2); color: var(--ink); border-radius: 4px; width: 100%; min-width: 0; transition: border-color .15s ease; }
.mfm .input:focus, .mfm .textarea:focus { outline: none; border-color: var(--pine); }
.mfm .textarea { min-height: 140px; resize: vertical; line-height: 1.55; }

/* Cards */
.mfm .card { background: var(--paper-2); border: 1px solid var(--hairline); padding: var(--s-6); display: flex; flex-direction: column; gap: var(--s-3); }
.mfm .card .crown { font-family: var(--font-mono); font-size: 10px; color: var(--mist); letter-spacing: 0.1em; text-transform: uppercase; }
.mfm .card h4 { font-family: var(--font-display); font-weight: 400; font-size: var(--t-2xl); margin: 0; letter-spacing: -0.01em; line-height: 1.1; }
.mfm .card h4 em { color: var(--ember); font-style: italic; }
.mfm .card p { margin: 0; font-size: var(--t-sm); color: var(--ink-2); }

.mfm .pull { font-family: var(--font-display); font-style: italic; font-weight: 400; font-size: clamp(28px, 3.6vw, 44px); line-height: 1.25; letter-spacing: -0.015em; padding-left: var(--s-5); border-left: 2px solid var(--ember); color: var(--ink); text-wrap: pretty; max-width: 36ch; }

/* Three pillars block */
.mfm .pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline); }
.mfm .pillar { padding: var(--s-7) var(--s-5); border-left: 1px solid var(--hairline); display: flex; flex-direction: column; gap: var(--s-4); background: var(--paper); transition: background .15s ease; }
.mfm .pillar:hover { background: var(--paper-2); }
.mfm .pillar:first-child { border-left: none; }
.mfm .pillar .num { font-family: var(--font-mono); font-size: 11px; color: var(--ember); letter-spacing: 0.06em; }
.mfm .pillar .num.pine { color: var(--pine); } .mfm .pillar .num.ochre { color: var(--ochre); }
.mfm .pillar h4 { font-family: var(--font-display); font-weight: 400; font-size: var(--t-2xl); margin: 0; letter-spacing: -0.01em; line-height: 1.1; }
.mfm .pillar h4 em { font-style: italic; color: var(--ember); }
.mfm .pillar p { font-size: var(--t-sm); color: var(--ink-2); margin: 0; }
.mfm .pillar svg { width: 56px; height: 56px; color: var(--pine); margin-bottom: var(--s-2); }
@media (max-width: 800px) { .mfm .pillars { grid-template-columns: 1fr; } .mfm .pillar { border-left: none; border-top: 1px solid var(--hairline); } .mfm .pillar:first-child { border-top: none; } }

/* Footer */
.mfm-footer { background: var(--ink); color: var(--paper); padding: var(--s-9) 0; margin-top: 0; }
.mfm-footer .grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1fr; gap: var(--s-7); }
.mfm-footer h5 { font-family: var(--font-body); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--mist-2); margin: 0 0 var(--s-4); font-weight: 600; }
.mfm-footer ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; font-size: var(--t-sm); }
.mfm-footer ul a { color: var(--paper); text-decoration: none; }
.mfm-footer ul a:hover { color: var(--ember); }
.mfm-footer .big { font-family: var(--font-display); font-style: italic; font-size: clamp(32px, 4.5vw, 56px); line-height: 1; letter-spacing: -0.025em; }
.mfm-footer .big em { color: var(--ember); }
.mfm-footer .colophon { font-family: var(--font-mono); font-size: 11px; color: var(--mist-2); display: flex; justify-content: space-between; border-top: 1px solid #322A52; padding-top: var(--s-5); margin-top: var(--s-8); }
@media (max-width: 1000px) { .mfm-footer .grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px) { .mfm-footer .grid { grid-template-columns: 1fr; } }

/* Article cards (used by blog, archive, search) */
.mfm .article-card { background: var(--paper-2); border: 1px solid var(--hairline); display: flex; flex-direction: column; gap: var(--s-3); padding: var(--s-5); transition: border-color .2s ease; text-decoration: none; color: inherit; }
.mfm .article-card:hover { border-color: var(--ember); }
.mfm .article-card .pillar-tag { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ember); }
.mfm .article-card .pillar-tag.pine { color: var(--pine); }
.mfm .article-card .pillar-tag.ochre { color: var(--ochre); }
.mfm .article-card h3 { font-family: var(--font-display); font-weight: 400; font-size: var(--t-xl); line-height: 1.2; letter-spacing: -0.01em; margin: 0; text-wrap: balance; }
.mfm .article-card h3 em { color: var(--ember); font-style: italic; }
.mfm .article-card .excerpt { font-size: var(--t-sm); color: var(--ink-2); line-height: 1.55; margin: 0; }
.mfm .article-card .meta { font-family: var(--font-mono); font-size: 10px; color: var(--mist); letter-spacing: 0.06em; text-transform: uppercase; margin-top: auto; padding-top: var(--s-3); border-top: 1px solid var(--hairline); display: flex; justify-content: space-between; }

/* Sidebar widgets */
.mfm .sidebar { display: flex; flex-direction: column; gap: var(--s-6); }
.mfm .widget { background: var(--paper-2); border: 1px solid var(--hairline); padding: var(--s-5); }
.mfm .widget .widget-title { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--mist); margin: 0 0 var(--s-4); padding-bottom: var(--s-3); border-bottom: 1px solid var(--hairline); }
.mfm .widget ul { list-style: none; padding: 0; margin: 0; }
.mfm .widget ul li { padding: var(--s-3) 0; border-bottom: 1px solid var(--hairline); font-size: var(--t-sm); color: var(--ink-2); display: flex; justify-content: space-between; align-items: center; gap: var(--s-3); }
.mfm .widget ul li:last-child { border-bottom: none; }
.mfm .widget ul li a { text-decoration: none; color: var(--ink); }
.mfm .widget ul li a:hover { color: var(--ember); }
.mfm .widget ul li .count { font-family: var(--font-mono); font-size: 10px; color: var(--mist); letter-spacing: 0.06em; }
.mfm .widget-newsletter { background: var(--ink); color: var(--paper); border-color: var(--ink); padding: var(--s-6); }
.mfm .widget-newsletter .widget-title { color: var(--mist-2); border-color: rgba(255,255,255,0.1); }
.mfm .widget-newsletter h4 { font-family: var(--font-display); font-weight: 400; font-size: var(--t-xl); line-height: 1.15; margin: var(--s-2) 0 var(--s-3); }
.mfm .widget-newsletter h4 em { color: var(--ember); font-style: italic; }
.mfm .widget-newsletter p { font-size: var(--t-sm); color: var(--mist-2); margin: 0 0 var(--s-3); }
.mfm .widget-newsletter input.input { background: rgba(255,255,255,0.06); border-color: rgba(255,255,255,0.18); color: var(--paper); margin-bottom: var(--s-3); }
.mfm .widget-newsletter input.input::placeholder { color: var(--mist-2); }
.mfm .widget-newsletter input.input:focus { border-color: var(--ember); }
.mfm .widget-newsletter .privacy { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--mist-2); margin-top: var(--s-2); }

/* Hide WordPress admin bar shifts when our header is sticky */
html.wp-toolbar .mfm-topbar { top: 32px; }
@media (max-width: 782px) { html.wp-toolbar .mfm-topbar { top: 46px; } }
