/* ══════════════════════════════════════════════════════════════════
   AHTC Inc. — Inner Page Styles
   inner_page.css  (loads AFTER style.css)
════════════════════════════════════════════════════════════════════ */

/* ══════════════════════════════════════
   INNER BANNER
══════════════════════════════════════ */
.inner-banner {
  position: relative;
  height: 500px;
  margin-top: 121px;
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: flex-end;
  overflow: hidden;          /* ← CRITICAL: must be hidden */
}

/* Fix: remove scale & negative inset */
.inner-banner::before {
  content: '';
  position: absolute;
  inset: 0;                  /* ← was -10%, causing overflow bleed */
  background: inherit;
  background-size: cover;
  background-position: center;
  filter: brightness(.60) saturate(1.1);
  transform: none;           /* ← remove scale(1.06) — was pushing beyond bounds */
  transition: none;
}

.inner-banner:hover::before {
  transform: none;           /* ← remove hover scale too */
}

/* Fix: Remove the diagonal angled edge — this is causing the right-side triangle bleed */
.inner-banner-edge {
  display: none;             /* ← THIS is the white diagonal crossing the image */
}

/* Gradient overlay — strong left, fades right */
.inner-banner-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    105deg,
    rgba(8,12,18,.70) 0%,
    rgba(8,12,18,.45) 55%,
    rgba(8,12,18,.20) 100%
  );
  z-index: 1;
}

/* Red accent bar at left edge */
.inner-banner::after {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 5px;
  background: var(--green);
  z-index: 3;
}

.inner-banner-content {
  position: relative;
  z-index: 2;
  padding-bottom: 3.5rem;
  width: 100%;
}

/* Decorative angled bottom edge */
.inner-banner-edge {
  position: absolute;
  bottom: -1px;
  left: 0; right: 0;
  height: 60px;
  background: var(--off-white);
  clip-path: polygon(0 100%, 100% 0, 100% 100%);
  z-index: 2;
}

/* ── Breadcrumb ── */
.inner-breadcrumb {
  margin-bottom: 1.4rem;
}
.inner-breadcrumb ol {
  list-style: none;
  padding: 0; margin: 0;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: .35rem;
}
.inner-breadcrumb li {
  display: flex;
  align-items: center;
  gap: .35rem;
  font-family: var(--font-cond);
  font-size: .72rem;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.inner-breadcrumb li a {
  color: var(--white);
  transition: color .2s;
}
.inner-breadcrumb li a:hover { color: var(--green-light); }
.inner-breadcrumb li.active span {
  color: var(--green-light);
}
.inner-breadcrumb li i.fa-chevron-right {
  font-size: .55rem;
  color: rgba(255,255,255,.3);
}
.inner-breadcrumb li i.fa-home {
  font-size: .75rem;
}

/* ── Page Title Block ── */
.inner-page-eyebrow {
  font-family: var(--font-cond);
  font-weight: 600;
  font-size: .75rem;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--green-light);
  display: flex;
  align-items: center;
  gap: .6rem;
  margin-bottom: .85rem;
}
.inner-page-eyebrow::before {
  content: '';
  display: inline-block;
  width: 26px; height: 2px;
  background: var(--green);
  flex-shrink: 0;
}

.inner-page-title {
  font-family: var(--font-head);
  font-size: clamp(2.8rem, 5vw, 4.8rem);
  line-height: .95;
  letter-spacing: .03em;
  color: #fff;
  margin-bottom: .75rem;
  max-width: 780px;
}

.inner-page-subtitle {
  font-size: 1.05rem;
  color: rgba(255,255,255,.65);
  line-height: 1.65;
  max-width: 560px;
  font-weight: 300;
  margin: 0;
}

/* ══════════════════════════════════════
   INNER PAGE BODY WRAPPER
══════════════════════════════════════ */
.inner-page-wrap {
  padding: 5rem 0 6rem;
  background: var(--off-white);
}

/* ══════════════════════════════════════
   PAGE CONTENT TYPOGRAPHY
══════════════════════════════════════ */
.inner-page-content {
  font-family: var(--font-body);
  font-size: 1.02rem;
  line-height: 1.85;
  color: var(--text);
}

/* ── Headings ── */
.inner-page-content h1,
.inner-page-content h2,
.inner-page-content h3,
.inner-page-content h4,
.inner-page-content h5,
.inner-page-content h6 {
  font-family: var(--font-head);
  letter-spacing: .03em;
  color: var(--dark);
  margin-top: 2.5rem;
  margin-bottom: .9rem;
  line-height: 1;
}
.inner-page-content h1 { font-size: clamp(2.2rem, 4vw, 3.5rem); }
.inner-page-content h2 {
  font-size: clamp(1.9rem, 3.5vw, 2.9rem);
  padding-bottom: .5rem;
  border-bottom: 2px solid var(--border);
}
.inner-page-content h3 { font-size: clamp(1.5rem, 2.5vw, 2rem); color: var(--green-dark); }
.inner-page-content h4 { font-size: 1.25rem; font-family: var(--font-cond); font-weight: 700; letter-spacing: .06em; text-transform: uppercase; color: var(--mid); }
.inner-page-content h5 { font-size: 1.05rem; font-family: var(--font-cond); font-weight: 700; }
.inner-page-content h6 { font-size: .95rem; font-family: var(--font-cond); font-weight: 600; color: var(--muted); }

