/* ============================================================
   WOODSTOCK DUMPSTER CO. — MAIN STYLESHEET
   ============================================================ */

:root {
  --orange:       #F97316;
  --orange-dark:  #EA580C;
  --orange-light: #FED7AA;
  --dark:         #1C1917;
  --gray-800:     #292524;
  --gray-700:     #44403C;
  --gray-500:     #78716C;
  --gray-400:     #A8A29E;
  --gray-300:     #D6D3D1;
  --gray-100:     #F5F5F4;
  --white:        #FFFFFF;
  --red-bg:       #FEF2F2;
  --red-border:   #FECACA;
  --red-text:     #991B1B;
  --shadow-sm:    0 1px 3px rgba(0,0,0,.10);
  --shadow-md:    0 4px 14px rgba(0,0,0,.12);
  --shadow-lg:    0 8px 32px rgba(0,0,0,.16);
  --radius:       8px;
  --radius-lg:    16px;
  --transition:   0.2s ease;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  color: var(--dark);
  background: var(--white);
  line-height: 1.6;
}
h1,h2,h3,h4 { font-weight:700; line-height:1.2; }
h1 { font-size: clamp(1.9rem, 5vw, 3.2rem); }
h2 { font-size: clamp(1.4rem, 3vw, 2.1rem); }
h3 { font-size: 1.2rem; }
p  { color: var(--gray-700); }
a  { color:inherit; text-decoration:none; }
img { max-width:100%; }

/* ---- Layout ---- */
.container { max-width:1100px; margin:0 auto; padding:0 1.5rem; }
.section    { padding:5rem 0; }

.section-header { text-align:center; margin-bottom:3rem; }
.section-header h2 { margin-bottom:.6rem; }
.section-header p  { color:var(--gray-500); max-width:540px; margin:0 auto; }

/* ---- Buttons ---- */
.btn {
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.75rem 1.75rem; border-radius:var(--radius);
  font-weight:600; font-size:1rem; cursor:pointer;
  border:2px solid transparent; transition:all var(--transition);
  text-decoration:none; font-family:inherit;
}
.btn-primary { background:var(--orange); color:var(--white); }
.btn-primary:hover { background:var(--orange-dark); transform:translateY(-1px); box-shadow:var(--shadow-md); }
.btn-outline  { border-color:var(--orange); color:var(--orange); }
.btn-outline:hover { background:var(--orange); color:var(--white); }
.btn-dark     { background:var(--dark); color:var(--white); }
.btn-dark:hover { background:var(--gray-800); transform:translateY(-1px); }
.btn-ghost    { background:rgba(255,255,255,.1); color:var(--white); border-color:rgba(255,255,255,.25); }
.btn-ghost:hover { background:rgba(255,255,255,.2); }
.btn-lg { padding:1rem 2.5rem; font-size:1.05rem; }
.btn:disabled { opacity:.5; cursor:not-allowed; transform:none !important; }


/* ============================================================
   NAVIGATION
   ============================================================ */
.nav {
  background:var(--dark);
  position:sticky; top:0; z-index:200;
  box-shadow:var(--shadow-md);
}
.nav-inner {
  display:flex; align-items:center; justify-content:space-between;
  padding:.9rem 1.5rem; max-width:1100px; margin:0 auto;
}
.nav-logo {
  display:flex; align-items:center; gap:.75rem;
  color:var(--white); font-weight:800; font-size:1.1rem;
  text-transform:uppercase; letter-spacing:.03em;
}
.nav-logo-icon {
  width:36px; height:36px; background:var(--orange); border-radius:6px;
  display:flex; align-items:center; justify-content:center; font-size:1.2rem;
}
.nav-logo em { color:var(--orange); font-style:normal; }
.nav-links { display:flex; align-items:center; gap:1.75rem; list-style:none; }
.nav-links a { color:var(--gray-300); font-weight:500; transition:color var(--transition); font-size:.95rem; }
.nav-links a:hover, .nav-links a.active { color:var(--white); }
.nav-right { display:flex; align-items:center; gap:1rem; }
.nav-phone { color:var(--orange); font-weight:700; font-size:.95rem; }
.nav-hamburger {
  display:none; flex-direction:column; gap:5px;
  cursor:pointer; background:none; border:none; padding:4px;
}
.nav-hamburger span { display:block; width:24px; height:2px; background:var(--white); border-radius:2px; transition:all var(--transition); }
.mobile-menu {
  display:none; background:var(--gray-800); padding:1rem 1.5rem 1.5rem;
}
.mobile-menu.open { display:block; }
.mobile-menu a { display:block; color:var(--gray-300); padding:.65rem 0; font-weight:500; border-bottom:1px solid rgba(255,255,255,.06); }
.mobile-menu a:last-child { border:none; }


