/* Accessibility: robust skip link */
.skip-link{position:fixed;left:1rem;top:1rem;transform:translateY(-150%);padding:.5rem .75rem;background:var(--navy);color:var(--magnolia-white);border-radius:.5rem;z-index:3000;text-decoration:none;}
.skip-link:focus{transform:translateY(0);} 
:root {
  --navy: #1F2A44;
  --magnolia-white: #F9F6F1;
  --magnolia-gold: #D8CAB8;
  --charcoal: #3A3A3A;
  --coral: #F26B5E;
  --coastal-sand: #f5e9ce;
}

/* ───────────────────────────── */
/*          GLOBAL STYLES        */
/* ───────────────────────────── */
html, body {
  margin: 0;
  padding: 0;
  overflow-x: hidden;
}

body {
  margin: 0;
  font-family: 'Open Sans', sans-serif;
  background: var(--magnolia-white);
  color: var(--navy);
}

@media (prefers-color-scheme: dark) {
  body {
    background: var(--navy);
    color: var(--magnolia-white);
  }
}

/* ───────────────────────────── */
/*       GLOBAL BUTTON STYLES    */
/* ───────────────────────────── */
a.btn-link,
a.btn,
button.btn, .modal-trigger {
  display: inline-block;
  background-color: var(--navy);
  color: var(--magnolia-white);
  padding: 12px 20px;
  border-radius: 8px;
  text-decoration: none;
  font-weight: 600;
  font-family: 'Open Sans', sans-serif;
  box-shadow: 0 3px 6px rgba(0,0,0,0.15);
  transition: all 0.3s ease;
  width: 175px; /* Desktop default */
  text-align: center;
}

a.btn-link:hover,
a.btn:hover,
button.btn:hover, .modal-trigger {
  background-color: #152032;
}

@media (max-width: 768px) {
  a.btn-link,
  a.btn,
  button.btn, .modal-trigger {
    width: 160px;
  }
}

@media (prefers-color-scheme: dark) {
  a.btn-link,
  a.btn,
  button.btn, .modal-trigger {
    background-color: var(--magnolia-white);
    color: var(--navy);
  }
  a.btn-link:hover,
  a.btn:hover,
  button.btn:hover {
    background-color: var(--magnolia-gold);
  }
}

.digital-controls { display:flex; gap:.5rem; margin-top:.75rem; }
.design-row { margin-bottom:.5rem; }

/* Global link styling (matches footer look) */
:root { --link-color: var(--coral); }

:where(a) {
  color: var(--link-color);
  font-style: italic;
  text-decoration: underline;
  text-underline-offset: 0.18em;
  text-decoration-thickness: 1.5px;
  transition: color .15s ease, text-underline-offset .15s ease;
}
:where(a:hover, a:focus-visible) {
  text-underline-offset: 0.28em;
}

/* Optional: keep footer links identical without extra rules */
.site-footer :where(a) { color: var(--link-color); }

@media (prefers-color-scheme: dark) {
  :root { --link-color: var(--magnolia-gold); }
}

/* ───────────────────────────── */
/*     PAYMENT POPUP WINDOW      */
/* ───────────────────────────── */
.payment-popup {
  position: fixed;
  top: 0; left: 0;
  width: 100%; height: 100%;
  background-color: rgba(0,0,0,0.6);
  display: flex; align-items: center; justify-content: center;
  z-index: 9999;
}

.payment-content {
  background-color: var(--magnolia-white);
  color: var(--navy);
  padding: 2rem;
  border-radius: 10px;
  text-align: center;
  width: 90%; max-width: 400px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.25);
}

@media (prefers-color-scheme: dark) {
  .payment-content {
    background-color: var(--navy);
    color: var(--magnolia-white);
  }
}