/* ── Paragraphs ── */
.inner-page-content p {
  margin-bottom: 1.4rem;
  color: var(--text);
}
.inner-page-content p:last-child { margin-bottom: 0; }



/* ── Bold / Strong ── */
.inner-page-content strong,
.inner-page-content b {
  font-weight: 700;
  color: var(--dark);
}

/* ── Italic / Em ── */
.inner-page-content em,
.inner-page-content i {
  font-style: italic;
  color: inherit;
}

/* ── Blockquote ── */
.inner-page-content blockquote {
  font-style: italic;
  font-size: 1.1rem;
  line-height: 1.75;
  color: var(--green-dark);
  border-left: 4px solid var(--green);
  padding: 1rem 1.6rem;
  margin: 2rem 0;
  background: rgba(178,34,34,.04);
  border-radius: 0 var(--radius) var(--radius) 0;
}

/* ── Horizontal Rule ── */
.inner-page-content hr {
  border: none;
  border-top: 2px solid var(--border);
  margin: 2.5rem 0;
}



/* ══════════════════════════════════════
   TABLE STYLES
══════════════════════════════════════ */
.inner-page-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 2rem 0;
  font-size: .93rem;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(0,0,0,.07);
}
.inner-page-content thead {
  background: var(--dark);
  color: #fff;
}
.inner-page-content thead th {
  font-family: var(--font-cond);
  font-weight: 700;
  font-size: .8rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 1rem 1.2rem;
  border: none;
}
.inner-page-content tbody tr {
  border-bottom: 1px solid var(--border);
  transition: background .2s;
}
.inner-page-content tbody tr:last-child { border-bottom: none; }
.inner-page-content tbody tr:hover { background: rgba(178,34,34,.04); }
.inner-page-content tbody td {
  padding: .9rem 1.2rem;
  vertical-align: top;
  color: var(--text);
}
.inner-page-content tbody tr:nth-child(even) td {
  background: rgba(0,0,0,.02);
}

/* ══════════════════════════════════════
   IMAGE inside content
══════════════════════════════════════ */
.inner-page-content img {
  max-width: 100%;
  height: auto;
  border-radius: var(--radius-lg);
  margin: 1.5rem 0;
  box-shadow: var(--shadow);
  display: block;
}

/* ══════════════════════════════════════
   CONTENT LEAD PARAGRAPH (first p)
══════════════════════════════════════ */
.inner-page-content > p:first-of-type {
  font-size: 1.12rem;
  line-height: 1.9;
  color: var(--dark);
  font-weight: 400;
  border-left: 4px solid var(--green);
  padding-left: 1.2rem;
  margin-bottom: 2rem;
}

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media (max-width: 991.98px) {
  .inner-banner { height: 420px; }
  .inner-page-title { font-size: 2.8rem; }
  .inner-page-wrap { padding: 3.5rem 0 5rem; }
}

@media (max-width: 767.98px) {
  .inner-banner {
    height: 360px;
	margin-top:84px;
    align-items: center;
  }
  .inner-banner-content { padding-bottom: 1.5rem; }
  .inner-page-title { font-size: 2.2rem; }
  .inner-page-subtitle { font-size: .95rem; }
  .inner-banner-edge { height: 36px; }
  .inner-page-content { font-size: .97rem; }
  .inner-page-content h2 { font-size: 1.8rem; }
  .inner-page-content h3 { font-size: 1.4rem; }
}

@media (max-width: 575.98px) {
  .inner-banner { height: 300px; }
  .inner-page-title { font-size: 1.9rem; }
  .inner-breadcrumb { display: none; }
  .inner-page-wrap { padding: 2.5rem 0 4rem; }
}

/* ══════════════════════════════════════
   ANCHOR / LINK — inline content links
══════════════════════════════════════ */
.inner-page-content a {
  color: var(--green);
  font-weight: 600;
  text-decoration: none;
  border-bottom: 1.5px solid rgba(178,34,34,.35);
  padding-bottom: 1px;
  transition: color .2s, border-color .2s, background .2s;
  border-radius: 2px;
}
.inner-page-content a:hover {
  color: #fff;
  background: var(--green);
  border-color: var(--green);
  padding: 1px 4px;
  margin: 0 -4px;
  border-radius: var(--radius);
}

