/* ============================================================
   PERLYN-IT | css/template-header.css v4.0
   All header styles — announcement bar, topbar, navbar,
   mega menu (Services + Academy), mobile drawer,
   WhatsApp floating widget, Google Translate integration.
   Prefix: pit-
   Save to: css/template-header.css
   Depends on: css/main.css (for CSS variables)
   ============================================================ */

/* ── ANNOUNCEMENT BAR ─────────────────────────────────────── */
.pit-ann {
  position: relative;
  background: var(--bg-secondary);
  border-bottom: 1px solid rgba(13,115,119,0.30);
  height: 32px;
  display: flex;
  align-items: center;
  overflow: hidden;
  z-index: 1001;
}

.pit-ann-wrap {
  flex: 1;
  overflow: hidden;
  height: 100%;
  display: flex;
  align-items: center;
  mask-image: linear-gradient(90deg, transparent 0%, #000 4%, #000 96%, transparent 100%);
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 4%, #000 96%, transparent 100%);
}

.pit-ann-track {
  display: flex;
  align-items: center;
  white-space: nowrap;
  gap: 0;
  animation: pitMarquee 40s linear infinite;
}

@keyframes pitMarquee {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

.pit-ann-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-body);
  font-size: 0.72rem;
  font-weight: 500;
  color: var(--text-secondary);
  letter-spacing: 0.03em;
  padding: 0 1.25rem;
}

.pit-ann-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--accent-teal-light);
  flex-shrink: 0;
}

.pit-ann-sep {
  font-size: 0.7rem;
  color: var(--text-muted);
  padding: 0 0.25rem;
}

.pit-ann-close {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  margin-right: 6px;
  border-radius: 4px;
  transition: color 0.2s, background 0.2s;
}
.pit-ann-close:hover {
  color: var(--text-primary);
  background: rgba(255,255,255,0.08);
}

.pit-ann.pit-ann--hidden {
  height: 0;
  opacity: 0;
  pointer-events: none;
  overflow: hidden;
  transition: height 0.35s ease, opacity 0.35s ease;
}

/* ── TOPBAR ───────────────────────────────────────────────── */
.pit-topbar {
  background: rgba(10,15,30,0.98);
  border-bottom: 1px solid var(--border-subtle);
  height: 38px;
  position: sticky;
  top: 0;
  z-index: 1002;
}

.pit-topbar-inner {
  width: 100%;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--container-pad);
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.pit-topbar-left,
.pit-topbar-right {
  display: flex;
  align-items: center;
  gap: 0;
}

.pit-topbar-link {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--font-body);
  font-size: 0.78rem;
  color: var(--text-secondary);
  text-decoration: none;
  padding: 0 0.75rem;
  height: 38px;
  transition: color 0.2s, background 0.2s;
  white-space: nowrap;
}
.pit-topbar-link:hover {
  color: var(--text-primary);
  background: rgba(255,255,255,0.05);
}
.pit-topbar-link svg { color: var(--text-muted); flex-shrink: 0; }
.pit-topbar-link:hover svg { color: var(--accent-teal-light); }

.pit-topbar-link--wa svg { color: #25D366 !important; }
.pit-topbar-link--wa:hover { background: rgba(37,211,102,0.10); }

.pit-tb-sep {
  display: block;
  width: 1px;
  height: 14px;
  background: var(--border-subtle);
  flex-shrink: 0;
}

.pit-topbar-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: var(--font-heading);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  color: var(--accent-gold);
  border: 1px solid rgba(201,168,76,0.25);
  border-radius: 999px;
  padding: 3px 12px;
  white-space: nowrap;
}

.pit-badge-pulse {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent-gold);
  position: relative;
  flex-shrink: 0;
}
.pit-badge-pulse::after {
  content: '';
  position: absolute;
  inset: -3px;
  border-radius: 50%;
  border: 1px solid rgba(201,168,76,0.50);
  animation: pitPulse 2s ease-in-out infinite;
}
@keyframes pitPulse {
  0%, 100% { opacity: 0.4; transform: scale(1); }
  50%       { opacity: 1;   transform: scale(1.4); }
}

.pit-topbar-socials {
  display: flex;
  align-items: center;
}

.pit-topbar-social {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 38px;
  color: var(--text-muted);
  text-decoration: none;
  transition: color 0.2s;
}
.pit-topbar-social:hover { color: var(--accent-teal-light); }

