/* ============================================================
   HNIP Website – Faithful HACU Reproduction
   ============================================================ */

/* ---- Elementor canvas overrides — only relax wrappers, keep widget spacing intact ---- */
body.page-template-elementor_canvas { margin: 0; padding: 0; }

/* Sections we mark as hnip-full-bleed stretch edge-to-edge so backgrounds (nav, hero) span the viewport. */
body.page-template-elementor_canvas .elementor-section.hnip-full-bleed,
body.page-template-elementor_canvas .elementor-section.hnip-full-bleed > .elementor-container {
  max-width: 100% !important;
  padding: 0 !important;
}
body.page-template-elementor_canvas .elementor-section.hnip-full-bleed > .elementor-container > .elementor-column,
body.page-template-elementor_canvas .elementor-section.hnip-full-bleed > .elementor-container > .elementor-column > .elementor-element-populated {
  padding: 0 !important;
}
body.page-template-elementor_canvas .elementor-section.hnip-full-bleed .elementor-widget-html,
body.page-template-elementor_canvas .elementor-section.hnip-full-bleed .elementor-widget-html > .elementor-widget-container {
  padding: 0 !important;
}

/* The sidebar+main inner section mimics the design's .content-layout wrapper. */
body.page-template-elementor_canvas .elementor-inner-section.hnip-inner-content {
  padding: 3% 5% !important;
  max-width: 1200px !important;
  margin: 0 auto !important;
}
body.page-template-elementor_canvas .elementor-inner-section.hnip-inner-content > .elementor-container {
  max-width: 100% !important;
  gap: 40px !important;
  padding: 0 !important;
  align-items: flex-start;
}
body.page-template-elementor_canvas .elementor-inner-section.hnip-inner-content > .elementor-container > .elementor-column {
  padding: 0 !important;
}
/* Column widths — match the original design: fixed 200px sidebar, main
   column grows to fill the rest. This avoids the overflow that happens
   when both columns use percentage widths with a 40px gap
   (17% + 83% + 40px > 100%). */
@media (min-width: 1025px) {
  body.page-template-elementor_canvas .hnip-sidebar-col {
    flex: 0 0 200px !important;
    width: 200px !important;
    max-width: 200px !important;
  }
  body.page-template-elementor_canvas .hnip-main-col {
    flex: 1 1 0 !important;
    width: auto !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }
}
/* Below the breakpoint the design already stacks vertically via its
   .content-layout media query — we mirror that by letting columns
   flow normally (Elementor stacks them at < 1025px by default). */
@media (max-width: 1024px) {
  body.page-template-elementor_canvas .elementor-inner-section.hnip-inner-content > .elementor-container {
    flex-direction: column !important;
    gap: 24px !important;
  }
  body.page-template-elementor_canvas .hnip-sidebar-col,
  body.page-template-elementor_canvas .hnip-main-col {
    width: 100% !important;
    flex-basis: 100% !important;
  }
}

/* Apply full-width to the single-column content sections too. */
body.page-template-elementor_canvas .elementor-section.hnip-section > .elementor-container {
  max-width: 100% !important;
  padding: 0 !important;
}

