/* ============================================================
   Newcomerstown Historical Society — shared stylesheet
   Dark editorial gallery theme · Orange (#F26A1B) + Black
   ============================================================ */

:root{
  --black:#0a0a0a;
  --panel:#141414;
  --panel-2:#1c1c1c;
  --orange:#F26A1B;
  --orange-soft:#ff8a3d;
  --white:#f6f4f0;
  --muted:#a9a6a0;
  --line:#2a2a2a;
  --maxw:1180px;
  --header-font:"Oswald","Arial Narrow",sans-serif;
  --body-font:"Inter","Helvetica Neue",Arial,sans-serif;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--black);
  color:var(--white);
  font-family:var(--body-font);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;}

/* ---------- Header / nav ---------- */
header.site{
  position:sticky;top:0;z-index:50;
  background:rgba(10,10,10,.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  max-width:var(--maxw);margin:0 auto;padding:14px 24px;
}
.brand{display:flex;align-items:center;gap:14px;}
.brand .mark{
  width:46px;height:46px;flex:none;border-radius:50%;overflow:hidden;
  background:#0d0d0d url('img/chief-logo.jpg') center/cover no-repeat;
  color:transparent;font-size:0;
  border:2px solid var(--orange);box-shadow:0 0 0 1px #0a0a0a;
}
.brand .names{line-height:1.1;}
.brand .t1{
  font-family:var(--header-font);font-weight:600;
  letter-spacing:.18em;text-transform:uppercase;font-size:15px;
}
.brand .t2{font-size:11px;letter-spacing:.22em;color:var(--orange-soft);text-transform:uppercase;}

nav.links{display:flex;gap:4px;flex-wrap:wrap;}
nav.links a{
  font-family:var(--header-font);font-weight:500;
  text-transform:uppercase;letter-spacing:.10em;font-size:13px;
  padding:8px 12px;border-radius:5px;color:var(--muted);
  transition:.18s;white-space:nowrap;
}
nav.links a:hover,nav.links a.active{color:var(--white);background:var(--panel-2);}
nav.links a.cta{color:#0a0a0a;background:var(--orange);}
nav.links a.cta:hover{background:var(--orange-soft);}

.menu-toggle{display:none;background:none;border:0;cursor:pointer;padding:6px;}
.menu-toggle span{display:block;width:26px;height:3px;background:var(--white);margin:5px 0;border-radius:2px;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;font-family:var(--header-font);font-weight:600;
  text-transform:uppercase;letter-spacing:.12em;font-size:14px;
  padding:14px 26px;border-radius:6px;cursor:pointer;border:2px solid var(--orange);
  transition:.18s;
}
.btn.primary{background:var(--orange);color:#0a0a0a;}
.btn.primary:hover{background:var(--orange-soft);border-color:var(--orange-soft);}
.btn.ghost{background:transparent;color:var(--white);}
.btn.ghost:hover{background:var(--orange);color:#0a0a0a;}

/* ---------- Hero ---------- */
.hero{
  position:relative;padding:120px 24px 90px;text-align:center;
  border-bottom:1px solid var(--line);
  background:
    radial-gradient(1100px 480px at 50% -10%, rgba(242,106,27,.16), transparent 70%),
    linear-gradient(180deg,#0c0c0c,#070707);
}
.hero-medallion{
  width:210px;height:210px;margin:0 auto 28px;border-radius:50%;overflow:hidden;
  border:5px solid var(--orange);
  box-shadow:0 0 0 2px #0a0a0a, 0 18px 50px rgba(0,0,0,.6), 0 0 60px rgba(242,106,27,.25);
}
.hero-medallion img{width:100%;height:100%;object-fit:cover;object-position:center 30%;}
@media(max-width:560px){ .hero-medallion{width:160px;height:160px;} }
.hero .eyebrow{
  font-family:var(--header-font);letter-spacing:.34em;text-transform:uppercase;
  color:var(--orange-soft);font-size:13px;margin-bottom:18px;
}
.hero h1{
  font-family:var(--header-font);font-weight:700;
  font-size:clamp(38px,6vw,76px);line-height:1.02;margin:0 auto 18px;
  letter-spacing:.02em;text-transform:uppercase;max-width:14ch;
}
.hero p.lead{max-width:60ch;margin:0 auto 30px;color:var(--muted);font-size:19px;}
.hero .cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* ---------- Page header (interior) ---------- */
.pagehead{padding:80px 24px 40px;border-bottom:1px solid var(--line);}
.pagehead .eyebrow{
  font-family:var(--header-font);letter-spacing:.3em;text-transform:uppercase;
  color:var(--orange-soft);font-size:13px;margin-bottom:14px;
}
.pagehead h1{
  font-family:var(--header-font);font-weight:700;text-transform:uppercase;
  font-size:clamp(34px,5vw,60px);margin:0 0 10px;letter-spacing:.01em;
}
.pagehead .sub{color:var(--muted);max-width:65ch;font-size:18px;}

/* ---------- Sections ---------- */
section.block{padding:64px 0;}
section.block.alt{background:var(--panel);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.kicker{
  font-family:var(--header-font);letter-spacing:.28em;text-transform:uppercase;
  color:var(--orange);font-size:13px;margin-bottom:12px;
}
h2.section-title{
  font-family:var(--header-font);font-weight:600;text-transform:uppercase;
  font-size:clamp(26px,3.6vw,40px);margin:0 0 26px;letter-spacing:.02em;
}
h3{font-family:var(--header-font);font-weight:600;text-transform:uppercase;letter-spacing:.04em;}

/* ---------- Gallery grid (home + collections) ---------- */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.grid.two{grid-template-columns:repeat(2,1fr);}
.tile{
  position:relative;display:block;overflow:hidden;border-radius:10px;
  border:1px solid var(--line);background:var(--panel-2);
  aspect-ratio:4/3;
}
.tile img{width:100%;height:100%;object-fit:contain;background:#0d0d0d;transition:.5s;}
.tile:hover img{transform:scale(1.03);}
.tile .label{
  position:absolute;left:16px;top:16px;
  font-family:var(--header-font);text-transform:uppercase;letter-spacing:.18em;
  font-size:14px;background:#0a0a0aee;padding:8px 14px;border-radius:4px;
}
.tile .meta{
  position:absolute;left:0;right:0;bottom:0;padding:22px 16px 16px;
  background:linear-gradient(180deg,transparent,rgba(8,8,8,.9));
}
.tile .meta .go{
  font-family:var(--header-font);text-transform:uppercase;letter-spacing:.16em;
  font-size:12px;color:var(--orange-soft);
}
.tile .meta .ttl{font-family:var(--header-font);font-size:20px;text-transform:uppercase;letter-spacing:.04em;}

/* Placeholder tile (no photo yet) */
.ph{
  width:100%;height:100%;display:flex;align-items:center;justify-content:center;
  text-align:center;color:#6f6c66;background:
    repeating-linear-gradient(45deg,#191919,#191919 12px,#161616 12px,#161616 24px);
  font-family:var(--header-font);text-transform:uppercase;letter-spacing:.18em;font-size:13px;padding:20px;
}
.ph small{display:block;color:#4f4d48;letter-spacing:.1em;margin-top:6px;font-size:11px;}

/* ---------- Two-column feature ---------- */
.feature{display:grid;grid-template-columns:1.1fr 1fr;gap:40px;align-items:center;}
.feature.flip{grid-template-columns:1fr 1.1fr;}
.feature .media{border-radius:12px;overflow:hidden;border:1px solid var(--line);background:#0d0d0d;display:flex;align-items:center;justify-content:center;min-height:320px;}
.feature .media img{width:100%;height:auto;max-height:560px;object-fit:contain;}
.feature p{color:#cfccc6;}
.addr{color:var(--muted);font-size:15px;border-left:3px solid var(--orange);padding-left:14px;margin:18px 0;}

/* ---------- Cards / lists ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:26px;}
.card h3{margin:0 0 8px;font-size:20px;color:var(--white);}
.card .price{font-family:var(--header-font);color:var(--orange);font-size:26px;margin:6px 0 14px;}
.card p{color:var(--muted);font-size:15px;margin:0 0 18px;}
.pill{display:inline-block;font-family:var(--header-font);letter-spacing:.14em;text-transform:uppercase;font-size:11px;color:var(--orange-soft);border:1px solid var(--orange);border-radius:999px;padding:4px 12px;margin-bottom:14px;}

.factbox{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:26px;}
.factbox dl{margin:0;display:grid;grid-template-columns:auto 1fr;gap:10px 22px;}
.factbox dt{font-family:var(--header-font);text-transform:uppercase;letter-spacing:.1em;font-size:13px;color:var(--orange-soft);}
.factbox dd{margin:0;color:#dcd9d3;}

.note{background:#17120c;border:1px solid #3a2a16;border-left:4px solid var(--orange);border-radius:8px;padding:16px 18px;color:#e9d9c5;font-size:14px;margin-top:18px;}

/* ---------- Footer ---------- */
footer.site{background:#070707;border-top:1px solid var(--line);padding:54px 0 34px;margin-top:20px;}
footer.site .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:32px;}
footer.site h4{font-family:var(--header-font);text-transform:uppercase;letter-spacing:.16em;font-size:14px;color:var(--orange-soft);margin:0 0 14px;}
footer.site a{color:var(--muted);display:block;padding:3px 0;font-size:15px;}
footer.site a:hover{color:var(--white);}
footer.site .copy{border-top:1px solid var(--line);margin-top:34px;padding-top:20px;color:#6f6c66;font-size:13px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;}

/* ---------- Utility ---------- */
.center{text-align:center;}
.mt0{margin-top:0;}
.lead-muted{color:var(--muted);}
.spacer{height:30px;}

/* ---------- Accessibility: color-blind & keyboard friendly ---------- */
/* Inline text links get an underline so they aren't signaled by color alone */
p a, .addr a, .factbox dd a, .hero p a, .note a{
  text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1.5px;
}
/* Clear, visible focus ring for keyboard & switch users on every interactive element */
a:focus-visible, .btn:focus-visible, button:focus-visible, iframe:focus-visible{
  outline:3px solid var(--orange-soft);outline-offset:3px;border-radius:4px;
}
/* Respect users who ask the system to reduce motion */
@media(prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important;}
  html{scroll-behavior:auto;}
  .tile:hover img{transform:none;}
}

/* ---------- Responsive ---------- */
@media(max-width:860px){
  .grid,.grid.two,.cards{grid-template-columns:1fr;}
  .feature,.feature.flip{grid-template-columns:1fr;}
  nav.links{
    display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;
    background:#0c0c0c;border-bottom:1px solid var(--line);padding:10px 16px 18px;
  }
  nav.links.open{display:flex;}
  nav.links a{padding:12px 10px;font-size:15px;}
  .menu-toggle{display:block;}
  footer.site .cols{grid-template-columns:1fr;}
}