/* ── GOOGLE TRANSLATE INTEGRATION ─────────────────────────── */
/*
  The Google Translate toolbar is hidden visually.
  Our custom pit-lang-btn triggers it via JS.
  The #google_translate_element at the bottom of the page
  hosts the actual widget which is moved off-screen.
*/

/* Hide the Google Translate banner/toolbar injected into the page */
.goog-te-banner-frame,
.goog-te-balloon-frame {
  display: none !important;
}

/* Remove the body top margin Google Translate adds */
body {
  top: 0 !important;
}

/* Suppress Google's iframe overlay */
.skiptranslate {
  display: none !important;
}

/*
  Google Translate requires its host element to be in the DOM flow.
  We position it off-screen instead of display:none so GT can initialize.
*/
#google_translate_element {
  position: fixed;
  top: -9999px;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
}

/* Our custom translate trigger button */
.pit-lang-wrap { position: relative; }

.pit-lang-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: none;
  border: none;
  font-family: var(--font-body);
  font-size: 0.78rem;
  color: var(--text-secondary);
  cursor: pointer;
  padding: 0 0.75rem;
  height: 38px;
  transition: color 0.2s;
  white-space: nowrap;
}
.pit-lang-btn:hover { color: var(--text-primary); }
.pit-lang-btn svg { color: var(--text-muted); flex-shrink: 0; }

.pit-lang-arrow {
  transition: transform 0.2s ease;
}
.pit-lang-btn.pit-lang-active .pit-lang-arrow {
  transform: rotate(180deg);
}

/* Translate language picker dropdown (custom UI over GT) */
.pit-lang-picker {
  position: absolute;
  top: calc(100% + 4px);
  right: 0;
  min-width: 200px;
  max-height: 320px;
  overflow-y: auto;
  background: var(--bg-card);
  border: 1px solid var(--border-card);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card-hover);
  list-style: none;
  padding: 0.4rem 0;
  z-index: 9999;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px);
  transition: opacity 0.2s ease, transform 0.2s ease, visibility 0s linear 0.2s;
}
.pit-lang-picker.pit-lang-picker--open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  transition: opacity 0.2s ease, transform 0.2s ease, visibility 0s;
}

/* Scrollbar styling for picker */
.pit-lang-picker::-webkit-scrollbar { width: 4px; }
.pit-lang-picker::-webkit-scrollbar-track { background: transparent; }
.pit-lang-picker::-webkit-scrollbar-thumb { background: var(--border-card); border-radius: 4px; }

.pit-lang-picker-item {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  background: none;
  border: none;
  text-align: left;
  font-family: var(--font-body);
  font-size: 0.825rem;
  color: var(--text-secondary);
  padding: 0.45rem 1rem;
  cursor: pointer;
  transition: color 0.15s, background 0.15s;
}
.pit-lang-picker-item:hover,
.pit-lang-picker-item.pit-lang-picker-item--active {
  color: var(--text-primary);
  background: rgba(255,255,255,0.06);
}
.pit-lang-picker-item--active { color: var(--accent-teal-light) !important; }

.pit-lang-picker-item .pit-lang-flag {
  font-size: 1rem;
  line-height: 1;
  flex-shrink: 0;
}

/* "Restore to English" button at top of picker */
.pit-lang-restore-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  background: rgba(13,115,119,0.08);
  border: none;
  border-bottom: 1px solid var(--border-subtle);
  text-align: left;
  font-family: var(--font-body);
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--accent-teal-light);
  padding: 0.55rem 1rem;
  cursor: pointer;
  transition: background 0.15s;
  margin-bottom: 0.25rem;
}
.pit-lang-restore-btn:hover { background: rgba(13,115,119,0.14); }

/* ── NAVBAR ───────────────────────────────────────────────── */
.pit-navbar {
  position: sticky;
  top: 38px;
  z-index: 1000;
  background: rgba(10,15,30,0.96);
  border-bottom: 1px solid var(--border-subtle);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  transition: box-shadow 0.25s ease, background 0.25s ease;
}

