/* ================================================
   HOME.CSS — Complete homepage overrides
   Loaded after styles.css on homepage only
   ================================================ */

/* === LOGO FIX — new icon+text layout === */
.header__logo {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0.5rem;
}
.header__logo small { display: none; }
.header__logo-icon { width: 40px; height: 40px; color: #0B8A8A; flex-shrink: 0; }
.header__logo-icon svg { width: 100%; height: 100%; }
.header__logo-text {
  font-family: "Poppins", sans-serif; font-weight: 800; font-size: 1.25rem;
  line-height: 1.1; color: #1a2332; display: flex; flex-direction: column;
}
.header__logo-text em { font-style: normal; color: #0B8A8A; }
.header__logo-text span { font-size: 0.8125rem; font-weight: 700; color: #2D3436; letter-spacing: 0.06em; text-transform: uppercase; }

/* === GLOBAL SVG SAFETY — prevent unsized SVGs from exploding === */
svg:not([width]):not(.header__logo-icon svg):not(.product-card__visual svg) {
  max-width: 28px;
  max-height: 28px;
}

/* === TOP BAR === */
.topbar { background: #1a2332; color: rgba(255,255,255,0.85); font-size: 0.8125rem; padding: 0.5rem 0; }
.topbar__inner { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 0.5rem; }
.topbar__left { display: flex; align-items: center; gap: 0.75rem; flex-wrap: wrap; }
.topbar__right { display: none; }
.topbar__item { display: inline-flex; align-items: center; gap: 0.375rem; white-space: nowrap; color: rgba(255,255,255,0.85); text-decoration: none; }
.topbar__item:hover { color: #fff; }
.topbar__item svg { width: 14px; height: 14px; color: #F5A623; flex-shrink: 0; }
.topbar__item strong { color: #F5A623; }
.topbar__item--phone strong { font-size: 0.9375rem; }
.topbar__divider { width: 1px; height: 14px; background: rgba(255,255,255,0.2); }
@media (max-width: 640px) { .topbar__item--hours { display: none; } }
@media (min-width: 768px) { .topbar__right { display: flex; align-items: center; } }

/* === LIGHT HERO === */
.hero-light { background: #fff; color: #0F1923; padding: 3.5rem 0 4rem; border-bottom: 1px solid #E2E8F0; }
.hero-light__grid { display: grid; grid-template-columns: 1fr; gap: 2.5rem; align-items: center; }
.hero-light__tag {
  display: inline-block; background: #E6F5F5; color: #0B8A8A;
  font-family: "Poppins", sans-serif; font-weight: 600; font-size: 0.8125rem;
  padding: 0.5rem 1.25rem; border-radius: 9999px; margin-bottom: 1.25rem;
}
.hero-light h1 { font-family: "Poppins", sans-serif; font-weight: 800; font-size: 2.25rem; line-height: 1.1; margin-bottom: 1rem; color: #0F1923; }
.hero-light h1 span { color: #0B8A8A; }
.hero-light__sub { color: #64748B; font-size: 1.0625rem; line-height: 1.7; margin-bottom: 1.5rem; max-width: 520px; }
.hero-light__checks { list-style: none; padding: 0; margin: 0 0 1.75rem; display: grid; grid-template-columns: 1fr 1fr; gap: 0.5rem; }
.hero-light__checks li { display: flex; align-items: center; gap: 0.5rem; font-size: 0.9375rem; font-weight: 500; color: #334155; }
.hero-light__checks li svg { width: 20px; height: 20px; color: #0B8A8A; flex-shrink: 0; }
.hero-light__actions { display: flex; flex-wrap: wrap; gap: 0.75rem; }
.hero-light__image img { width: 100%; max-width: 560px; height: auto; border-radius: 16px; box-shadow: 0 16px 48px rgba(0,0,0,0.12); }
@media (min-width: 768px) {
  .hero-light { padding: 4rem 0 5rem; }
  .hero-light h1 { font-size: 3rem; }
  .hero-light__grid { grid-template-columns: 1fr 1fr; gap: 3.5rem; }
}

/* === QUOTE SECTION === */
.quote-section { background: #F8FAFC; padding: 3.5rem 0; border-bottom: 1px solid #E2E8F0; }
.quote-section__inner { display: grid; grid-template-columns: 1fr; gap: 2rem; max-width: 880px; margin: 0 auto; }
.quote-section__text h2 { font-size: 1.75rem; margin-bottom: 0.75rem; }
.quote-section__text p { color: #64748B; line-height: 1.7; margin-bottom: 1.25rem; }
.quote-section__trust { display: flex; flex-direction: column; gap: 0.5rem; }
.quote-section__trust div { display: flex; align-items: center; gap: 0.5rem; font-size: 0.875rem; font-weight: 600; color: #0B8A8A; }
.quote-section__trust svg { width: 20px; height: 20px; color: #0B8A8A; flex-shrink: 0; }
.quote-section__form { background: #fff; padding: 2rem; border-radius: 16px; border: 1px solid #E2E8F0; box-shadow: 0 2px 12px rgba(0,0,0,0.04); }
@media (min-width: 768px) { .quote-section__inner { grid-template-columns: 1fr 1fr; gap: 3rem; } }

/* === METRICS === */
.metrics { background: #fff; border-bottom: 1px solid #E2E8F0; padding: 2.5rem 0; border-top: none; }
.metrics__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
.metrics__item { text-align: center; padding: 0.5rem; }
.metrics__icon { width: 48px; height: 48px; border-radius: 12px; background: #E6F5F5; display: flex; align-items: center; justify-content: center; margin: 0 auto 0.75rem; }
.metrics__icon svg { width: 24px; height: 24px; color: #0B8A8A; }
.metrics__number { font-family: "Poppins", sans-serif; font-weight: 800; font-size: 2rem; color: #0B8A8A; line-height: 1; margin-bottom: 0.25rem; }
.metrics__label { font-size: 0.8125rem; color: #94A3B8; }
@media (min-width: 768px) { .metrics__grid { grid-template-columns: repeat(4, 1fr); } .metrics__number { font-size: 2.25rem; } }

/* === SECTIONS === */
.section { padding: 4rem 0; }
.section--white { background: #fff; }
.section--light { background: #F8FAFC; border-top: 1px solid #E2E8F0; border-bottom: 1px solid #E2E8F0; }
.section__header { text-align: center; margin-bottom: 3rem; max-width: 680px; margin-left: auto; margin-right: auto; }
.section__header h2 { margin-bottom: 0.75rem; }
.section__header p { color: #64748B; font-size: 1.0625rem; line-height: 1.7; }
.section__tag { display: inline-block; background: #E6F5F5; color: #0B8A8A; font-family: "Poppins", sans-serif; font-weight: 600; font-size: 0.8125rem; padding: 0.5rem 1.25rem; border-radius: 9999px; margin-bottom: 1rem; text-transform: uppercase; }
.section__tag--light { background: rgba(255,255,255,0.1); color: #FFD166; }
.section__footer { text-align: center; margin-top: 2.5rem; }

/* === 3-STEP PROCESS === */
.process { display: flex; flex-direction: column; gap: 2rem; align-items: center; }
.process__step { text-align: center; max-width: 320px; }
.process__number { width: 60px; height: 60px; border-radius: 50%; background: linear-gradient(135deg, #0B8A8A, #066D6D); color: #fff; font-family: "Poppins", sans-serif; font-weight: 800; font-size: 1.375rem; display: flex; align-items: center; justify-content: center; margin: 0 auto 1rem; box-shadow: 0 6px 20px rgba(11,138,138,0.25); }
.process__icon { width: 64px; height: 64px; border-radius: 12px; background: #E6F5F5; display: flex; align-items: center; justify-content: center; margin: 0 auto 1rem; }
.process__icon svg { width: 28px; height: 28px; color: #0B8A8A; }
.process__step h3 { font-size: 1.125rem; margin-bottom: 0.5rem; }
.process__step p { font-size: 0.9375rem; color: #64748B; line-height: 1.6; }
.process__connector { display: none; }
.process__connector svg { width: 24px; height: 24px; color: #CBD5E0; }
@media (min-width: 768px) { .process { flex-direction: row; align-items: flex-start; gap: 1.5rem; } .process__step { flex: 1; } .process__connector { display: flex; align-items: center; padding-top: 2rem; } }

/* === PRODUCT CARDS === */
.products { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media (min-width: 640px) { .products { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .products { grid-template-columns: repeat(3, 1fr); } }
.product-card { display: flex; flex-direction: column; background: #fff; border: 1px solid #E2E8F0; border-radius: 12px; overflow: hidden; transition: all 0.25s ease; text-decoration: none; color: inherit; position: relative; }
.product-card:hover { border-color: #0B8A8A; box-shadow: 0 8px 32px rgba(11,138,138,0.1); transform: translateY(-4px); color: inherit; }
.product-card--popular { border-color: #F5A623; border-width: 2px; }
.product-card__badge { position: absolute; top: 0.75rem; right: 0.75rem; z-index: 2; background: #F5A623; color: #fff; font-family: "Poppins", sans-serif; font-weight: 700; font-size: 0.6875rem; text-transform: uppercase; padding: 0.25rem 0.75rem; border-radius: 9999px; }
.product-card__visual { height: 200px; background: #F8FAFC; overflow: hidden; border-bottom: 1px solid #F1F5F9; }
.product-card__visual img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease; }
.product-card:hover .product-card__visual img { transform: scale(1.06); }
.product-card__body { padding: 1.25rem 1.5rem 1.5rem; flex: 1; display: flex; flex-direction: column; }
.product-card__body h3 { font-size: 1.0625rem; margin-bottom: 0.375rem; }
.product-card__body p { font-size: 0.8125rem; color: #64748B; line-height: 1.6; margin-bottom: 1rem; flex: 1; }
.product-card__price { display: flex; align-items: baseline; gap: 0.25rem; padding-top: 0.75rem; border-top: 1px solid #F1F5F9; margin-bottom: 0.5rem; }
.product-card__from { font-size: 0.6875rem; color: #94A3B8; font-weight: 600; text-transform: uppercase; }
.product-card__amount { font-family: "Poppins", sans-serif; font-weight: 800; font-size: 1.75rem; color: #0B8A8A; }
.product-card__unit { font-size: 0.8125rem; color: #94A3B8; }
.product-card__includes { font-size: 0.75rem; color: #10B981; font-weight: 600; display: flex; align-items: center; gap: 0.25rem; margin-bottom: 1rem; }
.product-card__includes svg { width: 16px; height: 16px; }
.product-card__cta { display: inline-flex; align-items: center; gap: 0.25rem; font-family: "Poppins", sans-serif; font-weight: 700; font-size: 0.875rem; color: #0B8A8A; }
.product-card__cta svg { width: 16px; height: 16px; }
.product-card:hover .product-card__cta { gap: 0.5rem; }

/* === DUMPSTER SIZES === */
.sizes { display: grid; grid-template-columns: 1fr; gap: 1rem; }
@media (min-width: 640px) { .sizes { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 768px) { .sizes { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1100px) { .sizes { grid-template-columns: repeat(5, 1fr); } }
.size-card { background: #fff; border: 1px solid #E2E8F0; border-radius: 12px; overflow: hidden; transition: all 0.25s ease; }
.size-card:hover { border-color: #0B8A8A; box-shadow: 0 8px 24px rgba(11,138,138,0.1); transform: translateY(-3px); }
.size-card--featured { border: 2px solid #0B8A8A; }
.size-card__popular { background: #F5A623; color: #fff; text-align: center; font-family: "Poppins", sans-serif; font-weight: 700; font-size: 0.6875rem; text-transform: uppercase; padding: 0.375rem; }
.size-card__header { background: #F8FAFC; padding: 1.25rem 1rem; text-align: center; }
.size-card__volume { font-family: "Poppins", sans-serif; font-weight: 900; font-size: 2.5rem; color: #0B8A8A; line-height: 1; }
.size-card__volume span { display: block; font-size: 0.875rem; font-weight: 600; color: #94A3B8; }
.size-card__body { padding: 1.25rem 1rem; }
.size-card__dims { font-size: 0.75rem; color: #94A3B8; font-weight: 600; margin-bottom: 0.25rem; }
.size-card__detail { font-size: 0.75rem; color: #0B8A8A; font-weight: 700; margin-bottom: 0.75rem; }
.size-card__body p { font-size: 0.8125rem; color: #64748B; line-height: 1.5; margin-bottom: 0.75rem; }
.size-card__price { font-size: 0.875rem; margin-bottom: 0.75rem; }
.size-card__price strong { font-family: "Poppins", sans-serif; font-weight: 800; font-size: 1.25rem; color: #0B8A8A; }
.sizes__note { text-align: center; margin-top: 1.5rem; font-size: 0.875rem; color: #94A3B8; }

/* === USE CASES === */
.usecases { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media (min-width: 640px) { .usecases { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .usecases { grid-template-columns: repeat(4, 1fr); } }
.usecase { background: #fff; border: 1px solid #E2E8F0; border-radius: 12px; overflow: hidden; transition: all 0.25s ease; padding: 0; }
.usecase:hover { border-color: #0B8A8A; box-shadow: 0 8px 24px rgba(11,138,138,0.1); transform: translateY(-3px); }
.usecase__img { height: 200px; background-size: cover; background-position: center; }
.usecase__body { padding: 1.5rem; }
.usecase__body h3 { font-size: 1.0625rem; margin-bottom: 0.5rem; }
.usecase__body p { font-size: 0.8125rem; color: #64748B; line-height: 1.6; margin-bottom: 0.75rem; }
.usecase__products { font-size: 0.6875rem; font-weight: 600; color: #0B8A8A; background: #E6F5F5; padding: 0.25rem 0.625rem; border-radius: 9999px; display: inline-block; }

/* === REVIEWS === */
.reviews { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media (min-width: 640px) { .reviews { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .reviews { grid-template-columns: repeat(3, 1fr); } }
.review-card { background: #fff; border: 1px solid #E2E8F0; border-radius: 12px; padding: 1.75rem; transition: all 0.25s ease; }
.review-card:hover { box-shadow: 0 8px 24px rgba(0,0,0,0.06); transform: translateY(-2px); }
.review-card__stars { color: #F5A623; font-size: 1.125rem; margin-bottom: 0.75rem; letter-spacing: 2px; }
.review-card__text { font-size: 0.9375rem; color: #4A5568; line-height: 1.7; margin-bottom: 1.25rem; font-style: italic; }
.review-card__author { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 0.5rem; }
.review-card__avatar { width: 42px; height: 42px; border-radius: 50%; background: linear-gradient(135deg, #0B8A8A, #066D6D); color: #fff; display: flex; align-items: center; justify-content: center; font-family: "Poppins", sans-serif; font-weight: 700; font-size: 0.875rem; flex-shrink: 0; }
.review-card__name { font-weight: 600; font-size: 0.875rem; }
.review-card__role { font-size: 0.75rem; color: #94A3B8; }
.review-card__source { font-size: 0.6875rem; color: #94A3B8; padding-top: 0.5rem; border-top: 1px solid #F1F5F9; }

/* === SERVICE AREAS === */
.areas { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media (min-width: 768px) { .areas { grid-template-columns: repeat(2, 1fr); } }
.area-block { background: #fff; border: 1px solid #E2E8F0; border-radius: 12px; padding: 1.75rem; transition: all 0.25s ease; }
.area-block:hover { border-color: #0B8A8A; box-shadow: 0 4px 16px rgba(11,138,138,0.08); }
.area-block--coming { opacity: 0.7; }
.area-block__header { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 1rem; }
.area-block__header svg { width: 24px; height: 24px; color: #0B8A8A; flex-shrink: 0; }
.area-block__header h3 { flex: 1; }
.area-block__count { background: #E6F5F5; color: #0B8A8A; font-family: "Poppins", sans-serif; font-weight: 600; font-size: 0.6875rem; padding: 0.25rem 0.625rem; border-radius: 9999px; }
.area-block__cities { display: flex; flex-wrap: wrap; gap: 0.375rem; margin-bottom: 1rem; }
.area-block__cities span { background: #F8FAFC; color: #4A5568; font-size: 0.75rem; font-weight: 500; padding: 0.25rem 0.625rem; border-radius: 6px; border: 1px solid #E2E8F0; }
.area-block__link { font-size: 0.8125rem; font-weight: 600; color: #0B8A8A; text-decoration: none; }

/* === FAQ === */
.faq { max-width: 800px; margin: 0 auto; }

/* === CTA SECTION === */
.cta-section__inner { max-width: 640px; margin: 0 auto; }
.cta-section__buttons { display: flex; flex-wrap: wrap; gap: 0.75rem; justify-content: center; }
