@charset "UTF-8";

/* Base */
*,
*::before,
*::after{ box-sizing: border-box; }

html{ -webkit-text-size-adjust: 100%; }

body{
  margin: 0;
  padding: 0 0 64px;
  font-family: "Lato", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  background: linear-gradient(to top, #e6f0ff, #f9fcff);
  color: #000;
  line-height: 1.5;
}

/* Section sizing */
.price-list-section,
.packages-section,
.addons-section,
.payment-section,
.maintenance-section,
.faq-section,
.quote-request-section,
#contract-link-section{
  width: min(1200px, 92%);
  margin: clamp(14px, 2vw, 20px) auto;
  padding: clamp(6px, 1.2vw, 10px) 0;
}

/* Headings */
h1{
  margin: 10px 0 20px;
  text-align: center;
  letter-spacing: 1px;
  font-weight: 700;
  font-family: "Dancing Script", "Cabin", Arial, sans-serif;
  font-size: clamp(28px, 3.2vw, 52px);
  line-height: 1.08;
  background: linear-gradient(to right, #004080, #6e67d9, #5cd0b5);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-wrap: balance;
}

.section-title,
.package-title,
.add-ons-title,
.faq-title,
.section-heading{
  margin: 10px;
  font-family: "Dancing Script", "Cabin", Arial, sans-serif;
  text-align: center;
  letter-spacing: 1px;
  background: linear-gradient(to right, #004080, #6e67d9, #5cd0b5);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-size: clamp(22px, 2.2vw, 38px);
  line-height: 1.15;
  animation: pulse 1.5s infinite alternate;
}

/* Hero */
.price-list-hero-image,
.price-hero-bg{
  width: 100%;
  max-width: 1200px;
  max-width: 1500px; /* kept from your original; last one wins if both exist */
  min-height: clamp(260px, 52vh, 560px);

  display: flex;
  align-items: center;
  justify-content: center;

  text-align: center;
  color: #fff;

  background: url("../img/price_list_page/price_list_hero_01.jpg") no-repeat center / cover;
  border: 2px solid rgba(0, 64, 128, 0.22);
  border-radius: 26px;
  box-shadow: 0 14px 42px rgba(0, 64, 128, 0.18);
  will-change: background-position;
  padding: 0;
}

/* Pricing wrapper */
.pricing-table{
  max-width: 1200px;
  margin: clamp(14px, 2vw, 20px) auto;
  padding: clamp(14px, 2vw, 20px);
  background: #fff;
  border-radius: 22px;
  border: 1px solid rgba(0, 64, 128, 0.16);
  box-shadow: 0 10px 28px rgba(0, 64, 128, 0.14);
  overflow: hidden;
  animation: tableSlide 1s ease-out;
}

/* Card blocks */
.package-card,
.addons-section,
.maintenance-section,
.payment-section{
  max-width: 800px;
  margin: clamp(22px, 3.2vw, 40px) auto;
  padding: clamp(18px, 2.8vw, 30px);
  background: #fff;
  border-radius: 22px;
  border: 1px solid rgba(0, 64, 128, 0.16);
  box-shadow: 0 10px 28px rgba(0, 64, 128, 0.14);
}

/* Quote CTA */
.quote-request-section{
  max-width: 800px;
  margin: clamp(22px, 3.2vw, 40px) auto;
  padding: clamp(22px, 3.4vw, 40px) clamp(16px, 2.4vw, 20px);
  background: #fff;
  border-radius: 22px;
  text-align: center;
  border: 1px solid rgba(0, 64, 128, 0.16);
  box-shadow: 0 10px 28px rgba(0, 64, 128, 0.14);
}

.quote-form-container{ max-width: 600px; margin: 0 auto; }

.quote-header{
  margin: 0 0 20px;
  font-family: "Dancing Script", "Cabin", Arial, sans-serif;
  font-size: clamp(22px, 2vw, 28px);
  background: linear-gradient(to right, #002a55, #4d46b8, #1f8f7b);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.quote-instructions{
  margin: 0 0 24px;
  font-size: clamp(14px, 1.2vw, 16px);
  line-height: 1.6;
  color: #000;
}

.email-button{
  display: inline-block;
  padding: 14px 26px;
  border-radius: 40px;
  text-decoration: none;
  font-size: clamp(14px, 1.2vw, 16px);
  color: #fff;
  background: linear-gradient(to right, #004080, #6e67d9, #5cd0b5);
  box-shadow: 0 10px 28px rgba(0, 64, 128, 0.14);
  transition: transform 0.2s ease, filter 0.25s ease;
}

.email-button:hover{ transform: translateY(-2px); filter: brightness(1.03); }

.form-note{
  margin-top: 16px;
  font-size: 14px;
  color: rgba(0, 0, 0, 0.70);
}

/* Contract links */
#contract-link-section{
  margin: clamp(22px, 3.2vw, 40px) auto;
  padding: clamp(20px, 3vw, 32px) clamp(16px, 2.4vw, 20px);
  background: #fff;
  border-radius: 22px;
  border: 1px solid rgba(0, 64, 128, 0.16);
  box-shadow: 0 10px 28px rgba(0, 64, 128, 0.14);
}

#contract-link-section h2{
  margin: 0 0 24px;
  font-family: "Dancing Script", "Cabin", Arial, sans-serif;
  font-weight: 700;
  letter-spacing: 1px;
  font-size: clamp(26px, 2.8vw, 44px);
  line-height: 1.1;
  background: linear-gradient(to right, #004080, #6e67d9, #5cd0b5);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.contract-links{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 24px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.contract-item{
  width: 100%;
  max-width: 320px;
  padding: 24px 20px;
  border-radius: 22px;
  text-align: left;
  font-family: "Cabin", sans-serif;
  color: #000;
  background: #fff;
  border: 1px solid rgba(0, 64, 128, 0.16);
  box-shadow: 0 10px 28px rgba(0, 64, 128, 0.14);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.contract-item:hover{
  transform: translateY(-6px);
  box-shadow: 0 14px 42px rgba(0, 64, 128, 0.18);
}

.contract-item h3 a{
  font-size: clamp(18px, 1.4vw, 20px);
  font-weight: 800;
  color: #004080;
  text-decoration: none;
  transition: color 0.3s ease;
}

.contract-item h3 a:hover{ color: #4d46b8; }

.contract-item p{
  margin-top: 10px;
  font-size: clamp(13px, 1.1vw, 15px);
  line-height: 1.5;
  color: rgba(0, 0, 0, 0.80);
}

/* Back button */
.back-button{
  display: inline-block;
  margin: 10px;
  padding: 10px 20px;
  border-radius: 40px;
  font-size: clamp(14px, 1.3vw, 18px);
  text-decoration: none;
  color: #fff;
  background: linear-gradient(to right, #004080, #6e67d9, #5cd0b5);
  box-shadow: 0 10px 28px rgba(0, 64, 128, 0.14);
  transition: transform 0.2s ease, filter 0.25s ease;
}

.back-button:hover{ transform: translateY(-1px); filter: brightness(1.03); }
.back-button:focus{ outline: 2px solid rgba(0, 64, 128, 0.35); outline-offset: 2px; }

/* Accordions */
.service-section{
  margin-bottom: 20px;
  scroll-margin-top: 80px;
}

.accordion-toggle{
  width: 100%;
  margin-top: 20px;
  padding: 16px 24px;
  font-size: clamp(15px, 1.3vw, 18px);
  font-weight: 800;
  text-align: left;
  color: #fff;
  background: linear-gradient(to right, #004080, #6e67d9, #5cd0b5);
  border: none;
  border-radius: 12px;
  cursor: pointer;
  box-shadow: 0 10px 28px rgba(0, 64, 128, 0.14);
  transition: transform 0.15s ease, filter 0.25s ease;
}

.accordion-toggle:hover{ transform: translateY(-1px); filter: brightness(1.03); }
.accordion-toggle:focus{ outline: 2px solid rgba(0, 64, 128, 0.35); outline-offset: 2px; }
.accordion-toggle.active{ transform: translateY(-1px); }

.accordion-content{
  display: none;
  padding: 0 20px;
  background: #fff;
  overflow: hidden;
  border: 1px solid rgba(0, 64, 128, 0.16);
  border-top: none;
  border-radius: 0 0 12px 12px;
  box-shadow: inset 0 1px 4px rgba(0, 0, 0, 0.03);
  transition: padding-top 0.2s ease, padding-bottom 0.2s ease, border-color 0.2s ease;
}

.accordion-content.open{
  display: block;
  padding-top: 16px;
  padding-bottom: 16px;
}

.accordion-content ul,
.accordion-content p{
  margin: 0;
  font-family: "Cabin", sans-serif;
  font-size: clamp(14px, 1.15vw, 16px);
  line-height: 1.6;
  color: #000;
}

.accordion-content ul{ list-style: none; padding-left: 0; }

.accordion-content li{
  margin-bottom: 8px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(0, 64, 128, 0.10);
}

.accordion-content li:last-child{
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: none;
}

@media (prefers-reduced-motion: reduce){
  .accordion-content{ transition: none; }
}

/* Footer */
footer {
  background: #000;
  color: #fff;
  text-align: center;
  font-size: 12px;
  font-family: "Cabin";
  padding: 12px 0;
  margin-top: auto; 
}

/* Animations */
@keyframes pulse{
  0%, 100%{ color: #004080; }
  50%{ color: #6e67d9; }
}

@keyframes tableSlide{
  0%{ opacity: 0; transform: translateY(10px); }
  100%{ opacity: 1; transform: translateY(0); }
}

/* Media queries (your order) */
@media (min-width: 1920px){
  .price-list-hero-image,
  .price-hero-bg{ min-height: clamp(320px, 58vh, 620px); }
}

@media (max-width: 1920px){
  .price-list-hero-image,
  .price-hero-bg{ min-height: clamp(300px, 56vh, 600px); }
}

@media (max-width: 1200px){
  .price-list-hero-image,
  .price-hero-bg{ min-height: clamp(280px, 52vh, 560px); }
}

@media (max-width: 768px){
  body{ padding-bottom: 0; }

  .price-list-hero-image,
  .price-hero-bg{ min-height: clamp(240px, 42vh, 440px); }

  .package-card,
  .addons-section,
  .maintenance-section,
  .payment-section{
    margin: 24px auto;
    padding: 22px;
  }

  #contract-link-section{
    margin: 24px auto;
    padding: 20px;
  }

  .contract-links{
    flex-direction: column;
    align-items: center;
    gap: 16px;
  }

  .contract-item{
    max-width: 92%;
    text-align: center;
  }
}

@media (max-width: 480px){
  .price-list-hero-image,
  .price-hero-bg{
    min-height: clamp(220px, 34vh, 360px);
    padding: 16px;
  }

  .quote-request-section{ padding: 28px 16px; }

  .email-button{
    width: 100%;
    text-align: center;
  }

  #contract-link-section h2{ letter-spacing: 0.5px; }
  .service-section{ scroll-margin-top: 56px; }
}

@media (max-width: 300px){
  .price-list-section,
  .packages-section,
  .addons-section,
  .payment-section,
  .maintenance-section,
  .faq-section,
  .quote-request-section,
  #contract-link-section{ width: min(1200px, 95%); }

  .contract-item{ padding: 12px; }

  .price-list-hero-image,
  .price-hero-bg{
    min-height: 200px;
    border-radius: 8px;
  }
}
