/* ============================================================
   DocNetwork Productions — Stylesheet
   Theme: "Field Dispatch" — archival paper, olive & brass,
   typewriter-influenced display type, oral-history warmth.
   ============================================================ */

:root{
  --paper:      #f3ede1;
  --paper-deep: #e8ded0;
  --ink:        #2b2620;
  --ink-soft:   #5a5246;
  --olive:      #4a5d3a;
  --olive-deep: #34432a;
  --brass:      #b8863c;
  --brass-soft: #d8b87a;
  --rule:       #c9bda7;
  --max-width:  1120px;

  --font-display: "Spectral", "Iowan Old Style", Georgia, serif;
  --font-body:    "Source Sans 3", "Segoe UI", Arial, sans-serif;
  --font-mono:    "IBM Plex Mono", "Courier New", monospace;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
}

img{max-width:100%; display:block;}
a{color:var(--olive-deep); text-decoration:none;}
a:hover{color:var(--brass);}
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible{
  outline:3px solid var(--brass);
  outline-offset:2px;
}

.container{
  max-width:var(--max-width);
  margin:0 auto;
  padding:0 1.5rem;
}

/* Skip link */
.skip-link{
  position:absolute; left:-999px; top:auto;
  background:var(--olive-deep); color:#fff; padding:.5rem 1rem; z-index:200;
}
.skip-link:focus{ left:1rem; top:1rem; }

/* ---------------------------------------------------------- */
/* Header / Nav                                                 */
/* ---------------------------------------------------------- */
.site-header{
  background:var(--olive-deep);
  color:var(--paper);
  border-bottom:4px solid var(--brass);
}
.site-header .container{
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:1rem;
  padding-top:1rem;
  padding-bottom:1rem;
}
.brand{
  display:flex;
  align-items:center;
  gap:.75rem;
  font-family:var(--font-display);
  font-size:1.4rem;
  font-weight:600;
  color:#fff;
  letter-spacing:.02em;
}
.brand img{
  height:48px; width:auto;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,.3));
}
.brand .brand-tag{
  font-family:var(--font-mono);
  font-size:.7rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--brass-soft);
  display:block;
}

.main-nav ul{
  display:flex;
  list-style:none;
  margin:0; padding:0;
  gap:1.75rem;
  flex-wrap:wrap;
}
.main-nav a{
  color:var(--paper);
  font-weight:600;
  font-size:.95rem;
  letter-spacing:.04em;
  text-transform:uppercase;
  padding:.25rem 0;
  border-bottom:2px solid transparent;
  transition:border-color .2s, color .2s;
}
.main-nav a:hover,
.main-nav a[aria-current="page"]{
  color:var(--brass-soft);
  border-bottom-color:var(--brass);
}

.nav-toggle{
  display:none;
  background:none; border:1px solid var(--brass-soft); color:#fff;
  font-size:1.5rem; line-height:1; padding:.35rem .65rem; border-radius:4px;
  cursor:pointer;
}

/* ---------------------------------------------------------- */
/* Donation banner                                              */
/* ---------------------------------------------------------- */
.donate-banner{
  background:var(--brass);
  color:var(--olive-deep);
  text-align:center;
  font-weight:600;
  padding:.65rem 1rem;
}
.donate-banner a{
  color:var(--olive-deep);
  text-decoration:underline;
  font-weight:700;
}

/* ---------------------------------------------------------- */
/* Hero                                                         */
/* ---------------------------------------------------------- */
.hero{
  position:relative;
  background:var(--ink);
  color:var(--paper);
  padding:4.5rem 0 5.5rem;
  overflow:hidden;
  background-image:
    repeating-linear-gradient(135deg, rgba(184,134,60,.06) 0 2px, transparent 2px 26px);
}
.hero::after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(to top, var(--ink), transparent 60%);
  pointer-events:none;
}
.hero-inner{
  position:relative; z-index:1;
  max-width:760px;
}
.hero-eyebrow{
  font-family:var(--font-mono);
  text-transform:uppercase;
  letter-spacing:.28em;
  font-size:.78rem;
  color:var(--brass-soft);
  margin:0 0 1rem;
}
.hero h1{
  font-family:var(--font-display);
  font-size:clamp(2.2rem, 5vw, 3.6rem);
  line-height:1.15;
  margin:0 0 1.25rem;
  font-weight:600;
}
.hero h1 em{
  font-style:italic;
  color:var(--brass-soft);
}
.hero p{
  font-size:1.05rem;
  color:#d8d2c4;
}

