.elementor-590 .elementor-element.elementor-element-8901f60{--display:flex;}.elementor-590 .elementor-element.elementor-element-8901f60:not(.elementor-motion-effects-element-type-background), .elementor-590 .elementor-element.elementor-element-8901f60 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:transparent;background-image:linear-gradient(135deg, #0A1A2E 0%, #1A2F50 100%);}.elementor-590 .elementor-element.elementor-element-17f28a5{--display:flex;}.elementor-590 .elementor-element.elementor-element-36222ec{--display:flex;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-590 .elementor-element.elementor-element-36222ec:not(.elementor-motion-effects-element-type-background), .elementor-590 .elementor-element.elementor-element-36222ec > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#F5EFE4;}.elementor-590 .elementor-element.elementor-element-dd9bc70{--display:flex;}.elementor-590 .elementor-element.elementor-element-44d40a3{--display:flex;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-590 .elementor-element.elementor-element-f935998{--display:flex;}.elementor-590 .elementor-element.elementor-element-b2ea294{--display:flex;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-590 .elementor-element.elementor-element-6a8548a{--display:flex;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-590 .elementor-element.elementor-element-6a8548a:not(.elementor-motion-effects-element-type-background), .elementor-590 .elementor-element.elementor-element-6a8548a > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#F5EFE4;}.elementor-590 .elementor-element.elementor-element-9eba247{--display:flex;}@media(min-width:768px){.elementor-590 .elementor-element.elementor-element-8901f60{--content-width:1440px;}.elementor-590 .elementor-element.elementor-element-36222ec{--content-width:1440px;}.elementor-590 .elementor-element.elementor-element-44d40a3{--content-width:1440px;}.elementor-590 .elementor-element.elementor-element-6a8548a{--content-width:1440px;}}/* Start custom CSS for html, class: .elementor-element-10b1275 */.hero-section {
    background: linear-gradient(135deg, #0a1a2e, #1a2f50);
    padding: 88px 0 0;
    position: relative;
    overflow: hidden;
  }

  .hero-section::before {
    content: "";
    position: absolute;
    inset: 0;
    background-image: radial-gradient(
      circle,
      rgba(245, 239, 228, 0.4) 1px,
      transparent 1px
    );
    background-size: 28px 28px;
    opacity: 0.03;
    pointer-events: none;
  }

  .hero-container {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 28px 60px;
    position: relative;
    z-index: 1;
  }

  /* Breadcrumb */
  .hero-breadcrumb {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 4px;
    font-size: 12px;
    margin-bottom: 22px;
  }

  .hero-link {
    cursor: pointer;
    color: var(--gold2);
  }

  .hero-separator {
    color: rgba(245, 239, 228, 0.3);
    margin: 0 4px;
  }

  .hero-current {
    color: rgba(245, 239, 228, 0.75);
    font-weight: 500;
  }

  /* Badge */
  .hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(196, 150, 58, 0.15);
    border: 1px solid rgba(196, 150, 58, 0.3);
    border-radius: 30px;
    padding: 5px 14px;
    margin-bottom: 16px;
  }

  .hero-badge-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--gold);
    animation: breathe 2s infinite;
  }

  .hero-badge-text {
    font-size: 11px;
    font-weight: 700;
    color: var(--gold2);
    text-transform: uppercase;
    letter-spacing: 1.2px;
  }

  /* Heading */
  .hero-title {
    font-family: Fraunces, serif;
    font-size: clamp(1.9rem, 4.5vw, 3.2rem);
    font-weight: 800;
    color: var(--white);
    line-height: 1.08;
    letter-spacing: -0.03em;
    margin-bottom: 12px;
  }

  .hero-title-highlight {
    color: var(--gold2);
  }

  .hero-description {
    font-size: 15px;
    color: rgba(245, 239, 228, 0.7);
    line-height: 1.82;
    max-width: 580px;
    margin-bottom: 24px;
    font-weight: 300;
  }

  /* Buttons */
  .hero-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 24px;
  }

  .hero-btn {
    font-family: Inter, sans-serif;
    font-size: 14px;
    padding: 12px 22px;
    border-radius: 10px;
    cursor: pointer;
    transition: all 0.25s ease;
  }

  .hero-btn-primary {
    background: var(--gold);
    color: var(--white);
    font-weight: 700;
    border: none;
    box-shadow: 0 6px 20px rgba(196, 150, 58, 0.35);
  }

  .hero-btn-primary:hover {
    transform: translateY(-2px);
  }

  .hero-btn-secondary {
    background: rgba(245, 239, 228, 0.1);
    color: rgba(245, 239, 228, 0.8);
    border: 1.5px solid rgba(245, 239, 228, 0.25);
  }

  .hero-btn-secondary:hover {
    background: rgba(245, 239, 228, 0.15);
  }

  /* Stats */
  .hero-stats {
    display: flex;
    align-items: center;
    gap: 14px;
    flex-wrap: wrap;
    padding: 12px 18px;
    background: rgba(245, 239, 228, 0.06);
    border: 1px solid rgba(245, 239, 228, 0.1);
    border-radius: 13px;
    width: fit-content;
  }

  .hero-stat {
    text-align: center;
  }

  .hero-stat-number {
    font-family: Fraunces, serif;
    font-size: 22px;
    font-weight: 800;
    color: var(--gold2);
  }

  .hero-stat-label {
    font-size: 10px;
    color: rgba(245, 239, 228, 0.45);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-top: 2px;
  }

  .hero-divider {
    width: 1px;
    height: 26px;
    background: rgba(245, 239, 228, 0.12);
  }

  /* Tablet */
  @media (max-width: 991px) {
    .hero-section {
      padding-top: 72px;
    }

    .hero-container {
      padding: 0 24px 50px;
    }
  }

  /* Mobile */
  @media (max-width: 767px) {
    .hero-section {
      padding-top: 60px;
    }

    .hero-container {
      padding: 0 20px 40px;
    }

    .hero-title {
      line-height: 1.15;
    }

    .hero-description {
      font-size: 14px;
    }

    .hero-actions {
      flex-direction: column;
    }

    .hero-btn {
      width: 100%;
      text-align: center;
    }

    .hero-stats {
      width: 100%;
      justify-content: center;
      gap: 12px;
    }

    .hero-divider {
      display: none;
    }
  }/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-491c001 */.landing-service {
  background: var(--beige);
  padding: 60px 0;
}

