/* ACME Creation Lab — brand overrides on top of Bootstrap 5.
   Palette: forge charcoal + ember amber + steel gray (from the anvil logo). */

:root {
  --ink: #14151a;
  --ink-2: #1d1f26;
  --steel: #8a9099;
  --steel-light: #c7ccd2;
  --ember: #f0a500;
  --ember-dark: #d1890a;
  --bs-body-font-family: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}

body { color: var(--ink); }

h1, h2, h3, h4, h5, .navbar-brand, .btn { font-family: 'Oswald', 'Arial Narrow', sans-serif; letter-spacing: .01em; }

.eyebrow {
  font-family: 'Oswald', sans-serif; text-transform: uppercase; letter-spacing: .28em;
  font-size: .8rem; font-weight: 600; color: var(--ember-dark); margin-bottom: .8rem;
}
.section-sub { max-width: 720px; color: #545a63; font-size: 1.1rem; }

/* Buttons */
.btn-ember { background: var(--ember); border-color: var(--ember); color: var(--ink); font-weight: 600; text-transform: uppercase; letter-spacing: .05em; }
.btn-ember:hover, .btn-ember:focus { background: var(--ember-dark); border-color: var(--ember-dark); color: var(--ink); }
.btn-outline-dark, .btn-outline-light { text-transform: uppercase; letter-spacing: .05em; font-weight: 600; }
.btn-outline-dark.active { background: var(--ink); border-color: var(--ink); }

/* Navbar */
#mainNav { background: rgba(20,21,26,.85); backdrop-filter: blur(10px); transition: background .3s ease; }
#mainNav.scrolled { background: rgba(20,21,26,.97); }
.navbar-brand { text-transform: uppercase; font-weight: 500; font-size: 1.05rem; color: #fff; }
.navbar-brand strong { color: var(--ember); }
.brand-mark { filter: invert(1) brightness(1.6); }
.navbar .nav-link { text-transform: uppercase; letter-spacing: .05em; font-size: .92rem; color: var(--steel-light); }
.navbar .nav-link:hover, .navbar .nav-link.active { color: #fff; }
.navbar .nav-link.btn-link { text-decoration: none; border: 0; }

/* Sections */
.py-section { padding: 100px 0; }
.section-alt { background: #eceef1; }

/* Hero */
.hero { position: relative; min-height: 100vh; overflow: hidden; background: radial-gradient(ellipse at 50% 20%, #2a2d36 0%, var(--ink) 60%); }
.hero-bg { position: absolute; inset: 0; background-color: var(--ink);
  background-image:
    radial-gradient(circle at 80% 15%, rgba(240,165,0,.16), transparent 40%),
    radial-gradient(circle at 15% 85%, rgba(240,165,0,.10), transparent 45%); }
.hero-bg::after { content: ""; position: absolute; inset: 0; opacity: .06;
  background-image: linear-gradient(var(--steel) 1px, transparent 1px), linear-gradient(90deg, var(--steel) 1px, transparent 1px);
  background-size: 46px 46px; -webkit-mask-image: radial-gradient(ellipse at center, #000 40%, transparent 78%); mask-image: radial-gradient(ellipse at center, #000 40%, transparent 78%); }
.hero-logo { height: 150px; filter: invert(1) brightness(1.7) drop-shadow(0 6px 20px rgba(0,0,0,.5)); }
.hero-lead { max-width: 640px; color: var(--steel-light); font-size: 1.2rem; }
.hero-facts strong { display: block; font-family: 'Oswald', sans-serif; font-size: 1.9rem; color: var(--ember); }
.hero-facts span { text-transform: uppercase; letter-spacing: .12em; font-size: .72rem; color: var(--steel); }

/* Cards */
.unit-info, .cta-panel, .unit-card { border: 1px solid rgba(20,21,26,.10); border-radius: 14px; }
.unit-info { border-top: 3px solid var(--ember); }
.cta-panel { box-shadow: 0 18px 50px rgba(0,0,0,.15); }
.cta-panel.dark { background: var(--ink); color: var(--steel-light); border: 0; }
.cta-panel.dark h3 { color: #fff; }

/* Story / stats */
.story { background: var(--ink); color: var(--steel-light); }
.story-sub { max-width: 640px; color: var(--steel-light); }
.stats strong { display: block; font-family: 'Oswald', sans-serif; font-size: 2.2rem; color: var(--ember); line-height: 1; }
.stats span { text-transform: uppercase; letter-spacing: .1em; font-size: .74rem; color: var(--steel); }

/* Volunteer ways list */
.ways-list li { display: flex; gap: 20px; padding: 22px 0; border-bottom: 1px solid rgba(20,21,26,.10); }
.ways-list li:first-child { padding-top: 0; }
.ways-list span { font-family: 'Oswald', sans-serif; font-size: 1.5rem; font-weight: 700; color: var(--ember); min-width: 34px; }

/* Unit cards */
.unit-card { overflow: hidden; transition: transform .18s ease, box-shadow .18s ease; }
.unit-card:hover { transform: translateY(-4px); box-shadow: 0 14px 34px rgba(20,21,26,.12); }
.unit-photo { position: relative; aspect-ratio: 4 / 3; background: #d9dde1; overflow: hidden; }
.unit-photo img { width: 100%; height: 100%; object-fit: cover; }
.unit-photo.is-placeholder { display: flex; align-items: center; justify-content: center;
  background: radial-gradient(ellipse at center, #2a2d36 0%, var(--ink) 100%); }
.unit-photo.is-placeholder .placeholder-mark { width: 46%; height: auto; object-fit: contain; filter: invert(1) brightness(1.6); opacity: .85; }
.unit-badge { position: absolute; top: 12px; left: 12px; text-transform: uppercase; letter-spacing: .04em; }

/* Membership */
.membership-section {
  position: relative;
  background: radial-gradient(ellipse at 50% 0%, #2a2d36 0%, var(--ink) 65%);
  color: var(--steel-light);
  overflow: hidden;
}
.membership-section::before {
  content: ""; position: absolute; inset: 0; opacity: .5; pointer-events: none;
  background-image: radial-gradient(circle at 12% 20%, rgba(240,165,0,.14), transparent 40%),
                     radial-gradient(circle at 88% 80%, rgba(240,165,0,.10), transparent 45%);
}
.membership-section .eyebrow { color: var(--ember); }
.membership-section h2, .membership-section .section-sub { color: #fff; }
.membership-section .section-sub { color: var(--steel-light); }

.membership-card {
  position: relative; z-index: 1; border: none; border-radius: 20px;
  background: linear-gradient(160deg, #23252d, var(--ink));
  box-shadow: 0 0 0 1px rgba(240,165,0,.35), 0 30px 70px rgba(0,0,0,.55), 0 0 60px rgba(240,165,0,.12);
  animation: membership-glow 3.2s ease-in-out infinite;
}
@keyframes membership-glow {
  0%, 100% { box-shadow: 0 0 0 1px rgba(240,165,0,.35), 0 30px 70px rgba(0,0,0,.55), 0 0 60px rgba(240,165,0,.12); }
  50%      { box-shadow: 0 0 0 1px rgba(240,165,0,.6),  0 30px 70px rgba(0,0,0,.55), 0 0 90px rgba(240,165,0,.28); }
}
.membership-ribbon {
  position: absolute; top: 22px; right: -34px; width: 160px; padding: 6px 0; text-align: center;
  transform: rotate(45deg); background: var(--ember); color: var(--ink);
  font-family: 'Oswald', sans-serif; font-weight: 700; text-transform: uppercase; letter-spacing: .08em;
  font-size: .74rem; box-shadow: 0 4px 12px rgba(0,0,0,.35); z-index: 2;
}
.membership-card .eyebrow { color: var(--ember); }
.membership-price { line-height: 1; margin: .25rem 0 .5rem; font-family: 'Oswald', sans-serif; color: #fff; }
.membership-price .currency { font-size: 1.8rem; vertical-align: top; position: relative; top: .4rem; color: var(--ember); }
.membership-price .amount { font-size: 5rem; font-weight: 700; color: var(--ember); text-shadow: 0 0 30px rgba(240,165,0,.5); }
.membership-price .period { font-size: 1.3rem; color: var(--steel-light); }
.membership-card .text-muted { color: var(--steel) !important; }
.membership-perks { max-width: 360px; margin-left: auto; margin-right: auto; }
.membership-perks li { position: relative; padding: 7px 0 7px 30px; color: var(--steel-light); }
.membership-perks li::before {
  content: "✓"; position: absolute; left: 0; top: 7px; color: var(--ember); font-weight: 700;
}

/* Contact */
.contact-head { color: var(--ember-dark); }
.link-arrow { font-family: 'Oswald', sans-serif; text-transform: uppercase; letter-spacing: .05em; font-size: .9rem; color: var(--ember-dark); text-decoration: none; }
.socials a { font-family: 'Oswald', sans-serif; text-transform: uppercase; letter-spacing: .05em; color: var(--ink); text-decoration: none; }
.socials a:hover { color: var(--ember-dark); }

/* Footer */
.footer { background: var(--ink); }
.footer .navbar-brand { color: var(--steel-light); }

@media (max-width: 991px) {
  #mainNav { background: rgba(20,21,26,.97); }
  .navbar .nav-link.btn-link { padding-left: 0; text-align: left; }
}
@media (max-width: 575px) {
  .py-section { padding: 64px 0; }
  .hero-logo { height: 110px; }
}
