/*
Theme Name: MDB Reform Light
Theme URI: https://mdbreform.com
Author: MDB Reform
Description: Cream editorial theme — Foreign Affairs style. MDB in black, Reform in red italic. Fully dynamic.
Version: 1.0.0
Text Domain: mdbreform-light
*/

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,700;0,800;1,700&family=Source+Sans+Pro:ital,wght@0,300;0,400;0,600;1,300;1,400&display=swap');

:root {
  --bg:        #faf8f4;
  --bg-2:      #f2efe9;
  --bg-3:      #eae7e0;
  --rule:      #d8d3ca;
  --navy:      #1a2744;
  --gold:      #b07d3a;
  --ink:       #1a1a1a;
  --ink-mid:   #3c3c3c;
  --ink-dim:   #787064;
  --red:       #b5121b;
  --white:     #ffffff;
  --font-serif:'Playfair Display', Georgia, serif;
  --font-sans: 'Source Sans Pro', Arial, sans-serif;
  --max-width: 1200px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:16px;scroll-behavior:smooth;}
body{background:var(--bg);color:var(--ink-mid);font-family:var(--font-sans);font-size:1rem;line-height:1.75;-webkit-font-smoothing:antialiased;}
img{display:block;max-width:100%;height:auto;}
a{color:var(--navy);text-decoration:none;}
a:hover{color:var(--red);}
ul{list-style:none;}

.container{max-width:var(--max-width);margin:0 auto;padding:0 2rem;}

/* Utility bar */
.utility-bar{background:var(--navy);}
.utility-bar-inner{max-width:var(--max-width);margin:0 auto;padding:0 2rem;display:flex;align-items:center;justify-content:space-between;height:34px;}
.utility-bar a{font-size:0.66rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.5);margin-right:1.2rem;}
.utility-bar a:hover{color:var(--gold);}
.utility-date{font-size:0.66rem;color:rgba(255,255,255,0.3);letter-spacing:0.05em;}

/* Masthead */
.site-header{background:var(--white);border-bottom:3px solid var(--ink);padding:1.6rem 0 0.8rem;}
.masthead-inner{max-width:var(--max-width);margin:0 auto;padding:0 2rem;text-align:center;}
.site-eyebrow{font-family:var(--font-sans);font-size:0.62rem;font-weight:600;letter-spacing:0.22em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:0.3rem;}
.site-title{font-family:var(--font-serif);font-size:clamp(2.4rem,7vw,4.8rem);font-weight:700;letter-spacing:-0.02em;line-height:1;color:var(--ink);margin-bottom:0.5rem;}
.site-title a{color:inherit;}
.site-title a:hover{color:var(--ink);}
.site-title .reform{color:var(--red);font-style:italic;}
.masthead-rule-row{display:flex;align-items:center;gap:1rem;margin:0.4rem 0;}
.masthead-rule-row hr{flex:1;border:none;border-top:1px solid var(--rule);}
.masthead-tagline{font-family:var(--font-sans);font-size:0.65rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-dim);white-space:nowrap;}
.masthead-datebar{font-size:0.68rem;color:var(--ink-dim);letter-spacing:0.06em;display:flex;align-items:center;justify-content:center;gap:0.6rem;padding-bottom:0.5rem;}
.masthead-datebar .dot{width:3px;height:3px;background:var(--ink-dim);border-radius:50%;display:inline-block;}

/* Navigation */
.main-navigation{background:var(--white);border-bottom:1px solid var(--rule);position:sticky;top:0;z-index:100;box-shadow:0 1px 3px rgba(0,0,0,0.06);}
.nav-inner{max-width:var(--max-width);margin:0 auto;padding:0 2rem;}
.main-navigation ul{display:flex;align-items:center;flex-wrap:wrap;}
.main-navigation ul li a{display:block;padding:0.65rem 0.9rem;font-family:var(--font-sans);font-size:0.75rem;font-weight:600;color:var(--ink-mid);letter-spacing:0.05em;text-transform:uppercase;transition:color 0.2s;}
.main-navigation ul li a:hover,.main-navigation ul li.current-menu-item>a{color:var(--navy);border-bottom:2px solid var(--navy);}
.menu-toggle{display:none;background:none;border:1px solid var(--rule);color:var(--ink-mid);padding:0.4rem 0.8rem;font-size:0.85rem;cursor:pointer;margin:0.4rem 0;}