.container {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 28px;
}

.landing-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 44px;
  align-items: start;
}

/* Badge */

.section-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--white);
  border: 1px solid rgba(0, 90, 90, 0.1);
  border-radius: 30px;
  padding: 4px 14px;
  margin-bottom: 12px;
}

.badge-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--teal);
}

.badge-text {
  font-size: 11px;
  font-weight: 700;
  color: var(--teal);
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* Heading */

.section-title {
  font-family: Fraunces, serif;
  font-size: clamp(1.4rem, 3vw, 2.2rem);
  font-weight: 700;
  color: var(--dark);
  letter-spacing: -0.02em;
  margin-bottom: 10px;
}

.section-desc {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.8;
  font-weight: 300;
  margin-bottom: 20px;
}

/* Features */

.feature-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px 20px;
}

.feature-item {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 13px;
  color: var(--mid);
  line-height: 1.5;
}

.feature-icon {
  width: 18px;
  height: 18px;
  border-radius: 4px;
  background: rgba(0, 90, 90, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--teal);
  font-size: 10px;
  flex-shrink: 0;
  margin-top: 1px;
}

/* Process Card */

.process-card {
  background: linear-gradient(135deg, #003a3a, #005a5a);
  border-radius: 18px;
  padding: 24px;
}

.process-title {
  font-family: Fraunces, serif;
  font-size: 15px;
  font-weight: 700;
  color: var(--beige);
  margin-bottom: 14px;
}

.process-step {
  display: flex;
  gap: 14px;
  padding: 15px 0;
  border-bottom: 1px solid var(--border);
}

.last-step {
  border-bottom: 0;
}

.step-number {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: var(--teal);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: Fraunces, serif;
  font-size: 13px;
  font-weight: 800;
  color: var(--white);
  flex-shrink: 0;
}

.step-number.gold {
  background: var(--gold);
}

.process-step h4 {
  font-family: Fraunces, serif;
  font-size: 14px;
  font-weight: 700;
  color: var(--dark);
  margin-bottom: 3px;
}

.process-step p {
  font-size: 13px;
  color: var(--muted);
  line-height: 1.6;
  margin: 0;
}

.audit-btn {
  margin-top: 14px;
  width: 100%;
  background: var(--gold);
  color: var(--white);
  font-size: 13px;
  font-weight: 700;
  padding: 11px;
  border: none;
  border-radius: 9px;
  cursor: pointer;
}

/* Result Box */

.result-box {
  background: var(--teal);
  border-radius: 12px;
  padding: 18px 20px;
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-top: 16px;
}

.result-icon {
  font-size: 24px;
  flex-shrink: 0;
}

.result-box h4 {
  font-family: Fraunces, serif;
  font-size: 13px;
  font-weight: 700;
  color: var(--beige);
  margin-bottom: 3px;
}

.result-box p {
  font-size: 13px;
  color: rgba(245, 239, 228, 0.65);
  line-height: 1.65;
  margin: 0;
}

/* Tablet */

@media (max-width: 991px) {
  .landing-grid {
    grid-template-columns: 1fr;
    gap: 30px;
  }
}

/* Mobile */

@media (max-width: 767px) {
  .landing-service {
    padding: 50px 0;
  }

  .container {
    padding: 0 18px;
  }

  .feature-grid {
    grid-template-columns: 1fr;
  }

  .process-card {
    padding: 20px;
  }

  .process-step {
    gap: 12px;
  }

  .result-box {
    flex-direction: column;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-1db31ad *//* ==========================
   FAQ SECTION
========================== */

.faq-section {
  background: var(--white);
  padding: 60px 0;
}

.faq-container {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 28px;
}

/* Badge */

.faq-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--white);
  border: 1px solid rgba(0, 90, 90, 0.1);
  border-radius: 30px;
  padding: 4px 14px;
  margin-bottom: 12px;
}

.faq-badge-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--teal);
  flex-shrink: 0;
}