/* ---- Elementor Heading widget styling when HNIP classes are applied ---- */
.elementor-widget-heading.hnip-content-heading .elementor-heading-title {
  font-family: 'Poppins', sans-serif;
  font-size: 36px; font-weight: 500; line-height: 43px;
  color: #333333; margin-bottom: 24px;
}
.elementor-widget-heading.hnip-content-heading .elementor-heading-title .is-red { color: #CE1141; }

.elementor-widget-heading.hnip-content-section-title .elementor-heading-title {
  font-family: 'Poppins', sans-serif;
  font-size: 30px; font-weight: 400;
  color: #333333; margin-bottom: 16px;
}

.elementor-widget-heading.hnip-partner-section-title .elementor-heading-title {
  font-family: 'Poppins', sans-serif;
  font-size: 28px; font-weight: 700;
  color: #333333; margin-bottom: 16px;
}
.elementor-widget-heading.hnip-partner-subtitle .elementor-heading-title {
  font-family: 'Poppins', sans-serif;
  font-size: 20px; font-weight: 600;
  color: #006469; margin-bottom: 14px;
}
.elementor-widget-heading.hnip-partner-subtitle-red .elementor-heading-title { color: #CE1141; }
.elementor-widget-heading.hnip-partner-heading-teal .elementor-heading-title {
  font-family: 'Poppins', sans-serif;
  font-size: 16px; font-weight: 700; color: #006469;
  text-transform: uppercase; letter-spacing: .03em;
  margin: 24px 0 8px;
}

/* ---- Elementor Text Editor body paragraphs — HNIP content text ---- */
.elementor-widget-text-editor.hnip-content-text .elementor-widget-container {
  font-size: 15px; line-height: 1.8; color: #333333; margin-bottom: 16px;
}
.elementor-widget-text-editor.hnip-content-text .elementor-widget-container p {
  font-size: 15px; line-height: 1.8; color: #333333; margin-bottom: 16px;
}

/* Section wrapper for headings that mark each HNIP content-section — border-bottom like the design. */
.elementor-widget.hnip-section-start { margin-top: 30px !important; padding-top: 0; }
.elementor-widget.hnip-section-end   {
  padding-bottom: 30px !important;
  margin-bottom: 30px !important;
  border-bottom: 1px solid #1D2134;
}

/* ---- EA Advanced Accordion — teal variant (Program Overview) ---- */
.elementor-widget-eael-adv-accordion.hnip-teal-accordion .eael-adv-accordion .eael-accordion-list {
  margin-bottom: 4px !important;
}
.elementor-widget-eael-adv-accordion.hnip-teal-accordion .eael-adv-accordion .eael-accordion-list .eael-accordion-header {
  background: #006469 !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 15px 18px !important;
  color: #FFFFFF !important;
  font-family: 'Poppins', sans-serif !important;
  font-size: 16px !important; font-weight: 400 !important;
  transition: background .3s;
}
.elementor-widget-eael-adv-accordion.hnip-teal-accordion .eael-adv-accordion .eael-accordion-list .eael-accordion-header:hover {
  background: #004f53 !important;
}
.elementor-widget-eael-adv-accordion.hnip-teal-accordion .eael-adv-accordion .eael-accordion-list.active-default .eael-accordion-header,
.elementor-widget-eael-adv-accordion.hnip-teal-accordion .eael-adv-accordion .eael-accordion-list-item.active .eael-accordion-header,
.elementor-widget-eael-adv-accordion.hnip-teal-accordion .eael-adv-accordion .eael-accordion-list.active .eael-accordion-header {
  background: #1D2134 !important;
}
.elementor-widget-eael-adv-accordion.hnip-teal-accordion .eael-adv-accordion .eael-accordion-list .eael-accordion-header .eael-accordion-tab-title,
.elementor-widget-eael-adv-accordion.hnip-teal-accordion .eael-adv-accordion .eael-accordion-list .fa-accordion-icon {
  color: #FFFFFF !important;
}
.elementor-widget-eael-adv-accordion.hnip-teal-accordion .eael-adv-accordion .eael-accordion-list .eael-accordion-content {
  background: #F7F8F9 !important;
  border: none !important;
  padding: 18px 20px !important;
  font-size: 15px !important; color: #333333 !important; line-height: 1.7 !important;
}
.elementor-widget-eael-adv-accordion.hnip-teal-accordion .eael-adv-accordion .eael-accordion-list .eael-accordion-content ul {
  list-style: disc; padding-left: 24px; margin: 8px 0;
}
.elementor-widget-eael-adv-accordion.hnip-teal-accordion .eael-adv-accordion .eael-accordion-list .eael-accordion-content li {
  margin-bottom: 4px;
}

/* ---- EA Advanced Accordion — FAQ plain variant ---- */
.elementor-widget-eael-adv-accordion.hnip-faq-accordion .eael-adv-accordion .eael-accordion-list {
  margin-bottom: 0 !important;
  border: none !important;
  border-bottom: 1px solid #d5d8dc !important;
  background: transparent !important;
}
.elementor-widget-eael-adv-accordion.hnip-faq-accordion .eael-adv-accordion .eael-accordion-list:first-child {
  border-top: 1px solid #d5d8dc !important;
}
.elementor-widget-eael-adv-accordion.hnip-faq-accordion .eael-adv-accordion .eael-accordion-list .eael-accordion-header {
  background: transparent !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 14px 0 !important;
  color: #333333 !important;
  font-family: 'Poppins', sans-serif !important;
  font-size: 15px !important; font-weight: 700 !important;
}
.elementor-widget-eael-adv-accordion.hnip-faq-accordion .eael-adv-accordion .eael-accordion-list .eael-accordion-header:hover .eael-accordion-tab-title {
  color: #CE1141 !important;
}
.elementor-widget-eael-adv-accordion.hnip-faq-accordion .eael-adv-accordion .eael-accordion-list .eael-accordion-content {
  background: transparent !important;
  border: none !important;
  padding: 0 0 16px !important;
  font-size: 14px !important; color: #545F71 !important; line-height: 1.7 !important;
}
.elementor-widget-eael-adv-accordion.hnip-faq-accordion .eael-adv-accordion .eael-accordion-list .eael-accordion-content ul {
  list-style: disc; padding-left: 24px; margin-top: 8px;
}
.elementor-widget-eael-adv-accordion.hnip-faq-accordion .eael-adv-accordion .eael-accordion-list .eael-accordion-content li {
  margin-bottom: 4px;
}

/* Material Symbols proper rendering (icons otherwise appear as text) */
.material-symbols-outlined {
  font-family: 'Material Symbols Outlined';
  font-weight: normal;
  font-style: normal;
  font-size: 24px;
  display: inline-block;
  line-height: 1;
  text-transform: none;
  letter-spacing: normal;
  word-wrap: normal;
  white-space: nowrap;
  direction: ltr;
  -webkit-font-smoothing: antialiased;
  font-feature-settings: 'liga';
}

/* ---------- Reset & Custom Properties ---------- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --navy:       #1D2134;
  --teal:       #006469;
  --teal-dark:  #004f53;
  --red:        #CE1141;
  --red-dark:   #99042A;
  --gray-bg:    #F7F8F9;
  --gray-alt:   #F3F3F3;
  --gray-light: #d5d8dc;
  --white:      #FFFFFF;
  --text:       #333333;
  --text-muted: #545F71;
  --link:       #0060df;
  --max-width:  1200px;
}

html { scroll-behavior: smooth; font-size: 16px; }

/* Offset anchor targets by ~70px so they don't land underneath the
   sticky top nav when scrolling via #hash. */
#overview,
#datesanddeadlines,
#studenttestimonial,
#faq,
#contactus,
.elementor-element[id="overview"],
.elementor-element[id="datesanddeadlines"],
.elementor-element[id="studenttestimonial"],
.elementor-element[id="faq"],
.elementor-element[id="contactus"] {
  scroll-margin-top: 70px;
}

body {
  font-family: 'Poppins', sans-serif;
  color: var(--text);
  background: var(--white);
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; display: block; }
a   { color: var(--link); text-decoration: underline; text-underline-offset: 4px; transition: color .3s; }
a:hover { color: var(--red); }

.material-symbols-outlined {
  font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
  vertical-align: middle;
}

.container { max-width: var(--max-width); margin: 0 auto; padding: 0 5%; }
.text-center { text-align: center; }

/* ---------- Navigation ---------- */
.site-nav {
  background: var(--navy);
  position: sticky; top: 0; z-index: 100;
}
.site-nav .container {
  display: flex; align-items: center;
  gap: 0; padding-top: 0; padding-bottom: 0;
}
.site-nav a {
  color: rgba(255,255,255,.8); font-size: 14px; font-weight: 500;
  padding: 14px 20px;
  text-decoration: none;
  transition: background .3s, color .3s;
  white-space: nowrap;
}
.site-nav a.nav-logo {
  padding: 10px 20px 10px 0; margin-right: auto;
  display: flex; align-items: center;
}
.site-nav a.nav-logo img { height: 30px; width: auto; }
.site-nav a:hover { color: var(--white); background: rgba(255,255,255,.08); }
.site-nav a.active { background: var(--red); color: var(--white); }
.site-nav a.nav-logo:hover { background: none; }

/* ---------- Hero ---------- */
.hero {
  position: relative;
  background: url('https://hacu.net/wp-content/uploads/2024/11/HNIPFederalHeader.jpg') center right / cover no-repeat;
  min-height: 40vh;
  display: flex; align-items: flex-end;
}
.hero .container {
  width: 100%; max-width: 100%;
  background: #02010196;
  padding: 1% 5%;
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 10px;
}
.hero h1 {
  font-family: 'Poppins', sans-serif;
  font-size: 30px; font-weight: 400;
  color: var(--white);
  width: 61%;
  line-height: 35px;
}
.hero h1 span{font-size:18px;}
.hero .breadcrumb {
  font-family: 'Poppins', sans-serif;
  font-size: 12px; font-weight: 400;
  color: var(--white); margin-top: 10px;
}
.hero .breadcrumb a { color: var(--white); text-decoration: underline; }
.hero .breadcrumb span { margin: 0 4px; opacity: .7; }

/* ---------- Sidebar Layout ---------- */
.content-layout {
  display: flex; gap: 40px;
  padding: 3% 5%;
  max-width: var(--max-width);
  margin: 0 auto;
}
.sidebar {
  width: 200px; flex-shrink: 0;
}
.sidebar-nav { list-style: none; }
.sidebar-nav > li {
  border-bottom: 1px solid #000;
}
.sidebar-nav > li:last-child { border-bottom: none; }
.sidebar-nav > li > a {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 0;
  color: var(--text); font-size: 13px; font-weight: 600;
  text-decoration: none; text-transform: uppercase;
  letter-spacing: .3px;
  transition: color .3s;
}
.sidebar-nav > li > a:hover { color: var(--red); }
.sidebar-nav > li > a.active,
.sidebar-nav > li > a.parent-link.active { color: var(--navy); }
.sidebar-nav .has-children > .parent-link::after {
  content: '▾'; font-size: 10px; color: var(--text-muted);
}
.sidebar-nav .sub-list {
  list-style: none; padding-left: 16px; padding-bottom: 8px;
}
.sidebar-nav .sub-list li { border: none; }
.sidebar-nav .sub-list a {
  display: block; padding: 5px 0;
  font-size: 13px; font-weight: 400; color: var(--text-muted);
  text-decoration: none; text-transform: none;
}
.sidebar-nav .sub-list a:hover { color: var(--red); }
.sidebar-nav .sub-list a.active { color: var(--red); font-weight: 500; }

.main-content {
  flex: 1; min-width: 0;
}

/* ---------- Content Heading (HNIP Federal Internships) ---------- */
.content-heading {
  font-family: 'Poppins', sans-serif;
  font-size: 36px; font-weight: 500;
  line-height: 43px;
  color: var(--text);
  margin-bottom: 24px;
}
.content-heading span { color: var(--red); }

/* ---------- Deadline Box (inside content) ---------- */
.deadline-box {
  background: var(--navy);
  color: var(--white);
  padding: 30px;
  text-align: center;
  margin-bottom: 24px;
}
.deadline-title {
  font-size: 24px; font-weight: 600;
  margin-bottom: 4px;
}
.deadline-date {
  font-size: 16px; font-weight: 400;
  color: var(--red); margin-bottom: 20px;
}
.countdown {
  display: flex; justify-content: center; gap: 16px;
  max-width: 60%; margin: 0 auto 16px;
}
.countdown .unit {
  text-align: center; flex: 1;
  background: var(--teal); border-radius: 6px;
  padding: 16px 10px;
}
.countdown .number {
  display: block;
  font-family: 'Poppins', sans-serif;
  font-size: 35px; font-weight: 400;
  line-height: 27px; letter-spacing: -1.1px;
}
.countdown .lbl {
  display: block;
  font-family: 'Poppins', sans-serif;
  font-size: 18px; font-weight: 400;
  line-height: 21px; letter-spacing: -0.4px;
  margin-top: 8px;
}
.deadline-note {
  font-size: 13px; opacity: .7;
  max-width: 500px; margin: 0 auto;
  line-height: 1.5;
}

/* ---------- Positions Banner ---------- */
.positions-banner {
  background: var(--navy);
  color: var(--white);
  text-align: center;
  padding: 30px;
  margin-bottom: 4px;
}
.positions-banner h3 {
  font-size: 24px; font-weight: 500;
  margin-bottom: 14px;
}

/* ---------- Apply Section ---------- */
.apply-section {
  text-align: center;
  padding: 24px 0;
  margin-bottom: 20px;
}
.apply-section h3 {
  font-size: 24px; font-weight: 500;
  margin-bottom: 14px;
}

/* ---------- Content Sections ---------- */
.content-section {
  margin-bottom: 30px;
  padding-bottom: 30px;
  border-bottom: 1px solid var(--navy);
}
.content-section:last-child { border-bottom: none; }
.content-section-title {
  font-family: 'Poppins', sans-serif;
  font-size: 30px; font-weight: 400;
  color: var(--text);
  margin-bottom: 16px;
}
.content-text {
  font-size: 15px; line-height: 1.8;
  color: var(--text); margin-bottom: 16px;
}

/* ---------- Teal Accordion (Program Overview sub-sections) ---------- */
.teal-accordion { margin-top: 8px; }
.teal-accordion-item { margin-bottom: 4px; }
.teal-accordion-btn {
  width: 100%; text-align: left;
  background: var(--teal);
  border: none;
  padding: 15px 18px;
  font-family: 'Poppins', sans-serif;
  font-size: 16px; font-weight: 400;
  color: var(--white);
  cursor: pointer;
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  transition: background .3s;
}
.teal-accordion-btn:hover { background: var(--teal-dark); }
.teal-accordion-item.open > .teal-accordion-btn { background: var(--navy); }
.teal-accordion-btn .material-symbols-outlined {
  font-size: 20px; color: var(--white);
  transition: transform .3s;
}
.teal-accordion-item.open > .teal-accordion-btn .material-symbols-outlined { transform: rotate(45deg); }
.teal-accordion-content {
  display: none;
  background: var(--gray-bg);
}
.teal-accordion-item.open > .teal-accordion-content { display: block; }
.teal-accordion-inner {
  padding: 18px 20px;
  font-size: 15px; color: var(--text); line-height: 1.7;
}
.teal-accordion-inner ul { list-style: disc; padding-left: 24px; margin: 8px 0; }
.teal-accordion-inner li { margin-bottom: 4px; }

/* ---------- FAQ List (plain style with borders) ---------- */
.faq-list { margin-top: 8px; }
.faq-item {
  border-bottom: 1px solid var(--gray-light);
}
.faq-item:first-child { border-top: 1px solid var(--gray-light); }
.faq-btn {
  width: 100%; text-align: left;
  background: none;
  border: none;
  padding: 14px 0;
  font-family: 'Poppins', sans-serif;
  font-size: 15px; font-weight: 400;font-weight: bold;
  color: var(--text);
  cursor: pointer;
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  transition: color .3s;
}
.faq-btn:hover { color: var(--red); }
.faq-btn .material-symbols-outlined {
  font-size: 20px; color: var(--text-muted);
  transition: transform .3s;
  flex-shrink: 0;
}
.faq-item.open .faq-btn .material-symbols-outlined { transform: rotate(45deg); }
.faq-content {
  display: none;
}
.faq-item.open > .faq-content { display: block; }
.faq-inner {
  padding: 0 0 16px;
  font-size: 14px; color: var(--text-muted); line-height: 1.7;
}
.faq-inner ul { list-style: disc; padding-left: 24px; margin-top: 8px; }
.faq-inner li { margin-bottom: 4px; }

/* ---------- Position Accordion (positions.html) ---------- */
.position-accordion { margin-top: 8px; }
.position-item { margin-bottom: 4px; }
.position-btn {
  width: 100%; text-align: left;
  background: var(--navy);
  border: none;
  padding: 14px 18px;
  font-family: 'Poppins', sans-serif;
  font-size: 15px; font-weight: 500;
  color: var(--white);
  cursor: pointer;
  display: flex; align-items: center; gap: 12px;
  transition: background .3s;
}
.position-btn:hover { background: #2a2f47; }
.position-item.open > .position-btn { background: var(--teal); }
.position-title { flex: 1; min-width: 0; }
.position-meta-inline {
  display: flex; gap: 6px; flex-shrink: 0;
}
.position-meta-inline .card-tag { font-size: 11px; padding: 3px 8px; }
.position-meta-inline .card-tag .material-symbols-outlined { font-size: 13px; }
.position-icon {
  font-size: 20px; color: var(--white);
  transition: transform .3s;
  flex-shrink: 0;
}
.position-item.open > .position-btn .position-icon { transform: rotate(45deg); }
.position-content {
  display: none;
  background: var(--gray-bg);
  border-left: 3px solid var(--teal);
}
.position-item.open > .position-content { display: block; }
.position-inner {
  padding: 18px 20px;
  font-size: 14px; color: var(--text); line-height: 1.7;
}
.position-inner p { margin-bottom: 6px; }
.position-inner .card-label {
  font-size: 12px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--teal); margin-top: 12px; margin-bottom: 4px;
}
.position-inner ul { list-style: disc; padding-left: 24px; margin: 4px 0 8px; }
.position-inner li { font-size: 13px; line-height: 1.6; color: var(--text-muted); margin-bottom: 2px; }
/* Session Tab Buttons */
.session-tabs {
  display: flex; gap: 0; margin-bottom: 16px;
  border-bottom: 2px solid #ddd;
}
.session-tab {
  padding: 12px 28px;
  font-family: 'Poppins', sans-serif;
  font-size: 15px; font-weight: 600;
  color: var(--text-muted);
  background: transparent;
  border: none; border-bottom: 3px solid transparent;
  cursor: pointer;
  transition: color .3s, border-color .3s, background .3s;
  margin-bottom: -2px;
}
.session-tab:hover {
  color: var(--navy); background: rgba(0,100,105,.05);
}
.session-tab.active {
  color: var(--teal); border-bottom-color: var(--teal);
}

.session-heading {
  font-size: 18px; font-weight: 600; color: var(--teal);
  margin: 28px 0 6px; padding-bottom: 6px;
  border-bottom: 2px solid var(--teal);
}
.session-heading:first-child { margin-top: 0; }
.agency-desc {
  font-size: 13px; color: var(--text-muted); line-height: 1.6;
  margin: 0 0 12px; padding: 0;
}
.session-subheading {
  font-size: 14px; font-weight: 600; color: var(--navy);
  margin: 16px 0 8px; text-transform: uppercase; letter-spacing: .03em;
}

/* ---------- Testimonials Gallery ---------- */
.testimonial-gallery {
  display: flex; gap: 0;
  height: 400px;
  overflow: hidden;
}
.testimonial-slide {
  flex: 1;
  position: relative;
  transition: flex .4s ease;
  cursor: pointer;
  overflow: hidden;
}
.testimonial-slide:hover { flex: 2; }
.testimonial-overlay {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(0,0,0,.7));
  padding: 20px;
  color: var(--white);
}
.testimonial-quote {
  font-size: 14px; font-style: italic;
  line-height: 1.5; margin-bottom: 8px;
  opacity:0;
}
.testimonial-name {
  font-size: 13px; line-height: 1.4;opacity:0;
}

/* ---------- Partner GSA Block (in-content) ---------- */
.partner-gsa-section { background: transparent; }
.partner-gsa-block {
  background: var(--navy);
  color: var(--white);
  border-radius: 4px;
  padding: 28px;
  margin-top: 16px;
}
.partner-gsa-block h3 {
  font-size: 18px; font-weight: 500; margin-bottom: 10px;
}
.partner-gsa-block p {
  font-size: 15px; line-height: 1.7; opacity: .85;
}

/* ---------- Partner Page (federal-agencies style) ---------- */
.partner-tagline {
  font-size: 16px; font-weight: 400; color: var(--teal);
  border: 2px solid #ddd; border-radius: 4px;
  padding: 18px 24px; line-height: 1.6;
}
.section-divider {
  border: none; border-top: 2px solid #ddd;
  margin: 28px 0;
}
.partner-section-title {
  font-family: 'Poppins', sans-serif;
  font-size: 28px; font-weight: 700; color: var(--text);
  margin-bottom: 16px;
}
.partner-subtitle {
  font-family: 'Poppins', sans-serif;
  font-size: 20px; font-weight: 600; color: var(--teal);
  margin-bottom: 14px;
}
.partner-heading-teal {
  font-family: 'Poppins', sans-serif;
  font-size: 16px; font-weight: 700; color: var(--teal);
  text-transform: uppercase; letter-spacing: .03em;
  margin: 24px 0 8px;
}

/* ---------- Contact Section ---------- */
.contact-section { border-bottom: none !important; }
.contact-row {
  display: flex; gap: 0;
  border: 1px solid var(--gray-light);
  margin-top: 16px;
}
.contact-info {
  background: var(--navy);
  color: var(--white);
  padding: 28px;
  flex: 1;
  font-size: 14px; line-height: 1.7;
}
.contact-info h4 {
  font-size: 16px; font-weight: 600;
  color: var(--red); margin-bottom: 12px;
}
.contact-form {
  flex: 1.2;
  padding: 28px;
  background: var(--white);
}
.contact-form h4 {
  font-size: 18px; font-weight: 500;
  color: var(--red); margin-bottom: 16px;
}
.form-row {
  display: flex; gap: 12px;
  margin-bottom: 12px;
}
.form-row .form-input { flex: 1; }
.form-input {
  font-family: 'Poppins', sans-serif;
  font-size: 14px;
  padding: 10px 14px;
  border: 1px solid #ccc;
  border-radius: 4px;
  width: 100%;
  transition: border-color .3s;
}
.form-input:focus { outline: none; border-color: var(--teal); }
.form-textarea {
  min-height: 100px; resize: vertical;
  margin-bottom: 12px;
}
.btn--dark {
  background: #32373c; color: var(--white);
  border: none;
}
.btn--dark:hover { background: var(--red-dark); color: var(--white); }

/* Contact Form 7 — inherit the HNIP form styling on CF7's rendered output.
   CF7 wraps each line in <p> and adds <br> between inputs; we neutralise
   that so Name + Email sit side-by-side in .form-row. */
.contact-form .wpcf7-form p {
  margin: 0 0 12px;
}
.contact-form .wpcf7-form .form-row {
  display: flex;
  gap: 12px;
  margin-bottom: 12px;
}
.contact-form .wpcf7-form .form-row p {
  display: contents; /* let flex layout pick up the child wraps directly */
}
.contact-form .wpcf7-form .form-row br {
  display: none;
}
.contact-form .wpcf7-form .form-row .wpcf7-form-control-wrap {
  flex: 1 1 0;
  min-width: 0;
}
.contact-form .wpcf7-form-control-wrap,
.elementor-column.contact-form-col .wpcf7-form-control-wrap { display: block; }

/* Force CF7 input/textarea to fill the column width regardless of the
   cols/size HTML attributes CF7 emits. The inline <span> wraps stop
   children from naturally reaching 100% width, which is fixed above,
   but we also need to make sure the control itself isn't capped. */
.elementor-column.contact-form-col .wpcf7-form-control {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}
/* Submit keeps its auto width so the button doesn't stretch. */
.elementor-column.contact-form-col .wpcf7-form-control.wpcf7-submit {
  width: auto !important;
}
.contact-form .wpcf7-form .wpcf7-submit {
  cursor: pointer;
  /* CF7 renders submit without our .btn base padding — give it the same. */
  padding: calc(0.667em + 2px) calc(1.333em + 2px) !important;
  line-height: 23px !important;
  letter-spacing: 1.4px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  text-transform: uppercase !important;
  border-radius: 4px !important;
}
/* Validation messages */
.contact-form .wpcf7-not-valid-tip {
  color: var(--red);
  font-size: 12px;
  margin-top: 4px;
}
.contact-form .wpcf7-response-output {
  margin: 12px 0 0 !important;
  padding: 10px 14px !important;
  border-radius: 4px;
  font-size: 13px;
}
.contact-form .wpcf7 form.invalid .wpcf7-response-output,
.contact-form .wpcf7 form.unaccepted .wpcf7-response-output {
  border: 2px solid var(--red) !important;
  color: var(--red) !important;
  background: rgba(206, 17, 65, 0.05);
}
.contact-form .wpcf7 form.sent .wpcf7-response-output {
  border: 2px solid var(--teal) !important;
  color: var(--teal) !important;
  background: rgba(0, 100, 105, 0.05);
}

/* ---------- Sections (for non-sidebar pages) ---------- */
.section { padding: 3% 0; }
.section--white { background: var(--white); }
.section--gray  { background: var(--gray-bg); }
.section--navy  { background: var(--navy); color: var(--white); }

.section-title {
  font-family: 'Poppins', sans-serif;
  font-size: 36px; font-weight: 500;
  line-height: 43px;
  color: var(--text); margin-bottom: 12px;
}
.section--navy .section-title { color: var(--white); }
.section-subtitle {
  font-size: 15px; color: var(--text-muted);
  margin-bottom: 24px; line-height: 1.7;
}
.section--navy .section-subtitle { color: rgba(255,255,255,.7); }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: 'Poppins', sans-serif;
  font-weight: 500; font-size: 14px;
  text-transform: uppercase;
  letter-spacing: 1.4px;
  line-height: 23px;
  padding: calc(0.667em + 2px) calc(1.333em + 2px);
  border-radius: 4px; cursor: pointer;
  text-decoration: none;
  border: 2px solid transparent;
  transition: all .3s;
}
.btn .material-symbols-outlined { font-size: 18px; }
.btn--primary {
  background: var(--navy); color: var(--white);
  border-color: var(--red);
}
.btn--primary:hover { background: var(--red); color: var(--white); }
.btn--red { background: var(--red); color: var(--white); }
.btn--red:hover { background: var(--red-dark); color: var(--white); }
.btn--outline {
  background: transparent; color: var(--navy);
  border-color: var(--navy);
}
.btn--outline:hover { background: var(--navy); color: var(--white); }
.btn--white { background: var(--white); color: var(--navy); }
.btn--white:hover { background: var(--gray-bg); color: var(--navy); }
.btn--teal { background: var(--teal); color: var(--white); }
.btn--teal:hover { background: var(--teal-dark); color: var(--white); }