/* Gold shimmer line */
.pit-navbar::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1.5px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(201,168,76,0.05) 10%,
    rgba(201,168,76,0.70) 30%,
    rgba(224,191,111,1.00) 50%,
    rgba(201,168,76,0.70) 70%,
    rgba(201,168,76,0.05) 90%,
    transparent 100%
  );
  background-size: 300% 100%;
  background-position: 200% 0;
  animation: pitGoldSweep 2s cubic-bezier(0.22,1,0.36,1) 0.4s forwards,
             pitGoldBreathe 6s ease-in-out 2.4s infinite;
  pointer-events: none;
}
@keyframes pitGoldSweep {
  0%   { background-position: 200% 0; opacity: 0; }
  15%  { opacity: 1; }
  100% { background-position: -100% 0; opacity: 1; }
}
@keyframes pitGoldBreathe {
  0%, 100% { opacity: 0.55; }
  50%       { opacity: 1; }
}

.pit-navbar.pit-scrolled {
  box-shadow: 0 2px 32px rgba(0,0,0,0.60);
  background: rgba(8,13,26,0.98);
}

.pit-navbar-inner {
  width: 100%;
  max-width: var(--container-max);
  margin: 0 auto;
  padding: 0 var(--container-pad);
  display: flex;
  align-items: center;
  gap: 1.5rem;
  height: 72px;
}

/* ── BRAND ────────────────────────────────────────────────── */
.pit-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  flex-shrink: 0;
  transition: opacity 0.2s;
}
.pit-brand:hover { opacity: 0.88; }

.pit-brand-logo {
  width: 40px;
  height: 40px;
  object-fit: contain;
  border-radius: var(--radius-sm);
  flex-shrink: 0;
  transition: transform 0.2s;
  display: block;
}
.pit-brand:hover .pit-brand-logo { transform: scale(1.05); }

.pit-brand-logo--sm {
  width: 34px;
  height: 34px;
}

/* Keep .pit-brand-mark for backwards compatibility if referenced elsewhere */
.pit-brand-mark {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-sm);
  background: var(--gradient-teal);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: transform 0.2s;
}
.pit-brand:hover .pit-brand-mark { transform: scale(1.05); }
.pit-brand-mark span {
  font-family: var(--font-heading);
  font-size: 0.875rem;
  font-weight: 800;
  color: #fff;
}
.pit-brand-mark--sm {
  width: 34px;
  height: 34px;
}
.pit-brand-mark--sm span { font-size: 0.8rem; }

.pit-brand-text {
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.pit-brand-name {
  font-family: var(--font-heading);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1;
}
.pit-brand-tagline {
  font-family: var(--font-body);
  font-size: 0.6rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  color: var(--text-muted);
  line-height: 1;
}

/* ── DESKTOP NAV LIST ─────────────────────────────────────── */
.pit-nav-list {
  display: flex;
  align-items: stretch;
  list-style: none;
  margin: 0;
  padding: 0;
  flex: 1;
  justify-content: center;
  height: 100%;
  gap: 0;
}

.pit-nav-item {
  position: relative;
  display: flex;
  align-items: center;
}

.pit-nav-link {
  display: flex;
  align-items: center;
  gap: 4px;
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--text-secondary);
  text-decoration: none;
  padding: 0.55rem 0.65rem;
  border-radius: var(--radius-md);
  white-space: nowrap;
  position: relative;
  transition: color 0.2s, background 0.2s;
}
.pit-nav-link::after {
  content: '';
  position: absolute;
  bottom: 5px;
  left: 0.65rem;
  right: 0.65rem;
  height: 1.5px;
  background: var(--gradient-teal);
  border-radius: 2px;
  transform: scaleX(0);
  transition: transform 0.25s ease;
}
.pit-nav-link:hover,
.pit-nav-link.pit-active {
  color: var(--text-primary);
  background: rgba(255,255,255,0.06);
}
.pit-nav-link:hover::after,
.pit-nav-link.pit-active::after { transform: scaleX(1); }

/* Academy nav link - teal tint to stand out */
.pit-nav-link--academy {
  color: var(--accent-teal-light);
}
.pit-nav-link--academy:hover {
  color: var(--text-primary);
}

.pit-nav-arrow {
  color: var(--text-muted);
  flex-shrink: 0;
  transition: transform 0.2s ease;
}
.pit-has-mega.pit-mega-open .pit-nav-arrow { transform: rotate(180deg); }