.payment-actions button {
  background-color: var(--coral);
  color: white;
  padding: 10px 24px;
  border: none;
  border-radius: 8px;
  margin-top: 1rem;
  font-weight: bold;
  cursor: pointer;
  transition: background-color 0.3s ease;
}
.payment-actions button:hover { background-color: #e25c50; }

@media (prefers-color-scheme: dark) {
  .payment-actions button { background-color: var(--magnolia-gold); color: var(--navy); }
  .payment-actions button:hover { background-color: #cbb58f; }
}

/* ─────────────────────────────── */
/*     SERVICE DESCRIPTION COLOR   */
/* ─────────────────────────────── */
.description { display: block; margin-left: .5rem; margin-top: .2rem; color: coral; }
@media (prefers-color-scheme: dark) { .description { color: var(--magnolia-gold); } }

/* ───────────────────────────── */
/*            BANNER             */
/* ───────────────────────────── */
.banner-image {
  width: 100%;
  height: 300px;
  background-image: url("/img/RDbannerlttrans.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  /* match footer in light mode */
  background-color: var(--magnolia-white);
}
@media (prefers-color-scheme: dark) {
  .banner-image {
    background-image: url("/img/RDbannerdktrans.jpg");
    /* match footer in dark mode */
    background-color: var(--navy);
  }
}
@media (max-width: 600px) { .banner-image { height: 100px; } }

/* ───────────────────────────── */
/*         MAIN CONTENT          */
/* ───────────────────────────── */
main.content {
  padding: 1rem;
  background-color: #ffffff;
  max-width: 100%;
  box-sizing: border-box;
}
main.content h1,
main.content .hero,
main.content .start-project { text-align: center; }
main.content p { font-size: 1.1rem; line-height: 1.6; }

@media (max-width: 600px) {
  main.content { padding: 1rem; }
  main.content h1 { font-size: 1.5rem; }
  main.content p { font-size: 1rem; }
}
@media (prefers-color-scheme: dark) { main.content { background-color: #263248; } }

.hidden { display: none; }

/* ───────────────────────────── */
/*           GALLERY             */
/* ───────────────────────────── */
.image-gallery { padding: 2rem 1rem; }

.image-grid {
  display: grid;
  gap: 1rem;
  justify-items: center;
}

@media (min-width: 768px) {
  .image-grid { grid-template-columns: repeat(4, 1fr); gap: 1rem; }
  .image-grid img { max-height: 250px; }
}

/* Mobile: horizontal swipe with 2 stacked per slide */
@media (max-width: 767px) {
  .image-grid {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    gap: 0;
  }
  .image-grid::-webkit-scrollbar { display: none; }
  .image-grid .slide {
    flex: 0 0 100%;
    scroll-snap-align: start;
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
    padding: 0 1rem;
    box-sizing: border-box;
  }
  .image-grid figure { margin: 0; }
  .image-grid img { width: 100%; height: auto; max-height: none; object-fit: contain; }
  .image-grid img { max-height: 250px; }
}

.image-grid img {
  width: 100%;
  object-fit: contain;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.1);

  width: 250px;
  height: 250px;
  object-fit: contain;
}

/* Controls */
.catalog-controls {
  display: flex; align-items: center; justify-content: center;
  gap: 1.25rem; margin-top: 1rem; font-weight: 700;
}
.catalog-arrow {
  background: var(--navy);
  color: var(--magnolia-white);
  border: none; padding: 8px 14px;
  border-radius: 8px; cursor: pointer; font-weight: 700;
}
@media (prefers-color-scheme: dark) {
  .catalog-arrow { background: var(--magnolia-white); color: var(--navy); }
}

/* Hide legacy page number chips */
#catalogMarkers, .catalog-markers { display: none !important; }

/* ───────────────────────────── */
/*              MODAL            */
/* ───────────────────────────── */
.modal {
  display: none;
  position: fixed;
  z-index: 2000;
  top: 0; left: 0;
  width: 100%; height: 100%;
  overflow: auto;
  background-color: rgba(31, 42, 68, 0.6);
}

.modal-content {
  background-color: var(--magnolia-white);
  color: var(--navy);
  padding: 20px;
  border-radius: 10px;
  width: 90%; max-width: 600px;
  margin: 8% auto;
  box-shadow: 0 4px 16px rgba(0,0,0,0.3);
  position: relative;
}

@media (prefers-color-scheme: dark) {
  .modal-content { background-color: var(--charcoal); color: var(--magnolia-white); }
}

.close-btn {
  color: var(--navy);
  float: right;
  font-size: 28px;
  font-weight: bold;
  cursor: pointer;
}
@media (prefers-color-scheme: dark) { .close-btn { color: var(--magnolia-white); } }

.centered-btn { text-align: center; margin: 2rem 0; }

/* CTA */
.modal-trigger {
  display: inline-block;
  gap: 1rem 1rem;
  margin: 2rem auto;
  background-color: var(--navy);
  color: var(--magnolia-white);
  font-weight: 600;
  font-family: 'Open Sans', sans-serif;
  text-align: center;
  text-decoration: none;
  padding: 12px 24px;
  border-radius: 8px;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.15);
  transition: all 0.3s ease;
  cursor: pointer;
}
.modal-trigger:hover { background-color: #d1b98f; }

@media (prefers-color-scheme: dark) {
  .modal-trigger { background-color: var(--magnolia-white); color: var(--navy); }
  .modal-trigger:hover { background-color: #142033; }
}

/* ───────────────────────────── */
/*             FOOTER            */
/* ───────────────────────────── */
footer {
  background: var(--magnolia-white);
  color: var(--navy);
  padding: 20px;
  text-align: center;
  font-size: 0.9rem;
}
@media (prefers-color-scheme: dark) {
  footer { background: var(--navy); color: var(--magnolia-white); }
}
.footer-links { margin-top: 10px; }
.footer-links a {
  margin: 0 10px; text-decoration: none; color: inherit; font-weight: bold;
}

/* ───────────────────────────── */
/*           FORM STYLES         */
/* ───────────────────────────── */
.form-styled { max-width: 600px; margin: 0 auto; }
.form-group { margin-bottom: 1.5rem; }

.form-group label {
  display: block;
  margin-bottom: 0.5rem;
  font-weight: bold;
  color: var(--navy);
}

.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: 0.75rem;
  border: 2px solid var(--navy);
  border-radius: 6px;
  font-family: 'Open Sans', sans-serif;
  font-size: 1rem;
  box-sizing: border-box;
  background-color: var(--coastal-sand);
  color: var(--navy);
}

.form-group input::placeholder,
.form-group textarea::placeholder { color: #6e6e6e; }

@media (prefers-color-scheme: dark) {
  .form-group label { color: var(--magnolia-white); }
  .form-group input,
  .form-group select,
  .form-group textarea {
    background-color: var(--charcoal);
    color: var(--magnolia-white);
    border: 2px solid var(--magnolia-white);
  }
  .form-group input::placeholder,
  .form-group textarea::placeholder { color: #ccc; }
}

/* Facebook button */
.facebook-btn {
  background-color: #1877F2;
  color: white;
  font-weight: bold;
  border: none;
  padding: 10px 24px;
  border-radius: 8px;
  cursor: pointer;
  text-decoration: none;
  display: inline-block;
  margin-top: 1rem;
  transition: background-color 0.3s ease;
}




