/* =====================================
   OurDigital Services Page Styles
   System: v2.0 (tokens.css + global.css 기반)
   ===================================== */

/* =============================
   1. HERO SECTION
   NOTE: Hero container styles controlled by ourdigital-overrides.css
   ============================= */

#hero h1 {
  font-size: var(--text-size-h1);
  font-weight: 700;
  line-height: var(--line-height-heading);
  margin-top: 0; /* Remove browser default top margin */
  margin-bottom: 16px;
}
#hero p {
  font-size: 18px;
  color: var(--color-text-dim);
  max-width: 720px;
  margin: 0 auto 24px;
}
#hero .button-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 16px;
  margin-top: 24px;
}

/* =============================
   2. SERVICE GRID / CARDS
   ============================= */

/* Services section spacing */
#services {
  padding: var(--section-padding-desktop) var(--layout-padding-x);
}

@media (max-width: 960px) {
  #services {
    padding: var(--section-padding-tablet) var(--layout-padding-x);
  }
}

@media (max-width: 768px) {
  #services {
    padding: var(--section-padding-mobile) var(--layout-padding-x);
  }
}

/* Section header styling */
#services .eyebrow {
  font-size: 14px;
  font-weight: 600;
  color: var(--color-accent);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 1rem;
}

#services h2 {
  font-size: var(--text-size-h2);
  font-weight: 700;
  margin-bottom: 1rem;
}

#services .section-intro {
  color: var(--color-text-dim);
  font-size: 16px;
  margin-bottom: 3rem;
}

/* Cards grid with increased spacing */
.cards,
.service-grid {
  display: grid;
  gap: 48px; /* Increased from 32px for more breathing room */
  margin-top: 3rem;
}

@media (max-width: 1200px) {
  .cards,
  .service-grid {
    gap: 40px;
  }
}

@media (min-width: 768px) {
  .cards,
  .service-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .cards,
  .service-grid {
    grid-template-columns: 1fr;
    gap: 32px; /* Smaller gap on mobile to fit screen */
  }
}

/* Service card styling with better internal spacing */
.service-card {
  background-color: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  padding: 40px 32px; /* Increased from 32px 28px */
  box-shadow: 0 4px 12px rgba(0,0,0,0.03);
  transition: box-shadow var(--transition-fast), transform var(--transition-fast);
  display: flex;
  flex-direction: column;
}

.service-card:hover {
  box-shadow: var(--shadow-card-hover);
  transform: translateY(-4px);
}

.service-card .icon {
  font-size: 2.5rem;
  color: var(--color-accent);
  margin-bottom: 1.5rem; /* Increased space after icon */
}

.service-card h3 {
  font-size: 22px; /* Slightly larger */
  font-weight: 600;
  margin-bottom: 1rem; /* Increased from 12px */
  line-height: 1.4;
}

.service-card p {
  color: var(--color-text-dim);
  font-size: 15px;
  line-height: 1.7; /* Increased line height */
  margin-bottom: 1.5rem; /* Increased from 16px */
}

.service-card ul {
  list-style: none;
  padding: 0;
  margin: 0 0 2rem 0; /* Increased from 20px */
}

.service-card li {
  font-size: 15px;
  color: var(--color-text-main);
  margin-bottom: 12px; /* Increased from 8px */
  padding-left: 24px; /* Increased from 20px */
  position: relative;
  line-height: 1.6;
}

.service-card li::before {
  content: "•";
  position: absolute;
  left: 0;
  color: var(--color-accent);
  font-size: 18px;
}

.service-card a {
  font-weight: 600;
  color: var(--color-link);
  margin-top: auto; /* Push link to bottom of card */
  display: inline-block;
}

.service-card a:hover {
  color: var(--color-link-hover);
  text-decoration: underline;
}

@media (max-width: 768px) {
  .service-card {
    padding: 32px 24px; /* Smaller padding on mobile */
  }
}

/* =============================
   3. CTA SECTION
   ============================= */
#final-cta {
  background-color: var(--color-accent);
  color: #000;
  text-align: center;
  border-radius: var(--radius-card);
  margin-top: var(--section-padding-desktop);
  padding: var(--section-padding-desktop) var(--layout-padding-x);
}

@media (max-width: 960px) {
  #final-cta {
    margin-top: var(--section-padding-tablet);
    padding: var(--section-padding-tablet) var(--layout-padding-x);
  }
}

@media (max-width: 768px) {
  #final-cta {
    margin-top: var(--section-padding-mobile);
    padding: var(--section-padding-mobile) var(--layout-padding-x);
  }
}

#final-cta h2 {
  font-size: 32px;
  font-weight: 600;
  margin-bottom: 16px;
}
#final-cta p {
  font-size: 16px;
  max-width: 680px;
  margin: 0 auto 32px;
}
#final-cta .btn {
  font-size: 16px;
}

/* =============================
   4. OPTIONAL SECTION (PROCESS)
   ============================= */
.process {
  background-color: var(--color-bg-alt);
  border-radius: var(--radius-card);
  padding: 80px 40px;
  margin-top: 100px;
}
.process h2 {
  text-align: center;
  margin-bottom: 40px;
}
.process-steps {
  display: grid;
  gap: 32px;
}
@media (min-width: 768px) {
  .process-steps {
    grid-template-columns: repeat(4, 1fr);
  }
}
.process-step {
  background-color: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-card);
  padding: 24px;
  text-align: center;
  transition: box-shadow var(--transition-fast);
}
.process-step:hover {
  box-shadow: var(--shadow-card-hover);
}
.process-step h3 {
  font-size: 18px;
  margin-bottom: 8px;
}
.process-step p {
  font-size: 14px;
  color: var(--color-text-dim);
}

/* =============================
   5. FOOTER (inherits global)
   ============================= */
footer.site-footer {
  margin-top: 120px;
}