/* ── MEGA MENU BASE ───────────────────────────────────────── */
.pit-mega {
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%);
  width: 760px;
  background: var(--bg-card);
  border: 1px solid var(--border-card);
  border-radius: var(--radius-lg);
  box-shadow: 0 16px 64px rgba(0,0,0,0.55);
  opacity: 0;
  visibility: hidden;
  transform: translateX(-50%) translateY(-10px);
  transition: opacity 0.25s ease, transform 0.25s ease, visibility 0s linear 0.25s;
  pointer-events: none;
  z-index: 999;
}

.pit-has-mega.pit-mega-open .pit-mega {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
  pointer-events: all;
  transition: opacity 0.25s ease, transform 0.25s ease, visibility 0s;
}

.pit-mega-inner { padding: 1.75rem; }

.pit-mega-hd {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 1.25rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid var(--border-subtle);
}

.pit-mega-eyebrow {
  display: block;
  font-family: var(--font-body);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent-teal-light);
  margin-bottom: 0.35rem;
}

.pit-mega-title {
  font-family: var(--font-heading);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0 0 0.35rem;
}

.pit-mega-sub {
  font-size: 0.8rem;
  color: var(--text-muted);
  margin: 0;
}

.pit-mega-all-link {
  font-family: var(--font-body);
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--accent-teal-light);
  text-decoration: none;
  white-space: nowrap;
  padding: 0.4rem 0.85rem;
  border: 1px solid rgba(13,115,119,0.35);
  border-radius: var(--radius-full);
  transition: background 0.2s, border-color 0.2s;
  flex-shrink: 0;
  margin-top: 4px;
}
.pit-mega-all-link:hover {
  background: rgba(13,115,119,0.12);
  border-color: var(--accent-teal-light);
}

/* Services mega grid */
.pit-mega-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.6rem;
}

.pit-mega-card {
  display: flex;
  align-items: flex-start;
  gap: 0.85rem;
  padding: 0.85rem 1rem;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  text-decoration: none;
  transition: background 0.2s, border-color 0.2s;
}
.pit-mega-card:hover {
  background: rgba(255,255,255,0.04);
  border-color: var(--border-accent);
}

.pit-mega-card-icon {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-sm);
  flex-shrink: 0;
  background: rgba(13,115,119,0.12);
  border: 1px solid rgba(13,115,119,0.20);
  position: relative;
}
.pit-mega-card-icon--1::before { content: ''; position: absolute; inset: 7px; border: 1.5px solid var(--accent-teal-light); border-radius: 2px; }
.pit-mega-card-icon--2::before { content: ''; position: absolute; inset: 9px; border-radius: 50%; border: 1.5px solid var(--accent-teal-light); }
.pit-mega-card-icon--3::before { content: ''; position: absolute; inset: 8px 7px; border: 1.5px solid var(--accent-teal-light); border-radius: 1px; }
.pit-mega-card-icon--4::before { content: ''; position: absolute; inset: 8px; border-left: 1.5px solid var(--accent-teal-light); border-bottom: 1.5px solid var(--accent-teal-light); transform: rotate(45deg) scale(0.8); }
.pit-mega-card-icon--5::before { content: ''; position: absolute; inset: 8px; border: 1.5px solid var(--accent-teal-light); border-radius: 50%; }

.pit-mega-card-body { display: flex; flex-direction: column; gap: 3px; }
.pit-mega-card-title {
  font-family: var(--font-heading);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.3;
}
.pit-mega-card-desc {
  font-size: 0.78rem;
  color: var(--text-secondary);
  line-height: 1.5;
}

/* ── ACADEMY MEGA MENU ────────────────────────────────────── */
.pit-mega--academy {
  width: 1020px;
}

.pit-mega-academy-cols {
  display: grid;
  grid-template-columns: 1fr 1px 1fr 1px 1fr;
  gap: 0;
}

.pit-mega-academy-col {
  padding: 0 1.5rem;
}
.pit-mega-academy-col:first-child { padding-left: 0; }
.pit-mega-academy-col:last-child  { padding-right: 0; }

.pit-mega-academy-divider {
  background: var(--border-subtle);
  align-self: stretch;
}

/* Category header inside Academy mega */
.pit-mega-cat-hd {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 0.75rem;
  padding-bottom: 0.6rem;
  border-bottom: 1px solid var(--border-subtle);
}

