*{margin:0;padding:0;box-sizing:border-box}
body{font-family:Georgia,'Times New Roman',serif;line-height:1.8;color:#222;background:#f4f1eb}
.sidebar-7618f3{max-width:1100px;margin:0 auto;padding:0 24px}
.frame-84f7ce{background:linear-gradient(135deg,#2c3e50,#34495e);color:#fff;padding:48px 0;text-align:center;margin-bottom:48px}
.frame-84f7ce h1{font-size:36px;letter-spacing:2px;text-transform:uppercase;margin-bottom:6px}
.frame-84f7ce p{font-size:16px;opacity:.8;font-style:italic}
.frame-84f7ce .region-5bf0a7{color:#fff;text-decoration:none;font-size:20px;letter-spacing:1px;text-transform:uppercase}
.section-55fda8{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:28px}
.widget-6ba973{background:#fff;border-radius:4px;box-shadow:0 2px 12px rgba(0,0,0,.08);padding:28px;transition:box-shadow .2s}
.widget-6ba973:hover{box-shadow:0 4px 20px rgba(0,0,0,.14)}
.widget-6ba973 h2{font-size:22px;margin-bottom:10px;line-height:1.3}
.widget-6ba973 h2 a{color:#2c3e50;text-decoration:none}
.widget-6ba973 .panel-94e3af{font-size:12px;color:#888;margin-bottom:10px;text-transform:uppercase;letter-spacing:1px}
.widget-6ba973 p{font-size:15px;color:#555;margin-bottom:14px}
.shell-99d556{color:#e74c3c;text-decoration:none;font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.5px}
.outer-4cd6e7{max-width:780px;margin:0 auto;padding:0 24px 60px}
.outer-4cd6e7 h1{font-size:36px;margin-bottom:10px;line-height:1.2}
.outer-4cd6e7 .panel-94e3af{font-size:13px;color:#888;display:block;margin-bottom:28px;text-transform:uppercase;letter-spacing:1px}
.outer-4cd6e7 h2{font-size:24px;margin:36px 0 14px}
.outer-4cd6e7 h3{font-size:19px;margin:28px 0 10px}
.outer-4cd6e7 p{margin-bottom:18px;font-size:17px}
.outer-4cd6e7 ul,.outer-4cd6e7 ol{margin:0 0 18px 28px}
.outer-4cd6e7 a{color:#e74c3c}
.outer-4cd6e7 img{max-width:100%;height:auto;border-radius:4px;margin:20px 0}
.layout-185ee8{border-top:2px solid #ddd;padding:28px 0;margin-top:48px;text-align:center;font-size:13px;color:#888}
.layout-185ee8 a{color:#888}
.content-b6e9d3{border-top:1px solid #ccc;border-bottom:1px solid #ccc;padding:14px 0;margin-bottom:28px;font-size:14px;color:#888;font-style:italic;text-align:center}
.shell-addc1d{background:#f9f3e3;padding:16px 20px;margin-top:28px;font-size:13px;color:#7a6230;border-radius:4px}
.nav-3be1af{font-size:11px;color:#888;margin:-22px 0 28px;text-transform:uppercase;letter-spacing:1.5px}
.inner-87a54a{margin:0 0 28px}
.frame-d4b108{width:100%;height:auto;border-radius:4px}
.header-3ca976{margin:28px 0}
.widget-438b28{width:100%;height:auto;border-radius:4px}
.outer-24649f{border-top:2px solid #ddd;margin-top:40px;padding-top:24px}
.outer-24649f h4{font-size:16px;text-transform:uppercase;letter-spacing:1px;margin-bottom:16px;color:#888}
.mag-related-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.mag-related-item a{color:#2c3e50;text-decoration:none;font-size:15px}
.mag-related-item a:hover{color:#e74c3c}
/* === Theme === */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Montserrat:wght@400;700&display=swap');
body{font-family:'Inter',sans-serif;color:#212529;background:#F8F9FA}
.frame-84f7ce{background:#1B4332;color:#fff}
.frame-84f7ce h1{font-family:'Montserrat',serif;color:#fff}
.frame-84f7ce p{color:rgba(255,255,255,.75)}
.frame-84f7ce a{color:#fff;text-decoration:none}
.card h2{font-family:'Montserrat',serif}
.card h2 a{color:#1B4332}
.card h2 a:hover{color:#2ECC71}
.read-more{color:#2ECC71}
.article-content h1{font-family:'Montserrat',serif}
.article-content h2{font-family:'Montserrat',serif}
.article-content a{color:#2ECC71}
.article-content img{border-radius:8px}
.affiliate-disclosure{border-radius:8px}
.ymyl-disclaimer{border-radius:8px}
/* === Custom === */
/* ec-econo-fr — custom.css v1 · magazine template */
/* Laurent Pichon · palette ardoise (#1E3A5C) + sauge (#3D7A4E) */

@import url('https://fonts.googleapis.com/css2?family=Source+Serif+4:ital,opsz,wght@0,8..60,300;0,8..60,400;0,8..60,600;1,8..60,400&family=Work+Sans:wght@400;500;600;700&display=swap');

/* ─── Design tokens ─── */
:root {
  --color-primary:        #1E3A5C;
  --color-primary-dark:   #0F1F32;
  --color-primary-light:  #E4EBF4;
  --color-accent:         #3D7A4E;
  --color-accent-dark:    #255C35;
  --color-accent-light:   #E5F2E9;
  --color-bg:             #F5F4F0;
  --color-bg-alt:         #E9E7E2;
  --color-text:           #1A1918;
  --color-text-secondary: #4A4845;
  --color-text-muted:     #7A7775;
  --color-border:         #CCC9C3;
  --color-border-light:   #E2E0DA;
  --color-link:           #1E3A5C;
  --color-link-hover:     #3D7A4E;
  --font-heading:         'Work Sans', system-ui, sans-serif;
  --font-body:            'Source Serif 4', Georgia, serif;
  --font-size-base:       17px;
  --font-size-sm:         15px;
  --font-size-lg:         19px;
  --font-size-xl:         22px;
  --font-size-2xl:        28px;
  --font-size-3xl:        36px;
  --line-height-body:     1.72;
  --line-height-heading:  1.18;
  --radius:               4px;
  --space:                8px;
  --content-width:        68ch;
}

/* ─── Base ─── */
*, *::before, *::after { box-sizing: border-box; }

html { font-size: var(--font-size-base); scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  font-size: var(--font-size-base);
  font-weight: 400;
  line-height: var(--line-height-body);
  color: var(--color-text);
  background-color: var(--color-bg);
  margin: 0;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img { max-width: 100%; height: auto; }

/* ─── Links ─── */
a {
  color: var(--color-link);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
  transition: color 0.15s ease;
}
a:hover { color: var(--color-link-hover); }
a:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 3px;
  border-radius: 2px;
}

/* ─── Headings ─── */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  font-weight: 700;
  line-height: var(--line-height-heading);
  color: var(--color-text);
  margin-top: 0;
  margin-bottom: calc(var(--space) * 2);
}
h1 { font-size: var(--font-size-3xl); }
h2 { font-size: var(--font-size-2xl); }
h3 { font-size: var(--font-size-xl); }
h4 { font-size: var(--font-size-lg); font-weight: 600; }
h5, h6 { font-size: var(--font-size-base); font-weight: 600; }

/* ─── Prose ─── */
p {
  margin-top: 0;
  margin-bottom: calc(var(--space) * 2);
  max-width: var(--content-width);
}
ul, ol {
  margin-top: 0;
  margin-bottom: calc(var(--space) * 2);
  padding-left: calc(var(--space) * 3);
  max-width: var(--content-width);
}
li { margin-bottom: var(--space); line-height: var(--line-height-body); }
li ul, li ol { margin-top: var(--space); margin-bottom: 0; }

blockquote {
  margin: calc(var(--space) * 3) 0;
  padding: calc(var(--space) * 2) calc(var(--space) * 3);
  border-left: 3px solid var(--color-accent);
  background-color: var(--color-bg-alt);
  border-radius: 0 var(--radius) var(--radius) 0;
  font-size: var(--font-size-lg);
  font-style: italic;
  color: var(--color-text-secondary);
  max-width: var(--content-width);
}
blockquote p { margin-bottom: 0; }
blockquote cite {
  display: block;
  margin-top: var(--space);
  font-size: var(--font-size-sm);
  font-style: normal;
  color: var(--color-text-muted);
}

/* ─── Magazine header ─── */
.frame-84f7ce {
  background-color: var(--color-primary);
  color: #fff;
  padding: calc(var(--space) * 3) calc(var(--space) * 2);
}
.frame-84f7ce h1 {
  font-family: var(--font-heading);
  font-weight: 700;
  color: #fff;
  margin-bottom: calc(var(--space) / 2);
  letter-spacing: -0.01em;
}
.frame-84f7ce p {
  color: rgba(255,255,255,0.76);
  font-family: var(--font-heading);
  font-size: var(--font-size-sm);
  margin-bottom: 0;
  max-width: none;
}
.frame-84f7ce a { color: #fff; text-decoration: none; }
.frame-84f7ce a:hover { color: rgba(255,255,255,0.84); }

/* ─── Navigation ─── */
nav { background-color: var(--color-primary-dark); border-top: 1px solid rgba(255,255,255,0.08); }
nav a {
  color: rgba(255,255,255,0.82);
  text-decoration: none;
  font-family: var(--font-heading);
  font-size: var(--font-size-sm);
  font-weight: 500;
  padding: var(--space) calc(var(--space) * 1.5);
  display: inline-block;
  letter-spacing: 0.02em;
  transition: color 0.15s ease, background-color 0.15s ease;
}
nav a:hover { color: #fff; background-color: rgba(255,255,255,0.08); }

/* ─── Cards ─── */
.card {
  background-color: #fff;
  border: 1px solid var(--color-border-light);
  border-radius: var(--radius);
  overflow: hidden;
  transition: box-shadow 0.15s ease;
}
.card:hover { box-shadow: 0 2px 12px rgba(30,58,92,0.10); }
.card h2 {
  font-family: var(--font-heading);
  font-size: var(--font-size-xl);
  font-weight: 600;
  line-height: 1.25;
  margin-bottom: var(--space);
}
.card h2 a { color: var(--color-text); text-decoration: none; }
.card h2 a:hover { color: var(--color-primary); }
.card-excerpt { font-size: var(--font-size-sm); color: var(--color-text-secondary); line-height: 1.65; }
.read-more {
  font-family: var(--font-heading);
  font-size: var(--font-size-sm);
  font-weight: 600;
  color: var(--color-accent);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.read-more:hover { color: var(--color-accent-dark); }

/* ─── Article content ─── */
.article-content { max-width: 72ch; }
.article-content h1 {
  font-family: var(--font-heading);
  font-size: var(--font-size-3xl);
  font-weight: 700;
  line-height: 1.14;
}
.article-content h2 {
  font-family: var(--font-heading);
  font-size: var(--font-size-2xl);
  font-weight: 700;
  margin-top: calc(var(--space) * 5);
  padding-bottom: var(--space);
  border-bottom: 2px solid var(--color-border-light);
}
.article-content h3 {
  font-family: var(--font-heading);
  font-size: var(--font-size-xl);
  font-weight: 600;
  margin-top: calc(var(--space) * 4);
}
.article-content p { font-size: var(--font-size-base); line-height: var(--line-height-body); max-width: var(--content-width); }
.article-content a { color: var(--color-primary); text-underline-offset: 3px; }
.article-content a:hover { color: var(--color-accent); }
.article-content ul, .article-content ol { max-width: var(--content-width); }
.article-content img { border-radius: var(--radius); display: block; }
.article-content strong { font-weight: 600; }

/* ─── Post meta ─── */
.post-meta {
  font-family: var(--font-heading);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  margin-bottom: calc(var(--space) * 3);
}
.post-meta a { color: var(--color-text-secondary); text-decoration: none; }
.post-meta a:hover { color: var(--color-primary); }

/* ─── Footer ─── */
footer {
  background-color: var(--color-primary-dark);
  color: rgba(255,255,255,0.70);
  font-family: var(--font-heading);
  font-size: var(--font-size-sm);
  padding: calc(var(--space) * 4) calc(var(--space) * 2);
  margin-top: calc(var(--space) * 6);
}
footer a { color: rgba(255,255,255,0.82); text-decoration: none; }
footer a:hover { color: #fff; }

/* === R2 fixes (2026-06-21T23:20:08.210764+00:00) === */

/* Fix 1 — inline images: contain width so text stays the main element */
.header-3ca976 img {
  max-width: 620px;
  margin: 2em auto;
  display: block;
}

/* Fix 2 — related articles section: clear visual separator from article body */
.outer-24649f {
  border-top: 2px solid #1E3A5C;
  padding-top: 1.75em;
  margin-top: 3em;
}

/* Fix 3 — related article links: visual presence so they get noticed at end of read */
.outer-24649f .mag-related-item a {
  display: block;
  padding: 0.75em 1em;
  background: #f0ebe3;
  border-left: 3px solid #1E3A5C;
  font-weight: 600;
  text-decoration: none;
}

/* Fix 4 — homepage grid: trim excess whitespace above footer */
.section-55fda8 {
  padding-bottom: 3em;
}

/* === R3 fixes (2026-06-22T00:00:10.954491+00:00) === */

/* Fix 1 — inline images: 460px keeps them as secondary illustration, text stays dominant */
.header-3ca976,
.header-3ca976 img {
  max-width: 460px;
  margin: 1.5em auto;
  display: block;
}

/* Fix 2 — related articles: warm background + full padding creates clear visual separation */
.outer-24649f {
  border-top: 2px solid #1E3A5C;
  margin-top: 3em;
  padding: 1.5em;
  background: #eee8dc;
}

/* Fix 3 — related links: sage accent border + block treatment so readers notice before leaving */
.outer-24649f .mag-related-item a {
  display: block;
  padding: 0.75em 1em;
  background: #f5f0e8;
  border-left: 3px solid #3D7A4E;
  font-weight: 600;
  text-decoration: none;
  color: #1E3A5C;
  margin-top: 0.5em;
}

/* Fix 4 — homepage grid: remove excess height, page feels complete not unfinished */
.section-55fda8 {
  min-height: auto;
  padding-bottom: 2em;
}