/* ============================================================
   HERO
   ============================================================ */
.hero {
  background:var(--dark);
  padding:5rem 0 4rem;
  position:relative; overflow:hidden;
}
.hero::after {
  content:'';
  position:absolute; top:0; right:0;
  width:55%; height:100%;
  background:linear-gradient(135deg, transparent, rgba(249,115,22,.07));
  pointer-events:none;
}
.hero-inner {
  display:grid; grid-template-columns:1fr 1fr; gap:3rem; align-items:center;
  position:relative; z-index:1;
}
.hero-badge {
  display:inline-flex; align-items:center; gap:.4rem;
  background:rgba(249,115,22,.12); color:var(--orange);
  border:1px solid rgba(249,115,22,.3);
  padding:.3rem .85rem; border-radius:100px;
  font-size:.82rem; font-weight:600; margin-bottom:1.25rem;
}
.hero h1 { color:var(--white); margin-bottom:1.1rem; }
.hero h1 span { color:var(--orange); }
.hero-lead { color:var(--gray-300); font-size:1.05rem; margin-bottom:2rem; max-width:460px; }
.hero-actions { display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:2.5rem; }
.hero-stats { display:flex; gap:2.5rem; }
.hero-stat strong { display:block; font-size:1.7rem; color:var(--white); }
.hero-stat span   { font-size:.82rem; color:var(--gray-500); }

/* Pricing card */
.hero-card {
  background:var(--gray-800); border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-lg); padding:1.75rem; width:100%; max-width:340px; margin:0 auto;
}
.hero-card-title {
  color:var(--gray-300); font-size:.78rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.08em; margin-bottom:1.25rem;
}
.price-row {
  display:flex; justify-content:space-between; align-items:center;
  padding:.8rem 0; border-bottom:1px solid rgba(255,255,255,.07);
}
.price-row:last-child { border:none; }
.price-label { color:var(--white); font-weight:600; font-size:.95rem; }
.price-sub   { color:var(--gray-500); font-size:.78rem; }
.price-amount{ color:var(--orange); font-weight:800; font-size:1.2rem; }
.hero-card-note {
  margin-top:1.1rem; padding-top:1rem; border-top:1px solid rgba(255,255,255,.07);
  color:var(--gray-500); font-size:.8rem; text-align:center;
}


/* ============================================================
   HOW IT WORKS
   ============================================================ */
.how { background:var(--gray-100); }
.steps {
  display:grid; grid-template-columns:repeat(3,1fr); gap:2rem;
  position:relative;
}
.steps::before {
  content:'';
  position:absolute; top:1.9rem;
  left:calc(16.67% + 1rem); right:calc(16.67% + 1rem);
  height:2px; background:var(--orange);
}
.step { text-align:center; position:relative; }
.step-num {
  width:3.75rem; height:3.75rem;
  background:var(--orange); color:var(--white);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:1.3rem; font-weight:800;
  margin:0 auto 1.2rem;
  position:relative; z-index:1;
  box-shadow:0 0 0 6px var(--gray-100);
}
.step h3 { margin-bottom:.4rem; }
.step p { font-size:.92rem; }


/* ============================================================
   SIZES
   ============================================================ */
