/* ================ RECI Media Hub — Pitt-styled Base ===================== */

/* Vars */
:root{
  --pitt-blue:#003594; --pitt-gold:#FFB81C; --anthracite:#2B2B2B;
  --gray-100:#F7F7FB; --gray-150:#F1F2F6; --gray-300:#E8E9EE; --link-blue:#3366FF;
  --text:#1E1F24; --container:1280px; --radius:14px;
  --elev-1:0 2px 10px rgba(0,0,0,.08); --elev-2:0 8px 22px rgba(0,0,0,.12);
}

/* Reset & type */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font:16px/1.45 system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";
  color:var(--text); background:#fff; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{margin:0 0 .6rem;line-height:1.15;color:var(--anthracite)}
h1{font-size:clamp(1.8rem,2.4vw+1rem,2.4rem)}
h2{font-size:clamp(1.4rem,1.8vw+.8rem,2rem)}
h3{font-size:clamp(1.05rem,1.2vw+.7rem,1.35rem)}
p{margin:0 0 .9rem}
a{color:var(--link-blue);text-decoration:none}
a:hover{text-decoration:underline}

/* Utils */
.m-0{margin:0!important}.mt-1{margin-top:.5rem!important}.mt-2{margin-top:1rem!important}.mt-3{margin-top:1.5rem!important}
.mb-1{margin-bottom:.5rem!important}.mb-2{margin-bottom:1rem!important}

/* Layout */
.container{width:min(100%,calc(var(--container) + 32px));padding:0 16px;margin:0 auto}
.home-grid{display:grid;gap:22px;grid-template-columns:280px 1fr 320px}
@media (max-width:1180px){.home-grid{grid-template-columns:1fr}}

.grid{display:grid;gap:18px}
.grid-3{grid-template-columns:repeat(3,1fr)}
@media (max-width:1080px){.grid-3{grid-template-columns:repeat(2,1fr)}}
@media (max-width:720px){.grid-3{grid-template-columns:1fr}}