/* ── Standalone block link (when <a> wraps a full line) ── */
.inner-page-content p > a:only-child,
.inner-page-content li > a:only-child {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  font-family: var(--font-cond);
  font-weight: 700;
  font-size: .88rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--green);
  border-bottom: none;
  padding: 0;
  margin: 0;
}
.inner-page-content p > a:only-child::after,
.inner-page-content li > a:only-child::after {
  content: '\f054';
  font-family: 'Font Awesome 5 Free', FontAwesome;
  font-weight: 900;
  font-size: .6rem;
  transition: transform .2s;
}
.inner-page-content p > a:only-child:hover,
.inner-page-content li > a:only-child:hover {
  background: none;
  color: var(--green-dark);
  padding: 0;
  margin: 0;
}
.inner-page-content p > a:only-child:hover::after,
.inner-page-content li > a:only-child:hover::after {
  transform: translateX(4px);
}

/* ══════════════════════════════════════
   UL — indented to align text, not bullet
══════════════════════════════════════ */
.inner-page-content ul {
  list-style: none;
  padding: 0;
  margin: 1.4rem 0 2rem 1rem; /* left margin pushes ul inward */
  display: flex;
  flex-direction: column;
  gap: .6rem;
}
.inner-page-content ul li {
  position: relative;
  padding-left: 1.8rem; /* space for bullet, text starts here */
  font-size: 1rem;
  line-height: 1.75;
  color: var(--text);
}
.inner-page-content ul li::before {
  content: '\f054';
  font-family: 'Font Awesome 5 Free', 'Font Awesome 5 Pro', FontAwesome;
  font-weight: 900;
  position: absolute;
  left: 0;
  top: .28em;
  font-size: .6rem;
  color: var(--green);
  line-height: 1;
  transition: transform .2s;
}
.inner-page-content ul li:hover::before {
  transform: translateX(3px);
}

/* Nested ul */
.inner-page-content ul ul {
  margin: .5rem 0 .5rem 1rem;
}
.inner-page-content ul ul li::before {
  content: '\f111';
  font-size: .35rem;
  top: .5em;
  color: var(--muted);
}

/* ══════════════════════════════════════
   OL — same indent treatment
══════════════════════════════════════ */
.inner-page-content ol {
  list-style: none;
  padding: 0;
  margin: 1.4rem 0 2rem 1rem;
  counter-reset: inner-ol;
  display: flex;
  flex-direction: column;
  gap: .6rem;
}
.inner-page-content ol li {
  position: relative;
  padding-left: 2.6rem;
  font-size: 1rem;
  line-height: 1.75;
  counter-increment: inner-ol;
}
.inner-page-content ol li::before {
  content: counter(inner-ol);
  position: absolute;
  left: 0;
  top: .08em;
  width: 1.75rem;
  height: 1.75rem;
  background: var(--green);
  color: #fff;
  font-family: var(--font-cond);
  font-weight: 700;
  font-size: .75rem;
  letter-spacing: .04em;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  flex-shrink: 0;
}
/* ══════════════════════════════════════════════════════════════════
   AHTC Inc. — Contact Page Styles
   contact.css  (loads AFTER style.css and inner_page.css)
════════════════════════════════════════════════════════════════════ */

/* ══════════════════════════════════════
   CONTACT PAGE SECTION
══════════════════════════════════════ */
.contact-page-section {
  padding: 0 0 6rem;
  background: var(--off-white);
}

/* ══════════════════════════════════════
   INFO CARDS ROW
   — pulled up to overlap the banner
══════════════════════════════════════ */
.cp-info-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-top: -60px;   /* overlap the angled banner edge */
  margin-bottom: 4rem;
  position: relative;
  z-index: 10;
}

.cp-info-card {
  background: #fff;
  border-radius: var(--radius-lg);
  padding: 2rem 1.8rem;
  box-shadow: 0 8px 40px rgba(0,0,0,.10);
  border-top: 3px solid var(--green);
  display: flex;
  flex-direction: column;
  gap: .5rem;
  transition: transform .3s, box-shadow .3s;
}
.cp-info-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 56px rgba(0,0,0,.13);
}

.cp-info-icon {
  width: 46px; height: 46px;
  background: rgba(178,34,34,.08);
  border: 1px solid rgba(178,34,34,.2);
  color: var(--green);
  border-radius: var(--radius);
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem;
  margin-bottom: .4rem;
}

.cp-info-label {
  font-family: var(--font-cond);
  font-weight: 700;
  font-size: .68rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--muted);
}