/* Featured band */
.featured-band{background:var(--bg-2);border-bottom:1px solid var(--rule);padding:0.4rem 0;}
.featured-band-inner{max-width:var(--max-width);margin:0 auto;padding:0.3rem 2rem;display:flex;align-items:center;gap:1rem;font-size:0.82rem;}
.featured-badge{background:var(--red);color:var(--white);font-size:0.6rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;padding:0.2rem 0.5rem;white-space:nowrap;flex-shrink:0;}
.featured-band a{color:var(--ink-mid);font-style:italic;}
.featured-band a:hover{color:var(--red);}

/* Hero */
.hero-section{background:var(--white);border-bottom:1px solid var(--rule);padding:2.5rem 0;}
.hero-inner{max-width:var(--max-width);margin:0 auto;padding:0 2rem;display:grid;grid-template-columns:1fr 300px;gap:3rem;align-items:start;}
.hero-section-label{font-size:0.62rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-dim);border-bottom:2px solid var(--rule);padding-bottom:0.4rem;margin-bottom:1rem;display:block;}
.hero-title{font-family:var(--font-serif);font-size:clamp(1.5rem,3.5vw,2.4rem);font-weight:700;line-height:1.2;color:var(--ink);margin:0.3rem 0 0.8rem;}
.hero-title a{color:inherit;}
.hero-title a:hover{color:var(--red);}
.hero-deck{font-size:0.95rem;font-style:italic;color:var(--ink-mid);line-height:1.65;margin-bottom:0.8rem;}
.hero-meta{font-size:0.7rem;color:var(--ink-dim);letter-spacing:0.04em;text-transform:uppercase;margin-bottom:1rem;border-top:1px solid var(--rule);padding-top:0.6rem;}
.hero-secondary{border-left:1px solid var(--rule);padding-left:2rem;}

/* Cards */
.article-card{border-bottom:1px solid var(--rule);padding-bottom:1.4rem;}
.article-card:last-child{border-bottom:none;}
.card-category{display:inline-block;font-size:0.6rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--gold);margin-bottom:0.3rem;}
.card-title{font-family:var(--font-serif);font-size:1rem;font-weight:700;line-height:1.3;margin-bottom:0.4rem;}
.card-title a{color:var(--ink);}
.card-title a:hover{color:var(--red);}
.card-excerpt{font-size:0.83rem;color:var(--ink-dim);font-style:italic;line-height:1.55;margin-bottom:0.4rem;}
.card-meta{font-size:0.66rem;color:var(--ink-dim);}
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;}
.card-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;}
.card-image img{width:100%;height:160px;object-fit:cover;margin-bottom:0.7rem;}

/* Content area */
.content-area{max-width:var(--max-width);margin:0 auto;padding:2.5rem 2rem;display:grid;grid-template-columns:1fr 260px;gap:3rem;align-items:start;}
.content-area.no-sidebar{grid-template-columns:1fr;}
.section-label{display:block;font-size:0.6rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-dim);border-bottom:2px solid var(--ink);padding-bottom:0.4rem;margin-bottom:1.5rem;}
.section-divider{border:none;border-top:1px solid var(--rule);margin:2.5rem 0;}

/* Sidebar */
.widget{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid var(--rule);}
.widget:last-child{border-bottom:none;}
.widget-title{font-family:var(--font-serif);font-size:0.88rem;font-weight:700;color:var(--ink);margin-bottom:0.8rem;padding-bottom:0.3rem;border-bottom:2px solid var(--red);display:inline-block;}
.widget ul li{padding:0.35rem 0;border-bottom:1px solid var(--rule);font-size:0.84rem;}
.widget ul li:last-child{border-bottom:none;}
.widget ul li a{color:var(--ink-mid);}
.widget ul li a:hover{color:var(--red);}
.search-form{display:flex;gap:0.4rem;}
.search-form input[type="search"]{flex:1;background:var(--white);border:1px solid var(--rule);color:var(--ink);padding:0.4rem 0.6rem;font-size:0.85rem;outline:none;}
.search-form input[type="search"]:focus{border-color:var(--navy);}
.search-form button{background:var(--navy);border:none;color:var(--white);padding:0.4rem 0.6rem;cursor:pointer;}