/* ========================================================================
   NATIVE ELEMENTOR WIDGET SKINS — match HNIP design when the matching
   class is added to the widget's Advanced → CSS Classes field.
   ======================================================================== */

/* -- Elementor Button widget styled as an HNIP .btn (shared base) -- */
.elementor-widget-button.hnip-btn .elementor-button,
.elementor-widget-button.hnip-btn .elementor-button-link {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  font-family: 'Poppins', sans-serif !important;
  font-weight: 500 !important;
  font-size: 14px !important;
  text-transform: uppercase !important;
  letter-spacing: 1.4px !important;
  line-height: 23px !important;
  padding: calc(0.667em + 2px) calc(1.333em + 2px) !important;
  border-radius: 4px !important;
  border: 2px solid transparent !important;
  transition: all .3s !important;
  box-shadow: none !important;
  text-decoration: none !important;
}
.elementor-widget-button.hnip-btn.hnip-btn-teal .elementor-button {
  background: var(--teal) !important;
  color: var(--white) !important;
}
.elementor-widget-button.hnip-btn.hnip-btn-teal .elementor-button:hover {
  background: var(--teal-dark) !important;
  color: var(--white) !important;
}
.elementor-widget-button.hnip-btn.hnip-btn-outline .elementor-button {
  background: transparent !important;
  color: var(--navy) !important;
  border-color: var(--navy) !important;
}
.elementor-widget-button.hnip-btn.hnip-btn-outline .elementor-button:hover {
  background: var(--navy) !important;
  color: var(--white) !important;
}
.elementor-widget-button.hnip-btn.hnip-btn-red .elementor-button {
  background: var(--red) !important;
  color: var(--white) !important;
}
.elementor-widget-button.hnip-btn.hnip-btn-red .elementor-button:hover {
  background: var(--red-dark) !important;
  color: var(--white) !important;
}

