/* ============================================================
   THRIFTIQUE / NCJW Pittsburgh Section — 2026 Redesign
   Design signature: the "swing tag" — the die-cut price tag with
   a punched hole, borrowed straight from the racks of the store.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,300;9..144,500;9..144,600;9..144,700;9..144,900&family=Work+Sans:wght@400;500;600;700&family=Space+Mono:wght@400;700&display=swap');

:root{
  --ink-green:#1E3328;
  --ink-green-light:#274434;
  --paper:#F3ECDC;
  --paper-deep:#EAE0C8;
  --cream-white:#FBF8F1;
  --brass:#B8863B;
  --brass-dark:#8F6526;
  --clay:#C1694F;
  --clay-dark:#A5503A;
  --sage:#7C9070;
  --charcoal:#2A2520;
  --charcoal-70: rgba(42,37,32,.7);
  --charcoal-40: rgba(42,37,32,.4);
  --charcoal-15: rgba(42,37,32,.15);
  --shadow-tag: 3px 4px 0 rgba(30,51,40,.10);
  --shadow-tag-hover: 5px 7px 0 rgba(30,51,40,.14);
  --radius-soft: 4px;
  --max-w: 1180px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--paper);
  color:var(--charcoal);
  font-family:'Work Sans', sans-serif;
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;}
h1,h2,h3,h4{
  font-family:'Fraunces', serif;
  font-weight:600;
  line-height:1.12;
  margin:0 0 .5em;
  color:var(--ink-green);
}
p{margin:0 0 1.1em;}
.wrap{max-width:var(--max-w); margin:0 auto; padding:0 24px;}
.eyebrow{
  font-family:'Space Mono', monospace;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:.72rem;
  color:var(--brass-dark);
  font-weight:700;
}
:focus-visible{outline:3px solid var(--clay); outline-offset:2px;}
@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms !important; transition-duration:.001ms !important;}
}

/* ---------- skip link ---------- */
.skip-link{
  position:absolute; left:-999px; top:0; background:var(--ink-green); color:#fff;
  padding:10px 16px; z-index:999; font-family:'Space Mono',monospace; font-size:.8rem;
}
.skip-link:focus{ left:12px; top:12px; }

/* ---------- topbar ---------- */
.topbar{
  background:var(--ink-green);
  color:var(--paper);
  font-family:'Space Mono', monospace;
  font-size:.72rem;
  letter-spacing:.05em;
}
.topbar .wrap{
  display:flex; justify-content:space-between; align-items:center;
  padding:8px 24px; flex-wrap:wrap; gap:6px;
}
.topbar a{ color:var(--paper); text-decoration:none; }
.topbar a:hover{ color:var(--brass); }
.topbar__hours span{ opacity:.75; margin-right:6px; }

/* ---------- header ---------- */
.site-header{
  background:var(--paper);
  border-bottom:1px solid var(--charcoal-15);
  position:sticky; top:0; z-index:50;
}
.site-header .wrap{
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 24px; gap:20px;
}
.brand{
  display:flex; align-items:center; gap:12px; text-decoration:none;
}
.brand__mark{
  width:44px; height:44px; border-radius:50%;
  background:var(--ink-green); color:var(--paper);
  display:flex; align-items:center; justify-content:center;
  font-family:'Fraunces', serif; font-weight:700; font-size:1.2rem;
  flex-shrink:0;
}
.brand__text{ line-height:1.15; }
.brand__text strong{
  display:block; font-family:'Fraunces', serif; font-size:1.28rem; color:var(--ink-green);
}
.brand__text em{
  display:block; font-style:normal; font-size:.72rem; color:var(--charcoal-70);
  font-family:'Space Mono', monospace; letter-spacing:.03em;
}
.main-nav{ display:flex; align-items:center; gap:26px; }
.main-nav ul{ list-style:none; display:flex; gap:22px; margin:0; padding:0; flex-wrap:wrap; }
.main-nav a{
  text-decoration:none; font-weight:600; font-size:.95rem; color:var(--charcoal);
  padding:6px 2px; border-bottom:2px solid transparent;
}
.main-nav a:hover, .main-nav a[aria-current="page"]{ border-bottom-color:var(--clay); color:var(--ink-green); }
.nav-cta{
  background:var(--clay); color:#fff !important; padding:9px 18px !important;
  border-radius:2px; font-family:'Space Mono',monospace; text-transform:uppercase;
  letter-spacing:.06em; font-size:.72rem !important; border-bottom:none !important;
}
.nav-cta:hover{ background:var(--clay-dark); }
.nav-toggle{ display:none; }