.pit-mega-cat-icon {
  width: 26px;
  height: 26px;
  border-radius: var(--radius-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.pit-mega-cat-icon--tourism {
  background: rgba(201,168,76,0.12);
  border: 1px solid rgba(201,168,76,0.25);
  color: var(--accent-gold);
}
.pit-mega-cat-icon--it {
  background: rgba(13,115,119,0.12);
  border: 1px solid rgba(13,115,119,0.25);
  color: var(--accent-teal-light);
}

.pit-mega-cat-label {
  font-family: var(--font-heading);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-primary);
}

/* Program links inside Academy mega */
.pit-mega-academy-links {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.pit-mega-prog-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 0.5rem 0.6rem;
  border-radius: var(--radius-sm);
  text-decoration: none;
  transition: background 0.2s;
}
.pit-mega-prog-link:hover {
  background: rgba(255,255,255,0.05);
}

.pit-mega-prog-name {
  font-family: var(--font-body);
  font-size: 0.835rem;
  font-weight: 500;
  color: var(--text-secondary);
  line-height: 1.4;
  transition: color 0.2s;
}
.pit-mega-prog-link:hover .pit-mega-prog-name {
  color: var(--text-primary);
}

.pit-mega-prog-badge {
  font-family: var(--font-body);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  padding: 2px 7px;
  border-radius: var(--radius-full);
  white-space: nowrap;
  flex-shrink: 0;
}
.pit-mega-prog-badge--enrolling {
  background: rgba(37,211,102,0.15);
  color: #25D366;
  border: 1px solid rgba(37,211,102,0.30);
}
.pit-mega-prog-badge--soon {
  background: rgba(155,175,202,0.10);
  color: var(--text-muted);
  border: 1px solid rgba(155,175,202,0.15);
}
.pit-mega-prog-badge--gold {
  background: rgba(201,168,76,0.15);
  color: var(--accent-gold, #C9A84C);
  border: 1px solid rgba(201,168,76,0.30);
}

.pit-mega-cat-icon--services {
  background: rgba(99,102,241,0.12);
  border: 1px solid rgba(99,102,241,0.25);
  color: #818cf8;
}

.pit-mega-prog-link--view-all .pit-mega-prog-name {
  color: var(--accent-teal-light);
  font-size: 0.8rem;
  opacity: 0.8;
}
.pit-mega-prog-link--view-all:hover .pit-mega-prog-name {
  opacity: 1;
}

/* ── DESKTOP CTA + HAMBURGER ──────────────────────────────── */
.pit-nav-actions {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-shrink: 0;
}

.pit-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--gradient-teal);
  color: #fff;
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 600;
  padding: 0.55rem 1.35rem;
  border-radius: var(--radius-full);
  text-decoration: none;
  white-space: nowrap;
  flex-shrink: 0;
  box-shadow: 0 0 28px rgba(13,115,119,0.28);
  transition: transform 0.2s, box-shadow 0.2s, opacity 0.2s;
}
.pit-cta-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 0 40px rgba(13,115,119,0.45);
  opacity: 0.92;
  color: #fff;
}
.pit-cta-btn--full { width: 100%; justify-content: center; }

/* Hamburger */
.pit-hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 40px;
  height: 40px;
  background: rgba(255,255,255,0.07);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  cursor: pointer;
  flex-shrink: 0;
  transition: background 0.2s, border-color 0.2s;
}
.pit-hamburger:hover { background: rgba(255,255,255,0.12); border-color: var(--border-accent); }

.pit-ham {
  display: block;
  width: 20px;
  height: 2px;
  background: var(--text-secondary);
  border-radius: 2px;
  transition: transform 0.32s ease, opacity 0.32s ease;
  transform-origin: center;
}
.pit-hamburger[aria-expanded="true"] .pit-ham-1 { transform: translateY(7px) rotate(45deg); }
.pit-hamburger[aria-expanded="true"] .pit-ham-2 { opacity: 0; transform: scaleX(0); }
.pit-hamburger[aria-expanded="true"] .pit-ham-3 { transform: translateY(-7px) rotate(-45deg); }

/* ── MOBILE OVERLAY ───────────────────────────────────────── */
.pit-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(4,10,24,0.70);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  z-index: 1099;
  opacity: 0;
  transition: opacity 0.3s ease;
}
.pit-overlay.pit-open {
  display: block;
  opacity: 1;
}