/* -- Block/full-width button variant (e.g. CURRENT AGENCY LOGIN) -- */
.elementor-widget-button.hnip-btn.hnip-btn-block .elementor-button {
  display: flex !important;
  width: 100% !important;
  justify-content: center !important;
  padding: 16px !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  letter-spacing: .08em !important;
}

/* -- Partner tagline (was <div class="partner-tagline">) -- */
.elementor-widget-text-editor.partner-tagline .elementor-widget-container {
  font-family: 'Poppins', sans-serif;
  font-size: 16px;
  font-weight: 400;
  color: var(--teal) !important;
  border: 2px solid #ddd;
  border-radius: 4px;
  padding: 18px 24px !important;
  line-height: 1.6;
}
.elementor-widget-text-editor.partner-tagline .elementor-widget-container p {
  margin: 0 !important;
  color: var(--teal) !important;
}

/* -- Elementor Divider styled as the design's <hr class="section-divider"> -- */
.elementor-widget-divider.hnip-divider {
  margin: 28px 0 !important;
}
.elementor-widget-divider.hnip-divider .elementor-widget-container {
  padding: 0 !important;
}
.elementor-widget-divider.hnip-divider .elementor-divider {
  border: none !important;
  padding: 0 !important;
}
.elementor-widget-divider.hnip-divider .elementor-divider-separator {
  border-top: 2px solid #ddd !important;
  border-top-width: 2px !important;
  border-top-style: solid !important;
  border-top-color: #ddd !important;
}