/* Buttons */
.btn{display:inline-block;padding:0.5rem 1.2rem;font-size:0.7rem;font-weight:600;letter-spacing:0.07em;text-transform:uppercase;cursor:pointer;transition:all 0.2s;}
.btn-primary{background:var(--navy);color:var(--white);border:none;}
.btn-primary:hover{background:var(--red);color:var(--white);}
.btn-outline{background:transparent;color:var(--navy);border:1px solid var(--navy);}
.btn-outline:hover{background:var(--navy);color:var(--white);}

/* Single post */
.entry-header{margin-bottom:2rem;border-bottom:1px solid var(--rule);padding-bottom:1.5rem;}
.entry-title{font-family:var(--font-serif);font-size:clamp(1.6rem,4vw,2.8rem);font-weight:700;color:var(--ink);line-height:1.2;margin-bottom:1rem;}
.entry-meta{font-size:0.73rem;color:var(--ink-dim);}
.entry-thumbnail{margin-bottom:2rem;}
.entry-thumbnail img{width:100%;max-height:420px;object-fit:cover;}
.entry-content{font-size:1rem;line-height:1.82;color:var(--ink-mid);}
.entry-content p{margin-bottom:1.4rem;}
.entry-content h2{font-family:var(--font-serif);font-size:1.5rem;color:var(--ink);margin:2rem 0 1rem;border-left:4px solid var(--red);padding-left:1rem;}
.entry-content h3{font-family:var(--font-serif);font-size:1.2rem;color:var(--ink);margin:1.5rem 0 0.8rem;}
.entry-content blockquote{border-left:4px solid var(--gold);background:var(--bg-2);padding:1rem 1.5rem;margin:1.5rem 0;font-style:italic;color:var(--ink-dim);}
.entry-content ul,.entry-content ol{padding-left:1.5rem;margin-bottom:1.2rem;}
.entry-content ul{list-style:disc;}
.entry-content ol{list-style:decimal;}
.entry-content li{margin-bottom:0.4rem;}
.entry-content table{width:100%;border-collapse:collapse;margin:1.5rem 0;font-size:0.9rem;}
.entry-content th{background:var(--navy);color:var(--white);padding:0.6rem 0.8rem;text-align:left;font-weight:600;}
.entry-content td{padding:0.5rem 0.8rem;border-bottom:1px solid var(--rule);color:var(--ink-mid);}
.entry-content tr:nth-child(even) td{background:var(--bg-2);}

/* Breadcrumbs */
.breadcrumbs{max-width:var(--max-width);margin:0 auto;padding:0.55rem 2rem;font-size:0.73rem;color:var(--ink-dim);border-bottom:1px solid var(--rule);background:var(--bg-2);}
.breadcrumbs a{color:var(--navy);}
.breadcrumbs span{margin:0 0.4rem;}

/* About band */
.about-band{background:var(--bg-2);border-left:4px solid var(--navy);padding:2rem;}
.about-band h2{font-family:var(--font-serif);font-size:1.3rem;color:var(--ink);margin-bottom:0.8rem;}
.about-band p{font-size:0.9rem;color:var(--ink-dim);line-height:1.7;margin-bottom:1rem;}

/* Topic band */
.topic-band{background:var(--bg-2);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:2rem 0;}
.topic-band-inner{max-width:var(--max-width);margin:0 auto;padding:0 2rem;}
.topic-band h2{font-family:var(--font-sans);font-size:0.62rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:1rem;}
.topic-pills{display:flex;flex-wrap:wrap;gap:0.5rem;}
.topic-pill{display:inline-block;padding:0.3rem 0.75rem;font-size:0.65rem;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;color:var(--ink-dim);border:1px solid var(--rule);transition:all 0.2s;}
.topic-pill:hover{background:var(--navy);color:var(--white);border-color:var(--navy);}

/* Footer */
.site-footer{background:var(--ink);border-top:3px solid var(--red);padding:3rem 0 0;}
.footer-inner{max-width:var(--max-width);margin:0 auto;padding:0 2rem 2rem;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.5rem;}
.footer-title{font-family:var(--font-serif);font-size:1.3rem;font-weight:700;color:var(--white);margin-bottom:0.5rem;}
.footer-title .reform{color:var(--red);font-style:italic;}
.footer-brand p{font-size:0.78rem;color:rgba(255,255,255,0.35);line-height:1.65;margin-bottom:0.4rem;}
.footer-col h4{font-size:0.6rem;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:var(--gold);margin-bottom:0.8rem;padding-bottom:0.4rem;border-bottom:1px solid rgba(255,255,255,0.1);}
.footer-col ul li{padding:0.3rem 0;font-size:0.78rem;}
.footer-col ul li a{color:rgba(255,255,255,0.4);}
.footer-col ul li a:hover{color:var(--gold);}
.footer-bottom-outer{border-top:1px solid rgba(255,255,255,0.1);}
.footer-bottom{max-width:var(--max-width);margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;font-size:0.7rem;color:rgba(255,255,255,0.25);}
.footer-nav{display:flex;gap:1.5rem;}
.footer-nav a{color:rgba(255,255,255,0.25);}
.footer-nav a:hover{color:var(--gold);}