/* ---------- breadcrumbs ---------- */
.breadcrumbs{
  font-family:'Space Mono', monospace; font-size:.72rem; letter-spacing:.03em;
  color:var(--charcoal-70); padding:16px 0 0;
}
.breadcrumbs a{ text-decoration:none; color:var(--charcoal-70); }
.breadcrumbs a:hover{ color:var(--clay); }
.breadcrumbs span[aria-hidden]{ margin:0 6px; opacity:.5; }

/* ---------- hero ---------- */
.hero{
  position:relative;
  padding:64px 0 80px;
  overflow:hidden;
}
.hero .wrap{
  display:grid; grid-template-columns:1.1fr .9fr; gap:48px; align-items:center;
}
.hero__tag{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--cream-white); border:1px dashed var(--brass);
  padding:6px 14px 6px 10px; border-radius:3px; margin-bottom:22px;
  font-family:'Space Mono',monospace; font-size:.74rem; letter-spacing:.06em;
  color:var(--brass-dark); text-transform:uppercase;
}
.hero__tag::before{
  content:""; width:9px; height:9px; border-radius:50%;
  border:1.5px solid var(--brass-dark); background:var(--paper); display:block;
}
.hero h1{
  font-size:clamp(2.4rem, 4.6vw, 3.6rem);
  letter-spacing:-.01em;
}
.hero__lede{ font-size:1.14rem; color:var(--charcoal-70); max-width:46ch; }
.hero__actions{ display:flex; gap:14px; margin-top:26px; flex-wrap:wrap; }
.hero__media{ position:relative; }
.hero__media img{
  width:100%; height:420px; object-fit:cover; border-radius:4px;
  box-shadow:var(--shadow-tag-hover);
}
.hero__badge{
  position:absolute; bottom:-18px; left:-18px;
  background:var(--ink-green); color:var(--paper);
  padding:14px 18px; border-radius:3px; box-shadow:var(--shadow-tag-hover);
  font-family:'Fraunces', serif; max-width:200px;
}
.hero__badge strong{ display:block; font-size:1.5rem; color:var(--brass); }
.hero__badge span{ font-family:'Space Mono',monospace; font-size:.68rem; letter-spacing:.04em; text-transform:uppercase; opacity:.85; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:8px;
  font-family:'Space Mono', monospace; text-transform:uppercase; letter-spacing:.06em;
  font-size:.78rem; padding:13px 22px; border-radius:2px; text-decoration:none;
  border:1.5px solid var(--ink-green); font-weight:700;
  transition:transform .12s ease;
}
.btn:hover{ transform:translateY(-2px); }
.btn--solid{ background:var(--ink-green); color:var(--paper); }
.btn--solid:hover{ background:var(--ink-green-light); }
.btn--outline{ background:transparent; color:var(--ink-green); }
.btn--outline:hover{ background:var(--ink-green); color:var(--paper); }
.btn--clay{ background:var(--clay); border-color:var(--clay); color:#fff; }
.btn--clay:hover{ background:var(--clay-dark); border-color:var(--clay-dark); }

/* ---------- sections ---------- */
.section{ padding:64px 0; }
.section--tight{ padding:44px 0; }
.section--ink{ background:var(--ink-green); color:var(--paper); }
.section--ink h2, .section--ink h3{ color:var(--paper); }
.section-head{ max-width:640px; margin-bottom:38px; }
.section-head h2{ font-size:clamp(1.7rem,3vw,2.3rem); }
.section-head p{ color:var(--charcoal-70); font-size:1.04rem; }
.section--ink .section-head p{ color:rgba(243,236,220,.78); }

/* stitched divider — signature detail */
.stitch{
  border:none; height:0; margin:0;
  border-top:2px dashed var(--charcoal-40);
}
.stitch--light{ border-top-color:rgba(243,236,220,.35); }

/* ---------- swing-tag card system (signature element) ---------- */
.tag-grid{
  display:grid; gap:28px;
  grid-template-columns:repeat(auto-fit, minmax(260px,1fr));
}
.tag-card{
  position:relative;
  background:var(--cream-white);
  border:1px solid var(--charcoal-15);
  padding:30px 24px 26px 30px;
  clip-path:polygon(26px 0, 100% 0, 100% 100%, 0 100%, 0 26px);
  box-shadow:var(--shadow-tag);
  transition:transform .15s ease, box-shadow .15s ease;
}
.tag-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-tag-hover); }
.tag-card::before{
  content:""; position:absolute; top:9px; left:9px;
  width:10px; height:10px; border-radius:50%;
  background:var(--paper); border:1.5px solid var(--charcoal-40); z-index:2;
}
.tag-card:nth-child(3n+1){ transform:rotate(-.6deg); }
.tag-card:nth-child(3n+2){ transform:rotate(.4deg); }
.tag-card:nth-child(3n+1):hover, .tag-card:nth-child(3n+2):hover{ transform:translateY(-4px) rotate(0deg); }
.tag-card__icon{
  width:42px; height:42px; border-radius:50%;
  background:var(--paper-deep); display:flex; align-items:center; justify-content:center;
  font-family:'Fraunces',serif; font-weight:700; color:var(--ink-green); margin-bottom:14px;
}
.tag-card h3{ font-size:1.24rem; margin-bottom:.4em; }
.tag-card p{ color:var(--charcoal-70); font-size:.98rem; margin-bottom:0; }
.tag-card .eyebrow{ display:block; margin-bottom:8px; }