.faq-badge-text {
  font-size: 11px;
  font-weight: 700;
  color: var(--teal);
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* Heading */

.faq-title {
  font-family: Fraunces, serif;
  font-size: clamp(1.4rem, 3vw, 2.2rem);
  font-weight: 700;
  color: var(--dark);
  letter-spacing: -0.02em;
  margin-bottom: 10px;
}

.faq-title span {
  color: var(--teal);
}

/* Grid */

.faq-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  margin-top: 16px;
}

/* Card */

.faq-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 18px;
  transition: border-color 0.2s ease;
}

.faq-card:hover {
  border-color: var(--teal);
}

.faq-card h3 {
  font-family: Fraunces, serif;
  font-size: 13px;
  font-weight: 700;
  color: var(--dark);
  margin-bottom: 7px;
  line-height: 1.5;
}

.faq-card p {
  font-size: 13px;
  color: var(--muted);
  line-height: 1.7;
  margin: 0;
}

/* ==========================
   RESPONSIVE
========================== */

/* Tablet */

@media (max-width: 991px) {
  .faq-grid {
    grid-template-columns: 1fr;
  }
}

/* Mobile */

@media (max-width: 767px) {
  .faq-section {
    padding: 50px 0;
  }

  .faq-container {
    padding: 0 18px;
  }

  .faq-card {
    padding: 16px;
  }

  .faq-card h3 {
    font-size: 14px;
  }

  .faq-card p {
    font-size: 13px;
  }
}

/* Small Mobile */