.sizes-grid {
  display:grid; grid-template-columns:repeat(2,1fr);
  gap:1.5rem; max-width:680px; margin:0 auto;
}
.size-card {
  background:var(--white); border:2px solid var(--gray-300);
  border-radius:var(--radius-lg); padding:2rem;
  transition:all var(--transition); position:relative; overflow:hidden;
}
.size-card:hover       { border-color:var(--orange); box-shadow:var(--shadow-lg); transform:translateY(-4px); }
.size-card.popular     { border-color:var(--orange); }
.popular-badge {
  position:absolute; top:0; right:0;
  background:var(--orange); color:var(--white);
  font-size:.72rem; font-weight:700; padding:.3rem .85rem;
  border-bottom-left-radius:var(--radius);
  text-transform:uppercase; letter-spacing:.05em;
}
.size-icon  { font-size:2.25rem; margin-bottom:.65rem; }
.size-card h3 { font-size:1.4rem; margin-bottom:.2rem; }
.size-dims  { color:var(--gray-500); font-size:.82rem; margin-bottom:.9rem; }
.size-price { font-size:1.9rem; font-weight:800; color:var(--orange); }
.size-note  { color:var(--gray-500); font-size:.82rem; margin-bottom:1.25rem; }
.size-feats { list-style:none; margin-bottom:1.5rem; }
.size-feats li {
  padding:.3rem 0; color:var(--gray-700); font-size:.88rem;
  display:flex; align-items:center; gap:.5rem;
}
.size-feats li::before { content:'✓'; color:var(--orange); font-weight:700; }


/* ============================================================
   WHY US
   ============================================================ */
.why { background:var(--dark); }
.why .section-header h2 { color:var(--white); }
.why .section-header p  { color:var(--gray-300); }
.benefits {
  display:grid; grid-template-columns:repeat(3,1fr); gap:1.75rem;
}
.benefit {
  background:var(--gray-800); border:1px solid rgba(255,255,255,.07);
  border-radius:var(--radius-lg); padding:1.75rem;
  transition:all var(--transition);
}
.benefit:hover { border-color:rgba(249,115,22,.35); transform:translateY(-2px); }
.benefit-icon {
  width:3rem; height:3rem; background:rgba(249,115,22,.12);
  border-radius:var(--radius); display:flex; align-items:center; justify-content:center;
  font-size:1.35rem; margin-bottom:.9rem;
}
.benefit h3 { color:var(--white); margin-bottom:.4rem; }
.benefit p  { color:var(--gray-300); font-size:.9rem; }


/* ============================================================
   SERVICE AREA
   ============================================================ */
.area-inner {
  display:grid; grid-template-columns:1fr 1fr; gap:3.5rem; align-items:center;
}
.area-text h2 { margin-bottom:.75rem; }
.area-text p  { margin-bottom:1.25rem; }
.area-chips {
  display:flex; flex-wrap:wrap; gap:.6rem; margin-bottom:2rem;
}
.chip {
  background:var(--gray-100); border:1px solid var(--gray-300);
  border-radius:100px; padding:.3rem .85rem;
  font-size:.85rem; font-weight:600; color:var(--gray-700);
  display:flex; align-items:center; gap:.35rem;
}
.chip::before { content:'📍'; font-size:.75rem; }
.area-map {
  background:var(--gray-100); border-radius:var(--radius-lg);
  border:2px dashed var(--gray-300); height:320px;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:.5rem; color:var(--gray-500); font-size:.9rem; text-align:center;
}
.area-map-icon { font-size:3rem; }


/* ============================================================
   TESTIMONIALS
   ============================================================ */