/* ---------- program media cards (about page) ---------- */
.program-card{
  position:relative; background:var(--cream-white); border:1px solid var(--charcoal-15);
  border-radius:4px; overflow:hidden; box-shadow:var(--shadow-tag);
}
.program-card img{ width:100%; height:190px; object-fit:cover; }
.program-card__body{ padding:22px 22px 24px; }
.program-card__body h3{ font-size:1.2rem; }
.program-card__body p{ color:var(--charcoal-70); font-size:.96rem; margin-bottom:0; }

/* ---------- lists ---------- */
.check-list{ list-style:none; margin:0; padding:0; display:grid; gap:14px; }
.check-list li{
  display:flex; gap:12px; align-items:flex-start; font-size:1rem;
}
.check-list li::before{
  content:"✓"; flex-shrink:0; width:26px; height:26px; border-radius:50%;
  background:var(--sage); color:#fff; display:flex; align-items:center; justify-content:center;
  font-size:.8rem; font-weight:700; margin-top:1px;
}
.num-list{ margin:0; padding:0; list-style:none; counter-reset:num; display:grid; gap:20px; }
.num-list li{
  counter-increment:num; position:relative; padding-left:52px; font-size:1rem;
}
.num-list li::before{
  content: counter(num, decimal-leading-zero);
  position:absolute; left:0; top:-2px;
  font-family:'Fraunces', serif; font-weight:700; font-size:1.5rem; color:var(--brass);
}
.num-list strong{ display:block; color:var(--ink-green); font-family:'Fraunces',serif; font-size:1.08rem; margin-bottom:2px; }

/* ---------- FAQ (schema-backed) ---------- */
.faq-item{
  border-bottom:1px dashed var(--charcoal-40); padding:20px 0;
}
.faq-item:first-child{ border-top:1px dashed var(--charcoal-40); }
.faq-item h3{ font-size:1.08rem; margin-bottom:8px; }
.faq-item p{ color:var(--charcoal-70); margin-bottom:0; font-size:.98rem; }