/* -- Deadline Box (was <div class="deadline-box">) -- */
.elementor-inner-section.deadline-box {
  background: var(--navy) !important;
  text-align: center !important;
  margin-bottom: 24px !important;
}
.elementor-inner-section.deadline-box .elementor-widget-heading.deadline-title .elementor-heading-title {
  color: var(--white) !important;
  font-size: 24px !important;
  font-weight: 600 !important;
  margin-bottom: 4px !important;
}
.elementor-inner-section.deadline-box .elementor-widget-text-editor.deadline-date,
.elementor-inner-section.deadline-box .elementor-widget-text-editor.deadline-date .elementor-widget-container,
.elementor-inner-section.deadline-box .elementor-widget-text-editor.deadline-date p {
  color: var(--red) !important;
  font-size: 16px !important;
  font-weight: 400 !important;
}
.elementor-inner-section.deadline-box .elementor-widget-text-editor.deadline-note,
.elementor-inner-section.deadline-box .elementor-widget-text-editor.deadline-note .elementor-widget-container,
.elementor-inner-section.deadline-box .elementor-widget-text-editor.deadline-note p {
  color: var(--white) !important;
  font-size: 13px !important;
  max-width: 500px !important;
  margin: 0 auto !important;
  line-height: 1.5 !important;
}

