:root {
  --navy: #071a33;
  --navy-light: #0d315d;
  --blue: #0d6efd;
  --blue-soft: #57a5ff;
  --ice: #eaf4ff;
  --black: #06101b;
  --white: #ffffff;
  --muted: #617083;
  --line: #dbe5f0;
  --success: #087443;
  --warning: #fff4d8;
  --warning-text: #765300;
  --shadow: 0 18px 50px rgba(6, 16, 27, 0.12);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--black); background: #f8fbff; font-family: Arial, Helvetica, sans-serif; line-height: 1.55; }
a { color: inherit; text-decoration: none; }
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible, summary:focus-visible { outline: 3px solid var(--blue-soft); outline-offset: 3px; }
img { max-width: 100%; display: block; }

.site-header { position: sticky; top: 0; z-index: 10; display: flex; gap: 20px; align-items: center; justify-content: space-between; padding: 12px clamp(16px, 4vw, 64px); color: var(--white); background: rgba(5, 16, 31, 0.97); border-bottom: 1px solid rgba(255, 255, 255, 0.12); }
.brand { display: flex; gap: 10px; align-items: center; min-width: 190px; }
.brand img { width: 44px; height: 44px; border-radius: 10px; }
.brand strong, .brand small { display: block; }
.brand small { color: #a9c4e4; }
nav { display: flex; gap: clamp(12px, 2vw, 22px); color: #d7e7f8; font-weight: 700; }
nav a, .header-call { border-radius: 999px; }
nav a { padding: 8px 2px; }
.header-call { padding: 10px 14px; font-weight: 800; color: var(--white); background: var(--blue); white-space: nowrap; }

.hero { min-height: 650px; display: grid; align-items: center; padding: 88px clamp(20px, 7vw, 110px); color: var(--white); background: linear-gradient(90deg, rgba(2, 10, 22, 0.94), rgba(2, 10, 22, 0.58)), url("/bin-cleaning-preview.jpg?v=20260607-071335") center / cover; }
.hero-content { max-width: 760px; }
.eyebrow { display: inline-block; margin-bottom: 12px; color: var(--blue-soft); font-size: 0.78rem; font-weight: 900; letter-spacing: 0.14em; text-transform: uppercase; }
h1, h2, h3 { margin-top: 0; line-height: 1.12; }
h1 { margin-bottom: 18px; font-size: clamp(2.45rem, 7vw, 5.1rem); }
h2 { margin-bottom: 12px; font-size: clamp(1.9rem, 4vw, 3.1rem); }
h3 { margin-bottom: 10px; }
.hero p { max-width: 680px; color: #d7e7f8; font-size: 1.16rem; }
.hero-buttons, .payment-options, .contact-buttons, .thank-you-actions { display: flex; gap: 12px; flex-wrap: wrap; align-items: center; }
.button { display: inline-flex; justify-content: center; align-items: center; min-height: 46px; padding: 12px 18px; border: 0; border-radius: 8px; cursor: pointer; font-size: 0.98rem; font-weight: 900; }
.button.primary { color: var(--white); background: var(--blue); }
.button.secondary { color: var(--white); background: rgba(255, 255, 255, 0.14); border: 1px solid rgba(255, 255, 255, 0.35); }
.button.outline, .button.ghost { color: var(--navy); background: var(--white); border: 1px solid var(--line); }
.dark-button { background: var(--navy) !important; }
.large-button { width: 100%; margin-top: 18px; padding: 16px; }

.service-area-strip { display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; padding: 15px 20px; color: #d9e8f8; background: var(--navy); }
.section { max-width: 1260px; margin: 0 auto; padding: 82px 24px; }
.section-heading { max-width: 760px; margin: 0 auto 34px; text-align: center; }
.section-heading p { color: var(--muted); }
.three-column, .pricing-grid, .faq-grid { display: grid; gap: 18px; grid-template-columns: repeat(3, minmax(0, 1fr)); }
.info-card, .price-card, .booking-form, .empty-review, .review-card, details { padding: 24px; border-radius: 8px; background: var(--white); box-shadow: var(--shadow); }
.card-icon { display: grid; width: 44px; height: 44px; place-items: center; margin-bottom: 16px; color: var(--white); background: var(--navy); border-radius: 8px; font-weight: 900; }
.dark-section { max-width: none; padding-inline: max(24px, calc((100vw - 1212px) / 2)); color: var(--white); background: var(--navy); }
.dark-section .section-heading p { color: #b4c9df; }
.price-card { position: relative; color: var(--black); }
.price-card.featured { outline: 3px solid var(--blue); }
.popular { position: absolute; top: 16px; right: 16px; padding: 6px 10px; color: var(--white); border-radius: 999px; background: var(--blue); font-size: 0.72rem; font-weight: 900; text-transform: uppercase; }
.price { margin: 18px 0 2px; color: var(--navy); font-size: 2.3rem; font-weight: 900; }
.price small { color: var(--muted); font-size: 0.9rem; }
.deal { min-height: 48px; color: var(--blue); font-weight: 900; }
.price-card ul { min-height: 148px; padding-left: 20px; color: #445165; }

.route-section { display: grid; gap: 32px; align-items: center; grid-template-columns: 1.05fr 0.95fr; }
.route-section img { width: 100%; min-height: 330px; object-fit: cover; border-radius: 8px; box-shadow: var(--shadow); }
.steps-list { padding-left: 22px; color: #33445a; }
.steps-list li { margin: 8px 0; }

.booking-section { max-width: 1120px; }
.preview-warning, .etransfer-box { padding: 14px 16px; margin-bottom: 16px; border-radius: 8px; color: var(--warning-text); background: var(--warning); font-weight: 800; }
.booking-form { padding: 28px; }
.booking-layout { display: grid; gap: 24px; grid-template-columns: minmax(0, 1fr) 320px; align-items: start; }
fieldset { margin: 0 0 24px; padding: 0; border: 0; }
legend { margin-bottom: 12px; color: var(--navy); font-size: 1.1rem; font-weight: 900; }
.form-grid { display: grid; gap: 15px; margin-bottom: 18px; grid-template-columns: repeat(2, minmax(0, 1fr)); }
.compact-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.field-help { margin-top: -4px; color: var(--muted); }
label { display: grid; gap: 6px; color: #24364b; font-weight: 800; }
label small { color: var(--muted); font-weight: 500; }
input, select, textarea { width: 100%; min-height: 46px; padding: 12px; color: var(--black); border: 1px solid var(--line); border-radius: 8px; background: var(--white); font: inherit; }
textarea { min-height: 110px; resize: vertical; }
.payment-card { display: flex; flex: 1 1 250px; gap: 10px; align-items: flex-start; padding: 14px; border: 1px solid var(--line); border-radius: 8px; background: #fbfdff; }
.payment-card input { width: auto; min-height: auto; margin-top: 4px; }
.payment-card strong, .payment-card small { display: block; }
.booking-summary { position: sticky; top: 90px; padding: 20px; color: var(--black); border: 1px solid var(--line); border-radius: 8px; background: #fbfdff; }
.price-preview { padding: 14px; margin-bottom: 14px; color: var(--navy); border-radius: 8px; background: var(--ice); font-weight: 900; }
.summary-list { display: grid; gap: 10px; }
.summary-list p { display: flex; gap: 12px; justify-content: space-between; margin: 0; padding-bottom: 10px; border-bottom: 1px solid var(--line); }
.summary-list span { text-align: right; color: #34445a; }
.summary-note { color: var(--muted); font-size: 0.92rem; }
.form-message { min-height: 24px; color: var(--success); font-weight: 800; }
.hidden { display: none !important; }

.faq-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
summary { cursor: pointer; color: var(--navy); font-weight: 900; }
details p { color: #445165; }
.review-list { display: grid; gap: 16px; grid-template-columns: repeat(3, minmax(0, 1fr)); }
.stars { color: #f1a400; letter-spacing: 3px; font-weight: 900; }

footer { display: flex; gap: 20px; align-items: center; justify-content: space-between; padding: 30px clamp(18px, 5vw, 80px); color: #d5e6f8; background: var(--black); }
footer a { display: block; margin: 5px 0; }
.maker-link { display: inline-block; margin-top: 10px; color: #8fa8c4; font-size: 0.86rem; }
.thank-you-page { background: linear-gradient(180deg, var(--navy), #f8fbff 360px); }
.return-brand { width: max-content; margin-bottom: 24px; color: var(--white); }
.thank-you-card h1 { font-size: clamp(2.1rem, 5vw, 3.6rem); }
.next-steps { margin: 22px 0; padding: 18px; border-radius: 8px; background: var(--ice); }
.next-steps h2 { font-size: 1.25rem; }

.admin-stats { display: grid; gap: 12px; grid-template-columns: repeat(7, minmax(120px, 1fr)); margin: 18px 0; }
.stat-card { padding: 14px; border-radius: 8px; background: #fff; box-shadow: var(--shadow); }
.stat-card strong { display: block; color: var(--navy); font-size: 1.6rem; }
.admin-filters { display: grid; gap: 12px; grid-template-columns: 2fr repeat(3, 1fr); margin: 18px 0; }
.admin-card-header { display: flex; gap: 12px; justify-content: space-between; align-items: start; }
.admin-meta { display: grid; gap: 8px; grid-template-columns: repeat(2, minmax(0, 1fr)); }
.admin-notes { margin-top: 12px; }
.admin-notes textarea { min-height: 76px; }

@media (max-width: 980px) {
  nav { display: none; }
  .three-column, .pricing-grid, .review-list, .route-section, .faq-grid, .booking-layout, .admin-filters { grid-template-columns: 1fr; }
  .booking-summary { position: static; }
  .admin-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 640px) {
  .site-header { align-items: flex-start; }
  .brand { min-width: 0; }
  .brand small { display: none; }
  .header-call { font-size: 0.82rem; padding-inline: 10px; }
  .hero { min-height: 560px; }
  .form-grid, .compact-grid, .admin-meta { grid-template-columns: 1fr; }
  .price-card ul { min-height: 0; }
  .summary-list p { display: grid; }
  .summary-list span { text-align: left; }
  footer { display: block; }
}
