/* ============================================================
   RVA BIN BROS — global.css
   Industrial-clean aesthetic · Porkbun static hosting
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Barlow+Condensed:wght@400;500;600;700;900&family=Space+Mono:wght@400;700&display=swap');

:root {
  --green:  #2D7D2F;
  --lime:   #A8D520;
  --dark:   #1A1A1A;
  --mid:    #2C2C2C;
  --cream:  #F5F0E8;
  --orange: #E8620A;
  --white:  #FFFFFF;
  --muted:  #888888;
  --border: #333333;
}

/* RESET */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:'Barlow Condensed',sans-serif; background:var(--dark); color:var(--cream); font-size:16px; line-height:1.55; }
img { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }

/* ── TYPOGRAPHY HELPERS ── */
.bebas  { font-family:'Bebas Neue',sans-serif; letter-spacing:2px; }
.mono   { font-family:'Space Mono',monospace; }
.barlow { font-family:'Barlow Condensed',sans-serif; }

/* ── BUTTONS ── */
.btn {
  display:inline-block;
  font-family:'Bebas Neue',sans-serif;
  font-size:1.1rem; letter-spacing:3px;
  padding:14px 32px;
  cursor:pointer; border:none;
  transition:all .18s;
}
.btn-lime  { background:var(--lime);  color:var(--dark); }
.btn-lime:hover  { background:#bfe025; }
.btn-dark  { background:var(--dark);  color:var(--lime); border:2px solid var(--lime); }
.btn-dark:hover  { background:var(--lime); color:var(--dark); }
.btn-green { background:var(--green); color:var(--white); }
.btn-green:hover { background:#256327; }

/* ── SECTION WRAPPERS ── */
.section-dark  { background:var(--dark);  color:var(--cream); padding:72px 24px; }
.section-cream { background:var(--cream); color:var(--dark);  padding:72px 24px; }
.section-green { background:var(--green); color:var(--white); padding:72px 24px; }
.section-mid   { background:var(--mid);   color:var(--cream); padding:72px 24px; }

.container { max-width:1100px; margin:0 auto; }
.container-sm { max-width:760px; margin:0 auto; }

/* ── SECTION LABELS ── */
.sec-eyebrow {
  font-family:'Space Mono',monospace;
  font-size:.6rem; letter-spacing:3px;
  text-transform:uppercase; color:var(--lime);
  margin-bottom:8px;
}
.sec-title {
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(2rem,5vw,3.2rem);
  letter-spacing:3px; line-height:1;
  margin-bottom:16px;
}
.sec-sub {
  font-size:1.05rem; color:rgba(255,255,255,.75);
  max-width:560px; line-height:1.55;
}
.sec-sub.dark { color:rgba(0,0,0,.65); }

/* ── DIVIDER ── */
.lime-rule { width:48px; height:4px; background:var(--lime); margin:0 0 20px; }

/* ── IMG PLACEHOLDER ── */
.img-placeholder {
  background:var(--green); color:var(--lime);
  padding:60px 20px; text-align:center;
  font-family:'Space Mono',monospace; font-size:.7rem;
  letter-spacing:1px; line-height:2;
  border:2px dashed rgba(168,213,32,.4);
}

/* ============================================================
   NAVIGATION
   ============================================================ */
.site-nav {
  background:var(--dark);
  border-bottom:2px solid var(--border);
  position:sticky; top:0; z-index:900;
}
.nav-inner {
  max-width:1100px; margin:0 auto;
  display:flex; align-items:center;
  padding:0 24px; height:64px;
  gap:40px;
}
.nav-logo {
  font-family:'Bebas Neue',sans-serif;
  font-size:1.6rem; letter-spacing:4px;
  color:var(--white); flex-shrink:0;
}
.nav-logo .logo-rva { color:var(--lime); }
.nav-links { display:flex; align-items:center; gap:28px; margin-left:auto; }
.nav-links a {
  font-family:'Space Mono',monospace;
  font-size:.62rem; letter-spacing:1.5px;
  text-transform:uppercase; color:var(--muted);
  transition:color .15s;
}
.nav-links a:hover { color:var(--lime); }
.nav-links a.nav-cta {
  background:var(--lime); color:var(--dark);
  padding:8px 18px;
  font-weight:700;
}
.nav-links a.nav-cta:hover { background:#bfe025; }

.nav-hamburger {
  display:none; background:none; border:none;
  color:var(--cream); font-size:1.4rem;
  cursor:pointer; margin-left:auto;
}
.mobile-menu {
  display:none; flex-direction:column;
  background:var(--mid); border-top:1px solid var(--border);
  padding:16px 24px; gap:2px;
}
.mobile-menu a {
  font-family:'Space Mono',monospace;
  font-size:.68rem; letter-spacing:1.5px;
  text-transform:uppercase; color:var(--muted);
  padding:10px 0; border-bottom:1px solid var(--border);
}
.mobile-menu a:hover { color:var(--lime); }
.mobile-menu a.nav-cta {
  background:var(--lime); color:var(--dark);
  padding:12px 16px; text-align:center;
  margin-top:8px; border:none; font-weight:700;
}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
  background:#111; border-top:3px solid var(--green);
  padding:48px 24px 24px;
}
.footer-inner {
  max-width:1100px; margin:0 auto;
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:40px; margin-bottom:32px;
}
.footer-logo {
  font-family:'Bebas Neue',sans-serif;
  font-size:2rem; letter-spacing:4px;
  color:var(--lime); line-height:1;
  margin-bottom:6px;
}
.footer-logo span { color:var(--white); }
.footer-tagline {
  font-family:'Space Mono',monospace;
  font-size:.6rem; letter-spacing:1.5px;
  color:var(--muted); text-transform:uppercase;
}
.footer-llc {
  font-family:'Space Mono',monospace;
  font-size:.55rem; color:#444; margin-top:4px;
  text-transform:uppercase; letter-spacing:1px;
}
.footer-links { display:flex; flex-direction:column; gap:10px; }
.footer-links a {
  font-size:.88rem; color:var(--muted);
  transition:color .15s;
}
.footer-links a:hover { color:var(--lime); }
.footer-contact { display:flex; flex-direction:column; gap:10px; }
.footer-contact a {
  font-size:.88rem; color:var(--cream);
  transition:color .15s;
}
.footer-contact a:hover { color:var(--lime); }
.footer-cta {
  display:inline-block; margin-top:8px;
  background:var(--green); color:var(--lime) !important;
  font-family:'Bebas Neue',sans-serif;
  font-size:1rem; letter-spacing:2px;
  padding:10px 20px;
}
.footer-cta:hover { background:var(--lime) !important; color:var(--dark) !important; }
.footer-bottom {
  max-width:1100px; margin:0 auto;
  padding-top:20px; border-top:1px solid var(--border);
  display:flex; justify-content:space-between;
  font-family:'Space Mono',monospace;
  font-size:.55rem; color:#444;
  text-transform:uppercase; letter-spacing:1px;
  flex-wrap:wrap; gap:8px;
}

/* ============================================================
   PRICING CARDS
   ============================================================ */
.price-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:12px; margin:24px 0;
}
.price-card {
  background:var(--mid); border:2px solid var(--border);
  padding:24px 20px; text-align:center;
  transition:border-color .2s;
}
.price-card:hover { border-color:var(--lime); }
.price-card.featured { border-color:var(--lime); background:#1e2a12; }
.price-card .pc-label {
  font-family:'Space Mono',monospace;
  font-size:.6rem; letter-spacing:2px;
  text-transform:uppercase; color:var(--muted);
  margin-bottom:8px;
}
.price-card .pc-price {
  font-family:'Bebas Neue',sans-serif;
  font-size:3rem; color:var(--lime); line-height:1;
}
.price-card .pc-desc {
  font-size:.8rem; color:var(--muted);
  margin:6px 0 16px;
}
.price-card .pc-time {
  font-family:'Space Mono',monospace;
  font-size:.6rem; color:var(--muted);
  margin-bottom:16px;
}
.price-card .btn { width:100%; text-align:center; font-size:.85rem; padding:10px; }
.popular-tag {
  background:var(--orange); color:var(--white);
  font-family:'Space Mono',monospace; font-size:.55rem;
  padding:3px 10px; letter-spacing:1px;
  text-transform:uppercase; display:inline-block;
  margin-bottom:10px;
}

/* ============================================================
   CHECKLIST
   ============================================================ */
.checklist { list-style:none; }
.checklist li {
  padding:8px 0; border-bottom:1px solid rgba(255,255,255,.1);
  display:flex; align-items:center; gap:12px;
  font-size:.9rem;
}
.checklist li::before {
  content:'✓'; color:var(--lime);
  font-family:'Bebas Neue',sans-serif;
  font-size:1rem; flex-shrink:0;
}

/* ============================================================
   ACCORDION (FAQ — CSS only)
   ============================================================ */
.faq-item { border-bottom:1px solid var(--border); }
.faq-question {
  width:100%; background:none; border:none;
  text-align:left; cursor:pointer;
  display:flex; justify-content:space-between; align-items:center;
  padding:18px 0;
  font-family:'Barlow Condensed',sans-serif;
  font-size:1.05rem; font-weight:700;
  color:var(--cream); gap:16px;
}
.faq-question .faq-icon {
  font-size:1.4rem; color:var(--lime); flex-shrink:0;
  transition:transform .2s;
}
.faq-answer {
  max-height:0; overflow:hidden;
  transition:max-height .3s ease, padding .3s ease;
  font-size:.9rem; color:var(--muted); line-height:1.6;
}
.faq-item.open .faq-answer { max-height:300px; padding-bottom:16px; }
.faq-item.open .faq-icon { transform:rotate(45deg); }

/* ============================================================
   NEIGHBORHOOD PILLS
   ============================================================ */
.pill-wrap { display:flex; flex-wrap:wrap; gap:8px; margin:16px 0; }
.pill {
  background:rgba(168,213,32,.1);
  border:1px solid rgba(168,213,32,.3);
  color:var(--lime);
  font-family:'Space Mono',monospace;
  font-size:.62rem; letter-spacing:1px;
  padding:5px 14px; text-transform:uppercase;
}

/* ============================================================
   HOW-IT-WORKS STEPS
   ============================================================ */
.steps { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:32px; }
.step-card { text-align:center; }
.step-num {
  font-family:'Bebas Neue',sans-serif;
  font-size:5rem; color:var(--lime); line-height:1;
  opacity:.25; margin-bottom:-12px;
}
.step-title {
  font-family:'Bebas Neue',sans-serif;
  font-size:1.4rem; letter-spacing:2px;
  color:var(--dark); margin-bottom:8px;
}
.step-desc { font-size:.9rem; color:#555; line-height:1.5; }

/* ============================================================
   PRODUCT CARDS
   ============================================================ */
.product-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:16px; }
.product-card {
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1);
  padding:24px 20px;
}
.product-card .pc-name {
  font-family:'Bebas Neue',sans-serif;
  font-size:1.3rem; letter-spacing:2px; color:var(--lime);
  margin-bottom:8px;
}
.product-card .pc-role { font-size:.88rem; color:var(--cream); margin-bottom:8px; }
.product-card .pc-safe { font-family:'Space Mono',monospace; font-size:.62rem; color:var(--muted); line-height:1.6; }

/* ============================================================
   OBJECTION CARDS
   ============================================================ */
.objection-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:16px; }
.objection-card {
  background:var(--white); border-left:5px solid var(--green);
  padding:24px 20px;
}
.obj-q {
  font-family:'Bebas Neue',sans-serif;
  font-size:1.2rem; letter-spacing:1px; color:var(--dark);
  margin-bottom:10px;
}
.obj-a { font-size:.9rem; color:#555; line-height:1.55; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:768px) {
  .nav-links { display:none; }
  .nav-hamburger { display:block; }
  .footer-inner { grid-template-columns:1fr; gap:28px; }
  .footer-bottom { flex-direction:column; }
  .section-dark,.section-cream,.section-green,.section-mid { padding:48px 20px; }
  .steps { grid-template-columns:1fr; }
}
@media (max-width:480px) {
  .price-grid { grid-template-columns:1fr 1fr; }
}

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes fadeUp {
  from { opacity:0; transform:translateY(20px); }
  to   { opacity:1; transform:translateY(0); }
}
.fade-up { animation:fadeUp .5s ease both; }
.fade-up-2 { animation:fadeUp .5s .15s ease both; }
.fade-up-3 { animation:fadeUp .5s .3s ease both; }