/* -- Positions Banner (was <div class="positions-banner">) -- */
.elementor-inner-section.positions-banner {
  background: var(--navy) !important;
  text-align: center !important;
  margin-bottom: 4px !important;
}
.elementor-inner-section.positions-banner .elementor-widget-heading .elementor-heading-title {
  color: var(--white) !important;
  font-size: 24px !important;
  font-weight: 500 !important;
  margin-bottom: 14px !important;
}

/* -- Apply Section (was <div class="apply-section">) -- */
.elementor-inner-section.apply-section {
  text-align: center !important;
  margin-bottom: 20px !important;
}
.elementor-inner-section.apply-section > .elementor-container {
  padding: 24px 0 !important;
  max-width: 100% !important;
}
.elementor-inner-section.apply-section .elementor-widget-heading .elementor-heading-title {
  color: var(--text) !important;
  font-size: 24px !important;
  font-weight: 500 !important;
  margin-bottom: 14px !important;
  text-align: center !important;
}

/* -- Contact section (was <div class="content-layout" id="contactus"> HTML widget) -- */
/* Outer wrapper that centers the contact block like the original .content-layout */
.elementor-inner-section.hnip-content-container {
  padding: 3% 5% !important;
  max-width: 1200px !important;
  margin: 0 auto !important;
}
.elementor-inner-section.hnip-content-container > .elementor-container {
  max-width: 100% !important;
  padding: 0 !important;
}
.elementor-inner-section.hnip-content-container > .elementor-container > .elementor-column,
.elementor-inner-section.hnip-content-container > .elementor-container > .elementor-column > .elementor-widget-wrap {
  padding: 0 !important;
}

