/* Overview page-specific styles – minimal, scoped, and complementary to base.css */
:root {
  --ov-spacing-xxl: clamp(2rem, 3vw, 4rem);
  --ov-spacing-xl: clamp(1.5rem, 2.5vw, 3rem);
  --ov-spacing-lg: clamp(1.25rem, 2vw, 2rem);
  --ov-radius: 16px;
}

/* Hero */
.overview-hero {
  position: relative;
  color: #e8e8ea;
  isolation: isolate;
  padding: var(--ov-spacing-xxl) 0;
  overflow: clip;
}
.overview-hero__bg {
  position: absolute;
  inset: 0;
  background-image: linear-gradient(180deg, rgba(10,10,14,.75), rgba(10,10,14,.9)), url('/assets/images/hero-unbroken-soul.webp');
  background-size: cover;
  background-position: center;
  filter: saturate(.9) contrast(1.05);
  z-index: -1;
}
.overview-hero__inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 1rem;
}
.overview-hero h1 { 
  font-size: clamp(2rem, 4vw, 3rem);
  letter-spacing: .5px;
  margin-bottom: .5rem;
}
.lead { 
  font-size: clamp(1rem, 1.5vw, 1.125rem);
  line-height: 1.7;
  max-width: 70ch;
  margin-bottom: var(--ov-spacing-lg);
}

/* Search */
.overview-search { 
  display: flex; 
  gap: .5rem; 
  align-items: center; 
  margin-bottom: var(--ov-spacing-lg);
}
.overview-search input[type='search']{
  flex: 1;
  min-width: 0;
  padding: .8rem 1rem;
  border-radius: 10px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  color: #f0f0f3;
}
.overview-search input::placeholder{ color: #b7bac3; }

/* Buttons */
.overview-btn {
  display: inline-block;
  padding: .85rem 1.1rem;
  border-radius: 12px;
  text-decoration: none;
  font-weight: 600;
  transition: transform .15s ease, background .2s ease, border-color .2s ease;
  will-change: transform;
}
.overview-btn--primary {
  background: linear-gradient(135deg, #6c5ce7, #4d3bd6);
  color: #fff;
  border: 1px solid rgba(255,255,255,.12);
}
.overview-btn--primary:hover { transform: translateY(-1px); filter: brightness(1.06); }
.overview-btn--ghost {
  background: rgba(255,255,255,.06);
  color: #eaeaf1;
  border: 1px solid rgba(255,255,255,.14);
}
.overview-btn--ghost:hover { transform: translateY(-1px); background: rgba(255,255,255,.1); }

.overview-hero__actions{ display:flex; gap:.75rem; flex-wrap: wrap; }

/* Content wrapper */
.overview-container{
  max-width: 1100px;
  margin: 0 auto;
  padding: var(--ov-spacing-xl) 1rem;
}

/* Sections */
.overview-section{ 
  padding: var(--ov-spacing-lg) 0; 
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.overview-section:last-of-type{ border-bottom: none; }
.overview-section h2{ 
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  margin-bottom: .5rem; 
}
.overview-section p{ color: #d3d5dc; }

/* Lists */
.overview-list{ 
  margin: .5rem 0 0 0; 
  padding-left: 1.25rem; 
}
.overview-list li{ 
  margin: .35rem 0; 
}

/* Media */
.overview-media{ 
  margin-bottom: .75rem; 
  border-radius: var(--ov-radius);
  overflow: hidden; 
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
}
.overview-media img{ 
  width: 100%; 
  height: auto; 
  display: block; 
}

/* Link list */
.overview-links ul{ 
  list-style: none; 
  padding: 0; 
  margin: .25rem 0 0 0; 
}
.overview-links li{ 
  padding: .5rem 0; 
}
.overview-links a{ 
  color: #cfd2ff; 
  text-decoration: underline; 
  text-underline-offset: 2px; 
}
.overview-links a:hover{ color: #ffffff; }

/* CTA block */
.overview-cta{ 
  display: flex; 
  gap: .75rem; 
  flex-wrap: wrap; 
  margin-top: .75rem; 
}

/* Small utility for screen readers if not provided by base.css */
.sr-only{ 
  position: absolute !important; 
  width: 1px; 
  height: 1px; 
  padding: 0; 
  margin: -1px; 
  overflow: hidden; 
  clip: rect(0,0,0,0); 
  white-space: nowrap; 
  border: 0; 
}