/* ---------- info strip (address / hours) ---------- */
.info-strip{
  display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:24px;
}
.info-block{
  background:var(--cream-white); border:1px solid var(--charcoal-15); border-radius:4px;
  padding:22px 22px 20px;
}
.info-block h3{ font-size:1.02rem; display:flex; align-items:center; gap:8px; }
.info-block address, .info-block p{ font-style:normal; color:var(--charcoal-70); font-size:.95rem; margin:0; }
.hours-row{ display:flex; justify-content:space-between; font-size:.92rem; padding:3px 0; color:var(--charcoal-70); }
.hours-row strong{ color:var(--charcoal); font-weight:600; }

/* ---------- cta banner ---------- */
.cta-banner{
  background:var(--clay); color:#fff; border-radius:6px; padding:44px 40px;
  display:flex; justify-content:space-between; align-items:center; gap:24px; flex-wrap:wrap;
}
.cta-banner h2{ color:#fff; margin-bottom:.25em; font-size:1.7rem; }
.cta-banner p{ color:rgba(255,255,255,.88); margin-bottom:0; max-width:44ch; }
.cta-banner .btn--outline{ border-color:#fff; color:#fff; }
.cta-banner .btn--outline:hover{ background:#fff; color:var(--clay-dark); }

/* ---------- article / blog listing ---------- */
.post-card{
  display:grid; grid-template-columns:150px 1fr; gap:22px;
  background:var(--cream-white); border:1px solid var(--charcoal-15);
  padding:18px; border-radius:4px; box-shadow:var(--shadow-tag);
  margin-bottom:22px; align-items:center;
}
.post-card img{ width:100%; height:110px; object-fit:cover; border-radius:3px; }
.post-card__date{
  font-family:'Space Mono',monospace; font-size:.7rem; letter-spacing:.05em;
  color:var(--brass-dark); text-transform:uppercase; display:block; margin-bottom:6px;
}
.post-card h2{ font-size:1.28rem; margin-bottom:6px; }
.post-card h2 a{ text-decoration:none; }
.post-card h2 a:hover{ color:var(--clay); }
.post-card p{ color:var(--charcoal-70); font-size:.95rem; margin-bottom:0; }
.post-card--featured{
  grid-template-columns:1fr; 
}
.post-card--featured img{ height:230px; }
.post-badge{
  display:inline-block; background:var(--sage); color:#fff; font-family:'Space Mono',monospace;
  font-size:.64rem; text-transform:uppercase; letter-spacing:.06em; padding:3px 9px; border-radius:2px;
  margin-bottom:8px;
}

/* ---------- pagination ---------- */
.pagination{ display:flex; gap:10px; justify-content:center; margin-top:12px; font-family:'Space Mono',monospace; font-size:.85rem; }
.pagination a, .pagination span{
  width:36px; height:36px; display:flex; align-items:center; justify-content:center;
  border:1px solid var(--charcoal-15); border-radius:3px; text-decoration:none; color:var(--charcoal);
}
.pagination .current{ background:var(--ink-green); color:var(--paper); border-color:var(--ink-green); }
.pagination a:hover{ border-color:var(--clay); color:var(--clay); }

/* ---------- article single ---------- */
.article-hero{ padding:44px 0 0; }
.article-hero__meta{
  display:flex; gap:14px; align-items:center; flex-wrap:wrap;
  font-family:'Space Mono',monospace; font-size:.74rem; color:var(--charcoal-70);
  text-transform:uppercase; letter-spacing:.04em; margin-bottom:18px;
}
.article-hero__meta .dot{ width:4px; height:4px; border-radius:50%; background:var(--charcoal-40); }
.article-hero h1{ font-size:clamp(2rem,4.4vw,3rem); max-width:24ch; }
.article-hero__cover{ margin:30px 0 0; border-radius:6px; overflow:hidden; box-shadow:var(--shadow-tag-hover); }
.article-hero__cover img{ width:100%; height:420px; object-fit:cover; }
.article-body{
  max-width:740px; margin:0 auto; padding:48px 24px 20px; font-size:1.08rem;
}
.article-body h2{ font-size:1.55rem; margin-top:1.6em; }
.article-body h3{ font-size:1.2rem; margin-top:1.3em; }
.article-body figure{ margin:2em 0; }
.article-body figure img{ border-radius:4px; width:100%; height:auto; object-fit:cover; }
.article-body figcaption{
  font-family:'Space Mono',monospace; font-size:.72rem; color:var(--charcoal-70);
  margin-top:8px; letter-spacing:.02em;
}
.article-body blockquote{
  border-left:3px solid var(--clay); margin:1.8em 0; padding:.4em 0 .4em 22px;
  font-family:'Fraunces',serif; font-size:1.2rem; color:var(--ink-green); font-style:italic;
}
.pull-list{
  background:var(--cream-white); border:1px solid var(--charcoal-15); border-radius:4px;
  padding:26px 26px 22px; margin:2em 0;
}
.pull-list .eyebrow{ display:block; margin-bottom:10px; }
.author-box{
  display:flex; gap:16px; align-items:center; max-width:740px; margin:36px auto 0; padding:24px;
  background:var(--paper-deep); border-radius:5px;
}
.author-box__avatar{
  width:56px; height:56px; border-radius:50%; background:var(--ink-green); color:var(--paper);
  display:flex; align-items:center; justify-content:center; font-family:'Fraunces',serif; font-weight:700;
  flex-shrink:0; font-size:1.3rem;
}
.author-box strong{ display:block; color:var(--ink-green); font-family:'Fraunces',serif; }
.author-box span{ font-size:.9rem; color:var(--charcoal-70); }
.related{ max-width:740px; margin:48px auto 0; }
.related h2{ font-size:1.3rem; }
.tags-row{ display:flex; gap:8px; flex-wrap:wrap; margin:24px 0 0; }
.tags-row a{
  font-family:'Space Mono',monospace; font-size:.7rem; text-transform:uppercase; letter-spacing:.05em;
  background:var(--paper-deep); padding:6px 12px; border-radius:2px; text-decoration:none; color:var(--charcoal-70);
}
.tags-row a:hover{ background:var(--brass); color:#fff; }

/* ---------- footer ---------- */
.site-footer{ background:var(--ink-green); color:rgba(243,236,220,.85); margin-top:60px; }
.footer-grid{
  display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:32px; padding:56px 0 32px;
}
.footer-grid h4{
  color:var(--paper); font-family:'Space Mono',monospace; text-transform:uppercase; font-size:.76rem;
  letter-spacing:.07em; margin-bottom:16px;
}
.footer-grid p, .footer-grid address{ font-size:.92rem; line-height:1.6; font-style:normal; color:rgba(243,236,220,.75); }
.footer-grid ul{ list-style:none; margin:0; padding:0; display:grid; gap:9px; }
.footer-grid a{ text-decoration:none; color:rgba(243,236,220,.85); font-size:.92rem; }
.footer-grid a:hover{ color:var(--brass); }
.footer-bottom{
  border-top:1px solid rgba(243,236,220,.15); padding:18px 0; font-size:.8rem;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:8px; color:rgba(243,236,220,.6);
}
.footer-bottom a{ color:rgba(243,236,220,.6); text-decoration:underline; }

@media (max-width: 900px){
  .hero .wrap{ grid-template-columns:1fr; }
  .hero__media img{ height:300px; }
  .main-nav ul{ display:none; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .post-card{ grid-template-columns:1fr; }
  .post-card img{ height:170px; }
}
@media (max-width: 560px){
  .footer-grid{ grid-template-columns:1fr; }
  .cta-banner{ flex-direction:column; align-items:flex-start; }
}