/* ── MOBILE DRAWER ────────────────────────────────────────── */
.pit-drawer {
  position: fixed;
  top: 0;
  right: 0;
  width: min(320px, 90vw);
  height: 100dvh;
  background: var(--bg-secondary);
  border-left: 1px solid var(--border-card);
  z-index: 1100;
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.35s cubic-bezier(0.32,0,0.07,1);
  overflow-y: auto;
  overscroll-behavior: contain;
}
.pit-drawer.pit-open {
  transform: translateX(0);
}

.pit-drawer-hd {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.1rem 1.25rem;
  border-bottom: 1px solid var(--border-subtle);
  flex-shrink: 0;
}

.pit-drawer-close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  color: var(--text-secondary);
  cursor: pointer;
  transition: color 0.2s, background 0.2s;
}
.pit-drawer-close:hover { color: var(--text-primary); background: rgba(255,255,255,0.12); }

.pit-mob-list {
  list-style: none;
  padding: 0.75rem 0;
  margin: 0;
  flex: 1;
}

.pit-mob-item { border-bottom: 1px solid var(--border-subtle); }
.pit-mob-item:last-child { border-bottom: none; }

.pit-mob-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 0.95rem 1.25rem;
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--text-secondary);
  text-decoration: none;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  transition: color 0.2s, background 0.2s;
}
.pit-mob-link:hover,
.pit-mob-link.pit-active {
  color: var(--text-primary);
  background: rgba(255,255,255,0.04);
}
.pit-mob-link.pit-active { color: var(--accent-teal-light); }

.pit-mob-arrow {
  color: var(--text-muted);
  flex-shrink: 0;
  transition: transform 0.25s ease;
}
.pit-mob-acc[aria-expanded="true"] .pit-mob-arrow { transform: rotate(180deg); }

.pit-mob-sub {
  list-style: none;
  padding: 0;
  margin: 0;
  background: rgba(0,0,0,0.15);
  border-top: 1px solid var(--border-subtle);
}
.pit-mob-sub[hidden] { display: none; }

.pit-mob-sub-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 0.75rem 1.25rem 0.75rem 2rem;
  font-family: var(--font-body);
  font-size: 0.875rem;
  color: var(--text-secondary);
  text-decoration: none;
  border-bottom: 1px solid var(--border-subtle);
  transition: color 0.2s, background 0.2s;
}
.pit-mob-sub-link:last-child { border-bottom: none; }
.pit-mob-sub-link:hover { color: var(--text-primary); background: rgba(255,255,255,0.04); }

/* Muted sub-links for "Coming Soon" programs */
.pit-mob-sub-link--muted {
  opacity: 0.70;
}

/* Mobile category label inside sub-menu */
.pit-mob-sub-cat {
  display: block;
  padding: 0.5rem 1.25rem 0.35rem 1.25rem;
  font-family: var(--font-heading);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--accent-teal-light);
  background: rgba(13,115,119,0.07);
  border-bottom: 1px solid var(--border-subtle);
}

/* Mobile badge (Enrolling / Soon) */
.pit-mob-badge {
  font-size: 0.62rem;
  font-weight: 700;
  padding: 1px 6px;
  border-radius: var(--radius-full);
  background: rgba(155,175,202,0.12);
  color: var(--text-muted);
  flex-shrink: 0;
  white-space: nowrap;
}
.pit-mob-badge--enrolling {
  background: rgba(37,211,102,0.15);
  color: #25D366;
}

/* Drawer contact */
.pit-drawer-contact {
  padding: 1rem 1.25rem;
  border-top: 1px solid var(--border-subtle);
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  flex-shrink: 0;
}

.pit-drawer-contact-link {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-body);
  font-size: 0.85rem;
  color: var(--text-secondary);
  text-decoration: none;
  padding: 0.5rem 0.75rem;
  border-radius: var(--radius-md);
  transition: color 0.2s, background 0.2s;
}
.pit-drawer-contact-link:hover { color: var(--text-primary); background: rgba(255,255,255,0.06); }
.pit-drawer-contact-link svg { color: var(--text-muted); flex-shrink: 0; }