.reviews { background:var(--gray-100); }
.reviews-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem;
}
.review-card {
  background:var(--white); border-radius:var(--radius-lg);
  padding:1.75rem; box-shadow:var(--shadow-sm);
}
.stars { color:#FBBF24; font-size:1rem; letter-spacing:2px; margin-bottom:.75rem; }
.review-card blockquote {
  font-size:.93rem; font-style:italic;
  color:var(--gray-700); margin-bottom:1.1rem; line-height:1.65;
}
.reviewer { display:flex; align-items:center; gap:.75rem; }
.reviewer-avatar {
  width:2.4rem; height:2.4rem; border-radius:50%;
  background:var(--orange); color:var(--white);
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:.88rem; flex-shrink:0;
}
.reviewer-name { font-weight:700; font-size:.88rem; }
.reviewer-loc  { color:var(--gray-500); font-size:.78rem; }


/* ============================================================
   CTA BANNER
   ============================================================ */
.cta-banner { background:var(--orange); padding:4rem 0; }
.cta-banner .container { text-align:center; }
.cta-banner h2 { color:var(--white); margin-bottom:.65rem; }
.cta-banner p  { color:rgba(255,255,255,.85); font-size:1.05rem; margin-bottom:2rem; }


/* ============================================================
   FOOTER
   ============================================================ */
.footer { background:var(--dark); padding:3.5rem 0 1.5rem; }
.footer-grid {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:2rem;
  padding-bottom:2rem; border-bottom:1px solid rgba(255,255,255,.08); margin-bottom:1.5rem;
}
.footer-brand p { color:var(--gray-500); font-size:.88rem; margin:.75rem 0 1.25rem; max-width:260px; }
.footer h4 {
  color:var(--white); font-size:.82rem;
  text-transform:uppercase; letter-spacing:.08em; margin-bottom:1rem;
}
.footer-links { list-style:none; display:flex; flex-direction:column; gap:.5rem; }
.footer-links a { color:var(--gray-500); font-size:.88rem; transition:color var(--transition); }
.footer-links a:hover { color:var(--white); }
.footer-contact-list { list-style:none; display:flex; flex-direction:column; gap:.75rem; }
.footer-contact-list li { display:flex; align-items:flex-start; gap:.6rem; font-size:.88rem; color:var(--gray-500); }
.footer-bottom {
  display:flex; justify-content:space-between; align-items:center;
  font-size:.82rem; color:var(--gray-500);
}


/* ============================================================
   PAGE HERO (inner pages)
   ============================================================ */
.page-hero { background:var(--dark); padding:3.5rem 0; }
.page-hero h1 { color:var(--white); margin-bottom:.5rem; }
.page-hero p  { color:var(--gray-300); font-size:1.05rem; }
.breadcrumb {
  display:flex; align-items:center; gap:.5rem;
  color:var(--gray-500); font-size:.85rem; margin-bottom:1rem;
}
.breadcrumb a { color:var(--orange); }
.breadcrumb span { color:var(--gray-500); }


/* ============================================================
   SERVICES PAGE
   ============================================================ */
.pricing-table { width:100%; border-collapse:collapse; margin-top:1.5rem; border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-sm); }
.pricing-table th { background:var(--dark); color:var(--white); padding:.85rem 1.25rem; text-align:left; font-size:.82rem; text-transform:uppercase; letter-spacing:.05em; }
.pricing-table td { padding:1rem 1.25rem; border-bottom:1px solid var(--gray-300); color:var(--gray-700); }
.pricing-table tr:last-child td { border-bottom:none; }
.pricing-table tr:nth-child(even) td { background:var(--gray-100); }
.price-td { font-weight:700; color:var(--orange) !important; font-size:1rem; }

.addons-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:1rem; margin-top:1.5rem; }
.addon-item {
  background:var(--gray-100); border-radius:var(--radius);
  padding:1.1rem 1.35rem; display:flex; justify-content:space-between; align-items:center;
}
.addon-item .addon-name { font-weight:600; font-size:.92rem; }
.addon-item .addon-price { font-weight:700; color:var(--orange); }

.no-list {
  display:grid; grid-template-columns:repeat(3,1fr); gap:.75rem; margin-top:1.25rem;
}
.no-item {
  background:var(--red-bg); border:1px solid var(--red-border); border-radius:var(--radius);
  padding:.7rem 1rem; font-size:.88rem; color:var(--red-text);
  display:flex; align-items:center; gap:.5rem;
}


/* ============================================================
   BOOKING PAGE
   ============================================================ */
.book-hero { background:var(--dark); padding:3rem 0; text-align:center; }
.book-hero h1 { color:var(--white); margin-bottom:.4rem; }
.book-hero p  { color:var(--gray-300); }

.book-wrap { max-width:700px; margin:0 auto; padding:3rem 1.5rem 5rem; }

/* Progress */
.progress {
  display:flex; align-items:flex-start;
  margin-bottom:2.75rem;
}
.prog-step { display:flex; flex-direction:column; align-items:center; flex:1; position:relative; }
.prog-step:not(:last-child)::after {
  content:''; position:absolute; top:1.1rem; left:50%; width:100%;
  height:2px; background:var(--gray-300); z-index:0;
}
.prog-step.done:not(:last-child)::after,
.prog-step.active:not(:last-child)::after { background:var(--orange); }
.prog-dot {
  width:2.2rem; height:2.2rem; border-radius:50%;
  background:var(--gray-300); border:2px solid var(--gray-300);
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:.82rem; color:var(--gray-500);
  position:relative; z-index:1; transition:all var(--transition);
}
.prog-step.active .prog-dot { background:var(--orange); border-color:var(--orange); color:var(--white); }
.prog-step.done  .prog-dot  { background:var(--orange); border-color:var(--orange); color:var(--white); }
.prog-label { font-size:.72rem; font-weight:600; color:var(--gray-400); margin-top:.4rem; text-align:center; }
.prog-step.active .prog-label { color:var(--orange); }
.prog-step.done   .prog-label { color:var(--gray-700); }