/* The two-column contact row (navy info + white form) */
.elementor-inner-section.contact-row {
  border: 1px solid var(--gray-light) !important;
  margin-top: 16px !important;
}
.elementor-inner-section.contact-row > .elementor-container {
  max-width: 100% !important;
  padding: 0 !important;
  gap: 0 !important;
  align-items: stretch !important;
}

/* Left column — dark navy, white text */
.elementor-column.contact-info {
  background: var(--navy) !important;
  color: var(--white) !important;
}
.elementor-column.contact-info > .elementor-widget-wrap {
  padding: 28px !important;
}
.elementor-column.contact-info .elementor-widget-heading .elementor-heading-title {
  color: var(--red) !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  margin-bottom: 12px !important;
}
.elementor-column.contact-info .elementor-widget-text-editor,
.elementor-column.contact-info .elementor-widget-text-editor .elementor-widget-container,
.elementor-column.contact-info .elementor-widget-text-editor p {
  color: var(--white) !important;
  font-size: 14px !important;
  line-height: 1.7 !important;
  margin: 0 !important;
}
.elementor-column.contact-info .elementor-widget-text-editor .elementor-widget-container > p:not(:first-child),
.elementor-column.contact-info .elementor-widget-text-editor + .elementor-widget-text-editor {
  margin-top: 8px !important;
}
.elementor-column.contact-info a {
  color: var(--white) !important;
  text-decoration: underline;
}
.elementor-column.contact-info .material-symbols-outlined {
  font-size: 16px !important;
  vertical-align: middle;
  margin-right: 4px;
}

/* Right column — white bg, the CF7 form */
.elementor-column.contact-form-col {
  background: var(--white) !important;
}
.elementor-column.contact-form-col > .elementor-widget-wrap {
  padding: 28px !important;
}
.elementor-column.contact-form-col .elementor-widget-heading .elementor-heading-title {
  color: var(--red) !important;
  font-size: 18px !important;
  font-weight: 500 !important;
  margin-bottom: 16px !important;
}
/* The CF7 form inside — re-use the .contact-form styling hooks from
   earlier so .form-input layout / submit button remain unchanged. */
.elementor-column.contact-form-col .wpcf7-form p {
  margin: 0 0 12px;
}
.elementor-column.contact-form-col .wpcf7-form .form-row {
  display: flex;
  gap: 12px;
  margin-bottom: 12px;
}
.elementor-column.contact-form-col .wpcf7-form .form-row p {
  display: contents;
}
.elementor-column.contact-form-col .wpcf7-form .form-row br { display: none; }
.elementor-column.contact-form-col .wpcf7-form .form-row .wpcf7-form-control-wrap {
  flex: 1 1 0;
  min-width: 0;
}

/* Stack contact-info + contact-form vertically at ≤1024px */
@media (max-width: 1024px) {
  .elementor-inner-section.contact-row > .elementor-container {
    flex-direction: column !important;
  }
  .elementor-column.contact-info,
  .elementor-column.contact-form-col {
    width: 100% !important;
    flex-basis: 100% !important;
    max-width: 100% !important;
  }
}

/* Heading for the contact section title ("Get in Touch") when centered */
.elementor-widget-heading.contact-section-heading .elementor-heading-title {
  text-align: center;
}

/* -- CTA Group (inline flex of buttons, used inside apply-section) -- */
.elementor-inner-section.cta-group > .elementor-container {
  justify-content: center !important;
  gap: 12px !important;
  max-width: 100% !important;
  padding: 0 !important;
  flex-wrap: wrap !important;
}
.elementor-inner-section.cta-group > .elementor-container > .elementor-column {
  width: auto !important;
  flex-basis: auto !important;
  flex-grow: 0 !important;
  padding: 0 !important;
}
.elementor-inner-section.cta-group .elementor-widget-button {
  margin: 0 !important;
}

.cta-group { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; }

