/*
  Ellwanger Painting — Resources & Articles index
  Palette: primary #2e5f84, accent #c48416, dark #640505, text #0f172a
  Notes:
  - Mobile-first; breakpoints at 640px, 900px, 1100px
  - Magazine-style article grid that scales from 2 to 20+ articles
  - Header & footer styling lives in /bellingham-location/css/header_footer.css
  - Category taxonomy baked into data-category attributes for future filter UI
*/

:root{
  --brand-primary:#2e5f84;
  --brand-accent:#c48416;
  --brand-dark:#640505;
  --bg:#ffffff;
  --bg-soft:#f8fafc;
  --bg-tint:rgba(46,95,132,0.06);
  --text:#0f172a;
  --text-muted:#475569;
  --text-light:#64748b;
  --border:#e2e8f0;
  --border-strong:#cbd5e1;
  --radius:16px;
  --radius-sm:10px;
  --shadow-sm:0 4px 16px rgba(15,23,42,0.06);
  --shadow:0 6px 18px rgba(15,23,42,0.08);
  --shadow-lg:0 12px 30px rgba(15,23,42,0.16);
}

/* ── Page wrap ─────────────────────────────────────────────── */
.res-page{
  max-width:1100px;
  margin:0 auto;
  padding:1.75rem 1.25rem 3rem;
  color:var(--text);
  line-height:1.65;
  font-size:1rem;
}
@media (min-width:768px){
  .res-page{ padding:2.5rem 2rem 4rem; font-size:1.05rem; }
}

/* ── Breadcrumbs ───────────────────────────────────────────── */
.res-crumbs{ margin:0 0 1.5rem; }
.res-crumbs ol{
  list-style:none; padding:0; margin:0;
  display:flex; flex-wrap:wrap; align-items:center;
  gap:0.4rem; font-size:0.85rem; color:var(--text-light);
}
.res-crumbs a{
  color:var(--brand-primary); text-decoration:none; font-weight:600;
  transition:color 0.15s ease;
}
.res-crumbs a:hover{ color:var(--brand-accent); text-decoration:underline; }
.res-crumbs li[aria-current="page"]{ color:var(--text-muted); font-weight:600; }
.res-crumbs li[aria-hidden="true"]{ color:var(--border-strong); }

/* ── Hero ──────────────────────────────────────────────────── */
.res-hero{
  margin:0 0 2.5rem;
  padding-bottom:1.75rem;
  border-bottom:2px solid var(--border);
}
.res-hero h1{
  color:var(--brand-primary);
  font-size:1.85rem;
  font-weight:800;
  line-height:1.18;
  letter-spacing:-0.015em;
  margin:0 0 0.85rem;
}
@media (min-width:768px){
  .res-hero h1{ font-size:2.4rem; }
}
@media (min-width:1100px){
  .res-hero h1{ font-size:2.65rem; }
}
.res-tag{
  display:inline-flex; align-items:center; gap:0.4rem;
  padding:0.3rem 0.75rem;
  border-radius:999px;
  background:var(--bg-tint);
  color:var(--text-light);
  font-size:0.78rem;
  text-transform:uppercase;
  letter-spacing:0.12em;
  font-weight:600;
  margin-bottom:0.85rem;
}
.res-tag .dot{ width:6px; height:6px; border-radius:50%; background:var(--brand-accent); }
.res-subtitle{
  font-size:1.08rem;
  color:var(--text-muted);
  line-height:1.6;
  margin:0;
  max-width:62ch;
}
@media (min-width:768px){
  .res-subtitle{ font-size:1.15rem; }
}

/* ── Article grid ──────────────────────────────────────────── */
.res-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:1.5rem;
  margin:0 0 3rem;
}
@media (min-width:640px){
  .res-grid{ grid-template-columns:repeat(2, 1fr); gap:1.75rem; }
}
@media (min-width:1100px){
  .res-grid{ grid-template-columns:repeat(3, 1fr); }
}

/* ── Card ──────────────────────────────────────────────────── */
.res-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  transition:transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
  display:flex;
  flex-direction:column;
}
.res-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-lg);
  border-color:var(--border-strong);
}

.res-card__link{
  text-decoration:none;
  color:inherit;
  display:flex;
  flex-direction:column;
  height:100%;
}