/* Steps */
.form-step { display:none; animation:fadeIn .3s ease; }
.form-step.active { display:block; }
@keyframes fadeIn { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }
.step-title { margin-bottom:.4rem; }
.step-desc  { color:var(--gray-500); margin-bottom:2rem; }

/* Service type cards */
.svc-cards { display:grid; grid-template-columns:1fr 1fr; gap:1.25rem; margin-bottom:2rem; }
.svc-card {
  border:2px solid var(--gray-300); border-radius:var(--radius-lg);
  padding:1.75rem; cursor:pointer; transition:all var(--transition); text-align:center;
}
.svc-card:hover    { border-color:var(--orange); }
.svc-card.selected { border-color:var(--orange); background:rgba(249,115,22,.04); }
.svc-card-icon { font-size:2.5rem; margin-bottom:.65rem; }
.svc-card h3  { margin-bottom:.3rem; }
.svc-card p   { font-size:.85rem; color:var(--gray-500); }

/* Size options */
.size-opts { display:grid; grid-template-columns:1fr 1fr; gap:1.25rem; margin-bottom:1.5rem; }
.size-opt {
  border:2px solid var(--gray-300); border-radius:var(--radius-lg);
  padding:1.5rem; cursor:pointer; transition:all var(--transition); position:relative;
}
.size-opt:hover    { border-color:var(--orange); }
.size-opt.selected { border-color:var(--orange); background:rgba(249,115,22,.04); }
.size-opt-name  { font-size:1.15rem; font-weight:700; margin-bottom:.2rem; }
.size-opt-dims  { font-size:.78rem; color:var(--gray-500); margin-bottom:.6rem; }
.size-opt-uses  { font-size:.82rem; color:var(--gray-600); margin-bottom:.9rem; }
.size-opt-price { font-size:1.5rem; font-weight:800; color:var(--orange); }
.size-opt-note  { font-size:.75rem; color:var(--gray-500); }
.size-opt-pop {
  position:absolute; top:0; right:0;
  background:var(--orange); color:var(--white);
  font-size:.68rem; font-weight:700; padding:.25rem .7rem;
  border-bottom-left-radius:var(--radius); text-transform:uppercase; letter-spacing:.04em;
}

