/* ============================================
   COASTWISE HEALTH — Inner Page Styles
   Shared across hub pages, detail pages,
   about, and utility pages.
   ============================================ */

/* ---- Page Hero (shorter than homepage, graphic treatment) ---- */
.page-hero {
  position: relative;
  padding: calc(var(--space-2xl) + 70px) var(--space-md) var(--space-2xl);
  color: var(--color-white);
  text-align: center;
  min-height: 300px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--color-primary-dark) 0%, var(--color-primary) 50%, var(--color-teal-accent) 100%);
  overflow: hidden;
}

/* Left wave lines — 7 vertical lines, wide spacing reaching toward center */
.page-hero::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 360px;
  z-index: 1;
  pointer-events: none;
  background:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 360 400' preserveAspectRatio='none'%3E%3Cpath d='M15,0 C35,80 -5,160 20,240 C40,320 0,380 15,400' fill='none' stroke='rgba(255,255,255,0.14)' stroke-width='1'/%3E%3Cpath d='M65,0 C85,90 45,170 70,250 C90,330 50,370 65,400' fill='none' stroke='rgba(255,255,255,0.12)' stroke-width='1'/%3E%3Cpath d='M115,0 C135,70 95,150 120,230 C140,310 100,360 115,400' fill='none' stroke='rgba(255,255,255,0.10)' stroke-width='1'/%3E%3Cpath d='M170,0 C190,85 150,165 175,245 C195,325 155,375 170,400' fill='none' stroke='rgba(255,255,255,0.08)' stroke-width='1'/%3E%3Cpath d='M225,0 C245,75 205,155 230,235 C250,315 210,365 225,400' fill='none' stroke='rgba(255,255,255,0.06)' stroke-width='1'/%3E%3Cpath d='M280,0 C300,90 260,170 285,250 C305,330 265,380 280,400' fill='none' stroke='rgba(255,255,255,0.04)' stroke-width='1'/%3E%3Cpath d='M335,0 C355,80 315,160 340,240 C360,320 320,370 335,400' fill='none' stroke='rgba(255,255,255,0.03)' stroke-width='1'/%3E%3C/svg%3E") no-repeat left center;
  background-size: 360px 100%;
}

/* Right wave lines — 7 vertical lines, mirrored, wide spacing */
.page-hero::after {
  content: '';
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  width: 360px;
  z-index: 1;
  pointer-events: none;
  background:
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 360 400' preserveAspectRatio='none'%3E%3Cpath d='M345,0 C325,80 365,160 340,240 C320,320 360,380 345,400' fill='none' stroke='rgba(255,255,255,0.14)' stroke-width='1'/%3E%3Cpath d='M295,0 C275,90 315,170 290,250 C270,330 310,370 295,400' fill='none' stroke='rgba(255,255,255,0.12)' stroke-width='1'/%3E%3Cpath d='M245,0 C225,70 265,150 240,230 C220,310 260,360 245,400' fill='none' stroke='rgba(255,255,255,0.10)' stroke-width='1'/%3E%3Cpath d='M190,0 C170,85 210,165 185,245 C165,325 205,375 190,400' fill='none' stroke='rgba(255,255,255,0.08)' stroke-width='1'/%3E%3Cpath d='M135,0 C115,75 155,155 130,235 C110,315 150,365 135,400' fill='none' stroke='rgba(255,255,255,0.06)' stroke-width='1'/%3E%3Cpath d='M80,0 C60,90 100,170 75,250 C55,330 95,380 80,400' fill='none' stroke='rgba(255,255,255,0.04)' stroke-width='1'/%3E%3Cpath d='M25,0 C5,80 45,160 20,240 C0,320 40,370 25,400' fill='none' stroke='rgba(255,255,255,0.03)' stroke-width='1'/%3E%3C/svg%3E") no-repeat right center;
  background-size: 360px 100%;
}

.page-hero > * {
  position: relative;
  z-index: 2;
}

/* Reserved for future hero design elements */

/* Area cards — location page variant */
.area-card {
  background: var(--color-white);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  box-shadow: var(--shadow-sm);
  border-left: 4px solid var(--color-primary);
  text-align: left;
  display: flex;
  flex-direction: column;
  transition: box-shadow var(--transition-base), transform var(--transition-base), border-color var(--transition-base);
}