/* ---------- Data Table ---------- */
.table-wrap { overflow-x: auto; margin: 16px 0; }
.data-table {
  width: 100%; border-collapse: collapse;
  font-family: 'Poppins', sans-serif;
}
.data-table th, .data-table td {
  padding: 12px 16px; text-align: left;
  font-size: 14px; line-height: 20px;
}
.data-table thead th {
  background: var(--navy); color: var(--white);
  font-weight: 600; font-size: 13px;
}
.data-table tbody tr:nth-child(odd) td { background: var(--gray-alt); color: #000; }
.data-table tbody tr:nth-child(even) td { background: var(--white); color: #000; }

/* EA Data Table widget — alias onto the HNIP .data-table look.
   Use with CSS class `hnip-data-table` on the widget (via Elementor's
   Advanced → CSS Classes field). Higher specificity + !important beat
   EA's per-instance inline CSS. */
.elementor-widget-eael-data-table.hnip-data-table .elementor-widget-container { padding: 0 !important; }
.elementor-widget-eael-data-table.hnip-data-table .eael-data-table-wrap {
  overflow-x: auto !important;
  margin: 16px 0 !important;
}
.elementor-widget-eael-data-table.hnip-data-table .eael-data-table {
  width: 100% !important;
  border-collapse: collapse !important;
  font-family: 'Poppins', sans-serif !important;
  box-shadow: none !important;
  border: none !important;
}
.elementor-widget-eael-data-table.hnip-data-table .eael-data-table th,
.elementor-widget-eael-data-table.hnip-data-table .eael-data-table td {
  padding: 12px 16px !important;
  text-align: left !important;
  font-size: 14px !important;
  line-height: 20px !important;
  border: none !important;
}
.elementor-widget-eael-data-table.hnip-data-table .eael-data-table thead th,
.elementor-widget-eael-data-table.hnip-data-table .eael-data-table thead tr th {
  background: var(--navy) !important;
  color: var(--white) !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  border-radius: 0 !important;
  text-transform: none !important;
}
.elementor-widget-eael-data-table.hnip-data-table .eael-data-table tbody tr:nth-child(odd) td {
  background: var(--gray-alt) !important;
  color: #000 !important;
}
.elementor-widget-eael-data-table.hnip-data-table .eael-data-table tbody tr:nth-child(even) td {
  background: var(--white) !important;
  color: #000 !important;
}
/* Hide the mobile-collapsed column label (EA duplicates the header on mobile) */
.elementor-widget-eael-data-table.hnip-data-table .eael-data-table .th-mobile-screen {
  display: none !important;
}
.elementor-widget-eael-data-table.hnip-data-table .eael-data-table .data-table-header-text {
  font-family: 'Poppins', sans-serif !important;
  font-weight: 600 !important;
  font-size: 13px !important;
}

/* ---------- Card Grid (Positions) ---------- */
.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 24px;
}
.card {
  background: var(--white);
  border: 1px solid var(--gray-light);
  border-radius: 4px;
  overflow: hidden;
  transition: box-shadow .3s;
}
.card:hover { box-shadow: 0 4px 16px rgba(0,0,0,.1); }
.card-header {
  background: var(--navy); color: var(--white);
  padding: 14px 18px;
}
.card-header h3 {
  font-size: 16px; font-weight: 500; color: var(--white); margin: 0;
}
.card-body { padding: 18px; }
.card-body h3 { font-size: 16px; color: var(--navy); margin-bottom: 8px; font-weight: 500; }
.card-tag {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 12px; font-weight: 500;
  padding: 4px 10px; border-radius: 3px;
  margin-bottom: 6px; text-decoration: none;
}
.card-tag .material-symbols-outlined { font-size: 14px; }
.card-tag--location { background: #E8F5E9; color: #2E7D32; }
.card-tag--virtual  { background: #E3F2FD; color: #1565C0; }
.card-tag--hours    { background: #FFF3E0; color: #E65100; }
.card-meta { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 10px; }
.card-body > p { font-size: 14px; color: var(--text); line-height: 1.6; margin-bottom: 6px; }
.card-body ul { padding-left: 20px; margin: 4px 0 8px; }
.card-body li { font-size: 13px; line-height: 1.6; color: var(--text-muted); }
.card-label {
  font-size: 12px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--teal); margin-top: 12px; margin-bottom: 4px;
}

/* ---------- Filter Bar ---------- */
.filter-bar {
  display: flex; flex-wrap: wrap; gap: 10px;
  margin-bottom: 20px; align-items: center;
}
.filter-bar input[type="text"] {
  flex: 1; min-width: 200px;
  padding: 10px 16px; font-size: 14px;
  border: 1px solid #ccc; border-radius: 5px;
  font-family: 'Poppins', sans-serif;
}
.filter-bar input:focus { outline: none; border-color: #0073aa; box-shadow: 0 0 3px rgba(0,115,170,.3); }
.filter-bar select {
  padding: 10px 16px; font-size: 14px;
  border: 1px solid #ccc; border-radius: 5px;
  font-family: 'Poppins', sans-serif; cursor: pointer;
  background: var(--white);
}
.results-count { font-size: 14px; color: var(--text-muted); }

/* ---------- Features (Partners) ---------- */
.features { display: flex; gap: 30px; }
.feature-box { flex: 1; padding: 0; }
.feature-box .f-icon {
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--teal); color: var(--white);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 16px;
}
.feature-box .f-icon .material-symbols-outlined { font-size: 28px; }
.feature-box h3 { font-size: 20px; font-weight: 500; color: var(--text); margin-bottom: 10px; }
.feature-box p { font-size: 15px; color: var(--text-muted); line-height: 1.7; }

/* ---------- GSA Block ---------- */
.gsa-block {
  max-width: 720px; margin: 20px auto 0;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.15);
  border-radius: 4px; padding: 28px;
  text-align: left;
}
.gsa-block h3 { font-size: 18px; font-weight: 500; margin-bottom: 10px; }
.gsa-block p { font-size: 15px; line-height: 1.7; opacity: .85; }

/* ---------- Assist Cards ---------- */
.assist-cards { display: flex; flex-wrap: wrap; gap: 20px; justify-content: center; }
.assist-card {
  display: flex; align-items: center; gap: 16px;
  background: var(--white);
  border: 1px solid var(--gray-light);
  border-radius: 4px;
  padding: 20px 24px;
  flex: 1; min-width: 260px; max-width: 400px;
  transition: box-shadow .3s;
}
.assist-card:hover { box-shadow: 0 4px 12px rgba(0,0,0,.08); }
.assist-card .a-icon {
  width: 48px; height: 48px; border-radius: 50%;
  background: var(--teal); color: var(--white);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.assist-card .a-icon .material-symbols-outlined { font-size: 24px; }
.assist-card h3 { font-size: 16px; font-weight: 500; color: var(--text); margin-bottom: 4px; }
.assist-card p  { font-size: 14px; color: var(--text-muted); margin-bottom: 4px; }
.assist-card a  { font-size: 13px; font-weight: 600; }

/* ---------- Utilities ---------- */
.mb-8  { margin-bottom: 8px; }
.mb-16 { margin-bottom: 16px; }
.mb-24 { margin-bottom: 24px; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .hero h1 { font-size: 34px; }
  .countdown .number { font-size: 22px; }
  .countdown .lbl { font-size: 14px; }
  .countdown .unit { padding: 14px 8px; }
  .content-layout { flex-direction: column; gap: 24px; }
  .sidebar { width: 100%; }
  .features { flex-direction: column; }
  .contact-row { flex-direction: column; }
}

@media (max-width: 768px) {
  .hero { min-height: 30vh; }
  .hero h1 { font-size: 28px; width: 100%; }
  .hero .container { flex-direction: column; align-items: flex-start; }
  .section-title { font-size: 28px; line-height: 34px; }
  .content-section-title { font-size: 24px; }
  .content-heading { font-size: 28px; }
  .countdown { max-width: 90%; }
  .card-grid { grid-template-columns: 1fr; }
  .filter-bar { flex-direction: column; }
  .filter-bar input[type="text"],
  .filter-bar select { width: 100%; }
  .data-table th, .data-table td { padding: 10px 12px; font-size: 12px; }
  .form-row { flex-direction: column; }
}

@media (max-width: 600px) {
  .container { padding: 0 4%; }
  .content-layout { padding: 3% 4%; }
  .site-nav a { font-size: 12px; padding: 12px 14px; }
  .site-nav a.nav-logo img { height: 24px; }
  .hero h1 { font-size: 24px; }
  .countdown { max-width: 100%; }
  .testimonial-gallery { height: 200px; flex-direction: column; }
  .testimonial-slide:hover { flex: 1; }
}