/* ============================================================
WEEKLY SPECIAL BANNER
============================================================ */
.promo-banner {
  background: linear-gradient(135deg, #E8620A 0%, #c94f07 100%);
  color: var(--white);
  padding: 14px 24px;
  text-align: center;
  border-bottom: 3px solid #ffad00;
}
.promo-banner .promo-inner {
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
}
.promo-banner .promo-tag {
  font-family: 'Space Mono', monospace;
  font-size: .6rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  background: rgba(0,0,0,.25);
  padding: 3px 10px;
  flex-shrink: 0;
}
.promo-banner .promo-deals {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1.4rem;
  letter-spacing: 2px;
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
  justify-content: center;
}
.promo-banner .promo-deals span {
  background: rgba(0,0,0,.2);
  padding: 2px 14px;
}
.promo-banner .promo-cta {
  font-family: 'Bebas Neue', sans-serif;
  font-size: 1rem;
  letter-spacing: 2px;
  background: var(--lime);
  color: var(--dark);
  padding: 6px 18px;
  flex-shrink: 0;
  white-space: nowrap;
}
.promo-banner .promo-cta:hover {
  background: #bfe025;
}

/* ============================================================
HERO SECTION — MOBILE FIX
============================================================ */
.hero-section {
  background: var(--dark);
  position: relative;
  overflow: hidden;
}
.hero-inner {
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 520px;
  align-items: stretch;
}
.hero-content {
  padding: 60px 32px 60px 24px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  z-index: 2;
}
.hero-images {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 400px;
}
.hero-img-wrap {
  position: relative;
  overflow: hidden;
}
.hero-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.hero-img-label {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(0,0,0,.6);
  font-family: 'Space Mono', monospace;
  font-size: .6rem;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--lime);
  padding: 6px 10px;
  text-align: center;
}

@media (max-width: 768px) {
  .hero-inner {
    grid-template-columns: 1fr;
  }
  .hero-content {
    padding: 40px 20px 32px;
  }
  .hero-images {
    min-height: 200px;
    grid-template-columns: 1fr 1fr;
  }
  .promo-banner .promo-deals {
    font-size: 1.1rem;
  }
}

@media (max-width: 480px) {
  .hero-images {
    min-height: 160px;
  }
  .promo-banner .promo-inner {
    flex-direction: column;
    gap: 8px;
  }
  .promo-banner .promo-deals {
    font-size: 1rem;
    gap: 10px;
  }
}
.promo-banner .promo-deals span + span::before {
  content: '|';
  margin-right: 8px;
  opacity: 0.4;
}
.promo-banner .promo-deals span {
  display: inline-flex;
  align-items: center;
  gap: 0;
}