/* Pagination */
.pagination{display:flex;gap:0.3rem;margin-top:2rem;flex-wrap:wrap;}
.pagination a,.pagination span{display:inline-block;padding:0.4rem 0.8rem;font-size:0.78rem;border:1px solid var(--rule);color:var(--ink-dim);background:var(--white);}
.pagination a:hover{background:var(--navy);color:var(--white);border-color:var(--navy);}
.pagination .current{background:var(--red);color:var(--white);border-color:var(--red);}

/* Archive */
.archive-header{border-top:3px solid var(--navy);padding-top:1.5rem;margin-bottom:2rem;}
.archive-header h1{font-family:var(--font-serif);font-size:2rem;color:var(--ink);}

/* 404 */
.error-404{text-align:center;padding:5rem 2rem;}
.error-404 h1{font-family:var(--font-serif);font-size:4rem;color:var(--red);margin-bottom:1rem;}
.error-404 p{color:var(--ink-dim);margin-bottom:1.5rem;}

/* Responsive */
@media(max-width:900px){
  .hero-inner{grid-template-columns:1fr;}
  .hero-secondary{border-left:none;padding-left:0;border-top:1px solid var(--rule);padding-top:1.5rem;}
  .content-area{grid-template-columns:1fr;}
  .sidebar{border-top:1px solid var(--rule);padding-top:2rem;}
  .card-grid{grid-template-columns:repeat(2,1fr);}
  .footer-inner{grid-template-columns:1fr 1fr;}
}
@media(max-width:600px){
  .main-navigation ul{display:none;flex-direction:column;}
  .main-navigation ul.active{display:flex;}
  .menu-toggle{display:block;}
  .utility-bar{display:none;}
  .card-grid,.card-grid-2{grid-template-columns:1fr;}
  .footer-inner{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;gap:0.5rem;text-align:center;}
}

/* ── Painting Hero ────────────────────────────────────────── */
.painting-section {
  background: var(--ink);
  border-bottom: 1px solid var(--rule);
}
.painting-inner {
  max-width: var(--max-width);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 380px 1fr;
  align-items: stretch;
  min-height: 460px;
}
.painting-image-wrap {
  position: relative;
  overflow: hidden;
}
.painting-image-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 15%;
  display: block;
}
.painting-placeholder {
  width: 100%;
  height: 100%;
  min-height: 460px;
  background: var(--bg-3);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ink-dim);
  font-size: 0.78rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: center;
  padding: 2rem;
}
.painting-text {
  padding: 3.5rem 3.5rem 3.5rem 4rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.painting-eyebrow {
  font-family: var(--font-sans);
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 1.2rem;
}
.painting-quote {
  font-family: var(--font-serif);
  font-size: clamp(1.6rem, 3vw, 2.6rem);
  font-weight: 700;
  font-style: italic;
  line-height: 1.25;
  color: var(--white);
  margin-bottom: 1.5rem;
}
.painting-quote em {
  color: var(--red);
  font-style: normal;
}
.painting-body {
  font-size: 0.92rem;
  color: rgba(255,255,255,0.55);
  line-height: 1.75;
  margin-bottom: 1.8rem;
  max-width: 480px;
}
.painting-caption {
  font-family: var(--font-sans);
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.25);
  border-top: 1px solid rgba(255,255,255,0.1);
  padding-top: 1rem;
  margin-top: auto;
}
@media (max-width: 900px) {
  .painting-inner {
    display: flex;
    flex-direction: column;
  }
  .painting-image-wrap {
    order: 1;
    height: 520px;
    flex-shrink: 0;
  }
  .painting-image-wrap img {
    width: 100%;
    height: 520px;
    object-fit: cover;
    object-position: center 20%;
    display: block;
  }
  .painting-placeholder {
    min-height: 520px;
    order: 1;
  }
  .painting-text {
    order: 2;
    padding: 2.5rem 2rem;
    background: var(--ink);
  }
}