/*
 * Handwriting Heroes — 2026 redesign (shared).
 * Scoped under .hhnew so the global Astra stylesheet does not interfere.
 * Used by header-2.php, page-new-home.php, page-about2.php, page-pricing2.php.
 */

.hhnew *,
.hhnew *::before,
.hhnew *::after { box-sizing: border-box; margin: 0; padding: 0; }

.hhnew {
  --hh-blue: #29ABE2;
  --hh-blue-stat: #62C8EE;
  --hh-red: #E24B4A;
  --hh-yellow: #F5C842;
  --hh-green: #3BAF7E;
  --hh-dark: #1a1a1a;
  --hh-muted: #555;
  --hh-cream: #FFF8E8;
  --hh-sky: #EEF6FB;
  --font-body: 'Quicksand', sans-serif;
  --font-heading: 'Roboto', sans-serif;
  --hh-text-base: 1rem;
  --hh-text-md: 0.98rem;
  --hh-text-lg: 1.1rem;
  --hh-text-sm: 0.9rem;
  --hh-text-xs: 0.85rem;
  --hh-text-label: 0.6875rem;
  --hh-text-ui: 0.8125rem;
  --hh-heading-xl: clamp(1.75rem, 3.5vw, 2.65rem);
  --hh-heading-md: 1.05rem;
  font-family: var(--font-body);
  background: #fff;
  color: var(--hh-dark);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

.hhnew-inner {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 28px;
}

.hhnew :is(
  h1, h2, h3, h4, h5, h6,
  .section-h2, .cta-h2,
  .step-title, .feat-title, .feat-title-text, .pillar-title,
  .t-name, .stat-n,
  .red-badge, .hero-btn, .cta-btn, .nav-cta,
  .nav-logo, .foot-logo,
  .page-title,
  .callout-card-title, .tier-name, .col-label, .tier-lbl, .video-lbl, .cta-eyebrow,
  .plan-name, .plan-price, .plan-price-custom, .plan-btn,
  .catalog-header .section-h2, .binder-tab, .hh-popup-title,
  .highlight-bar, .classroom-badge, .product-name
) {
  font-family: var(--font-heading);
}

/* NAV */
.hhnew .nav {
  background: var(--hh-blue);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 28px;
  position: sticky;
  top: 0;
  z-index: 1000;
}
.hhnew .nav-logo {
  font-size: 18px;
  font-weight: 800;
  color: #fff;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
}
.hhnew .nav-logo img { width: 200px;
  aspect-ratio: 200 / 94;
  display: block; padding: 10px;}
.hhnew .nav-links { display: flex; gap: 22px; align-items: center; }
.hhnew .nav-login { margin-left: 18px; }
.hhnew .nav-links a {
  color: #fff;
  font-size: 21px;
  font-weight: 700;
  text-decoration: none;
  font-family: var(--font-body);
}
.hhnew .nav-cta {
  background: var(--hh-red);
  color: #fff !important;
  font-size: 13px;
  font-weight: 700;
  padding: 8px 18px;
  border-radius: 24px;
  text-decoration: none;
}

/* HERO */
.hhnew .hero { background: #f0f8fd; position: relative; margin-bottom: 0; }
.hhnew .hero-img { width: 100%; display: block; vertical-align: bottom; }
.hhnew .hero-body { position: absolute;
  left: 6.5%;
  top: 59%;
  width: 36%;
  max-width: 380px;
  padding: 0; }
.hhnew .hero-eyebrow {
  font-size: clamp(8px, 1.3vw, 13px);
  font-weight: 600;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: #7c878f;
  margin-bottom: clamp(4px, 0.9vw, 10px);
}
.hhnew .hero-sub {
  font-size: clamp(9px, 1.45vw, 15px);
  color: #7c878f;
  line-height: 1.6;
  margin-bottom: clamp(8px, 1.5vw, 18px);
  max-width: 100%;
}
.hhnew .hero-btn {
  display: inline-block;
  background: var(--hh-dark);
  color: #fff;
  font-size: clamp(9px, 1.4vw, 15px);
  font-weight: 700;
  padding: clamp(7px, 1vw, 12px) clamp(16px, 2.2vw, 28px);
  border-radius: 8px;
  text-decoration: none;
}
.hhnew .badges-bar {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  transform: translateY(-50%);
  z-index: 2;
  display: flex;
  justify-content: center;
  padding: 0 20px;
  pointer-events: none;
}
.hhnew .badges {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: clamp(16px, 3vw, 36px);
  padding: 14px clamp(24px, 4vw, 48px);
  background: rgba(255, 255, 255, 0.41);
  border-radius: 999px;
  box-shadow: 0 6px 28px rgba(0, 0, 0, 0.12);
  flex-wrap: nowrap;
  pointer-events: auto;
}
.hhnew .badge-img { height: 90px; width: auto; display: block; object-fit: contain; flex-shrink: 0; }

/* SECTION COMMON */
.hhnew .section { padding: 56px 0; }
.hhnew .section-how {
  position: relative;
  background: #dcf0f0;
  padding-top: calc(56px + 58px);
  margin-top: 0;
}
.hhnew .section-cream { background: var(--hh-cream); }
.hhnew .red-badge {
  display: inline-block;
  background: var(--hh-red);
  color: #fff;
  font-size: var(--hh-text-label);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 6px 14px;
  border-radius: 4px;
  margin-bottom: 16px;
}
.hhnew .section-h2 {
  font-size: var(--hh-heading-xl);
  font-weight: 700;
  color: var(--hh-dark);
  line-height: 1.2;
  margin-bottom: 20px;
}
.hhnew .section-h2 .red { color: var(--hh-red); }
.hhnew .section-h2 .highlight {
  background: var(--hh-yellow);
  padding: 2px 6px;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}
.hhnew .section-sub {
  font-size: var(--hh-text-base);
  color: var(--hh-muted);
  line-height: 1.65;
  margin-bottom: 28px;
  max-width: 560px;
}

/* HOW IT WORKS */
.hhnew .section-how .section-h2 { margin-bottom: 70px; }
.hhnew .steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
  margin-top: 8px;
}
.hhnew .step {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  background: #fff;
  border-radius: 18px;
  padding: 0 18px 18px;
  padding-top: 38px;
}
.hhnew .step-num {    width:100px;
      height: 100px;
      border-radius: 50%;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 2.25rem;
      font-weight: 800;
      background: #fff;
      margin: -87px auto 10px;
      flex-shrink: 0;
      line-height: 1;
      border: solid 8px #dcf0f0;
}
.hhnew .n1 { color: var(--hh-blue); }
.hhnew .n2 { color: var(--hh-yellow); }
.hhnew .n3 { color: var(--hh-red); }
.hhnew .n4 { color: var(--hh-green); }
.hhnew .step-title {
  font-size: 1.05rem;
  font-weight: 700;
  margin-bottom: 8px;
  line-height: 1.25;
}
.hhnew .t-blue { color: var(--hh-blue); }
.hhnew .t-yellow { color: var(--hh-yellow); }
.hhnew .t-red { color: var(--hh-red); }
.hhnew .t-green { color: var(--hh-green); }
.hhnew .step-desc {
  font-family: var(--font-body);
  font-size: 0.98rem;
  color: var(--hh-dark);
  line-height: 1.55;
  margin-bottom: 24px;
  font-weight: 700;
  margin-top: 20px;
}
.hhnew .step-line {
  width: 89%;
  height: 3px;
  border-radius: 2px;
  margin: 0 auto 14px;
  flex-shrink: 0;
}
.hhnew .l-blue { background: var(--hh-blue); }
.hhnew .l-yellow { background: var(--hh-yellow); }
.hhnew .l-red { background: var(--hh-red); }
.hhnew .l-green { background: var(--hh-green); }
.hhnew .step-img,
.hhnew .step-video {
  width: 100%;
  height: auto;
  object-fit: contain;
  border-radius: 0;
  margin-top: auto;
  display: block;
  background: transparent;
}
.hhnew .step-video { background: #000; }

/* RESULTS */
.hhnew .section-results {
  background:#fff;
}
.hhnew .two-col { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: start; }
.hhnew .scope-card,
.hhnew .video-card {
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
}
.hhnew .scope-card img { width: 100%; display: block; height: auto; }
.hhnew .scope-footer { padding: 14px 16px; }
.hhnew .scope-footer p { font-size: 0.9rem; color: var(--hh-muted); }
.hhnew .video-card video {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  background: #000;
}
.hhnew .video-footer { padding: 14px 16px; }
.hhnew .video-footer p { font-size: 0.9rem; color: var(--hh-muted); line-height: 1.55; }

/* WHY IT WORKS */
.hhnew .section-cream .section-h2 { margin-bottom: 28px; }
.hhnew .featured {
  background: #3982E7;
  border-radius: 20px;
  padding: 28px 32px;
  margin: 0 0 32px;
  display: flex;
  gap: 32px;
  align-items: center;
}
.hhnew .feat-stat {
  flex-shrink: 0;
  background: #86B2F0;
  border-radius: 18px;
  padding: 24px 28px;
  min-width: 190px;
  text-align: center;
}
.hhnew .stat-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
}
.hhnew .stat-n {
  font-family: var(--font-heading);
  font-size: 3rem;
  font-weight: 900;
  color: #fff;
  line-height: 1;
  flex-shrink: 0;
  
}
.hhnew .stat-l {
  font-family: var(--font-body);
  font-size: 0.88rem;
  font-weight: 700;
  color: #fff;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  line-height: 1.3;
  text-align: center;
}
.hhnew .stat-div { border-top: 1px solid #fff; margin: 16px 0; opacity: 0.9; }
.hhnew .feat-body { flex: 1; min-width: 0; }
.hhnew .feat-title {
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.hhnew .feat-title-text {
  font-size: 2rem;
  font-weight: 800;
  color: #fff;
  -webkit-text-stroke: 2px var(--hh-yellow);
  paint-order: stroke fill;
  line-height: 1.15;
}
.hhnew .feat-icon {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  width: 48px;
  height: 34px;
  color: var(--hh-yellow);
  line-height: 0;
}
.hhnew .feat-icon svg { width: 100%; height: 100%; display: block; }
.hhnew .feat-desc { font-size: 1.1rem;
  color: #fff;
  line-height: 1.65;
  font-weight: 600;}
.hhnew .pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.hhnew .pillar {
  border-radius: 12px;
  padding: 4px 8px 0;
  text-align: center;
}
.hhnew .pillar-icon {
  width: 48px;
  height: 42px;
  margin: 0 auto 14px;
  color: #7a7a7a;
  line-height: 0;
}
.hhnew .pillar-icon svg,
.hhnew .pillar-icon img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
}
.hhnew .pillar-title {
  font-size: 1rem;
  font-weight: 700;
  color: #3982E7;
  margin-bottom: 6px;
  text-align: center;
}
.hhnew .pillar-desc { font-size: 0.9rem; color: var(--hh-muted); line-height: 1.55; text-align: left; }

/* MID CTA */
.hhnew .section-mid-cta { padding: 40px 0; text-align: center; }
.hhnew .cta-btn {
  display: inline-block;
  background: var(--hh-dark);
  color: #fff;
  font-size: 15px;
  font-weight: 700;
  padding: 14px 36px;
  border-radius: 10px;
  text-decoration: none;
  transition: opacity 0.2s;
}
.hhnew .cta-btn:hover { opacity: 0.88; }

/* TESTIMONIALS */
.hhnew .section-testimonials .section-h2 { margin-bottom: 32px; }
.hhnew .testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  padding-right: 8px;
  padding-bottom: 8px;
}
.hhnew .t-card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1.5px solid var(--hh-dark);
  border-radius: 24px;
  padding: 28px 30px;
  box-shadow: 8px 8px 0 #d3d3d3;
}
.hhnew .stars {
  color: var(--hh-yellow);
  font-size: 15px;
  margin-bottom: 16px;
  letter-spacing: 3px;
  text-align: center;
}
.hhnew .t-text {
  font-size: 0.9rem;
  color: var(--hh-dark);
  line-height: 1.55;
  margin-bottom: 24px;
}
.hhnew .t-author {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: auto;
}
.hhnew .t-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}
.hhnew .t-name { font-size: 0.9rem; font-weight: 700; color: var(--hh-dark); line-height: 1.3; }
.hhnew .t-role { font-size: 0.85rem; color: var(--hh-dark); line-height: 1.35; }