/* Form fields */
.form-row   { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-group { margin-bottom:1.25rem; }
.form-group label {
  display:block; font-weight:600; font-size:.88rem; margin-bottom:.4rem; color:var(--dark);
}
.form-group input,
.form-group select,
.form-group textarea {
  width:100%; padding:.75rem 1rem;
  border:2px solid var(--gray-300); border-radius:var(--radius);
  font-size:.95rem; color:var(--dark); font-family:inherit;
  transition:border-color var(--transition); background:var(--white);
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { outline:none; border-color:var(--orange); }
.form-group textarea { resize:vertical; min-height:90px; }
.field-note { font-size:.78rem; color:var(--gray-500); margin-top:.3rem; }
.field-error { font-size:.78rem; color:#DC2626; margin-top:.3rem; display:none; }
.field-error.show { display:block; }
.form-group input.error,
.form-group select.error,
.form-group textarea.error { border-color:#DC2626; }

/* Rental duration chips */
.duration-chips { display:flex; flex-wrap:wrap; gap:.6rem; margin-top:.4rem; }
.dur-chip {
  padding:.4rem 1rem; border:2px solid var(--gray-300); border-radius:100px;
  font-size:.88rem; font-weight:600; cursor:pointer; transition:all var(--transition);
  background:var(--white); color:var(--gray-700); font-family:inherit;
}
.dur-chip:hover    { border-color:var(--orange); color:var(--orange); }
.dur-chip.selected { background:var(--orange); border-color:var(--orange); color:var(--white); }

/* Summary */
.summary-box {
  background:var(--gray-100); border-radius:var(--radius-lg); padding:1.75rem; margin-bottom:1.5rem;
}
.summary-box h3 { margin-bottom:1rem; padding-bottom:.75rem; border-bottom:1px solid var(--gray-300); }
.summary-row {
  display:flex; justify-content:space-between; padding:.45rem 0; font-size:.92rem;
}
.summary-row span:first-child { color:var(--gray-500); }
.summary-row span:last-child  { font-weight:600; }
.summary-total {
  display:flex; justify-content:space-between;
  padding:.75rem 0 0; margin-top:.5rem;
  border-top:2px solid var(--gray-300); font-weight:700; font-size:1.05rem;
}
.summary-total span:last-child { color:var(--orange); font-size:1.25rem; }

.terms-row { display:flex; align-items:flex-start; gap:.75rem; margin-bottom:1.5rem; }
.terms-row input[type=checkbox] { width:1rem; height:1rem; margin-top:.2rem; accent-color:var(--orange); flex-shrink:0; }
.terms-row label { font-size:.85rem; color:var(--gray-700); cursor:pointer; }
.terms-row a { color:var(--orange); }

/* Form nav */
.form-nav {
  display:flex; justify-content:space-between; align-items:center;
  margin-top:2rem; padding-top:1.5rem; border-top:1px solid var(--gray-300);
}

/* Confirmation */
.confirm-box { text-align:center; padding:2.5rem 0; }
.confirm-icon {
  width:5rem; height:5rem; background:rgba(34,197,94,.1);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:2.5rem; margin:0 auto 1.5rem;
}
.confirm-box h2 { margin-bottom:.65rem; }
.confirm-box p  { color:var(--gray-500); max-width:400px; margin:0 auto 1.5rem; }
.confirm-num    { font-size:1.6rem; font-weight:800; color:var(--orange); margin-bottom:.3rem; }
.confirm-details {
  background:var(--gray-100); border-radius:var(--radius-lg); padding:1.5rem;
  margin:1.5rem 0 2rem; text-align:left;
}
.confirm-details h4 { margin-bottom:.75rem; color:var(--gray-500); font-size:.8rem; text-transform:uppercase; letter-spacing:.06em; }


/* ============================================================
   CONTACT PAGE
   ============================================================ */
.contact-grid { display:grid; grid-template-columns:1fr 1.5fr; gap:3rem; align-items:start; }
.contact-info h2 { margin-bottom:1rem; }
.contact-info > p { margin-bottom:1.75rem; }
.contact-item { display:flex; gap:1rem; margin-bottom:1.5rem; }
.contact-ico {
  width:2.75rem; height:2.75rem; background:rgba(249,115,22,.1);
  border-radius:var(--radius); display:flex; align-items:center; justify-content:center;
  font-size:1.2rem; flex-shrink:0;
}
.contact-item h4 { margin-bottom:.15rem; font-size:.95rem; }
.contact-item p  { color:var(--gray-500); font-size:.88rem; }
.contact-form-box { background:var(--gray-100); border-radius:var(--radius-lg); padding:2.25rem; }
.contact-form-box h3 { margin-bottom:1.5rem; }


/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 900px) {
  .footer-grid { grid-template-columns:1fr 1fr; }
}

@media (max-width: 768px) {
  .nav-links, .nav-right { display:none; }
  .nav-hamburger { display:flex; }

  .hero-inner { grid-template-columns:1fr; }
  .hero-visual { display:none; }
  .hero-stats { gap:1.5rem; }

  .steps { grid-template-columns:1fr; }
  .steps::before { display:none; }

  .sizes-grid { grid-template-columns:1fr; max-width:360px; }
  .benefits   { grid-template-columns:1fr; }
  .area-inner { grid-template-columns:1fr; }
  .reviews-grid { grid-template-columns:1fr; }

  .footer-grid { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; gap:.5rem; text-align:center; }

  .svc-cards  { grid-template-columns:1fr; }
  .size-opts  { grid-template-columns:1fr; }
  .form-row   { grid-template-columns:1fr; }
  .contact-grid { grid-template-columns:1fr; }
  .addons-grid  { grid-template-columns:1fr; }
  .no-list      { grid-template-columns:1fr 1fr; }
}