.area-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-3px);
  border-color: var(--color-accent);
  text-decoration: none;
}

.area-card h3 {
  font-size: var(--text-lg);
  margin-bottom: var(--space-xs);
  color: var(--color-text-heading);
}

.area-card .area-subtitle {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-primary);
  margin-bottom: var(--space-sm);
}

.area-card p {
  font-size: var(--text-sm);
  color: var(--color-text-body);
  line-height: 1.6;
  flex-grow: 1;
}

.area-card .area-link {
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  color: var(--color-primary);
  margin-top: var(--space-sm);
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.area-card:hover .area-link {
  color: var(--color-accent);
}

.area-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
}

@media (max-width: 991px) {
  .area-cards { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 767px) {
  .area-cards { grid-template-columns: 1fr; }
}

.page-hero h1 {
  color: var(--color-white);
  font-size: var(--text-4xl);
  margin-bottom: var(--space-sm);
  text-shadow: 0 2px 16px rgba(0, 0, 0, 0.3);
}

.page-hero p {
  font-size: var(--text-lg);
  color: rgba(255, 255, 255, 0.9);
  max-width: 640px;
  margin: 0 auto;
}

.page-hero .eyebrow {
  color: var(--color-accent);
  text-shadow: none;
}

/* ---- Hub Page Cards Grid ---- */
.hub-section {
  padding: var(--space-2xl) var(--space-md);
}

.hub-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
}

.hub-card {
  background: var(--color-white);
  border-radius: var(--radius-md);
  border-top: 3px solid var(--color-accent);
  padding: var(--space-lg);
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-base), transform var(--transition-base);
  display: flex;
  flex-direction: column;
  text-align: center;
}

.hub-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-3px);
}

.hub-card h3 {
  font-size: var(--text-lg);
  margin-bottom: var(--space-xs);
}

.hub-card p {
  font-size: var(--text-sm);
  color: var(--color-text-body);
  line-height: 1.7;
  flex-grow: 1;
}

.hub-card .btn {
  margin-top: var(--space-md);
  align-self: center;
}

.hub-cards--2col {
  grid-template-columns: repeat(2, 1fr);
}

/* ---- Detail Page Layout ---- */
.detail-content {
  padding: var(--space-2xl) var(--space-md);
}

.detail-content .container {
  max-width: var(--container-max);
}

.detail-body {
  max-width: var(--container-narrow);
  margin: 0 auto;
}

.detail-body h2 {
  font-size: var(--text-2xl);
  margin-top: var(--space-xl);
  margin-bottom: var(--space-sm);
}

.detail-body h2::after {
  content: '';
  display: block;
  width: 40px;
  height: 2px;
  background: var(--color-accent);
  margin-top: var(--space-xs);
}

.detail-body h2:first-child {
  margin-top: 0;
}

.detail-body p {
  line-height: 1.8;
  margin-bottom: var(--space-md);
}

.detail-body ul {
  margin-bottom: var(--space-md);
  padding-left: var(--space-md);
}

.detail-body li {
  list-style: disc;
  padding: var(--space-xs) 0;
  line-height: 1.7;
  color: var(--color-text-body);
}

/* ---- Callout Box (used in detail pages) ---- */
.callout {
  background: linear-gradient(135deg, var(--color-off-white) 0%, rgba(236, 177, 90, 0.08) 100%);
  border-left: 4px solid var(--color-accent);
  border-radius: var(--radius-sm);
  padding: var(--space-lg);
  margin: var(--space-lg) 0;
}

.callout h3 {
  font-size: var(--text-lg);
  margin-bottom: var(--space-xs);
}

.callout p {
  margin-bottom: 0;
}

/* ---- Info Grid (What to Expect, Who It's For, etc.) ---- */
.info-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
  margin: var(--space-lg) 0;
}

.info-box {
  text-align: center;
  padding: var(--space-lg) var(--space-sm);
  background: var(--color-white);
  border-radius: var(--radius-md);
  border-left: 3px solid var(--color-accent);
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
}

.info-box:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: var(--color-primary);
}