/* PAGE TITLE (about, pricing) */
.hhnew .page-title {
  font-size: var(--hh-heading-xl);
  font-weight: 700;
  color: var(--hh-dark);
  line-height: 1.2;
}

/* CTA BANNER (new-home, about) */
.hhnew .cta-banner {
  background: var(--hh-yellow);
  padding: 56px 0;
  text-align: center;
}
.hhnew .cta-banner .cta-eyebrow {
  font-size: var(--hh-text-label);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #7a5c00;
  margin-bottom: 12px;
}
.hhnew .cta-banner .cta-h2 {
  font-size: var(--hh-heading-xl);
  font-weight: 700;
  color: var(--hh-dark);
  margin-bottom: 16px;
  line-height: 1.2;
}
.hhnew .cta-banner .cta-sub {
  font-size: var(--hh-text-base);
  color: var(--hh-muted);
  margin-bottom: 24px;
  line-height: 1.65;
  font-family: var(--font-body);
}
.hhnew .cta-banner .cta-btn {
  background: var(--hh-red);
  color: #fff;
  font-size: 15px;
  font-weight: 700;
  padding: 14px 36px;
  border-radius: 10px;
  margin-bottom: 10px;
}
.hhnew .cta-includes {
  display: flex;
  justify-content: center;
  gap: 20px;
  flex-wrap: wrap;
  margin-bottom: 22px;
}
.hhnew .cta-inc {
  font-size: var(--hh-text-sm);
  font-weight: 600;
  color: var(--hh-dark);
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
}
.hhnew .cta-check {
  color: var(--hh-blue);
  font-size: 1rem;
  font-weight: 800;
  font-family: var(--font-heading);
  line-height: 1;
}
.hhnew .cta-fine {
  font-size: var(--hh-text-label);
  color: rgba(0, 0, 0, 0.4);
  font-family: var(--font-body);
}