/* Card media (colored header block with category icon) */
.res-card__media{
  position:relative;
  aspect-ratio:16/9;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.res-card__media--blue{
  background:linear-gradient(135deg, #2e5f84 0%, #4a7ba6 60%, #1e4360 100%);
}
.res-card__media--gold{
  background:linear-gradient(135deg, #c48416 0%, #e0a64a 55%, #8a5d10 100%);
}
.res-card__media--maroon{
  background:linear-gradient(135deg, #640505 0%, #92242a 55%, #4a0a0a 100%);
}
.res-card__media--slate{
  background:linear-gradient(135deg, #475569 0%, #64748b 60%, #334155 100%);
}

.res-card__icon{
  color:rgba(255,255,255,0.78);
  font-size:3.2rem;
  line-height:1;
  filter:drop-shadow(0 4px 12px rgba(0,0,0,0.18));
  transition:transform 0.25s ease, color 0.25s ease;
}
.res-card:hover .res-card__icon{
  transform:scale(1.08);
  color:#fff;
}

.res-card__badge{
  position:absolute;
  top:0.85rem;
  right:0.85rem;
  background:#fff;
  color:var(--brand-dark);
  font-size:0.72rem;
  font-weight:800;
  letter-spacing:0.12em;
  text-transform:uppercase;
  padding:0.3rem 0.65rem;
  border-radius:999px;
  box-shadow:0 2px 8px rgba(0,0,0,0.14);
}

/* Card body */
.res-card__body{
  padding:1.25rem 1.4rem 1.4rem;
  display:flex;
  flex-direction:column;
  flex:1;
  gap:0.6rem;
}

.res-card__meta{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:0.4rem;
  font-size:0.78rem;
  color:var(--text-light);
  text-transform:uppercase;
  letter-spacing:0.08em;
  font-weight:600;
}
.res-card__category{
  color:var(--brand-primary);
}
.res-card__divider{
  color:var(--border-strong);
}
.res-card__time{
  color:var(--text-light);
  font-weight:500;
  letter-spacing:0.04em;
  text-transform:none;
  font-size:0.8rem;
}

.res-card__title{
  font-size:1.18rem;
  font-weight:700;
  line-height:1.28;
  color:var(--text);
  margin:0;
  letter-spacing:-0.005em;
}
@media (min-width:768px){
  .res-card__title{ font-size:1.25rem; }
}

.res-card__dek{
  font-size:0.95rem;
  color:var(--text-muted);
  line-height:1.55;
  margin:0;
}

.res-card__cta{
  margin-top:auto;
  padding-top:0.75rem;
  display:inline-flex;
  align-items:center;
  gap:0.3rem;
  font-size:0.95rem;
  font-weight:700;
  color:var(--brand-primary);
  letter-spacing:0.01em;
  transition:color 0.18s ease, transform 0.18s ease;
}
.res-card:hover .res-card__cta{
  color:var(--brand-accent);
}
.res-card:hover .res-card__cta::after{
  transform:translateX(4px);
}

/* ── Coming soon section ──────────────────────────────────── */
.res-coming{
  background:var(--bg-soft);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:1.5rem 1.75rem;
  margin:0 0 2.5rem;
}
.res-coming h2{
  margin:0 0 0.75rem;
  font-size:1.25rem;
  color:var(--brand-primary);
  font-weight:700;
}
.res-coming p{
  margin:0 0 0.85rem;
  color:var(--text);
  font-size:0.98rem;
}
.res-coming__list{
  list-style:none;
  padding:0;
  margin:0 0 1rem;
  display:flex;
  flex-direction:column;
  gap:0.5rem;
}
.res-coming__list li{
  padding:0.6rem 0.85rem;
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius-sm);
  font-size:0.95rem;
  line-height:1.5;
}
.res-coming__cat{
  display:inline-block;
  font-size:0.72rem;
  font-weight:700;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--brand-primary);
  background:var(--bg-tint);
  padding:0.2rem 0.55rem;
  border-radius:999px;
  margin-right:0.5rem;
}
.res-coming__note{
  font-size:0.92rem !important;
  color:var(--text-muted) !important;
  margin:0 !important;
  padding-top:0.85rem;
  border-top:1px solid var(--border);
}
.res-coming a{
  color:var(--brand-primary);
  font-weight:600;
}
.res-coming a:hover{
  color:var(--brand-accent);
}

/* ── CTA ───────────────────────────────────────────────────── */
.res-cta{
  text-align:center;
  background:var(--brand-primary);
  color:#fff;
  border-radius:var(--radius);
  padding:2rem 1.5rem;
  box-shadow:var(--shadow);
}
.res-cta h2{
  color:#fff;
  margin:0 0 0.6rem;
  font-size:1.45rem;
  font-weight:700;
}
.res-cta p{
  color:rgba(255,255,255,0.92);
  font-size:1rem;
  margin:0 0 1.25rem;
}
.res-cta .btn-primary{
  display:inline-block;
  background:var(--brand-accent);
  color:#fff;
  padding:0.85rem 1.6rem;
  border-radius:999px;
  font-weight:700;
  text-decoration:none;
  font-size:1rem;
  letter-spacing:0.01em;
  box-shadow:0 4px 14px rgba(196,132,22,0.4);
  transition:transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}
.res-cta .btn-primary:hover{
  background:#a86f12;
  transform:translateY(-2px);
  box-shadow:0 6px 18px rgba(196,132,22,0.5);
}

/* ── Print ─────────────────────────────────────────────────── */
@media print{
  .site-header, footer, .res-cta{ display:none !important; }
  .res-page{ max-width:100%; padding:0; }
  .res-card{ box-shadow:none; break-inside:avoid; }
}