.pit-drawer-wa svg { color: #25D366 !important; }
.pit-drawer-wa:hover { background: rgba(37,211,102,0.10) !important; }

.pit-drawer-cta {
  padding: 1rem 1.25rem;
  flex-shrink: 0;
}

/* Prevent blank space before template injects into <header> tag */
header[data-template],
header:empty {
  display: none;
}

/* ── REDUCED MOTION ───────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .pit-ann-track { animation: none; }
  .pit-navbar::before { animation: none; }
  .pit-badge-pulse::after { animation: none; }
  .pit-wa-fab-dot { animation: none; }
  .pit-wa-popup,
  .pit-wa-fab-icon { transition: none; }
}

/* ================================================================
   RESPONSIVE BREAKPOINTS — added v4.1
   These were missing and caused: no hamburger, no mobile menu,
   CTA overflow, topbar clipping on small screens.
   ================================================================ */

/* ── DESKTOP: always show CTA button ──────────────────────────── */
@media (min-width: 641px) {
  .pit-nav-actions .pit-cta-btn {
    display: inline-flex;
  }
}

/* ── 1280px — start compressing nav link padding ──────────────── */
@media (max-width: 1280px) {
  .pit-nav-link {
    padding: 0.55rem 0.5rem;
    font-size: 0.82rem;
  }
  .pit-cta-btn {
    padding: 0.5rem 1.1rem;
    font-size: 0.82rem;
  }
}

/* ── 1024px — hide topbar badge, compress social icons ────────── */
@media (max-width: 1024px) {
  .pit-topbar-badge { display: none; }
  .pit-topbar-socials { display: none; }
  .pit-tb-sep:last-of-type { display: none; }
}

/* ── 900px — switch to mobile nav ─────────────────────────────── */
@media (max-width: 900px) {

  /* Hide desktop nav list */
  .pit-nav-list {
    display: none;
  }

  /* Show hamburger button */
  .pit-hamburger {
    display: flex;
  }

  /* Hide CTA button text on very small screens — keep hamburger only */
  /* (CTA stays visible until 640px) */

  /* Navbar inner: brand + actions only */
  .pit-navbar-inner {
    gap: 1rem;
  }

  /* Topbar: hide phone on mid screens, keep email + WA */
  #pit-tb-phone {
    display: none;
  }
}

/* ── 640px — full mobile ───────────────────────────────────────── */
@media (max-width: 640px) {

  /* Hide topbar entirely on very small screens */
  .pit-topbar {
    display: none;
  }

  /* Navbar becomes full-width brand + hamburger only */
  .pit-navbar-inner {
    height: 60px;
    padding: 0 1rem;
    gap: 0.75rem;
  }

  /* Hide desktop CTA on mobile — CTA is inside drawer */
  .pit-nav-actions .pit-cta-btn {
    display: none;
  }

  /* Brand text — slightly smaller */
  .pit-brand-name {
    font-size: 0.95rem;
  }
  .pit-brand-tagline {
    display: none;
  }
  .pit-brand-mark {
    width: 34px;
    height: 34px;
  }
  .pit-brand-mark span {
    font-size: 0.78rem;
  }

  /* Announcement bar — smaller font on mobile */
  .pit-ann {
    height: 28px;
  }
  .pit-ann-item {
    font-size: 0.68rem;
    padding: 0 0.9rem;
  }

  /* Mega menus never show on mobile (drawer handles navigation) */
  .pit-mega {
    display: none !important;
  }

  /* Language button — hide label text, keep icon */
  #pit-lang-label {
    display: none;
  }
  .pit-lang-arrow {
    display: none;
  }
}

/* ── 400px — very small phones ─────────────────────────────────── */
@media (max-width: 400px) {
  .pit-navbar-inner {
    padding: 0 0.75rem;
  }
  .pit-ann {
    height: 26px;
  }
  .pit-ann-item {
    font-size: 0.65rem;
    padding: 0 0.75rem;
  }
}

/* ── GOOGLE TRANSLATE FLICKER FIX ─────────────────────────── */
/*
  GT wraps translated content in <font> tags and temporarily
  removes/re-adds elements causing layout flicker on the topbar.
  These rules suppress the visual artifacts.
*/
.goog-te-banner-frame  { display: none !important; }
.goog-te-balloon-frame { display: none !important; }
.skiptranslate         { display: none !important; }

/* Prevent GT from pushing body down */
body { top: 0 !important; }

/* Suppress the GT font-size change on translated elements in topbar */
.pit-topbar font,
.pit-navbar font {
  font-size: inherit !important;
  color: inherit !important;
  vertical-align: baseline !important;
}

/* Prevent topbar repaint flash during translation */
.pit-topbar,
.pit-navbar {
  will-change: auto;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