/* ---------------------------------------------------------- */
/* Sections / general                                           */
/* ---------------------------------------------------------- */
section{ padding:3.5rem 0; }
section.alt{ background:var(--paper-deep); }

.section-head{
  margin-bottom:2rem;
  max-width:760px;
}
.section-eyebrow{
  font-family:var(--font-mono);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.75rem;
  color:var(--brass);
  margin:0 0 .5rem;
}
h1,h2,h3,h4{ font-family:var(--font-display); color:var(--olive-deep); margin-top:0;}
h2{ font-size:clamp(1.6rem, 3vw, 2.2rem); }
h3{ font-size:1.3rem; }

.lede{
  font-size:1.05rem;
  color:var(--ink-soft);
  max-width:700px;
}

/* ---------------------------------------------------------- */
/* Cards / grid                                                 */
/* ---------------------------------------------------------- */
.grid{
  display:grid;
  gap:1.75rem;
  grid-template-columns:repeat(auto-fit, minmax(280px, 1fr));
}

.card{
  background:#fff;
  border:1px solid var(--rule);
  border-radius:4px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  box-shadow:0 1px 3px rgba(43,38,32,.06);
  transition:transform .18s ease, box-shadow .18s ease;
}
.card:hover{
  transform:translateY(-3px);
  box-shadow:0 8px 22px rgba(43,38,32,.12);
}
.card img{ aspect-ratio:1/1; object-fit:cover; width:100%; background:var(--paper-deep);}
.card-body{ padding:1.25rem 1.4rem 1.5rem; display:flex; flex-direction:column; flex:1;}
.card-body h3{ margin-bottom:.5rem; }
.card-body p{ color:var(--ink-soft); font-size:.95rem; flex:1;}
.card-tag{
  display:inline-block;
  font-family:var(--font-mono);
  font-size:.7rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  background:var(--olive);
  color:#fff;
  padding:.25rem .6rem;
  border-radius:3px;
  margin-bottom:.6rem;
  align-self:flex-start;
}