/* Header */
.topbar{background:var(--pitt-blue);color:#fff;box-shadow:var(--elev-1)}
.topbar-inner{display:grid;align-items:center;gap:16px;grid-template-columns:auto 1fr auto;padding:12px 16px}
.brand{display:flex;align-items:center;gap:14px}
.brand img.pitt{height:42px}
.brand img.reci{height:62px} /* enlarged RECI logo */
.site-title{display:flex;flex-direction:column;line-height:1.05;color:#fff;font-weight:800}
.site-title .top{font-size:22px;letter-spacing:.2px}
.site-title .bottom{font-size:16px;opacity:.95}
@media (max-width:980px){.site-title{display:none}}

.nav{display:flex;align-items:center;gap:18px}
.nav a{color:#fff;font-weight:600;padding:8px 10px;border-radius:10px}
.nav a.active,.nav a:hover{background:rgba(255,255,255,.14);text-decoration:none}

.actions{display:flex;align-items:center;gap:12px}
.search input{width:360px;max-width:42vw;border:0;outline:0;padding:10px 12px;border-radius:12px}
.donate{background:#fff;color:var(--pitt-blue);font-weight:800;padding:.55rem 1rem;border-radius:12px;text-decoration:none}
.donate:hover{filter:brightness(.98)}

/* Sidebar */
.sidebar .widget{background:#fff;border:1px solid var(--gray-300);border-radius:var(--radius);padding:16px 16px 14px;box-shadow:var(--elev-1)}
.widget + .widget{margin-top:16px}
.pill{display:inline-flex;align-items:center;background:var(--gray-150);color:var(--pitt-blue);padding:8px 12px;border-radius:999px;font-weight:700}
.pill:hover{background:var(--gray-300);text-decoration:none}

/* Cards */
.card{background:#fff;border:1px solid var(--gray-300);border-radius:var(--radius);overflow:hidden;box-shadow:var(--elev-1)}
.media,.hero-media{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden}
.media{border-radius:var(--radius) var(--radius) 0 0}
.hero-media{border-radius:16px;box-shadow:var(--elev-2);background:#0b2f7a} /* fallback bg for letterbox */

/* Default: cover for standard cards */
.media>img,.hero-media>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block;transition:transform .45s ease}

/* For the 3 FEATURE tiles: fit (no cropping) */
.feature .hero-media>img{object-fit:contain;background:#0b2f7a}

/* Overlay */
.hero-media::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,rgba(0,0,0,.06) 20%,rgba(0,0,0,.32) 100%)}
.card:hover .media>img,.feature:hover .hero-media>img{transform:scale(1.03)}
.feature{position:relative;display:flex;flex-direction:column}
.feature .inner{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:18px 18px 20px;color:#fff}
.feature .inner h3{color:#fff;margin:.25rem 0 .35rem;line-height:1.12}
.feature .inner p{margin:0 0 .85rem;color:rgba(255,255,255,.96)}
.chip{display:inline-flex;align-items:center;gap:8px;background:#fff;color:var(--pitt-blue);padding:6px 12px;border-radius:999px;font-weight:800}

.card .body{padding:14px}
.btn{display:inline-flex;align-items:center;justify-content:center;border:0;cursor:pointer;font-weight:700;border-radius:12px;padding:.65rem 1rem;text-decoration:none}
.btn-royal{background:var(--pitt-blue);color:#fff}.btn-royal:hover{filter:brightness(1.03);text-decoration:none}
.btn-gold{background:var(--pitt-gold);color:#0F1B42}.btn-gold:hover{filter:brightness(1.03);text-decoration:none}

.notice{background:var(--gray-150);border:1px solid var(--gray-300);padding:12px 14px;border-radius:12px}

/* Footer */
.site-footer{background:var(--pitt-blue);color:#fff;margin-top:36px}
.site-footer .inner{display:grid;gap:24px;padding:26px 16px;grid-template-columns:repeat(2,1fr)}
.site-footer a{color:var(--pitt-gold)}
@media (max-width:720px){.site-footer .inner{grid-template-columns:1fr}}

/* === Featured 3-up cards: image fits box, text below === */
.feature-row{
  --gap: 22px;
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--gap);
  margin-top: 18px;
}

@media (min-width: 900px){
  .feature-row{ grid-template-columns: repeat(3, 1fr); }
}

.feature-card{
  background: #fff;
  border-radius: 16px;
  overflow: hidden;                 /* keep image inside the card */
  box-shadow: 0 8px 24px rgba(0,0,0,.08);
  display: flex;
  flex-direction: column;
}

.feature-media{
  width: 100%;
  aspect-ratio: 16/9;               /* consistent visual height */
  overflow: hidden;                 /* no bleed */
  background: #0b2f7a;              /* subtle letterbox if image loads late */
}

.feature-media img{
  width: 100%;
  height: 100%;
  object-fit: cover;                /* “exactly fills the box”, no stretching */
  object-position: center;
  display: block;
}

.feature-body{
  padding: 14px 16px 18px;
}

.kicker{
  display: inline-block;
  font: 600 12px/1.2 Roboto, system-ui, -apple-system, Segoe UI, Arial, sans-serif;
  color: #0b2f7a;
  background: #e8e9ee;
  border-radius: 999px;
  padding: 6px 10px;
  margin-bottom: 8px;
}

.feature-title{
  font: 700 22px/1.2 "Alternate Gothic ATF", Roboto, Arial, sans-serif;
  color: #2b2b2b;
  margin: 2px 0 8px;
}

.feature-blurb{
  margin: 0 0 12px;
  color: #3a3a3a;
}

.btn.btn-primary{
  display: inline-block;
  background: #003594;             /* Pitt Royal Blue */
  color: #fff;
  border-radius: 12px;
  padding: 10px 16px;
  text-decoration: none;
  font-weight: 600;
  transition: transform .05s ease, box-shadow .15s ease;
}

.btn.btn-primary:hover{
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(0,53,148,.25);
}

/* ===================== Learn page additions ===================== */

.page-learn { padding-block: 28px 56px; }

/* Aspect ratio helpers (robust image fit) */
.ratio-16x9 { position: relative; padding-top: 56.25%; overflow: hidden; border-radius: 12px; }
.ratio-1x1   { position: relative; padding-top: 100%;    overflow: hidden; border-radius: 12px; }
.ratio-16x9 > img, .ratio-1x1 > img {
  position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover;
}

/* Cards */
.card { background: #fff; border-radius: 14px; box-shadow: 0 8px 18px rgba(0,0,0,.06); overflow: hidden; }
.card-body { padding: 18px 20px; }
.card.hero-card .card-body { padding: 18px 20px 22px; }

/* Hero grid */
.learn-hero {
  display: grid; grid-template-columns: 2fr 1fr; gap: 24px; align-items: stretch; margin-bottom: 28px;
}
.key-points { margin: 10px 0 14px; padding-left: 18px; }
.key-points li { margin: 4px 0; }

.progress-card .progress-wrap { display: grid; grid-template-columns: 130px 1fr; gap: 16px; align-items: center; }
.progress-card .topic-list { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 8px; }
.chip { display:inline-block; padding: 6px 10px; border-radius: 999px; background:#e8e9ee; font-size: 13px; }
.muted { color:#62718a; font-size: 13px; }

/* Conic gradient progress ring */
.progress-circle {
  --value: 40;
  --track: #e8e9ee;
  --fill: #ffb81c; /* Pitt Gold */
  width: 120px; height: 120px; border-radius: 50%;
  background: conic-gradient(var(--fill) calc(var(--value) * 1%), var(--track) 0);
  display: grid; place-items: center;
  mask: radial-gradient(circle at 50% 50%, transparent 52%, #000 53%);
}
.progress-circle span { font-weight: 700; color:#2b2b2b; }

/* Buttons */
.btn { display:inline-flex; align-items:center; gap:8px; padding:10px 16px; border-radius:10px; font-weight:600; text-decoration:none; }
.btn-royal { background:#003594; color:#fff; }
.btn-gold { background:#ffb81c; color:#2b2b2b; }
.btn-outline { border:2px solid #003594; color:#003594; background:#fff; }
.btn-sm { padding:7px 12px; font-size: 14px; }
.btn:hover { filter: brightness(.95); }

/* Timeline (Accordion) */
.timeline-card { margin: 18px 0 28px; }
.accordion { display: grid; gap: 10px; }
.acc-item { border:1px solid #e8e9ee; border-radius:12px; overflow:hidden; }
.acc-head { width:100%; text-align:left; background:#f7f8fb; border:none; padding:14px 16px; font-weight:700; display:flex; justify-content:space-between; cursor:pointer; }
.acc-panel { display:none; padding:14px 16px; background:#fff; }
.acc-item.open .acc-panel { display:block; }
.acc-item.open .acc-icon { transform: rotate(180deg); }

/* Quick Reads grid */
.qr-header { display:flex; gap:16px; align-items:center; justify-content:space-between; flex-wrap:wrap; }
.qr-filters { display:flex; align-items:center; gap:12px; }
.qr-filters select { padding:8px 10px; border-radius:8px; border:1px solid #d7d9e0; }
.format-set label { margin-right:10px; font-size:14px; }
.qr-grid { display:grid; gap:18px; grid-template-columns: repeat(3, minmax(0,1fr)); margin-top:14px; }
.qr-card { background:#fff; border:1px solid #eef0f5; border-radius:14px; overflow:hidden; }
.qr-card .qr-meta { display:flex; justify-content:space-between; padding:10px 12px 0; }
.qr-card .pill { background:#e8e9ee; border-radius:999px; padding:4px 8px; font-size:12px; }
.qr-card .qr-title { padding:6px 12px 14px; font-size:18px; line-height:1.25; }

/* Dashboard widgets */
.learn-dash { display:grid; gap:18px; grid-template-columns: 280px 1fr; margin-top: 28px; }
.dash-card { height: 100%; }
.dash-card.wide { grid-column: 1 / -1; }
.badge-list { display:flex; flex-wrap:wrap; gap:8px; margin-top:8px; }
.activity-list { margin: 8px 0 0 16px; }
.events-row { display:grid; gap:16px; grid-template-columns: repeat(3, minmax(0,1fr)); }
.event-title { margin-top:8px; font-size:16px; }

/* Footer RECI */
.footer-reci { height: 34px; }

/* Small screens */
@media (max-width: 960px) {
  .learn-hero { grid-template-columns: 1fr; }
  .learn-dash { grid-template-columns: 1fr; }
  .qr-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 640px) {
  .qr-grid { grid-template-columns: 1fr; }
  .progress-card .progress-wrap { grid-template-columns: 1fr; justify-items:center; text-align:center; }
}

/* =========================
   LEARN PAGE (scoped only)
   ========================= */
.page-learn {
  --blue:#003594; --gold:#FFB81C; --ink:#0F172A; --muted:#E8E9EE; --card:#fff;
  background:#f6f8fc; color:var(--ink);
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

/* container + 2-col layout (main + sticky aside) */
.page-learn .container{max-width:1200px;margin-inline:auto;padding:28px 16px}
.page-learn .learn-layout{display:grid;grid-template-columns:1fr 360px;gap:24px}
.page-learn .sidebar{position:sticky;top:84px;height:max-content;display:flex;flex-direction:column;gap:18px}
@media (max-width:1080px){
  .page-learn .learn-layout{grid-template-columns:1fr}
  .page-learn .sidebar{position:static}
}

/* generic card */
.page-learn .card{background:var(--card);border:1px solid var(--muted);border-radius:18px;box-shadow:0 8px 24px #0001;padding:18px}

/* ----------------- HERO + “other courses” ----------------- */
.page-learn .hero{position:relative;border-radius:20px;overflow:hidden}
.page-learn .hero img{width:100%;height:100%;aspect-ratio:21/9;object-fit:cover;display:block}
.page-learn .hero .overlay{position:absolute;inset:0;background:linear-gradient(180deg,#0000 30%,#0007 100%)}
.page-learn .hero .meta{position:absolute;left:20px;right:20px;bottom:20px;color:#fff;text-shadow:0 2px 8px #0008}
.page-learn .pill{display:inline-flex;align-items:center;padding:6px 12px;border-radius:999px;background:#fff;color:#111;font-weight:800}
.page-learn .cta-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.page-learn .btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 16px;border-radius:12px;font-weight:700;text-decoration:none;border:2px solid transparent}
.page-learn .btn--blue{background:var(--blue);color:#fff}
.page-learn .btn--outline{background:#fff;color:var(--blue);border-color:var(--blue)}

/* “other courses” now UNDER hero (fixes the big gap) */
.page-learn .under-hero{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
@media (max-width:720px){.page-learn .under-hero{grid-template-columns:1fr}}
.page-learn .feature{position:relative;overflow:hidden;border-radius:18px}
.page-learn .feature img{width:100%;height:100%;aspect-ratio:16/9;object-fit:cover;display:block}
.page-learn .feature .meta{position:absolute;left:14px;right:14px;bottom:14px;color:#fff;text-shadow:0 2px 8px #0009}

/* ----------------- Timeline (accordion) ----------------- */
.page-learn .timeline .acc{border:1px solid var(--muted);border-radius:14px;overflow:hidden;background:#fff;margin:10px 0}
.page-learn .timeline .acc summary{list-style:none;padding:14px 16px;cursor:pointer;font-weight:800;display:flex;justify-content:space-between;align-items:center}
.page-learn .timeline .acc[open] summary{background:#f7f8fc;border-bottom:1px solid var(--muted)}
.page-learn .timeline .acc .body{padding:12px 16px}

/* ----------------- Quick Reads (images from web) ----------------- */
.page-learn .qr-head{display:flex;justify-content:space-between;gap:16px;align-items:center;margin-top:4px}
.page-learn .qr-filters{display:flex;gap:12px;align-items:center}
.page-learn .qr-grid{display:grid;gap:18px;grid-template-columns:repeat(3,minmax(0,1fr));margin-top:14px}
@media (max-width:1080px){.page-learn .qr-grid{grid-template-columns:1fr 1fr}}
@media (max-width:640px){.page-learn .qr-grid{grid-template-columns:1fr}}
.page-learn .qr-card{background:#fff;border:1px solid #eef0f5;border-radius:16px;overflow:hidden}
.page-learn .qr-card img{width:100%;height:220px;object-fit:cover;display:block} /* ensures images show */
.page-learn .qr-card .pad{padding:12px 14px}
.page-learn .qr-card .kicker{display:inline-block;background:#eef2ff;border:1px solid #dbe3ff;color:#102a72;font-weight:800;border-radius:999px;padding:4px 8px;font-size:12px;margin-bottom:6px}

/* ----------------- Resume (smaller) + Badges ----------------- */
.page-learn .resume-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width:980px){.page-learn .resume-grid{grid-template-columns:1fr}}
.page-learn .resume img{width:100%;height:240px;object-fit:cover;border-radius:12px;margin:8px 0 12px} /* smaller module */
.page-learn .badges .chips{display:flex;flex-wrap:wrap;gap:10px}
.page-learn .chip{background:#f0f3ff;border:1px solid #e1e7ff;color:#0b2e81;padding:8px 12px;border-radius:999px;font-weight:700}

/* ----------------- Recent Activities ----------------- */
.page-learn .activities{margin:8px 0 0 18px}

/* ----------------- Events (no cut off) ----------------- */
.page-learn .events-grid{display:grid;gap:18px;grid-template-columns:repeat(3,minmax(0,1fr))}
@media (max-width:1080px){.page-learn .events-grid{grid-template-columns:1fr 1fr}}
@media (max-width:720px){.page-learn .events-grid{grid-template-columns:1fr}}
.page-learn .event{border-radius:16px;overflow:hidden;background:#fff;border:1px solid #eef0f5;box-shadow:0 8px 24px #0001}
.page-learn .event img{width:100%;height:230px;object-fit:cover;display:block}
.page-learn .event .pad{padding:12px 14px 16px}

/* === Learn: quick patch === */
.learn-page .feature-card__overlay{
  /* a touch stronger so overlaid text reads on any photo */
  background: linear-gradient(180deg, rgba(0,0,0,.06) 0%,
                                      rgba(0,0,0,.48) 68%,
                                      rgba(0,0,0,.72) 100%);
}
.learn-page .feature-card__title{ color:#fff; text-shadow:0 2px 8px rgba(0,0,0,.55); }
.learn-page .feature-card__dek{ color:#eef2ff; }

/* simple progress donut (no SVG) */
.learn-page .ring{
  --p:40; /* default */
  width:110px; height:110px; border-radius:50%;
  background: conic-gradient(var(--pitt-gold) calc(var(--p)*1%), #e6ecfb 0);
  display:grid; place-items:center; margin:0 auto 6px;
}
.learn-page .ring > span{
  width:70px; height:70px; border-radius:50%; background:#fff;
  display:grid; place-items:center; font-weight:800; color:var(--pitt-blue);
}

/* be extra safe about missing-height images */
.learn-page .qr-card img,
.learn-page .events img,
.learn-page .side-feature .thumb img { object-fit: cover; }

/* ===== CONNECT (scoped) ===== */
.page-connect .connect-main { padding-block: 22px 48px; }
.page-connect .card { border:1px solid #e8e9ee; border-radius:18px; background:#fff; box-shadow:0 8px 24px rgba(16,24,40,.06); padding:18px; }

.page-connect .hero { padding:0; overflow:hidden; position:relative; }
.page-connect .hero::before{
  content:""; position:absolute; inset:0;
  background: linear-gradient(135deg, #003594 0%, #0a2e7a 55%) no-repeat;
}
.page-connect .hero-inner{ position:relative; color:#fff; padding:26px 22px; }
.page-connect .hero h1{ margin:0 0 .35rem; font-size:clamp(24px,2.6vw,34px); }
.page-connect .hero .lead{ opacity:.95; max-width:60ch; }
.page-connect .hero-cta{ margin-top:12px; display:flex; gap:10px; flex-wrap:wrap; }

.page-connect .connect-layout{
  display:grid; gap:18px; grid-template-columns: 1.1fr .9fr;
}
@media (max-width: 980px){ .page-connect .connect-layout{ grid-template-columns:1fr; } }

.page-connect .contact-form .form-grid{
  display:grid; gap:12px; grid-template-columns:1fr 1fr; margin-bottom:10px;
}
@media (max-width:680px){ .page-connect .contact-form .form-grid{ grid-template-columns:1fr; } }

.page-connect .field{ display:flex; flex-direction:column; gap:6px; }
.page-connect .field > span{ font-weight:700; font-size:.95rem; color:#1f2937; }
.page-connect input[type="text"],
.page-connect input[type="email"],
.page-connect select,
.page-connect textarea{
  width:100%; padding:10px 12px; border:1px solid #d7d9e0; border-radius:10px;
  font:inherit; outline:none; background:#fff;
}
.page-connect textarea{ resize:vertical; }
.page-connect input:focus, .page-connect select:focus, .page-connect textarea:focus{
  border-color:#003594; box-shadow:0 0 0 3px rgba(0,53,148,.12);
}
.page-connect .agree{ display:flex; align-items:center; gap:10px; margin:10px 0; }
.page-connect .actions-row{ display:flex; gap:10px; flex-wrap:wrap; margin-top:6px; }

.page-connect .info .info-list{ list-style:none; padding:0; margin:0; display:grid; gap:10px; }

.page-connect .visit .map-wrap{ margin-top:10px; border-radius:14px; overflow:hidden; }
.page-connect .visit iframe{ width:100%; aspect-ratio:16/9; border:0; display:block; }

.page-connect .quick.grid-3{ display:grid; gap:18px; grid-template-columns:repeat(3,1fr); margin-top:18px; }
@media (max-width:980px){ .page-connect .quick.grid-3{ grid-template-columns:1fr 1fr; } }
@media (max-width:640px){ .page-connect .quick.grid-3{ grid-template-columns:1fr; } }
.page-connect .qa{ text-decoration:none; color:inherit; padding:16px; transition:transform .12s ease, box-shadow .12s ease; }
.page-connect .qa:hover{ transform:translateY(-2px); box-shadow:0 10px 24px rgba(16,24,40,.12); }
.page-connect .qa-emoji{ font-size:24px; line-height:1; margin-bottom:6px; }

.page-connect .faq .acc{ border:1px solid #e8e9ee; border-radius:12px; margin:8px 0; padding:0; overflow:hidden; }
.page-connect .faq summary{ list-style:none; cursor:pointer; padding:12px 14px; font-weight:700; }
.page-connect .faq details[open] summary{ background:#f8f9fc; border-bottom:1px solid #eef1fb; }
.page-connect .faq p{ padding:10px 14px 12px; margin:0; }