.cp-info-val {
  font-size: 1rem;
  font-weight: 500;
  color: var(--dark);
  line-height: 1.6;
}
.cp-info-val a {
  color: var(--dark);
  text-decoration: none;
  transition: color .2s;
  font-family: var(--font-cond);
  font-weight: 700;
  font-size: 1.15rem;
  letter-spacing: .02em;
}
.cp-info-val a:hover { color: var(--green); }

.cp-info-link {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-family: var(--font-cond);
  font-weight: 600;
  font-size: .75rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--green);
  text-decoration: none;
  margin-top: .4rem;
  transition: gap .2s;
}
.cp-info-link:hover { gap: .7rem; color: var(--green-dark); }
.cp-info-link i { font-size: .6rem; }

.cp-info-hours {
  font-size: .82rem;
  color: var(--muted);
  font-style: italic;
  margin-top: .2rem;
}

/* ══════════════════════════════════════
   BODY ROW — form left, map right
══════════════════════════════════════ */
.cp-body-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: start;
}

/* ── Form Panel ── */
.cp-form-panel {
  background: #fff;
  border-radius: var(--radius-lg);
  padding: 3rem;
  box-shadow: 0 8px 40px rgba(0,0,0,.08);
}

.cp-form-head {
  margin-bottom: 2.2rem;
}
.cp-form-title {
  font-family: var(--font-head);
  font-size: clamp(2.2rem, 4vw, 3.2rem);
  line-height: .95;
  letter-spacing: .03em;
  color: var(--dark);
  margin: .5rem 0 .8rem;
}
.cp-form-intro {
  font-size: .92rem;
  color: var(--muted);
  line-height: 1.7;
  margin: 0;
}

/* Inputs — extend the home page custom-input */
.cp-form .form-label {
  font-family: var(--font-cond);
  font-weight: 700;
  font-size: .68rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: .4rem;
  display: block;
}

.cp-form .custom-input {
  background: var(--cream) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: var(--radius) !important;
  padding: .75rem 1rem !important;
  font-family: var(--font-body) !important;
  font-size: .93rem !important;
  color: var(--text) !important;
  transition: border-color .2s, box-shadow .2s !important;
  box-shadow: none !important;
  width: 100%;
}
.cp-form .custom-input:focus {
  border-color: var(--green) !important;
  box-shadow: 0 0 0 3px rgba(178,34,34,.10) !important;
  outline: none;
  background: #fff !important;
}
.cp-form .custom-input::placeholder { color: #bbb !important; }

/* Submit button — full width on contact page */
.cp-form .btn-submit-form {
  background: var(--green);
  color: #fff;
  font-family: var(--font-cond);
  font-weight: 700;
  font-size: .9rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  padding: 1rem 2.2rem;
  border-radius: var(--radius);
  border: none;
  width: 100%;
  cursor: pointer;
  transition: background .2s, transform .2s, box-shadow .2s;
  box-shadow: var(--shadow-red);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .6rem;
}
.cp-form .btn-submit-form:hover {
  background: var(--green-dark);
  transform: translateY(-2px);
}

/* ── Map Panel ── */
.cp-map-panel {
  position: sticky;
  top: 110px; /* clears fixed navbar */
}

.cp-map-inner {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: 0 8px 40px rgba(0,0,0,.12);
}

#contact-page-map {
  width: 100%;
  height: 560px;
  display: block;
}

/* Badge overlay on map */
.cp-map-badge {
  position: absolute;
  bottom: 1.5rem;
  left: 1.5rem;
  background: var(--dark);
  color: #fff;
  padding: .85rem 1.2rem;
  border-radius: var(--radius);
  display: flex;
  align-items: center;
  gap: .75rem;
  box-shadow: 0 4px 20px rgba(0,0,0,.3);
  z-index: 400;
  pointer-events: none;
}
.cp-map-badge i {
  color: var(--green-light);
  font-size: 1.1rem;
  flex-shrink: 0;
}
.cp-map-badge strong {
  display: block;
  font-family: var(--font-cond);
  font-weight: 700;
  font-size: .95rem;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.cp-map-badge span {
  font-size: .78rem;
  color: rgba(255,255,255,.5);
  letter-spacing: .06em;
}

/* ══════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════ */
@media (max-width: 991.98px) {
  .cp-info-row {
    grid-template-columns: 1fr 1fr;
    margin-top: -40px;
  }
  .cp-body-row {
    grid-template-columns: 1fr;
    gap: 2rem;
  }
  .cp-map-panel { position: static; }
  #contact-page-map { height: 380px; }
}

@media (max-width: 767.98px) {
  .cp-info-row {
    grid-template-columns: 1fr;
    margin-top: 2rem;
  }
  .cp-form-panel { padding: 2rem 1.5rem; }
  .cp-form-title { font-size: 2rem; }
  #contact-page-map { height: 300px; }
}

@media (max-width: 575.98px) {
  .cp-form-panel { padding: 1.5rem 1.2rem; }
}