/* Clickable info-box (when wrapped in <a>) */
a.info-box {
  border-top: 3px solid var(--color-accent);
  cursor: pointer;
  position: relative;
}

a.info-box::after {
  content: '\2192';
  display: block;
  font-size: var(--text-sm);
  color: var(--color-primary);
  margin-top: var(--space-xs);
  transition: color var(--transition-fast), transform var(--transition-fast);
}

a.info-box:hover {
  border-top-color: var(--color-primary);
}

a.info-box:hover::after {
  color: var(--color-accent);
  transform: translateX(4px);
}

.info-box svg {
  width: 36px;
  height: 36px;
  margin: 0 auto var(--space-sm);
  color: var(--color-primary);
}

.info-box h4 {
  font-size: var(--text-base);
  margin-bottom: var(--space-xs);
}

.info-box p {
  font-size: var(--text-sm);
  color: var(--color-text-light);
  margin-bottom: 0;
}

/* ---- Page CTA Bar (used at bottom of detail pages) ---- */
.page-cta {
  background: var(--color-primary-dark);
  color: var(--color-white);
  text-align: center;
  padding: var(--space-2xl) var(--space-md);
}

.page-cta h2 {
  color: var(--color-white);
  font-size: var(--text-2xl);
  margin-bottom: var(--space-xs);
}

.page-cta p {
  color: rgba(255, 255, 255, 0.85);
  font-size: var(--text-lg);
  margin-bottom: var(--space-lg);
  max-width: var(--container-narrow);
  margin-left: auto;
  margin-right: auto;
}

.page-cta .btn {
  margin: 0 var(--space-xs);
}

/* ---- About: Team Grid ---- */
.team-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-lg);
}

.team-card {
  text-align: center;
}

.team-photo {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: var(--radius-md);
  background: var(--color-light-gray);
  margin-bottom: var(--space-sm);
  filter: grayscale(0.3);
  transition: filter var(--transition-base);
}

.team-card:hover .team-photo {
  filter: grayscale(0);
}

.team-card h4 {
  font-size: var(--text-base);
  margin-bottom: 2px;
}

.team-card .team-title {
  font-size: var(--text-sm);
  color: var(--color-primary);
  font-style: italic;
  margin-bottom: var(--space-xs);
}

.team-card .team-bio {
  font-size: var(--text-xs);
  color: var(--color-text-light);
  line-height: 1.5;
}

.team-card p {
  font-size: var(--text-sm);
  color: var(--color-text-light);
}

/* ---- About: Values / Pillars ---- */
.values-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
}

.value-item {
  text-align: center;
  padding: var(--space-lg) var(--space-sm);
}

.value-icon {
  width: 48px;
  height: 48px;
  margin: 0 auto var(--space-sm);
  color: var(--color-accent);
}

.value-item h4 {
  font-size: var(--text-base);
  margin-bottom: var(--space-xs);
}

.value-item p {
  font-size: var(--text-sm);
  color: var(--color-text-light);
  line-height: 1.6;
}

/* ---- Gallery Grid ---- */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-sm);
}

.gallery-grid img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  border-radius: var(--radius-sm);
}

/* ---- Contact Form ---- */
.contact-grid {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: var(--space-xl);
  align-items: start;
}

.form-group {
  margin-bottom: var(--space-md);
}

.form-group label {
  display: block;
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  margin-bottom: var(--space-xs);
  color: var(--color-text-heading);
}

.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: 0.75rem 1rem;
  font-family: var(--font-body);
  font-size: var(--text-base);
  border: 1px solid var(--color-mid-gray);
  border-radius: var(--radius-sm);
  background: var(--color-white);
  color: var(--color-text-body);
  transition: border-color var(--transition-fast);
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(14, 95, 117, 0.1);
}

.form-group textarea {
  min-height: 120px;
  resize: vertical;
}

.contact-info-card {
  background: var(--color-off-white);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
}

.contact-info-card h3 {
  font-size: var(--text-lg);
  margin-bottom: var(--space-md);
}

.contact-info-item {
  display: flex;
  gap: var(--space-sm);
  margin-bottom: var(--space-md);
  align-items: flex-start;
}