@media (max-width: 480px) {
  .faq-title {
    line-height: 1.3;
  }

  .faq-card {
    padding: 15px;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-76182ae *//* ===================================
   CTA SECTION
=================================== */

.cta-section {
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, #1a2f50, #0a1a2e);
  padding: 56px 0;
}

/* Pattern Overlay */

.cta-pattern {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: repeating-linear-gradient(
    45deg,
    rgba(255, 255, 255, 0.02) 0,
    rgba(255, 255, 255, 0.02) 1px,
    transparent 0,
    transparent 50%
  );
  background-size: 14px 14px;
}

/* Container */

.cta-container {
  position: relative;
  z-index: 2;
  max-width: 660px;
  margin: 0 auto;
  padding: 0 28px;
  text-align: center;
}

/* Heading */

.cta-title {
  font-family: Fraunces, serif;
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 800;
  line-height: 1.1;
  letter-spacing: -0.03em;
  color: var(--white);
  margin-bottom: 10px;
}

/* Description */

.cta-description {
  font-size: 15px;
  font-weight: 300;
  line-height: 1.7;
  color: rgba(245, 239, 228, 0.65);
  margin-bottom: 22px;
}

/* Buttons */

.cta-buttons {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

/* Primary Button */

.btn-primary {
  background: var(--gold);
  color: var(--white);
  font-family: Inter, sans-serif;
  font-size: 14px;
  font-weight: 700;
  padding: 12px 24px;
  border: none;
  border-radius: 10px;
  cursor: pointer;
  box-shadow: 0 6px 20px rgba(196, 150, 58, 0.35);
  transition: all 0.3s ease;
}

.btn-primary:hover {
  transform: translateY(-2px);
}

/* Secondary Button */

.btn-secondary {
  background: rgba(245, 239, 228, 0.1);
  color: var(--beige);
  font-family: Inter, sans-serif;
  font-size: 14px;
  padding: 12px 24px;
  border-radius: 10px;
  border: 1.5px solid rgba(245, 239, 228, 0.25);
  cursor: pointer;
  transition: all 0.3s ease;
}

.btn-secondary:hover {
  background: rgba(245, 239, 228, 0.15);
}

/* ===================================
   RESPONSIVE
=================================== */

/* Tablet */

@media (max-width: 991px) {
  .cta-section {
    padding: 52px 0;
  }

  .cta-container {
    max-width: 700px;
  }
}

/* Mobile */

@media (max-width: 767px) {
  .cta-section {
    padding: 48px 0;
  }

  .cta-container {
    padding: 0 18px;
  }

  .cta-title {
    line-height: 1.2;
  }

  .cta-description {
    font-size: 14px;
  }

  .cta-buttons {
    flex-direction: column;
    width: 100%;
  }

  .btn-primary,
  .btn-secondary {
    width: 100%;
    max-width: 320px;
    justify-content: center;
  }
}

/* Small Mobile */

@media (max-width: 480px) {
  .cta-title {
    font-size: 1.75rem;
  }

  .btn-primary,
  .btn-secondary {
    max-width: 100%;
    padding: 12px 20px;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-6dd1ae9 *//* ===================================
   RELATED SERVICES
=================================== */

.related-services {
  background: var(--beige);
  padding: 44px 0;
}

.related-services-container {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 28px;
}

/* Heading */

.related-services-title {
  font-family: Fraunces, serif;
  font-size: 1.7rem;
  font-weight: 700;
  color: var(--dark);
  margin-bottom: 18px;
}

.related-services-title span {
  color: var(--teal);
}

/* ===================================
   SERVICES GRID
=================================== */

.svc-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

/* Service Card */

.svc-card {
  cursor: pointer;
  transition: transform 0.3s ease;
}

.svc-card:hover {
  transform: translateY(-4px);
}

/*
  Existing classes retained:
  .svc-web
  .svc-ads
  .svc-header
  .svc-header-icon
  .svc-body
  .svc-title
  .expand-pill
  .ep-ico
  .ep-txt

  (Use your existing styles for these classes.)
*/

/* ===================================
   RESPONSIVE
=================================== */

.svc-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-top:40px;}
@media(min-width:640px){.svc-grid{grid-template-columns:1fr 1fr;gap:14px;}}
@media(min-width:1024px){.svc-grid{grid-template-columns:repeat(3,1fr);gap:16px;}}
.svc-card{background:var(--white);border:1px solid var(--border);border-radius:18px;overflow:hidden;cursor:pointer;transition:transform .3s var(--ease),box-shadow .3s,border-color .3s;}
.svc-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,90,90,.1);border-color:var(--teal);}
/* CSS-only card header — always renders */
.svc-header{height:160px;position:relative;overflow:hidden;display:flex;align-items:flex-end;padding:16px;}
.svc-header-overlay{position:absolute;inset:0;opacity:.18;transition:opacity .3s;}
.svc-card:hover .svc-header-overlay{opacity:.28;}
.svc-header-icon{font-size:48px;position:absolute;top:50%;left:50%;transform:translate(-50%,-60%);opacity:.35;transition:all .3s;}
.svc-card:hover .svc-header-icon{opacity:.55;transform:translate(-50%,-55%) scale(1.1);}
/* Each service gets unique gradient */
.svc-seo .svc-header{background:linear-gradient(135deg,#005a5a 0%,#007a7a 60%,#003d3d 100%);}
.svc-social .svc-header{background:linear-gradient(135deg,#1a3a3a 0%,#005a5a 50%,#c4963a 100%);}
.svc-web .svc-header{background:linear-gradient(135deg,#003d3d 0%,#005a5a 100%);}
.svc-design .svc-header{background:linear-gradient(135deg,#c4963a 0%,#8a6020 60%,#005a5a 100%);}
.svc-content .svc-header{background:linear-gradient(135deg,#2d4040 0%,#005a5a 60%,#e2c98a 100%);}
.svc-ads .svc-header{background:linear-gradient(135deg,#8a6020 0%,#c4963a 50%,#004848 100%);}
.svc-body{padding:22px 22px 20px;}
.svc-title{font-family:'Fraunces',serif;font-size:18px;font-weight:700;color:var(--dark);margin-bottom:7px;}
.svc-desc{font-size:13px;color:var(--muted);line-height:1.65;margin-bottom:16px;}
/* Expanding pill */
.expand-pill{height:32px;border-radius:9999px;background:var(--teal);display:flex;align-items:center;overflow:hidden;width:32px;transition:width .35s ease;cursor:pointer;}
.svc-card:hover .expand-pill{width:128px;}
.ep-ico{width:32px;height:32px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.ep-ico svg{transition:transform .35s var(--ease);}
.svc-card:hover .ep-ico svg{transform:rotate(-45deg);}
.ep-txt{font-size:12px;font-weight:500;color:var(--white);white-space:nowrap;padding-right:14px;opacity:0;transition:opacity .2s ease .1s;}
.svc-card:hover .ep-txt{opacity:1;}/* End custom CSS */