/* ---------------------------------------------------------- */
/* Buttons / links                                              */
/* ---------------------------------------------------------- */
.btn{
  display:inline-block;
  font-weight:700;
  font-family:var(--font-mono);
  font-size:.8rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  padding:.65rem 1.4rem;
  border-radius:3px;
  border:2px solid var(--olive-deep);
  color:var(--olive-deep);
  background:transparent;
  transition:background .2s, color .2s;
  margin-top:.75rem;
}
.btn:hover{ background:var(--olive-deep); color:#fff; }
.btn.btn-solid{ background:var(--brass); border-color:var(--brass); color:var(--ink); }
.btn.btn-solid:hover{ background:var(--brass-soft); color:var(--ink); }

/* ---------------------------------------------------------- */
/* Spotify embed                                                */
/* ---------------------------------------------------------- */
.embed-wrap{
  border:1px solid var(--rule);
  border-radius:6px;
  overflow:hidden;
  background:#fff;
}
.embed-wrap iframe{ width:100%; height:232px; border:0; display:block; }

/* ---------------------------------------------------------- */
/* Team page                                                    */
/* ---------------------------------------------------------- */
.profile{
  display:grid;
  grid-template-columns:240px 1fr;
  gap:2rem;
  align-items:start;
}
.profile img{
  border-radius:4px;
  border:1px solid var(--rule);
}
.profile .role{
  font-family:var(--font-mono);
  font-size:.8rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  color:var(--brass);
  margin-bottom:.75rem;
}
@media (max-width:680px){
  .profile{ grid-template-columns:1fr; }
  .profile img{ max-width:220px; }
}

/* ---------------------------------------------------------- */
/* Support page extras                                          */
/* ---------------------------------------------------------- */
.support-grid{
  display:grid;
  gap:1.75rem;
  grid-template-columns:repeat(auto-fit, minmax(240px,1fr));
}
.support-card{
  background:#fff;
  border:1px solid var(--rule);
  border-radius:4px;
  padding:1.5rem;
}
.support-card h3{ margin-bottom:.5rem; }
.support-card p{ color:var(--ink-soft); font-size:.95rem; }

/* ---------------------------------------------------------- */
/* Blog / Articles                                              */
/* ---------------------------------------------------------- */
.article-list{ display:grid; gap:1.75rem; }
.article-card{
  display:grid;
  grid-template-columns:200px 1fr;
  gap:1.5rem;
  background:#fff;
  border:1px solid var(--rule);
  border-radius:4px;
  padding:1.25rem;
}
.article-card img{ border-radius:3px; aspect-ratio:4/3; object-fit:cover; }
.article-card .meta{
  font-family:var(--font-mono);
  font-size:.75rem;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:var(--olive);
  margin-bottom:.4rem;
}
@media (max-width:600px){
  .article-card{ grid-template-columns:1fr; }
  .article-card img{ aspect-ratio:16/9; }
}

.article-body{
  max-width:760px;
}
.article-body img{ border-radius:4px; margin:1.5rem 0; }
.article-body h2, .article-body h3{ margin-top:2rem; }
.article-body p{ margin-bottom:1.2rem; }
.article-cover{
  width:100%;
  aspect-ratio:16/9;
  object-fit:cover;
  border-radius:6px;
  margin-bottom:1.5rem;
}

/* ---------------------------------------------------------- */
/* Footer                                                       */
/* ---------------------------------------------------------- */
.site-footer{
  background:var(--ink);
  color:#cfc8ba;
  padding:3rem 0 2rem;
  font-size:.9rem;
}
.site-footer h3{ color:var(--brass-soft); font-size:1rem; }
.footer-grid{
  display:grid;
  gap:2rem;
  grid-template-columns:repeat(auto-fit, minmax(200px,1fr));
  margin-bottom:2rem;
}
.site-footer a{ color:#cfc8ba; }
.site-footer a:hover{ color:var(--brass-soft); }
.footer-nav ul{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:.4rem; }
.acknowledgement{
  border-top:1px solid #3c352b;
  padding-top:1.5rem;
  font-size:.85rem;
  color:#a59c8c;
}
.footer-bottom{
  border-top:1px solid #3c352b;
  margin-top:1.5rem;
  padding-top:1.5rem;
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:.75rem;
  font-size:.8rem;
  color:#8b8273;
}

/* ---------------------------------------------------------- */
/* Responsive nav                                               */
/* ---------------------------------------------------------- */
@media (max-width:820px){
  .nav-toggle{ display:inline-block; }
  .main-nav{
    display:none;
    width:100%;
    order:3;
  }
  .main-nav.open{ display:block; }
  .main-nav ul{ flex-direction:column; gap:0; padding:.5rem 0; }
  .main-nav a{ display:block; padding:.6rem 0; border-bottom:1px solid rgba(255,255,255,.08); }
}

/* ---------------------------------------------------------- */
/* Forms (admin)                                                */
/* ---------------------------------------------------------- */
.field{ margin-bottom:1.1rem; }
.field label{ display:block; font-weight:600; margin-bottom:.35rem; font-size:.9rem; }
.field input[type=text],
.field input[type=password],
.field input[type=email],
.field input[type=url],
.field input[type=number],
.field input[type=date],
.field input[type=file],
.field select,
.field textarea{
  width:100%;
  padding:.6rem .75rem;
  border:1px solid var(--rule);
  border-radius:4px;
  font-family:var(--font-body);
  font-size:.95rem;
  background:#fff;
}
.field textarea{ min-height:220px; font-family:var(--font-mono); font-size:.85rem; }
.field-hint{ font-size:.8rem; color:var(--ink-soft); margin-top:.3rem; }

/* ---------------------------------------------------------- */
/* Utility                                                      */
/* ---------------------------------------------------------- */
.text-center{ text-align:center; }
.mt-0{ margin-top:0; }
.flash{
  padding:.85rem 1.1rem;
  border-radius:4px;
  margin-bottom:1.25rem;
  font-size:.9rem;
}
.flash.success{ background:#e3edd9; color:var(--olive-deep); border:1px solid var(--olive); }
.flash.error{ background:#f6dede; color:#7a2424; border:1px solid #c97a7a; }