.contact-info-item svg {
  width: 20px;
  height: 20px;
  color: var(--color-primary);
  flex-shrink: 0;
  margin-top: 2px;
}

.contact-info-item p {
  font-size: var(--text-sm);
  margin-bottom: 0;
}

.contact-info-item a {
  color: var(--color-primary);
  font-weight: var(--font-weight-medium);
}

/* ---- FAQ Accordion ---- */
.faq-list {
  max-width: var(--container-narrow);
  margin: 0 auto;
}

.faq-item {
  border-bottom: 1px solid var(--color-light-gray);
}

.faq-question {
  width: 100%;
  background: none;
  border: none;
  padding: var(--space-md) 0;
  font-family: var(--font-heading);
  font-size: var(--text-base);
  color: var(--color-text-heading);
  text-align: left;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-sm);
}

.faq-question:hover {
  color: var(--color-primary);
}

.faq-question svg {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  transition: transform var(--transition-base);
}

.faq-item.open .faq-question svg {
  transform: rotate(45deg);
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease, padding 0.3s ease;
}

.faq-item.open .faq-answer {
  max-height: 500px;
  padding-bottom: var(--space-md);
}

.faq-answer p {
  font-size: var(--text-base);
  color: var(--color-text-body);
  line-height: 1.7;
}

.trust-bar .accreditations img {
  height: 45px;
}

/* Compact trust bar on inner pages */
.page-trust-bar {
  padding: var(--space-md) var(--space-md);
  text-align: center;
}

.page-trust-bar .trust-badges {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-xl);
  flex-wrap: wrap;
}

.page-trust-bar .trust-badges img {
  height: 45px;
  width: auto;
  object-fit: contain;
}

.page-trust-bar .trust-badges img:first-child {
  height: 55px;
}

.page-trust-bar h2 {
  font-size: var(--text-base);
  margin-bottom: var(--space-xs);
}

.page-trust-bar p {
  font-size: var(--text-sm);
  margin-bottom: var(--space-sm);
}

/* Treatment/What We Treat card variant with icon accent */
.hub-card--treat {
  border-top: none;
  border-left: 4px solid var(--color-accent);
  text-align: left;
}

.hub-card--treat h3 {
  font-size: var(--text-base);
}

/* Detail page spacing between callouts and info grids */
.detail-body .callout + .callout {
  margin-top: var(--space-lg);
}

.detail-body h2 + .info-grid {
  margin-top: var(--space-md);
}

/* Cross-link bar before page CTA */
.cross-links {
  background: var(--color-off-white);
  padding: var(--space-lg) var(--space-md);
}

.cross-links-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-lg);
  max-width: var(--container-max);
  margin: 0 auto;
  flex-wrap: wrap;
}

.cross-link {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  color: var(--color-text-body);
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: var(--space-sm) var(--space-md);
  border: 1px solid var(--color-mid-gray);
  border-radius: var(--radius-sm);
  transition: all var(--transition-fast);
}

.cross-link:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
  background: var(--color-white);
}

.cross-link svg {
  width: 18px;
  height: 18px;
}

/* ---- Insurance Logos Row ---- */
.insurance-logos {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: var(--space-lg);
  padding: var(--space-lg) 0;
}

.insurance-logos img {
  height: 50px;
  width: auto;
  object-fit: contain;
  filter: grayscale(0.3);
  transition: filter var(--transition-fast);
}

.insurance-logos img:hover {
  filter: grayscale(0);
}

/* ---- Responsive ---- */
@media (max-width: 991px) {
  .page-hero h1 {
    font-size: var(--text-3xl);
  }

  .hub-cards {
    grid-template-columns: repeat(2, 1fr);
  }

  .info-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .team-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .values-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .contact-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  .page-hero {
    min-height: 260px;
    padding: calc(var(--space-xl) + 60px) var(--space-sm) var(--space-xl);
  }

  .page-hero h1 {
    font-size: var(--text-2xl);
  }

  .hub-cards,
  .hub-cards--2col {
    grid-template-columns: 1fr;
  }

  .info-grid {
    grid-template-columns: 1fr;
  }

  .team-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .values-grid {
    grid-template-columns: 1fr;
  }

  .gallery-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