/* SITE FOOTER (footer-2.php) */
.hhnew .site-footer { background: var(--hh-dark); color: #cfcfcf; padding: 40px 28px 32px; text-align: center; }
.hhnew .site-footer .foot-logo { font-size: 18px; font-weight: 800; color: #fff; text-decoration: none; }
.hhnew .site-footer .foot-logo span { color: var(--hh-yellow); }
.hhnew .footer-links { display: flex; justify-content: center; flex-wrap: wrap; gap: 20px; margin: 18px 0; }
.hhnew .footer-links a { color: #cfcfcf; font-size: 13px; text-decoration: none; }
.hhnew .footer-links a:hover { color: var(--hh-yellow); }
.hhnew .footer-copy { font-size: 12px; color: #888; margin-top: 10px; }

/* RESPONSIVE */
@media (max-width: 900px) {
  .hhnew .steps { grid-template-columns: repeat(2, 1fr); }
  .hhnew .two-col { grid-template-columns: 1fr; }
  .hhnew .pillars { grid-template-columns: 1fr; }
  .hhnew .testimonials-grid { grid-template-columns: 1fr; }
  .hhnew .featured { flex-direction: column; text-align: left; align-items: stretch; }
  .hhnew .feat-title { justify-content: flex-start; }
  .hhnew .feat-stat { min-width: 0; }
  .hhnew .hero-body { top: 54%; width: 42%; left: 3%; z-index: 1; }
  .hhnew .hero-eyebrow { font-size: clamp(6px, 1.7vw, 11px); margin-bottom: clamp(2px, 0.8vw, 6px); }
  .hhnew .hero-sub { font-size: clamp(6.5px, 1.9vw, 12px); line-height: 1.4; margin-bottom: clamp(4px, 1.2vw, 10px); }
  .hhnew .hero-btn { font-size: clamp(6.5px, 1.9vw, 12px); padding: clamp(4px, 1vw, 8px) clamp(10px, 2.4vw, 18px); border-radius: 6px; }
  .hhnew .badges-bar {
    position: static;
    transform: none;
    padding: 16px 20px 0;
  }
  .hhnew .section-how { padding-top: 40px; }
  .hhnew .badge-img {
    height: 48px;
}
}
@media (max-width: 600px) {
  .hhnew .nav {
    padding: 6px 12px 10px;
    height: auto;
    min-height: 56px;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-start;
    gap: 8px 6px;
  }
  .hhnew .nav-logo {
    order: 1;
    width: auto;
    flex-shrink: 0;
  }
  .hhnew .nav-logo img {
    width: 110px;
    padding: 4px;
  }
  .hhnew .nav-cta {
    order: 2;
    flex-shrink: 0;
    font-size: 11px;
    padding: 6px 12px;
    margin-left: auto;
  }
  .hhnew .nav-links {
    order: 3;
    flex: none;
    width: 100%;
    flex-basis: 100%;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: center;
  }
  .hhnew .nav-links a {
    font-size: 14px;
    white-space: nowrap;
  }
  .hhnew .nav-login { margin-left: 0; }
  .hhnew .steps { grid-template-columns: 1fr; }
  .hhnew .badge-img { height: 48px; }
  .hhnew .badges-bar {
    position: static;
    transform: none;
    padding: 12px 12px 0;
    margin-bottom: 20px;
  }
  .hhnew .badges {
    gap: 10px;
    padding: 10px 16px;
    flex-wrap: nowrap;
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .hhnew .section-how { padding-top: 0px; }
  .hhnew-inner { padding: 0 20px; }
}

/* SKY BACKGROUND (about hero, alt sections, pricing catalog) */
.hhnew .bg-sky { background: var(--hh-sky); }

/* ABOUT PAGE (page-about2.php) */
.hhnew .page-hero { padding: 40px 0 32px; }
.hhnew .hero-top { display: flex; gap: 24px; align-items: flex-start; margin-bottom: 16px; }
.hhnew .page-hero .hero-img { width
  : 324px;
      height: 255px; border-radius: 10px; object-fit: cover; flex-shrink: 0; border: 2.5px solid var(--hh-blue); }
.hhnew .page-hero .hero-body { flex: 1; min-width: 0; position: static; width: auto; max-width: none; left: auto; top: auto; padding: 0; }
.hhnew .page-hero .page-title { margin-bottom: 16px; }
.hhnew .page-hero p { font-size: var(--hh-text-base); color: var(--hh-muted); line-height: 1.65; }
.hhnew .cred-row { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 16px; }
.hhnew .cred-tag { display: inline-flex; align-items: center; background: #fff; border: 1px solid var(--hh-blue); border-radius: 20px; padding: 6px 14px; font-size: var(--hh-text-ui); font-weight: 600; color: #1a7aab; white-space: nowrap; font-family: var(--font-heading); max-width: 100%; min-width: 0; }
.hhnew .divider { border: none; border-top: 0.5px solid #eee; margin: 0; }
.hhnew .story-body p { font-size: var(--hh-text-base); color: var(--hh-muted); line-height: 1.65; margin-bottom: 16px; }
.hhnew .pull-quote { border-left: 4px solid var(--hh-blue); padding: 12px 18px; margin: 24px 0; font-size: var(--hh-text-lg); font-style: italic; color: var(--hh-blue); font-weight: 600; line-height: 1.65; background: var(--hh-sky); border-radius: 0 8px 8px 0; font-family: var(--font-body); }
.hhnew .story-callouts { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 24px; }
.hhnew .callout-card { background: #fff; border: 0.5px solid #e5e5e5; border-radius: 10px; padding: 20px; }
.hhnew .callout-card-title { font-size: 1rem; font-weight: 700; color: var(--hh-dark); margin-bottom: 10px; }
.hhnew .callout-card-body { font-size: var(--hh-text-base); color: var(--hh-muted); line-height: 1.55; font-family: var(--font-body); }
.hhnew .approach-intro { font-size: var(--hh-text-lg); color: var(--hh-muted); line-height: 1.65; margin-top: 8px; margin-bottom: 24px; font-weight: 600; }
.hhnew .col-label { font-size: var(--hh-text-ui); font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--hh-blue); margin-bottom: 10px; }
.hhnew .col-body { font-size: var(--hh-text-base); color: var(--hh-muted); line-height: 1.65; font-family: var(--font-body); }
.hhnew .inclusive-layout { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: start; margin-top: 24px; }
.hhnew .tier-card { border-radius: 8px; padding: 16px 18px; margin-bottom: 12px; }
.hhnew .tier-card.t1 { background: #E8F5E9; border-left: 3px solid #4CAF50; }
.hhnew .tier-card.t2 { background: #FFF8E1; border-left: 3px solid #FFC107; }
.hhnew .tier-card.t3 { background: #FCE4EC; border-left: 3px solid #E91E63; margin-bottom: 0; }
.hhnew .tier-header { display: flex; flex-direction: column; gap: 4px; margin-bottom: 6px; }
.hhnew .tier-lbl { font-size: var(--hh-text-ui); font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; }
.hhnew .tier-lbl.t1 { color: #2E7D32; }
.hhnew .tier-lbl.t2 { color: #F57F17; }
.hhnew .tier-lbl.t3 { color: #AD1457; }
.hhnew .tier-name { font-size: var(--hh-heading-md); font-weight: 700; color: var(--hh-dark); }
.hhnew .tier-desc { font-size: var(--hh-text-base); color: var(--hh-muted); line-height: 1.55; font-family: var(--font-body); }
.hhnew .video-lbl { font-size: var(--hh-text-ui); font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--hh-blue); margin-bottom: 10px; }
.hhnew .video-wrapper { position: relative; border-radius: 10px; overflow: hidden; aspect-ratio: 16/9; background: #1a3a4a; display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 8px; }
.hhnew .video-wrapper iframe,
.hhnew .video-wrapper video { position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: 0; object-fit: cover; }
.hhnew .video-caption { margin-top: 10px; font-size: var(--hh-text-base); color: var(--hh-muted); font-style: italic; line-height: 1.55; }
/* PRICING PAGE (page-pricing2.php) */
.hhnew .page-header { text-align: center; padding-bottom: 8px; }
.hhnew .plan-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.hhnew .plan-card { background: #fff; border-radius: 14px; overflow: hidden; border: 1.5px solid #e0e8f0; display: grid; grid-template-rows: auto auto 1fr auto; }
.hhnew .plan-card.highlighted { border: 2.5px solid var(--hh-blue); box-shadow: 0 4px 24px rgba(41,171,226,0.15); }
.hhnew .highlight-bar { background: var(--hh-blue); color: #fff; text-align: center; font-size: var(--hh-text-ui); font-weight: 700; padding: 8px; letter-spacing: 0.06em; text-transform: uppercase; }
.hhnew .highlight-bar-empty { padding: 8px; visibility: hidden; font-size: var(--hh-text-ui); }
.hhnew .plan-header { padding: 24px 24px 18px; text-align: center; }
.hhnew .plan-name { font-size: var(--hh-text-ui); font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: #aaa; margin-bottom: 12px; }
.hhnew .plan-price { font-size: 34px; font-weight: 800; color: var(--hh-dark); line-height: 1; margin-bottom: 6px; }
.hhnew .plan-price span { font-size: var(--hh-text-base); font-weight: 500; color: #888; font-family: var(--font-body); }
.hhnew .plan-price-custom { font-size: 1.25rem; font-weight: 700; color: var(--hh-dark); margin: 10px 0 6px; }
.hhnew .plan-billing { font-size: var(--hh-text-sm); color: #888; font-family: var(--font-body); }
.hhnew .plan-divider { border: none; border-top: 0.5px solid #eee; }
.hhnew .plan-body { padding: 20px 24px; }
.hhnew .plan-desc { font-size: var(--hh-text-base); color: var(--hh-muted); line-height: 1.65; margin-bottom: 16px; font-family: var(--font-body); font-weight: 500;}
.hhnew .plan-features { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.hhnew .plan-features li { display: flex; gap: 10px; align-items: flex-start; font-size: var(--hh-text-base); color: var(--hh-dark); line-height: 1.55; font-family: var(--font-body); }
.hhnew .check { color: var(--hh-blue); font-weight: 800; flex-shrink: 0; font-size: 1.1rem; }
.hhnew .plan-footer { padding: 16px 24px 24px; }
.hhnew .plan-btn { display: block; width: 100%; text-align: center; font-size: 15px; font-weight: 700; padding: 14px; border-radius: 10px; text-decoration: none; background: var(--hh-blue); color: #fff; border: none; cursor: pointer; }
.hhnew .plan-btn.dark { background: var(--hh-dark); }
.hhnew .plan-fine { font-size: var(--hh-text-sm); color: #888; text-align: center; margin-top: 10px; font-family: var(--font-body); line-height: 1.5; }
.hhnew .section-catalog { border-top: 0.5px solid #eee; }
.hhnew .catalog-header { text-align: center; margin-bottom: 36px; }
.hhnew .catalog-header .section-h2 { margin-bottom: 16px; }
.hhnew .catalog-header p { font-size: var(--hh-text-base); color: var(--hh-muted); font-style: italic; line-height: 1.65; font-family: var(--font-body); }
.hhnew .binder-tabs { display: flex; gap: 0; align-items: flex-end; margin-bottom: 0; padding-left: 4px; }
.hhnew .binder-tab { position: relative; padding: 12px 24px 14px; font-size: var(--hh-text-base); font-weight: 500; cursor: pointer; border: 0.5px solid #ccd9e8; border-bottom: none; border-radius: 8px 8px 0 0; background: #dce8f2; color: var(--hh-muted); margin-right: 4px; bottom: -1px; transition: background 0.1s; display: flex; align-items: center; gap: 8px; }
.hhnew .binder-tab.active { background: #fff; color: var(--hh-dark); font-weight: 600; z-index: 2; border-color: #ccd9e8; padding-bottom: 16px; }
.hhnew .binder-tab:hover:not(.active) { background: #cfdcea; }
.hhnew .classroom-badge { font-size: var(--hh-text-ui); font-weight: 700; background: var(--hh-yellow); color: #633806; padding: 3px 8px; border-radius: 4px; letter-spacing: 0.03em; }
.hhnew .binder-content { background: #fff; border: 0.5px solid #ccd9e8; border-radius: 0 8px 8px 8px; padding: 24px; position: relative; z-index: 1; }
.hhnew .sub-nav { display: flex; gap: 0; margin-bottom: 0; border-bottom: 1.5px solid #e0e8f0; flex-wrap: wrap; }
.hhnew .sub-nav-item { font-size: 1.1rem; font-weight: 500; padding: 10px 18px; cursor: pointer; color: #888; border-bottom: 2px solid transparent; margin-bottom: -1.5px; white-space: nowrap; font-family: var(--font-body); }
.hhnew .sub-nav-item:hover:not(.active) { color: var(--hh-dark); }
.hhnew .sub-nav-item.active { color: var(--hh-blue); border-bottom-color: var(--hh-blue); }
.hhnew .sub-panel { display: none; }
.hhnew .sub-panel.active { display: block; }
.hhnew .access-row {     margin-top: 10px;display: flex; align-items: center; gap: 8px; margin-bottom: 16px; font-size: var(--hh-text-sm); color: #888; font-family: var(--font-body); }
.hhnew .access-pills { display: none; align-items: center; gap: 8px; }
.hhnew .access-pills.active { display: inline-flex; }
.hhnew .pill-web { background: var(--hh-sky); color: #185FA5; font-size: var(--hh-text-ui); font-weight: 700; padding: 3px 9px; border-radius: 10px; border: 0.5px solid #B5D4F4; font-family: var(--font-heading); }
.hhnew .pill-mobile { background: #EAF3DE; color: #3B6D11; font-size: var(--hh-text-ui); font-weight: 700; padding: 3px 9px; border-radius: 10px; font-family: var(--font-heading); }
.hhnew .product-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.hhnew .product-card { background: #f5f8fb; border: 0.5px solid #d0e4f0; border-radius: 8px; overflow: hidden; cursor: pointer; }
.hhnew .product-card:hover { border-color: var(--hh-blue); box-shadow: 0 2px 8px rgba(41,171,226,0.1); }
.hhnew .product-ph { width: 100%; aspect-ratio: 16/10; background: #dceaf5; display: flex; align-items: center; justify-content: center; }
.hhnew .product-ph span { font-size: var(--hh-text-sm); color: #aac4d8; text-align: center; padding: 0 8px; font-family: var(--font-body); }
.hhnew .product-img { width: 100%; aspect-ratio: 16/10; object-fit: cover; display: block; }
.hhnew .product-name { font-size: var(--hh-text-base); font-weight: 600; color: var(--hh-dark); padding: 10px 12px; line-height: 1.4; }
.hhnew .tab-note { font-size: var(--hh-text-sm); color: #888; margin-top: 14px; font-style: italic; font-family: var(--font-body); line-height: 1.55; }
.hhnew .panel { display: none; }
.hhnew .panel.active { display: block; }
.hhnew .student-desc { font-size: var(--hh-text-base); color: var(--hh-muted); margin-bottom: 14px; line-height: 1.65; }
.hhnew .bottom-note { text-align: center; padding: 32px 0 48px; background: #fff; }
.hhnew .bottom-note p { font-size: var(--hh-text-base); color: var(--hh-muted); font-family: var(--font-body); }
.hhnew .bottom-note a { color: var(--hh-blue); text-decoration: none; font-weight: 600; }
.hhnew .hh-product-popup { display: none; position: fixed; inset: 0; z-index: 99999; background: rgba(0,0,0,0.6); align-items: center; justify-content: center; padding: 24px; }
.hhnew .hh-product-popup.is-open { display: flex; }
.hhnew .hh-product-popup__inner { width: 100%; max-width: 560px; }
.hhnew .hh-product-popup__content { position: relative; background: #fff; border-radius: 14px; padding: 28px; max-height: 85vh; overflow-y: auto; box-shadow: 0 20px 60px rgba(0,0,0,0.3); }
.hhnew .hh-product-popup__close { position: absolute; top: 10px; right: 12px; width: 32px; height: 32px; border: none; background: var(--hh-sky); color: var(--hh-dark); font-size: 22px; line-height: 1; border-radius: 50%; cursor: pointer; display: flex; align-items: center; justify-content: center; }
.hhnew .hh-product-popup__close:hover { background: var(--hh-blue); color: #fff; }
.hhnew .hh-product-popup__body .hh-popup-content { display: block !important; }
.hhnew .hh-popup-img { width: 100%; border-radius: 10px; display: block; margin-bottom: 16px; }
.hhnew .hh-popup-title { font-size: 1.25rem; font-weight: 700; color: var(--hh-dark); margin-bottom: 12px; }
.hhnew .hh-popup-desc { font-size: var(--hh-text-base); color: var(--hh-muted); line-height: 1.65; font-family: var(--font-body); }
.hhnew .hh-product-trigger { cursor: pointer; }

@media (max-width: 700px) {
  .hhnew .plan-grid { grid-template-columns: 1fr; }
  .hhnew .product-grid { grid-template-columns: repeat(2, 1fr); }
  .hhnew .binder-tab { padding: 10px 16px 12px; font-size: var(--hh-text-sm); }
}

@media (max-width: 768px) {
  .hhnew .cred-tag { white-space: normal; line-height: 1.35; }
}

@media (max-width: 600px) {
  .hhnew .hero-top { flex-direction: column; }
  .hhnew .page-hero .hero-img { width: 100%; height: 200px; }
  .hhnew .cred-row { padding-left: 0; }
  .hhnew .story-callouts { grid-template-columns: 1fr; }
  .hhnew .inclusive-layout { grid-template-columns: 1fr; }
}
.elementor-button-text {
  display: inline-block;
  color: #fff !important;
}