/* ============================================================
   TravHawk Theme Override CSS - v21.0
   Complete rebuild - all styles preserved + new fixes
   Colors: Turquoise #57d6e2, Denim #176eba, Navy #0b1d3a
   Page templates max-width: 1540px
   ============================================================ */

/* === GLOBAL RESET & BASE === */
*, *::before, *::after { box-sizing: border-box; }

body { font-family: 'Plus Jakarta Sans', 'DM Sans', sans-serif; margin: 0; padding: 0; }

/* Admin bar margin fix - home page only keeps normal margin */
body.admin-bar:not(.home) { margin-top: 0 !important; }

body.admin-bar { margin-top: 0 !important; }

#wpadminbar { position: fixed !important; }

/* === ANNOUNCEMENT BAR - hidden === */
.th-announcement-bar, .airband-announcement { display: none !important; }

/* === TOP BAR === */
.tw-topbar {
  background: #0b1d3a;
  padding: 8px 0;
  font-size: .82rem;
  color: rgba(255,255,255,.75);
}

.tw-topbar__inner,
.tw-topbar-inner {
  max-width: var(--tw-max-width, 1540px);
  margin: 0 auto;
  padding: 0 40px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.tw-topbar__left,
.tw-topbar-left { display: flex; align-items: center; gap: 24px; }

.tw-topbar__item { display: flex; align-items: center; gap: 6px; }

.tw-topbar__item a { color: rgba(255,255,255,.75); text-decoration: none; }

.tw-topbar__item a:hover { color: var(--th-palette-turquoise, #57d6e2); }

.tw-topbar__right,
.tw-topbar-right { display: flex; align-items: center; gap: 8px; }

.tw-topbar__rating { color: var(--th-palette-turquoise, #57d6e2); font-weight: 700; }

.tw-topbar__stars { color: #57d6e2; letter-spacing: 2px; }

/* === HEADER === */
.tw-hdr {
  background: #fff;
  border-bottom: 1px solid rgba(11,29,58,.08);
  position: sticky;
  top: 0;
  z-index: 9999;
}

body.admin-bar .tw-hdr { top: 32px; }

.tw-hdr__inner {
  max-width: var(--tw-max-width, 1540px);
  margin: 0 auto;
  padding: 0 40px;
  display: flex;
  align-items: center;
  height: 72px;
  gap: 32px;
}

.tw-hdr__logo { flex-shrink: 0; }

.tw-hdr__logo img { height: 40px; width: auto; display: block; }

.tw-hdr__nav { flex: 1; display: flex; justify-content: center; }

.tw-hdr__actions { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }

/* === NAVIGATION === */
.tw-nav-list {
  display: flex;
  align-items: center;
  gap: 4px;
  list-style: none;
  margin: 0;
  padding: 0;
}

.tw-nav-list li { position: relative; list-style: none; }

.tw-nav-link {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 8px 14px;
  font-size: .9rem;
  font-weight: 500;
  color: #374151;
  text-decoration: none;
  border-radius: 8px;
  transition: color .2s, background .2s;
  white-space: nowrap;
}

.tw-nav-link:hover { color: #0b1d3a; background: rgba(11,29,58,.05); }

.tw-nav-link svg { opacity: .6; transition: transform .2s; }

.tw-has-dd:hover .tw-nav-link svg { transform: rotate(180deg); }

/* Nav active item - teal */
.tw-nav-link--active,
.tw-nav-link.current-menu-item,
.current-menu-item > .tw-nav-link,
.current-menu-ancestor > .tw-nav-link {
  color: var(--th-palette-turquoise, #57d6e2) !important;
  background: transparent !important;
  font-weight: 700 !important;
  position: relative;
}

.tw-nav-link--active::after,
.current-menu-item > .tw-nav-link::after,
.current-menu-ancestor > .tw-nav-link::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 100%;
  height: 2px;
  background: var(--th-palette-turquoise, #57d6e2);
  border-radius: 2px;
}

/* === DROPDOWN === */
.tw-dd {
  display: none;
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  background: #fff;
  border: 1px solid rgba(11,29,58,.08);
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(11,29,58,.12);
  padding: 24px;
  min-width: 520px;
  z-index: 10000;
}

.tw-has-dd:hover .tw-dd { display: block; }

.tw-dd-inner { display: flex; gap: 32px; }

.tw-dd-col { min-width: 200px; }

.tw-dd-head {
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: #9ca3af;
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid #f3f4f6;
}

.tw-dd-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 10px;
  text-decoration: none;
  color: #374151;
  transition: background .15s;
  margin-bottom: 4px;
}

.tw-dd-item:hover { background: #f8fafc; }

.tw-dd-speed {
  font-size: 1.3rem;
  font-weight: 900;
  color: #0b1d3a;
  line-height: 1;
  min-width: 52px;
}

.tw-dd-speed span { font-size: .65rem; font-weight: 500; color: #9ca3af; }

.tw-dd-item strong { display: block; font-size: .88rem; color: #0b1d3a; }

.tw-dd-item span { font-size: .78rem; color: #6b7280; }

.tw-dd-promo {
  background: linear-gradient(135deg, #0b1d3a 0%, #063d4f 100%);
  border-radius: 12px;
  padding: 20px;
  margin-top: 4px;
}

.tw-dd-promo__label {
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--th-palette-turquoise, #57d6e2);
  margin-bottom: 6px;
}

.tw-dd-promo h4 { font-size: 1rem; font-weight: 800; color: #fff; margin: 0 0 8px; }

.tw-dd-promo p { font-size: .8rem; color: rgba(255,255,255,.65); margin: 0 0 12px; line-height: 1.4; }

.tw-dd-promo-btn {
  display: inline-block;
  background: var(--th-palette-turquoise, #57d6e2);
  color: #0b1d3a;
  font-size: .8rem;
  font-weight: 700;
  padding: 8px 16px;
  border-radius: 50px;
  text-decoration: none;
}

/* === BUTTONS === */
.tw-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 22px;
  border-radius: 50px;
  font-weight: 700;
  font-size: .88rem;
  text-decoration: none;
  transition: background .2s, color .2s, box-shadow .2s;
  cursor: pointer;
  border: none;
  white-space: nowrap;
}

.tw-btn--primary {
  background: var(--th-palette-turquoise, #57d6e2);
  color: #0b1d3a;
}

.tw-btn--primary:hover {
  background: #3ec8d8;
  color: #0b1d3a;
  box-shadow: 0 4px 16px rgba(87,214,226,.35);
}

.tw-hdr-cta {
  background: var(--th-palette-turquoise, #57d6e2);
  color: #0b1d3a;
  font-size: .82rem;
  padding: 8px 18px;
}

/* === HAMBURGER === */
.tw-hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px;
}

.tw-hamburger span {
  display: block;
  width: 24px;
  height: 2px;
  background: #0b1d3a;
  border-radius: 2px;
  transition: transform .3s, opacity .3s;
}

.tw-hamburger.active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }

.tw-hamburger.active span:nth-child(2) { opacity: 0; }

.tw-hamburger.active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* === MOBILE NAV === */
.tw-mobile-nav {
  display: none;
  position: fixed;
  inset: 0;
  background: #0b1d3a;
  z-index: 9998;
  overflow-y: auto;
  padding: 80px 24px 40px;
  flex-direction: column;
}

.tw-mobile-nav.open { display: flex; }

.tw-mob-list { display: flex; flex-direction: column; gap: 4px; }

.tw-mob-section-title {
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: rgba(255,255,255,.4);
  padding: 16px 12px 8px;
}

.tw-mob-list a {
  display: block;
  padding: 12px;
  color: #fff;
  text-decoration: none;
  font-size: .95rem;
  border-radius: 10px;
}

.tw-mob-list a:hover { background: rgba(255,255,255,.08); }

.tw-mob-cta {
  margin-top: 24px;
  display: block;
  background: var(--th-palette-turquoise, #57d6e2);
  color: #0b1d3a;
  font-weight: 700;
  text-align: center;
  padding: 14px;
  border-radius: 50px;
  text-decoration: none;
}

.tw-mob-close {
  position: absolute;
  top: 20px;
  right: 20px;
  background: none;
  border: none;
  color: #fff;
  font-size: 1.5rem;
  cursor: pointer;
}

/* === FOOTER === */
.tw-footer {
  background: #0b1d3a;
  color: rgba(255,255,255,.75);
}

.tw-footer__main,
.tw-footer__inner {
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 48px;
}

.tw-footer__brand img { height: 36px; margin-bottom: 16px; }

.tw-footer__brand p { font-size: .88rem; line-height: 1.6; color: rgba(255,255,255,.6); max-width: 240px; }

.tw-footer__col h4,
.tw-footer__heading {
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: rgba(255,255,255,.4);
  margin-bottom: 16px;
}

.tw-footer__col ul { list-style: none; padding: 0; margin: 0; }

.tw-footer__col li { margin-bottom: 10px; }

.tw-footer__col a { color: rgba(255,255,255,.7); text-decoration: none; font-size: .88rem; }

.tw-footer__col a:hover { color: var(--th-palette-turquoise, #57d6e2); }

.tw-footer__bottom {
  border-top: 1px solid rgba(255,255,255,.08);
  width: 100%;
  margin: 0;
  padding: 0;
}

.tw-footer__bottom-inner {
  max-width: var(--tw-max-width, 1540px);
  margin: 0 auto;
  padding: 24px 24px 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px 24px;
}

.tw-footer__copy { font-size: .82rem; color: rgba(255,255,255,.5); }

.tw-footer__copy a { color: rgba(255,255,255,.6); text-decoration: none; }

.tw-footer__copy a:hover { color: var(--th-palette-turquoise, #57d6e2); }

.tw-footer__badges { display: flex; align-items: center; gap: 12px; }

.tw-footer__badge {
  display: flex;
  align-items: center;
  gap: 6px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 50px;
  padding: 6px 14px;
  font-size: .75rem;
  color: rgba(255,255,255,.7);
}

/* === HOME PAGE HERO === */
.tw-hero {
  position: relative;
  overflow: hidden;
  background: url('https://images.unsplash.com/photo-1609220136736-443140cffec6?w=1600&auto=format&fit=crop&q=80') center center / cover no-repeat !important;
  min-height: 0;
  padding: 40px 0 36px;
}

.tw-accent { color: var(--th-palette-turquoise, #57d6e2); }

.tw-hero__actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 48px;
}

.tw-hero__stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid rgba(255,255,255,.1);
  padding-top: 32px;
}

.tw-hero__stat-lbl {
  font-size: .75rem;
  color: rgba(255,255,255,.5);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-top: 4px;
}

.tw-hero__visual {
  display: flex;
  justify-content: center;
  align-items: center;
}

.tw-hero__widget {
  background: rgba(255,255,255,.06);
  backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 24px;
  padding: 32px;
  width: 100%;
  max-width: 400px;
}

/* === INNER PAGE HERO (tw-* design system) === */
.tw-inner-hero {
  background: linear-gradient(135deg, #0b1d3a 0%, #0d2545 55%, #063d4f 100%) !important;
  position: relative;
  overflow: hidden;
  padding: 50px 0;
  min-height: 300px;
}

.tw-inner-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 70% 50%, rgba(87,214,226,.12) 0%, transparent 65%);
  pointer-events: none;
}

.tw-inner-hero__inner {
  max-width: var(--tw-max-width, 1540px);
  margin: 0 auto;
  padding: 0 24px;
  position: relative;
  z-index: 1;
}

.tw-inner-hero__badge {
  display: inline-flex;
  align-items: center;
  background: rgba(87,214,226,.12);
  border: 1px solid rgba(87,214,226,.25);
  color: var(--th-palette-turquoise, #57d6e2);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: 50px;
  margin-bottom: 20px;
}

.tw-inner-hero h1 {
  font-size: 2.8rem;
  font-weight: 900;
  color: #fff;
  line-height: 1.15;
  margin: 0 0 18px;
  max-width: 700px;
}

.tw-inner-hero p {
  font-size: 1rem;
  color: rgba(255,255,255,.7);
  line-height: 1.65;
  max-width: 560px;
  margin: 0 0 32px;
}

.tw-inner-hero__actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.tw-inner-hero__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid rgba(255,255,255,.12);
  margin-top: 48px;
  padding-top: 32px;
}

.tw-inner-hero__stat-item { text-align: left; padding-right: 20px; }

.tw-inner-hero__stat-num {
  font-size: 2rem;
  font-weight: 900;
  color: var(--th-palette-turquoise, #57d6e2);
  line-height: 1;
  margin-bottom: 4px;
}

.tw-inner-hero__stat-lbl {
  font-size: .72rem;
  color: rgba(255,255,255,.55);
  text-transform: uppercase;
  letter-spacing: .06em;
}

/* === INNER PAGE SECTIONS === */
.tw-inner-section {
  padding: 50px 0;
  background: #fff;
}

.tw-inner-section--gray { background: #f8fafc; }

.tw-inner-section--dark {
  background: linear-gradient(135deg, #0b1d3a 0%, #0d2545 100%);
  color: #fff;
}

.tw-inner-section__inner {
  max-width: var(--tw-max-width, 1540px);
  margin: 0 auto;
  padding: 0 24px;
}

.tw-inner-section__header {
  text-align: center;
  margin-bottom: 56px;
}

.tw-inner-section__label {
  display: inline-block;
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--th-palette-turquoise, #57d6e2);
  margin-bottom: 12px;
}

.tw-inner-section__header h2 {
  font-size: 2.2rem;
  font-weight: 800;
  color: #0b1d3a;
  line-height: 1.25;
  margin: 0 0 14px;
}

.tw-inner-section--dark .tw-inner-section__header h2 { color: #fff; }

.tw-inner-section__header p {
  font-size: 1rem;
  color: #667085;
  line-height: 1.65;
  max-width: 560px;
  margin: 0 auto;
}

.tw-inner-section--dark .tw-inner-section__header p { color: rgba(255,255,255,.65); }

/* === PRICING GRID === */
.tw-price-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}

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

.tw-price-card {
  background: #fff;
  border: 2px solid #e8edf3;
  border-radius: 20px;
  padding: 32px 28px;
  position: relative;
  transition: transform .2s, box-shadow .2s;
}

.tw-price-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(11,29,58,.1);
}

.tw-price-card--featured {
  border-color: var(--th-palette-turquoise, #57d6e2);
  box-shadow: 0 8px 32px rgba(87,214,226,.2);
}

.tw-price-card__badge {
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--th-palette-turquoise, #57d6e2);
  color: #0b1d3a;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .08em;
  padding: 4px 16px;
  border-radius: 50px;
  white-space: nowrap;
}

.tw-price-card__speed {
  font-size: 2.8rem;
  font-weight: 900;
  color: #0b1d3a;
  line-height: 1;
}

.tw-price-card__speed span { font-size: 1rem; font-weight: 500; color: #667085; }

.tw-price-card__name {
  font-size: .85rem;
  color: #667085;
  margin: 4px 0 16px;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.tw-price-card__price {
  font-size: 1.8rem;
  font-weight: 900;
  color: var(--th-palette-turquoise, #57d6e2);
  margin-bottom: 4px;
}

.tw-price-card__price span { font-size: .85rem; font-weight: 500; color: #667085; }

.tw-price-card__period { font-size: .78rem; color: #9ca3af; margin-bottom: 24px; }

.tw-price-card__features {
  list-style: none;
  padding: 0;
  margin: 0 0 28px;
  border-top: 1px solid #f3f4f6;
  padding-top: 20px;
}

.tw-price-card__features li {
  font-size: .88rem;
  color: #374151;
  padding: 6px 0;
  display: flex;
  align-items: center;
  gap: 8px;
}

.tw-price-card__features li::before {
  content: '✓';
  color: var(--th-palette-turquoise, #57d6e2);
  font-weight: 700;
  flex-shrink: 0;
}

/* ALL price card buttons - teal */
.tw-price-card__btn {
  display: block;
  text-align: center;
  padding: 12px 24px;
  border-radius: 50px;
  font-weight: 700;
  font-size: .9rem;
  background: var(--th-palette-turquoise, #57d6e2);
  color: #0b1d3a;
  text-decoration: none;
  transition: background .2s;
}

.tw-price-card__btn:hover {
  background: #3ec8d8;
  color: #0b1d3a;
}

.tw-price-card--featured .tw-price-card__btn {
  background: var(--th-palette-turquoise, #57d6e2);
  color: #0b1d3a;
}

/* === FEATURE / CARDS GRID === */
.tw-feat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 28px;
}

.tw-feat-card {
  background: #fff;
  border-radius: 16px;
  padding: 32px;
  box-shadow: 0 2px 12px rgba(11,29,58,.06);
  border: 1px solid #f0f4f8;
  transition: box-shadow .2s, transform .2s;
}

.tw-feat-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(11,29,58,.1);
}

.tw-feat-card--dark {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
}

.tw-feat-card__icon { font-size: 2.2rem; margin-bottom: 16px; }

.tw-feat-card__title {
  font-size: 1.05rem;
  font-weight: 700;
  color: #0b1d3a;
  margin-bottom: 8px;
}

.tw-feat-card--dark .tw-feat-card__title { color: #fff; }

.tw-feat-card__text {
  font-size: .9rem;
  color: #667085;
  line-height: 1.6;
}

.tw-feat-card--dark .tw-feat-card__text { color: rgba(255,255,255,.65); }

/* === STATS ROW === */
.tw-stats-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid rgba(255,255,255,.12);
  margin-top: 48px;
  padding-top: 32px;
}

.tw-stat-item { text-align: left; padding-right: 20px; }

.tw-stat-item__num {
  font-size: 2.2rem;
  font-weight: 900;
  color: var(--th-palette-turquoise, #57d6e2);
  line-height: 1;
  margin-bottom: 4px;
}

.tw-stat-item__lbl {
  font-size: .78rem;
  color: rgba(255,255,255,.55);
  text-transform: uppercase;
  letter-spacing: .06em;
}

/* === INNER CTA === */
.tw-inner-cta {
  background: #0b1d3a;
  padding: 50px 0;
  text-align: center;
}

.tw-inner-cta__inner {
  max-width: var(--tw-max-width, 1540px);
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  text-align: left;
  flex-wrap: wrap;
}

.tw-inner-cta__inner > div:first-child {
  flex: 1 1 320px;
  min-width: 0;
}

.tw-inner-cta h2 {
  font-size: 2rem;
  font-weight: 800;
  color: #fff;
  margin: 0 0 12px;
}

.tw-inner-cta p {
  font-size: 1rem;
  color: rgba(255,255,255,.65);
  margin: 0 0 32px;
  line-height: 1.6;
}

.tw-inner-cta__actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
}

.tw-inner-cta .tw-btn--primary {
  background: var(--th-palette-turquoise, #57d6e2);
  color: #0b1d3a;
}

.tw-inner-cta .tw-btn--phone {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: rgba(255,255,255,.8);
  text-decoration: none;
  font-weight: 600;
  font-size: .9rem;
  padding: 10px 20px;
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 50px;
  transition: background .2s;
}

.tw-inner-cta .tw-btn--phone:hover {
  background: rgba(255,255,255,.08);
  color: #fff;
}

.tw-inner-cta .tw-btn--phone i,
.tw-cta-phone i,
.tw-btn--phone-outline i {
  color: var(--th-palette-turquoise, #57d6e2) !important;
  font-size: 0.95em;
}

.tw-btn--phone-primary i {
  color: #0b1d3a !important;
}

.tw-btn--phone-outline i {
  margin-right: 2px;
}

.tw-cta-phone,
.tw-inner-cta .tw-btn--phone {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
}

.tw-cta-phone--text {
  color: rgba(255,255,255,.85);
  text-decoration: none;
  font-weight: 600;
  font-size: .9rem;
}

/* Split inner-page hero (content + side panel) */
.tw-inner-hero--split .tw-inner-hero__inner {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 40px;
  align-items: center;
}

.tw-inner-hero__panel {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(87,214,226,.22);
  border-radius: 20px;
  padding: 28px 26px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}

.tw-inner-hero__panel-stat {
  text-align: left;
}

.tw-inner-hero__panel-num {
  display: block;
  font-size: 1.75rem;
  font-weight: 900;
  color: var(--th-palette-turquoise, #57d6e2);
  line-height: 1.1;
  margin-bottom: 4px;
}

.tw-inner-hero__panel-lbl {
  display: block;
  font-size: .72rem;
  color: rgba(255,255,255,.6);
  text-transform: uppercase;
  letter-spacing: .06em;
  line-height: 1.4;
}

.tw-inner-hero__panel-row {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  grid-column: 1 / -1;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.tw-inner-hero__panel-row:last-child {
  padding-bottom: 0;
  border-bottom: none;
}

.tw-inner-hero__panel-icon {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  background: rgba(87,214,226,.12);
  border: 1px solid rgba(87,214,226,.25);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--th-palette-turquoise, #57d6e2);
  flex-shrink: 0;
}

.tw-inner-hero__panel-row strong {
  display: block;
  color: #fff;
  font-size: .9rem;
  margin-bottom: 2px;
}

.tw-inner-hero__panel-row span,
.tw-inner-hero__panel-row a {
  color: rgba(255,255,255,.72);
  font-size: .88rem;
  line-height: 1.5;
  text-decoration: none;
}

.tw-inner-hero__panel-row a:hover {
  color: var(--th-palette-turquoise, #57d6e2);
}

.tw-contact-item__icon i {
  color: var(--th-palette-turquoise, #57d6e2);
  font-size: 1.1rem;
}

/* Inner hero visual panel (right side) */
.tw-inner-hero__visual {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(87,214,226,.22);
  border-radius: 20px;
  padding: 26px 24px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  height: 100%;
}

.tw-inner-hero__visual-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  align-self: flex-start;
  background: rgba(87,214,226,.12);
  border: 1px solid rgba(87,214,226,.28);
  color: var(--th-palette-turquoise, #57d6e2);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 6px 14px;
  border-radius: 50px;
}

.tw-inner-hero__visual-main {
  text-align: center;
  padding: 22px 18px;
  background: rgba(87,214,226,.08);
  border: 1px solid rgba(87,214,226,.18);
  border-radius: 16px;
}

.tw-inner-hero__visual-num {
  display: block;
  font-size: clamp(2rem, 4vw, 2.75rem);
  font-weight: 900;
  color: var(--th-palette-turquoise, #57d6e2);
  line-height: 1;
  margin-bottom: 6px;
}

.tw-inner-hero__visual-num span {
  font-size: .45em;
  font-weight: 800;
  margin-left: 2px;
}

.tw-inner-hero__visual-lbl {
  display: block;
  font-size: .82rem;
  color: rgba(255,255,255,.65);
  line-height: 1.4;
}

.tw-inner-hero__visual-stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

.tw-inner-hero__visual-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.tw-inner-hero__visual-list li {
  display: flex;
  align-items: center;
  gap: 10px;
  color: rgba(255,255,255,.85);
  font-size: .88rem;
  line-height: 1.45;
  padding: 9px 0;
  border-bottom: 1px solid rgba(255,255,255,.06);
}

.tw-inner-hero__visual-list li:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.tw-inner-hero__visual-list li i {
  color: var(--th-palette-turquoise, #57d6e2);
  font-size: .95rem;
  flex-shrink: 0;
}

.tw-inner-hero__visual-tp {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 14px;
  text-decoration: none;
  transition: background .2s ease, border-color .2s ease;
}

.tw-inner-hero__visual-tp:hover {
  background: rgba(255,255,255,.08);
  border-color: rgba(87,214,226,.25);
}

.tw-inner-hero__visual-tp-stars {
  color: #00b67a;
  font-size: .9rem;
  letter-spacing: 1px;
  flex-shrink: 0;
}

.tw-inner-hero__visual-tp span:last-child {
  display: flex;
  flex-direction: column;
  gap: 2px;
  color: rgba(255,255,255,.75);
  font-size: .82rem;
  line-height: 1.35;
}

.tw-inner-hero__visual-tp strong {
  color: #fff;
  font-size: .88rem;
}

/* Service status hero panel */
.tw-inner-hero__visual--status {
  gap: 0;
  padding: 0;
  overflow: hidden;
}

.tw-inner-hero__status-head {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 20px 22px;
  background: rgba(87,214,226,.1);
  border-bottom: 1px solid rgba(87,214,226,.2);
}

.tw-inner-hero__status-head-text {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

.tw-inner-hero__status-title {
  display: block;
  color: #ffffff;
  font-size: 1.05rem;
  font-weight: 800;
  line-height: 1.3;
}

.tw-inner-hero__status-time {
  display: block;
  color: rgba(255,255,255,.72);
  font-size: .82rem;
  line-height: 1.4;
}

.tw-inner-hero__status-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #10b981;
  box-shadow: 0 0 0 4px rgba(16,185,129,.28);
  flex-shrink: 0;
  margin-top: 4px;
}

.tw-inner-hero__status-list {
  list-style: none;
  margin: 0;
  padding: 8px 22px 4px;
}

.tw-inner-hero__status-list li {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.tw-inner-hero__status-list li:last-child {
  border-bottom: none;
}

.tw-inner-hero__status-list li i {
  width: 32px;
  height: 32px;
  border-radius: 10px;
  background: rgba(87,214,226,.12);
  border: 1px solid rgba(87,214,226,.22);
  color: var(--th-palette-turquoise, #57d6e2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .85rem;
  flex-shrink: 0;
}

.tw-inner-hero__status-name {
  flex: 1;
  color: rgba(255,255,255,.92);
  font-size: .9rem;
  font-weight: 600;
  line-height: 1.35;
}

.tw-inner-hero__status-ok {
  color: #34d399;
  font-size: .78rem;
  font-weight: 700;
  white-space: nowrap;
  background: rgba(16,185,129,.14);
  border: 1px solid rgba(16,185,129,.28);
  padding: 4px 10px;
  border-radius: 50px;
}

.tw-inner-hero__status-foot {
  padding: 16px 22px 20px;
  border-top: 1px solid rgba(255,255,255,.08);
  margin-top: auto;
}

.tw-inner-hero__status-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--th-palette-turquoise, #57d6e2);
  font-size: .88rem;
  font-weight: 700;
  text-decoration: none;
}

.tw-inner-hero__status-link:hover {
  color: #fff;
}

.tw-inner-hero__status-link i {
  font-size: .8rem;
}

.tw-inner-hero--split .tw-inner-hero__content h1 {
  max-width: none;
}

.tw-inner-hero--split .tw-inner-hero__content p {
  max-width: none;
}

/* === COMPARE TABLE === */
.tw-compare-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .9rem;
}

.tw-compare-table th {
  background: #0b1d3a;
  color: #fff;
  padding: 14px 20px;
  text-align: left;
  font-weight: 700;
}

.tw-compare-table th:first-child { border-radius: 10px 0 0 0; }

.tw-compare-table th:last-child { border-radius: 0 10px 0 0; }

.tw-compare-table td {
  padding: 14px 20px;
  border-bottom: 1px solid #f0f4f8;
  color: #374151;
}

.tw-compare-table tr:nth-child(even) td { background: #f8fafc; }

.tw-compare-table .tw-compare-yes { color: var(--th-palette-turquoise, #57d6e2); font-weight: 700; }

.tw-compare-table .tw-compare-no { color: #d1d5db; }

/* === COVERAGE CHECKER PAGE === */
.cov-hero {
  background: linear-gradient(135deg, #0b1d3a 0%, #0d2545 55%, #063d4f 100%);
  padding: 50px 0;
  position: relative;
  overflow: hidden;
}

.cov-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 70% 50%, rgba(87,214,226,.12) 0%, transparent 65%);
}

.cov-hero__inner {
  max-width: var(--tw-max-width, 1540px);
  margin: 0 auto;
  padding: 0 40px;
  position: relative;
  z-index: 1;
}

.cov-form-card {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 20px;
  padding: 48px;
  max-width: 700px;
  margin: 32px auto 0;
}

/* === ABOUT PAGE === */
.tw-about-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
  max-width: var(--tw-max-width, 1540px);
  margin: 0 auto;
  padding: 0 40px;
}

.tw-about-grid__text h2 {
  font-size: 2.2rem;
  font-weight: 800;
  color: #0b1d3a;
  margin-bottom: 20px;
  line-height: 1.25;
}

.tw-about-grid__text p {
  color: #4a5568;
  font-size: 1rem;
  line-height: 1.7;
  margin-bottom: 16px;
}

.tw-about-values {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 24px;
}

.tw-about-value {
  background: #f8fafc;
  border-radius: 16px;
  padding: 28px 24px;
  border: 1px solid #e8edf3;
  transition: box-shadow .2s;
}

.tw-about-value:hover { box-shadow: 0 4px 20px rgba(11,29,58,.08); }

.tw-about-value__icon { font-size: 2rem; margin-bottom: 12px; }

.tw-about-value__title {
  font-size: 1rem;
  font-weight: 700;
  color: #0b1d3a;
  margin-bottom: 8px;
}

.tw-about-value__text { font-size: .9rem; color: #667085; line-height: 1.6; }

.tw-team-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 28px;
}

.tw-team-card {
  text-align: center;
  background: #fff;
  border-radius: 16px;
  padding: 32px 20px;
  border: 1px solid #e8edf3;
  box-shadow: 0 2px 12px rgba(11,29,58,.06);
  transition: transform .2s;
}

.tw-team-card:hover { transform: translateY(-3px); }

.tw-team-card__avatar {
  width: 72px;
  height: 72px;
  background: var(--th-palette-turquoise, #57d6e2);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.8rem;
  margin: 0 auto 16px;
}

.tw-team-card__name { font-size: 1rem; font-weight: 700; color: #0b1d3a; margin-bottom: 4px; }

.tw-team-card__role { font-size: .85rem; color: var(--th-palette-turquoise, #57d6e2); font-weight: 600; }

.tw-team-card__bio { font-size: .82rem; color: #667085; line-height: 1.5; margin-top: 8px; }

/* === CONTACT PAGE === */
.tw-contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.5fr;
  gap: 60px;
  max-width: var(--tw-max-width, 1540px);
  margin: 0 auto;
  padding: 0 40px;
  align-items: start;
}

.tw-contact-info-card {
  background: #0b1d3a;
  border-radius: 20px;
  padding: 40px 36px;
  color: #fff;
  position: sticky;
  top: 120px;
  align-self: flex-start;
}

.tw-contact-info-card h3 {
  font-size: 1.4rem;
  font-weight: 800;
  margin-bottom: 8px;
  color: #fff;
}

.tw-contact-info-card > p {
  font-size: .9rem;
  color: rgba(255,255,255,.6);
  margin-bottom: 32px;
  line-height: 1.6;
}

.tw-contact-item {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 24px;
}

.tw-contact-item__icon {
  width: 44px;
  height: 44px;
  background: rgba(87,214,226,.15);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  flex-shrink: 0;
}

.tw-contact-item__label {
  font-size: .72rem;
  color: rgba(255,255,255,.5);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 4px;
}

.tw-contact-item__value { font-size: 1rem; font-weight: 600; color: #fff; }

.tw-contact-item__value a { color: var(--th-palette-turquoise, #57d6e2); text-decoration: none; }

.tw-contact-item__value a:hover { text-decoration: underline; }

.tw-contact-form-card {
  background: #fff;
  border-radius: 20px;
  padding: 40px 36px;
  border: 1px solid #e8edf3;
  box-shadow: 0 4px 20px rgba(11,29,58,.06);
}

.tw-contact-form-card h3 { font-size: 1.4rem; font-weight: 800; color: #0b1d3a; margin-bottom: 8px; }

.tw-contact-form-card > p { color: #667085; font-size: .9rem; margin-bottom: 28px; }

.tw-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }

.tw-form-group { margin-bottom: 16px; }

.tw-form-group label { display: block; font-size: .85rem; font-weight: 600; color: #374151; margin-bottom: 6px; }

.tw-form-group input,
.tw-form-group select,
.tw-form-group textarea {
  width: 100%;
  padding: 12px 16px;
  border: 2px solid #e8edf3;
  border-radius: 10px;
  font-size: .95rem;
  font-family: inherit;
  color: #0b1d3a;
  transition: border-color .2s;
  box-sizing: border-box;
  background: #fff;
}

.tw-form-group input:focus,
.tw-form-group select:focus,
.tw-form-group textarea:focus {
  outline: none;
  border-color: var(--th-palette-turquoise, #57d6e2);
  box-shadow: 0 0 0 3px rgba(87,214,226,.12);
}

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

.tw-form-submit {
  background: var(--th-palette-turquoise, #57d6e2);
  color: #0b1d3a;
  border: none;
  padding: 14px 32px;
  border-radius: 50px;
  font-weight: 700;
  font-size: 1rem;
  cursor: pointer;
  width: 100%;
  transition: background .2s;
  font-family: inherit;
}

.tw-form-submit:hover { background: #3ec8d8; }

/* === MODAL FIXES === */
.th-avail-btn,
#modal-submit {
  background: var(--th-palette-turquoise, #57d6e2) !important;
  color: #fff !important;
  border: none !important;
  font-weight: 700 !important;
}

.th-avail-btn:hover { background: #3ec8d8 !important; }

/* ============================================================
   HOME PAGE SECTIONS — Complete Styles v20.0
   ============================================================ */

/* --- Section base padding --- */
.tw-packages, .tw-why, .tw-coverage, .tw-how, .tw-tech,
.tw-business, .tw-faq, .tw-reviews, .tw-trust-bar-section { padding: 50px 0; }

.tw-stats { background: #0b1d3a !important; padding: 50px 0; }

/* --- Section backgrounds --- */
.tw-section--white, .tw-section-white { background: #fff; }

.tw-section--dark, .tw-section-dark { background: #0b1d3a; color: #fff; }

.tw-section--gray, .tw-section-gray { background: #f4f7fc; }

/* --- Common inner container --- */
.tw-packages__inner, .tw-why__inner, .tw-coverage__inner,
.tw-how__inner, .tw-tech__inner, .tw-business__inner,
.tw-faq__inner, .tw-reviews__inner, .tw-stats__inner,
.tw-cta__inner, .tw-trust-bar__inner {
  max-width: var(--tw-max-width, 1540px);
  margin: 0 auto;
  padding: 0 40px;
}

/* --- Section badge (pill label above headings) --- */
.tw-section-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(87,214,226,.1);
  color: var(--th-palette-turquoise, #57d6e2);
  border: 1px solid rgba(87,214,226,.25);
  border-radius: 50px;
  padding: 6px 16px;
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 16px;
}

/* --- Section header --- */
.tw-section-header { margin-bottom: 48px; }

.tw-section-header h2 {
  font-size: 2.2rem;
  font-weight: 800;
  color: #0b1d3a;
  line-height: 1.2;
  margin: 0 0 12px;
}

.tw-section-header p {
  font-size: 1rem;
  color: #6b7280;
  line-height: 1.6;
  margin: 0;
}

.tw-green { color: var(--th-palette-turquoise, #57d6e2); }

/* ============================================================
   TRUST BAR
   ============================================================ */
.tw-trust-bar {
  background: #fff;
  border-top: 1px solid #e8edf3;
  border-bottom: 1px solid #e8edf3;
  padding: 20px 0;
}

/* ============================================================
   PACKAGES / PRICING TABS
   ============================================================ */
.tw-pkg-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 32px;
  flex-wrap: wrap;
}

.tw-pkg-tab:hover {
  background: rgba(87,214,226,.08);
  border-color: var(--th-palette-turquoise, #57d6e2);
  color: var(--th-palette-turquoise, #57d6e2);
}

.tw-pkg-tab.active {
  background: var(--th-palette-turquoise, #57d6e2);
  border-color: var(--th-palette-turquoise, #57d6e2);
  color: #0b1d3a;
}

/* Panel visibility */
.tw-pkg-panel { display: none; }

/* Package card */
.tw-pkg-card {
  background: #0e1e38;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  transition: transform .2s, box-shadow .2s;
  position: relative;
}

/* Package badge */
.tw-pkg-badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--th-palette-turquoise, #57d6e2);
  color: #0b1d3a;
  font-size: .72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 4px 16px;
  border-radius: 20px;
  white-space: nowrap;
}

/* Package icon */
.tw-pkg-icon {
  width: 44px;
  height: 44px;
  background: rgba(87,214,226,.15);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 12px;
  color: var(--th-palette-turquoise, #57d6e2);
  font-size: 1.1rem;
}

/* Package text */
.tw-pkg-name {
  font-size: 1.25rem;
  font-weight: 800;
  color: #fff;
  margin: 0 0 4px;
}

.tw-pkg-cta:hover { gap: 10px; color: #fff; }

/* ============================================================
   WHY TRAVHAWK SECTION
   ============================================================ */
.tw-why__inner {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 60px;
  align-items: center;
}

.tw-why__image { position: relative; border-radius: 16px; overflow: hidden; }

.tw-why__image img { width: 100%; height: auto; display: block; border-radius: 16px; }

.tw-why__image-badge {
  position: absolute;
  bottom: 20px;
  left: 20px;
  background: rgba(11,29,58,.85);
  color: #fff;
  padding: 8px 16px;
  border-radius: 8px;
  font-size: .82rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  gap: 6px;
}

.tw-why__image-badge i { color: var(--th-palette-turquoise, #57d6e2); }

.tw-why__content h2 {
  font-size: 2.2rem;
  font-weight: 800;
  color: #0b1d3a;
  margin-bottom: 12px;
  line-height: 1.2;
}

.tw-why__content > p { color: #6b7280; line-height: 1.6; margin-bottom: 32px; }

.tw-why__features { display: flex; flex-direction: column; gap: 20px; }

.tw-why__feature {
  display: flex;
  align-items: flex-start;
  gap: 16px;
}

.tw-why__feature-icon {
  width: 44px;
  height: 44px;
  background: rgba(87,214,226,.12);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--th-palette-turquoise, #57d6e2);
  font-size: 1.1rem;
  flex-shrink: 0;
}

.tw-why__feature h4 { font-size: 1rem; font-weight: 700; color: #0b1d3a; margin: 0 0 4px; }

.tw-why__feature p { font-size: .88rem; color: #6b7280; line-height: 1.5; margin: 0; }

/* ============================================================
   COVERAGE SECTION
   ============================================================ */
.tw-coverage__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}

.tw-coverage__info h2 { font-size: 2.2rem; font-weight: 800; color: #0b1d3a; margin-bottom: 12px; line-height: 1.2; }

.tw-coverage__info > p { color: #6b7280; line-height: 1.6; margin-bottom: 32px; }

.tw-coverage__stat {
  background: #fff;
  border: 1px solid #e8edf3;
  border-radius: 12px;
  padding: 20px;
  text-align: center;
}

.tw-coverage__stat-num {
  font-size: 2rem;
  font-weight: 800;
  color: var(--th-palette-turquoise, #57d6e2);
  display: block;
  line-height: 1;
  margin-bottom: 4px;
}

.tw-coverage__stat p, .tw-coverage__stat-lbl { font-size: .82rem; color: #6b7280; margin: 0; }

.tw-coverage__form { margin-top: 24px; }

.tw-coverage__input:focus { border-color: var(--th-palette-turquoise, #57d6e2); }

.tw-coverage__btn {
  background: var(--th-palette-turquoise, #57d6e2);
  color: #0b1d3a;
  font-weight: 700;
  padding: 12px 28px;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  font-size: .95rem;
  transition: background .2s;
  white-space: nowrap;
}

.tw-coverage__btn:hover { background: #3ec8d8; }

.tw-coverage__image { border-radius: 16px; overflow: hidden; }

.tw-coverage__image img { width: 100%; height: auto; display: block; border-radius: 16px; }

/* ============================================================
   HOW IT WORKS SECTION
   ============================================================ */
.tw-how__steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin-top: 48px;
}

.tw-how__step {
  background: #fff;
  border: 1px solid #e8edf3;
  border-radius: 16px;
  padding: 28px 24px;
  text-align: center;
  position: relative;
}

.tw-how__num {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  background: var(--th-palette-turquoise, #57d6e2);
  color: #0b1d3a;
  font-weight: 800;
  font-size: 1.2rem;
  border-radius: 50%;
  margin: 0 auto 16px;
}

.tw-how__step h4 { font-size: 1rem; font-weight: 700; color: #0b1d3a; margin: 0 0 8px; }

.tw-how__step p { font-size: .88rem; color: #6b7280; line-height: 1.5; margin: 0; }

/* ============================================================
   STATS SECTION
   ============================================================ */
.tw-stats__inner {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px;
  text-align: center;
}

.tw-stats__item {}

.tw-stats__num {
  font-size: 3rem;
  font-weight: 800;
  color: var(--th-palette-turquoise, #57d6e2);
  display: block;
  line-height: 1;
  margin-bottom: 8px;
}

.tw-stats__label {
  font-size: .88rem;
  color: rgba(255,255,255,.65);
  text-transform: uppercase;
  letter-spacing: .08em;
}

/* ============================================================
   TECHNOLOGY SECTION
   ============================================================ */
.tw-tech__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
  margin-top: 48px;
}

.tw-tech__cards { display: flex; flex-direction: column; gap: 20px; }

.tw-tech__card:hover { box-shadow: 0 4px 16px rgba(11,29,58,.08); }

.tw-tech__card-icon {
  width: 44px;
  height: 44px;
  background: rgba(87,214,226,.12);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--th-palette-turquoise, #57d6e2);
  font-size: 1.1rem;
  flex-shrink: 0;
}

.tw-tech__card h4 { font-size: 1rem; font-weight: 700; color: #0b1d3a; margin: 0 0 4px; }

.tw-tech__card p { font-size: .88rem; color: #6b7280; line-height: 1.5; margin: 0; }

.tw-tech__image { border-radius: 16px; overflow: hidden; }

.tw-tech__image img { width: 100%; height: auto; display: block; border-radius: 16px; }

/* ============================================================
   REVIEWS SECTION
   ============================================================ */
.tw-reviews__header { margin-bottom: 48px; }

.tw-reviews__score { display: flex; align-items: center; gap: 12px; margin-top: 12px; }

.tw-reviews__score-num { font-size: 2.5rem; font-weight: 800; color: #0b1d3a; }

.tw-reviews__score-stars { color: #f59e0b; font-size: 1.2rem; }

.tw-reviews__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.tw-review-card {
  background: #fff;
  border: 1px solid #e8edf3;
  border-radius: 16px;
  padding: 24px;
  box-shadow: 0 2px 8px rgba(11,29,58,.06);
}

.tw-review-card__head {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}

.tw-review-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--th-palette-turquoise, #57d6e2);
  color: #0b1d3a;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .9rem;
  flex-shrink: 0;
}

.tw-review-name { font-weight: 700; color: #0b1d3a; font-size: .9rem; }

.tw-review-date { font-size: .78rem; color: #9ca3af; }

.tw-review-stars { color: #f59e0b; font-size: .9rem; margin-bottom: 8px; }

.tw-review-title { font-weight: 700; color: #0b1d3a; margin-bottom: 8px; font-size: .95rem; }

.tw-review-text { color: #4b5563; font-size: .88rem; line-height: 1.6; margin: 0; }

.tw-review-verified { color: var(--th-palette-turquoise, #57d6e2); font-size: .8rem; font-weight: 600; margin-top: 12px; display: flex; align-items: center; gap: 4px; }

/* ============================================================
   BUSINESS SECTION
   ============================================================ */
.tw-business__inner {
  display: grid;
  grid-template-columns: 1.1fr 1fr !important;
  gap: 60px;
  align-items: center;
}

.tw-business__feat {
  display: flex;
  align-items: flex-start;
  gap: 14px;
}

.tw-business__feat-icon {
  width: 40px;
  height: 40px;
  background: rgba(87,214,226,.12);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--th-palette-turquoise, #57d6e2);
  font-size: 1rem;
  flex-shrink: 0;
}

.tw-business__feat h4 { font-size: .95rem; font-weight: 700; color: #0b1d3a; margin: 0 0 4px; }

.tw-business__feat p { font-size: .86rem; color: #6b7280; line-height: 1.5; margin: 0; }

.tw-business__image { border-radius: 16px; overflow: hidden; }

.tw-business__image img { width: 100%; height: auto; display: block; border-radius: 16px; }

/* ============================================================
   FAQ SECTION
   ============================================================ */

.tw-faq__item {
  border: 1px solid #e8edf3;
  border-radius: 12px;
  margin-bottom: 12px;
  overflow: hidden;
  background: #fff;
}

.tw-faq__question {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  font-weight: 700;
  color: #0b1d3a;
  cursor: pointer;
  font-size: .95rem;
  gap: 12px;
}

.tw-faq__question:hover { color: var(--th-palette-turquoise, #57d6e2); }

.tw-faq__icon { color: var(--th-palette-turquoise, #57d6e2); font-size: .9rem; flex-shrink: 0; }

.tw-faq__answer {
  padding: 0 24px 20px;
  color: #6b7280;
  font-size: .9rem;
  line-height: 1.6;
}

/* ============================================================
   CTA SECTION
   ============================================================ */
.tw-cta {
  background: linear-gradient(135deg, #0b1d3a 0%, #063d4f 100%) !important;
  padding: 50px 0;
  text-align: center;
}

.tw-cta h2 { font-size: 2.2rem; font-weight: 800; color: #fff; margin-bottom: 12px; }

.tw-cta p { color: rgba(255,255,255,.7); font-size: 1rem; margin-bottom: 36px; }

.tw-cta__input::placeholder { color: rgba(255,255,255,.45); }

.tw-cta__input:focus { border-color: var(--th-palette-turquoise, #57d6e2); }

.tw-cta__btn, .tw-btn--primary {
  background: var(--th-palette-turquoise, #57d6e2);
  color: #0b1d3a;
  font-weight: 700;
  padding: 14px 32px;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  font-size: .95rem;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: background .2s;
}

.tw-cta__btn:hover, .tw-btn--primary:hover { background: #3ec8d8; }

.tw-btn--outline {
  background: transparent;
  color: #fff;
  border: 2px solid rgba(255,255,255,.4);
  font-weight: 700;
  padding: 12px 28px;
  border-radius: 8px;
  cursor: pointer;
  font-size: .95rem;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: all .2s;
}

.tw-btn--outline:hover { border-color: #fff; background: rgba(255,255,255,.08); }

/* ============================================================
   FOOTER — fix brand column + grid
   ============================================================ */
.tw-footer__brand { max-width: 280px; }

/* Footer: __main is a single-col wrapper, __inner is the 4-col grid */
.tw-footer__main {
  display: block !important;
  padding: 0;
  max-width: 1540px;
  width: 100%;
  margin: 0 auto;
  box-sizing: border-box;
}

.tw-footer__inner {
  display: grid !important;
  grid-template-columns: 1.5fr 1fr 1fr 1fr !important;
  gap: 48px;
  max-width: 1540px;
  width: 100%;
  margin: 0 auto;
  box-sizing: border-box;
}

/* ============================================================
   RESPONSIVE FIXES
   ============================================================ */
@media (max-width: 1200px) {
  .tw-pkg-panel.active { grid-template-columns: repeat(2, 1fr); }
  .tw-reviews__grid { grid-template-columns: repeat(2, 1fr); }
  .tw-tech__grid { grid-template-columns: 1fr; gap: 40px; }
  .tw-business__inner { grid-template-columns: 1fr; gap: 40px; }
}

@media (max-width: 900px) {
  .tw-why__inner { grid-template-columns: 1fr; gap: 40px; }
  .tw-coverage__inner { grid-template-columns: 1fr; gap: 40px; }
  .tw-how__steps { grid-template-columns: repeat(2, 1fr); }
  .tw-stats__inner { grid-template-columns: repeat(2, 1fr); }
  .tw-footer__inner, .tw-footer__main { grid-template-columns: 1fr 1fr; gap: 32px; }
  .tw-footer__brand { max-width: 100%; }
}

@media (max-width: 600px) {
  .tw-pkg-panel.active { grid-template-columns: 1fr; }
  .tw-reviews__grid { grid-template-columns: 1fr; }
  .tw-how__steps { grid-template-columns: 1fr; }
  .tw-stats__inner { grid-template-columns: 1fr 1fr; }
  .tw-footer__inner, .tw-footer__main { grid-template-columns: 1fr; }
  .tw-coverage__stats { grid-template-columns: 1fr 1fr; }
  .tw-packages__inner, .tw-why__inner, .tw-coverage__inner,
  .tw-how__inner, .tw-tech__inner, .tw-business__inner,
  .tw-faq__inner, .tw-reviews__inner, .tw-stats__inner,
  .tw-cta__inner { padding: 0 20px; }
}

/* === CONTACT FORM CF7 OVERRIDES - PREMIUM === */

/* --- Form card padding tighter --- */
.tw-contact-form-card {
  padding: 32px 36px !important;
}

/* --- Reduce spacing between all CF7 <p> tags --- */
.tw-contact-form-card .wpcf7-form p {
  margin-bottom: 10px !important;
}

/* --- Section headings inside form (h3 class) --- */
.tw-contact-form-card .wpcf7-form p.h3 {
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: #0b1d3a !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  margin-top: 18px !important;
  margin-bottom: 8px !important;
  padding-top: 14px !important;
  border-top: 1px solid #eef0f4 !important;
}

.tw-contact-form-card .wpcf7-form p.h3:first-child {
  border-top: none !important;
  padding-top: 0 !important;
  margin-top: 0 !important;
}

/* --- 2-column grid for paired fields --- */
/* First name + Last name in one row */
.tw-contact-form-card .wpcf7-form p[data-cf7-row="names"] {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

/* Force first+last name paragraphs to sit side by side using nth-of-type trick */
/* Instead, use a CSS grid wrapper approach via the form's own structure */
/* Use :has() or target by data-name on wraps */

/* Target the p containing first-name and last-name - make them float / use flex trick */
/* CF7 uses plain <p> tags - we can use nth-child targeting */
/* p:nth-child(6) = first name, p:nth-child(7) = last name (based on analysis) */
/* Better: use the wpcf7-form-control-wrap data-name attribute to target parent p */

/* Compact all input fields */
.tw-contact-form-card .wpcf7-form-control:not([type="radio"]):not([type="checkbox"]):not([type="submit"]):not(.wpcf7-radio) {
  width: 100% !important;
  padding: 10px 14px !important;
  border: 1.5px solid #e2e8f0 !important;
  border-radius: 8px !important;
  font-size: 0.925rem !important;
  font-family: inherit !important;
  color: #0b1d3a !important;
  -webkit-text-fill-color: #0b1d3a !important;
  background: #ffffff !important;
  box-sizing: border-box !important;
  transition: border-color .2s, box-shadow .2s !important;
  height: 42px !important;
}

/* Override: .wpcf7-radio span has wpcf7-form-control class but needs transparent bg */
.tw-contact-form-card .wpcf7-form-control.wpcf7-radio {
  background: transparent !important;
  background-color: transparent !important;
  background-image: none !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

/* Focus state */
.tw-contact-form-card .wpcf7-form-control:not([type="radio"]):not([type="checkbox"]):not([type="submit"]):not(.wpcf7-radio):focus {
  outline: none !important;
  border-color: var(--th-palette-turquoise, #57d6e2) !important;
  box-shadow: 0 0 0 3px rgba(87,214,226,.15) !important;
  background: #fff !important;
}

/* Select dropdown */
.tw-contact-form-card select.wpcf7-form-control {
  height: 42px !important;
  appearance: auto !important;
  padding: 10px 14px !important;
  border: 1.5px solid #e2e8f0 !important;
  border-radius: 8px !important;
  font-size: 0.925rem !important;
  color: #0b1d3a !important;
  -webkit-text-fill-color: #0b1d3a !important;
  background: #ffffff !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

/* Textarea - compact height */
.tw-contact-form-card textarea.wpcf7-form-control {
  height: 110px !important;
  min-height: 110px !important;
  resize: vertical !important;
  padding: 10px 14px !important;
}

/* Submit button */
.tw-contact-form-card .wpcf7-submit {
  background: linear-gradient(135deg, var(--th-palette-turquoise, #57d6e2) 0%, #4cc8d4 100%) !important;
  color: #fff !important;
  border: none !important;
  padding: 13px 32px !important;
  border-radius: 50px !important;
  font-weight: 700 !important;
  font-size: 1rem !important;
  cursor: pointer !important;
  width: 100% !important;
  transition: all .25s !important;
  font-family: inherit !important;
  margin-top: 10px !important;
  letter-spacing: 0.02em !important;
  box-shadow: 0 4px 20px rgba(87,214,226,.3) !important;
}

.tw-contact-form-card .wpcf7-submit:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 6px 28px rgba(87,214,226,.45) !important;
  filter: brightness(1.05) !important;
}

/* Labels inside form */
.tw-contact-form-card .wpcf7-form label {
  font-size: 0.82rem !important;
  font-weight: 600 !important;
  color: #374151 !important;
  display: block !important;
  margin-bottom: 4px !important;
  letter-spacing: 0.01em !important;
}

/* Radio option buttons - clean card style */

/* ============================================================
   RADIO BUTTONS - CLEAN TOGGLE (Final Fix)
   No circles, no pseudo-elements, span-only visual
   ============================================================ */

/* Hide the native radio input completely */
.tw-contact-form-card .wpcf7-radio input[type="radio"],
body .tw-contact-form-card .wpcf7-radio input[type="radio"] {
  opacity: 0 !important;
  width: 1px !important;
  height: 1px !important;
  position: absolute !important;
  margin: 0 !important;
  padding: 0 !important;
  clip: rect(0, 0, 0, 0) !important;
  overflow: hidden !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/* Kill the ::before circle */
.tw-contact-form-card .wpcf7-radio .wpcf7-list-item label::before,
body .tw-contact-form-card .wpcf7-radio .wpcf7-list-item label::before {
  content: none !important;
  display: none !important;
  width: 0 !important;
  height: 0 !important;
  border: none !important;
}

/* Kill ::after too */
.tw-contact-form-card .wpcf7-radio .wpcf7-list-item label::after,
body .tw-contact-form-card .wpcf7-radio .wpcf7-list-item label::after {
  content: none !important;
  display: none !important;
}

/* Radio row container */
.tw-contact-form-card .wpcf7-radio,
body .tw-contact-form-card .wpcf7-radio {
  display: flex !important;
  flex-direction: row !important;
  gap: 10px !important;
  width: 100% !important;
  margin-top: 8px !important;
}

/* List item */
.tw-contact-form-card .wpcf7-radio .wpcf7-list-item,
body .tw-contact-form-card .wpcf7-radio .wpcf7-list-item {
  flex: 1 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
  display: block !important;
  height: 46px !important;
  overflow: hidden !important;
  border-radius: 10px !important;
}

/* The label - transparent wrapper, NO flex children visible */
.tw-contact-form-card .wpcf7-radio .wpcf7-list-item label,
body .tw-contact-form-card .wpcf7-radio .wpcf7-list-item label {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  border: none !important;
  background: transparent !important;
  background-color: transparent !important;
  cursor: pointer !important;
  font-size: 0 !important;
  line-height: 0 !important;
  color: transparent !important;
  flex-direction: unset !important;
  align-items: unset !important;
  gap: 0 !important;
  justify-content: unset !important;
  position: relative !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

/* The SPAN - this is the ONLY visual element */
.tw-contact-form-card .wpcf7-radio .wpcf7-list-item .wpcf7-list-item-label,
body .tw-contact-form-card .wpcf7-radio .wpcf7-list-item .wpcf7-list-item-label {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  height: 100% !important;
  padding: 0 12px !important;
  background: #f0f2f5 !important;
  background-color: #f0f2f5 !important;
  border: 1.5px solid #d8dde6 !important;
  border-radius: 10px !important;
  font-size: 0.77rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: #64748b !important;
  cursor: pointer !important;
  box-sizing: border-box !important;
  transition: background 0.18s, color 0.18s, border-color 0.18s !important;
  line-height: 1 !important;
  gap: 0 !important;
  white-space: nowrap !important;
}

/* Hover */
.tw-contact-form-card .wpcf7-radio .wpcf7-list-item label:hover .wpcf7-list-item-label,
body .tw-contact-form-card .wpcf7-radio .wpcf7-list-item label:hover .wpcf7-list-item-label,
.tw-contact-form-card .wpcf7-radio .wpcf7-list-item:not(.is-checked):not(:has(input:checked)) .wpcf7-list-item-label:hover,
body .tw-contact-form-card .wpcf7-radio .wpcf7-list-item:not(.is-checked):not(:has(input:checked)) .wpcf7-list-item-label:hover {
  background: #e8f8fa !important;
  background-color: #e8f8fa !important;
  border-color: #57d6e2 !important;
  color: #0b1d3a !important;
}

/* Selected state - dark navy fill */
.tw-contact-form-card .wpcf7-radio .wpcf7-list-item.is-checked .wpcf7-list-item-label,
.tw-contact-form-card .wpcf7-radio .wpcf7-list-item:has(input:checked) .wpcf7-list-item-label,
body .tw-contact-form-card .wpcf7-radio .wpcf7-list-item.is-checked .wpcf7-list-item-label,
body .tw-contact-form-card .wpcf7-radio .wpcf7-list-item:has(input:checked) .wpcf7-list-item-label {
  background: #0b1d3a !important;
  background-color: #0b1d3a !important;
  border-color: #0b1d3a !important;
  color: #ffffff !important;
}

/* ========================================
   FAMILY LIFESTYLE SECTION
   ======================================== */
.tw-family {
    padding: 50px 0;
    background: #ffffff;
    overflow: hidden;
}

.tw-family__image-wrap {
    position: relative;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0,0,0,0.15);
}

.tw-family__img {
    width: 100%;
    height: 480px;
    object-fit: cover;
    display: block;
    transition: transform 0.5s ease;
}

.tw-family__image-wrap:hover .tw-family__img {
    transform: scale(1.03);
}

.tw-family__content .tw-section-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(87, 214, 226, 0.12);
    color: #57d6e2;
    padding: 8px 16px;
    border-radius: 50px;
    font-size: 0.8rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin-bottom: 20px;
}

.tw-family__content > p {
    font-size: 1.05rem;
    color: #4a5568;
    line-height: 1.7;
    margin: 0 0 30px;
}

.tw-family__content .tw-btn--primary {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: #57d6e2;
    color: #ffffff;
    padding: 14px 28px;
    border-radius: 50px;
    font-weight: 700;
    font-size: 1rem;
    text-decoration: none;
    transition: all 0.3s ease;
    box-shadow: 0 8px 25px rgba(87, 214, 226, 0.35);
}

.tw-family__content .tw-btn--primary:hover {
    background: #176eba;
    transform: translateY(-2px);
    box-shadow: 0 12px 35px rgba(23, 110, 186, 0.35);
}

@media (max-width: 900px) {
    .tw-family__inner {
        grid-template-columns: 1fr;
        gap: 40px;
    }
    .tw-family__img {
        height: 300px;
    }
    .tw-family__content h2 {
        font-size: 1.9rem;
    }
}

/* ========================================
   PREMIUM HOMEPAGE REDESIGN - JUNE 2026
   ======================================== */

/* ---- HERO SECTION: Full-Width Family Photo Background ---- */
.tw-hero {
  position: relative;
  overflow: hidden;
  background: url('https://images.unsplash.com/photo-1609220136736-443140cffec6?w=1600&auto=format&fit=crop&q=80') center center / cover no-repeat !important;
  min-height: 0;
  padding: 40px 0 36px;
}

.tw-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg, rgba(7,18,38,0.88) 0%, rgba(7,28,55,0.80) 50%, rgba(4,48,68,0.65) 100%);
  z-index: 0;
}



.tw-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(87,214,226,0.18);
  border: 1px solid rgba(87,214,226,0.45);
  color: #57d6e2;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1.8px;
  text-transform: uppercase;
  padding: 8px 18px;
  border-radius: 30px;
  margin-bottom: 14px;
}

.tw-hero h1 {
  font-size: clamp(2.4rem, 5vw, 3.8rem) !important;
  font-weight: 800 !important;
  line-height: 1.1 !important;
  color: #fff !important;
  margin-bottom: 14px !important;
}

.tw-hero h1 .tw-green { color: #57d6e2 !important; display: block; }

.tw-hero__desc {
  font-size: 1.15rem;
  color: rgba(255,255,255,0.85);
  line-height: 1.7;
  margin-bottom: 20px;
  max-width: 480px;
}

.tw-hero__features {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 20px;
  margin-bottom: 18px;
}

.tw-hero__feature-item {
  display: flex;
  align-items: center;
  gap: 8px;
  color: rgba(255,255,255,0.9);
  font-size: 0.93rem;
  font-weight: 500;
}

.tw-hero__feature-item i { color: #57d6e2; font-size: 14px; }

.tw-hero__search {
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 16px;
  padding: 20px 24px;
  backdrop-filter: blur(10px);
}

.tw-hero__search-input {
  flex: 1;
  background: rgba(255,255,255,0.12) !important;
  border: 1px solid rgba(255,255,255,0.25) !important;
  border-radius: 10px !important;
  color: #fff !important;
  padding: 14px 18px !important;
  font-size: 1rem !important;
}

.tw-hero__search-input::placeholder { color: rgba(255,255,255,0.5) !important; }

.tw-hero__search-btn {
  background: linear-gradient(135deg, #57d6e2, #29a0ac) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 10px !important;
  padding: 14px 28px !important;
  font-weight: 700 !important;
  font-size: 0.95rem !important;
  cursor: pointer;
  white-space: nowrap;
}

.tw-hero__stat-main {
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(87,214,226,0.3);
  border-radius: 20px;
  padding: 18px 22px;
  backdrop-filter: blur(12px);
  text-align: center;
}

.tw-hero__stat-num {
  font-size: 3.5rem;
  font-weight: 800;
  color: #57d6e2;
  line-height: 1;
  display: block;
}

.tw-hero__stat-card {
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 16px;
  padding: 16px 18px;
  text-align: center;
  backdrop-filter: blur(8px);
}

.tw-hero__stat-card .tw-hero__stat-num { font-size: 2rem; }

.tw-hero__trustpilot-card {
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 16px;
  padding: 16px 20px;
  display: flex;
  align-items: center;
  gap: 12px;
  backdrop-filter: blur(8px);
}

.tw-hero__tp-logo { font-size: 1.2rem; font-weight: 800; color: #57d6e2; }

.tw-hero__tp-stars { color: #00b67a; font-size: 1rem; }

/* ---- TRUST BAR ---- */
.tw-trust-bar {
  background: linear-gradient(90deg, #0a1628 0%, #0d2040 50%, #0a1628 100%) !important;
  border-top: 2px solid rgba(87,214,226,0.3) !important;
  border-bottom: 2px solid rgba(87,214,226,0.3) !important;
  padding: 18px 0 !important;
}



/* Trust bar item layout — customizer.css */

/* ---- FAMILY SECTION ---- */
.tw-family {
  padding: 50px 0 !important;
  background: #fff !important;
}

.tw-family__inner {
  max-width: 1540px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 70px;
  align-items: center;
}

.tw-family__img-wrap, .tw-family__image-wrap {
  border-radius: 24px !important;
  overflow: hidden !important;
  box-shadow: 0 25px 70px rgba(0,0,0,0.15) !important;
  position: relative !important;
}

.tw-family__image-wrap img {
  height: 480px !important;
  object-fit: cover !important;
  width: 100% !important;
  display: block !important;
}

.tw-family__img-badge {
  position: absolute !important;
  bottom: 24px !important;
  left: 24px !important;
  background: linear-gradient(135deg, #57d6e2, #29a0ac) !important;
  color: #fff !important;
  padding: 12px 20px !important;
  border-radius: 14px !important;
  font-size: 0.88rem !important;
  font-weight: 700 !important;
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  box-shadow: 0 8px 24px rgba(87,214,226,0.4) !important;
}

.tw-section-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(87,214,226,0.1);
  border: 1px solid rgba(87,214,226,0.3);
  color: #57d6e2;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: 7px 16px;
  border-radius: 30px;
  margin-bottom: 18px;
}

.tw-family__content h2 {
  font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  font-weight: 800;
  color: #0d1b3e;
  line-height: 1.2;
  margin-bottom: 16px;
}

.tw-family__content h2 .tw-green { color: #57d6e2; }

.tw-family__desc {
  color: #5a6a85;
  font-size: 1.05rem;
  line-height: 1.75;
  margin-bottom: 24px;
}

.tw-family__features {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 32px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
}

.tw-family__features li {
  display: flex !important;
  align-items: flex-start !important;
  gap: 12px !important;
  color: #374151 !important;
  font-size: 0.97rem !important;
  line-height: 1.5 !important;
}

.tw-family__features li i {
  color: #57d6e2 !important;
  font-size: 15px !important;
  margin-top: 2px !important;
  flex-shrink: 0 !important;
  background: rgba(87,214,226,0.1) !important;
  padding: 5px !important;
  border-radius: 50% !important;
}

.tw-family__cta {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  background: linear-gradient(135deg, #57d6e2 0%, #29a0ac 100%) !important;
  color: #fff !important;
  padding: 16px 32px !important;
  border-radius: 50px !important;
  font-weight: 700 !important;
  font-size: 1rem !important;
  text-decoration: none !important;
  box-shadow: 0 8px 30px rgba(87,214,226,0.35) !important;
  transition: transform 0.2s, box-shadow 0.2s !important;
}

.tw-family__cta:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 12px 40px rgba(87,214,226,0.5) !important;
}

/* ---- PACKAGES SECTION ---- */
.tw-packages {
  background: linear-gradient(180deg, #071224 0%, #0b1d3a 100%) !important;
  padding: 50px 0 !important;
}

.tw-packages__header {
  text-align: center;
  margin-bottom: 48px;
}

.tw-packages__header h2 {
  font-size: clamp(1.8rem, 3vw, 2.6rem) !important;
  font-weight: 800 !important;
  color: #fff !important;
  margin-bottom: 10px !important;
}

.tw-packages__header h2 .tw-green { color: #57d6e2 !important; }

.tw-packages__sub, .tw-section-sub {
  color: rgba(255,255,255,0.65) !important;
  font-size: 1.05rem !important;
}

.tw-pkg-tab {
  padding: 12px 30px !important;
  border-radius: 50px !important;
  border: 1.5px solid rgba(255,255,255,0.25) !important;
  background: transparent !important;
  color: rgba(255,255,255,0.75) !important;
  font-weight: 600 !important;
  font-size: 0.95rem !important;
  cursor: pointer !important;
  transition: all 0.2s !important;
}

.tw-pkg-tab.active, .tw-pkg-tab:hover {
  background: linear-gradient(135deg, #57d6e2, #29a0ac) !important;
  border-color: #57d6e2 !important;
  color: #fff !important;
  box-shadow: 0 4px 20px rgba(87,214,226,0.3) !important;
}

.tw-packages__grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)) !important;
  gap: 24px !important;
  max-width: 1540px !important;
  margin: 0 auto !important;
}

.tw-pkg-panel { display: none; }

.tw-pkg-panel.active { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 24px; max-width: 1540px; margin: 0 auto; }

.tw-pkg-card {
  background: rgba(255,255,255,0.06) !important;
  border: 1px solid rgba(255,255,255,0.1) !important;
  border-radius: 20px !important;
  padding: 28px 24px !important;
  display: flex !important;
  flex-direction: column !important;
  transition: transform 0.25s, border-color 0.25s, box-shadow 0.25s !important;
  position: relative !important;
}

.tw-pkg-card:hover {
  transform: translateY(-6px) !important;
  border-color: rgba(87,214,226,0.45) !important;
  box-shadow: 0 20px 50px rgba(87,214,226,0.12) !important;
}

.tw-pkg-card--featured {
  background: rgba(87,214,226,0.08) !important;
  border-color: rgba(87,214,226,0.35) !important;
}

.tw-pkg-badge {
  position: absolute !important;
  top: -14px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  background: linear-gradient(135deg, #57d6e2, #29a0ac) !important;
  color: #fff !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 1.2px !important;
  text-transform: uppercase !important;
  padding: 5px 16px !important;
  border-radius: 20px !important;
  white-space: nowrap !important;
}

.tw-pkg-badge--gold {
  background: linear-gradient(135deg, #f59e0b, #d97706) !important;
}

.tw-pkg-icon {
  width: 48px !important;
  height: 48px !important;
  background: rgba(87,214,226,0.12) !important;
  border-radius: 14px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-bottom: 16px !important;
  color: #57d6e2 !important;
  font-size: 1.2rem !important;
}

.tw-pkg-name {
  font-size: 1.15rem !important;
  font-weight: 700 !important;
  color: #fff !important;
  margin-bottom: 4px !important;
}

.tw-pkg-sub {
  font-size: 0.82rem !important;
  color: rgba(255,255,255,0.55) !important;
  margin-bottom: 16px !important;
}

.tw-pkg-speed {
  font-size: 2.2rem !important;
  font-weight: 800 !important;
  color: #57d6e2 !important;
  line-height: 1 !important;
  margin-bottom: 4px !important;
}

.tw-pkg-price {
  font-size: 1.4rem !important;
  font-weight: 700 !important;
  color: #fff !important;
  margin-bottom: 8px !important;
}

.tw-pkg-meta {
  font-size: 0.8rem !important;
  color: rgba(255,255,255,0.45) !important;
  margin-bottom: 16px !important;
}

.tw-pkg-divider {
  height: 1px !important;
  background: rgba(255,255,255,0.1) !important;
  margin: 16px 0 !important;
}

.tw-pkg-features {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 20px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  flex: 1 !important;
}

.tw-pkg-features li {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  color: rgba(255,255,255,0.85) !important;
  font-size: 0.88rem !important;
}

.tw-pkg-features li i, .tw-pkg-features .fa-check {
  color: #57d6e2 !important;
  font-size: 13px !important;
  flex-shrink: 0 !important;
}

.tw-pkg-features li::before {
  display: none !important;
}

div.tw-pkg-cta {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  background: none !important;
  padding: 16px 0 0 !important;
  border-radius: 0 !important;
  border: none !important;
  width: 100% !important;
  box-shadow: none !important;
}

.tw-pkg-cta a,
.tw-pkg-cta .tw-btn,
a.tw-pkg-cta {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  background: linear-gradient(135deg, #57d6e2, #3bc4d0) !important;
  color: #fff !important;
  font-weight: 700 !important;
  font-size: 0.88rem !important;
  text-decoration: none !important;
  padding: 10px 22px !important;
  border-radius: 50px !important;
  border: none !important;
  width: auto !important;
  min-width: 0 !important;
  white-space: nowrap !important;
  transition: all 0.2s ease !important;
}

.tw-pkg-cta a:hover,
.tw-pkg-cta .tw-btn:hover,
a.tw-pkg-cta:hover {
  background: linear-gradient(135deg, #3bc4d0, #29a0ac) !important;
  color: #fff !important;
  transform: translateY(-1px) !important;
}
.tw-pkg-cta:hover {
  background: none !important;
  border-color: transparent !important;
  color: #fff !important;
  box-shadow: none !important;
}

/* Why + Coverage premium light — customizer.css */

/* ---- HOW IT WORKS SECTION ---- */
.tw-how {
  background: #071224 !important;
  padding: 50px 0 !important;
}


.tw-how .tw-section-header { margin-bottom: 56px; }
.tw-how .tw-section-header h2 {
  font-size: clamp(1.8rem, 3vw, 2.5rem) !important;
  font-weight: 800 !important;
  color: #fff !important;
  margin-bottom: 12px !important;
}
.tw-how .tw-green { color: #57d6e2 !important; }
.tw-how .tw-section-sub { color: rgba(255,255,255,0.65) !important; font-size: 1rem !important; }
.tw-how__steps {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 32px !important;
}
.tw-how__step {
  background: rgba(255,255,255,0.05) !important;
  border: 1px solid rgba(255,255,255,0.1) !important;
  border-radius: 20px !important;
  padding: 32px 24px !important;
  text-align: center !important;
  transition: transform 0.25s, border-color 0.25s !important;
}
.tw-how__step:hover {
  transform: translateY(-4px) !important;
  border-color: rgba(87,214,226,0.35) !important;
}
.tw-how__step-num {
  width: 52px !important;
  height: 52px !important;
  background: linear-gradient(135deg, #57d6e2, #29a0ac) !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 1.2rem !important;
  font-weight: 800 !important;
  color: #fff !important;
  margin: 0 auto 20px !important;
}
.tw-how__step h3 {
  font-size: 1.05rem !important;
  font-weight: 700 !important;
  color: #fff !important;
  margin-bottom: 10px !important;
}
.tw-how__step p {
  font-size: 0.88rem !important;
  color: rgba(255,255,255,0.65) !important;
  line-height: 1.6 !important;
  margin: 0 !important;
}

/* ---- STATS BAR ---- */
.tw-stats {
  background: linear-gradient(90deg, #0a1628, #0d2040, #0a1628) !important;
  padding: 56px 60px !important;
  border-top: 2px solid rgba(87,214,226,0.2) !important;
  border-bottom: 2px solid rgba(87,214,226,0.2) !important;
}
.tw-stats__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  text-align: center;
}
.tw-stats__item {
  padding: 0 20px;
  border-right: 1px solid rgba(255,255,255,0.1);
}
.tw-stats__item:last-child { border-right: none; }
.tw-stats__num {
  font-size: 3rem !important;
  font-weight: 800 !important;
  color: #57d6e2 !important;
  line-height: 1 !important;
  display: block !important;
  margin-bottom: 8px !important;
}
.tw-stats__label {
  font-size: 0.8rem !important;
  color: rgba(255,255,255,0.6) !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
}

/* ---- TECHNOLOGY SECTION ---- */
.tw-tech {
  background: #f7faff !important;
  padding: 50px 0 !important;
}
.tw-tech__inner {
  max-width: 1200px;
  margin: 0 auto;
}
.tw-tech .tw-section-header {
  text-align: center;
  margin-bottom: 56px;
}
.tw-tech .tw-section-header h2 {
  font-size: clamp(1.8rem, 3vw, 2.5rem) !important;
  font-weight: 800 !important;
  color: #0d1b3e !important;
  margin-bottom: 12px !important;
}
.tw-tech .tw-green { color: #57d6e2 !important; }
.tw-tech .tw-section-sub { color: #5a6a85 !important; font-size: 1rem !important; }
.tw-tech__grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 40px !important;
}
.tw-tech__card {
  background: #fff !important;
  border: 1px solid rgba(87,214,226,0.12) !important;
  border-radius: 20px !important;
  padding: 32px !important;
  box-shadow: 0 4px 20px rgba(0,0,0,0.05) !important;
  transition: transform 0.25s, box-shadow 0.25s !important;
}
.tw-tech__card:hover {
  transform: translateY(-4px) !important;
  box-shadow: 0 16px 40px rgba(87,214,226,0.12) !important;
}
.tw-tech__card-icon {
  width: 56px !important;
  height: 56px !important;
  background: rgba(87,214,226,0.1) !important;
  border-radius: 16px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 1.4rem !important;
  color: #57d6e2 !important;
  margin-bottom: 20px !important;
}
.tw-tech__card h3 {
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  color: #0d1b3e !important;
  margin-bottom: 10px !important;
}
.tw-tech__card p {
  color: #5a6a85 !important;
  font-size: 0.93rem !important;
  line-height: 1.65 !important;
  margin: 0 !important;
}

/* ---- TRUSTPILOT REVIEWS SECTION ---- */
.tw-reviews {
  background: #fff !important;
  padding: 50px 0 !important;
}
.tw-reviews__inner {
  max-width: 1200px;
  margin: 0 auto;
}
.tw-reviews .tw-section-header {
  text-align: center;
  margin-bottom: 20px;
}
.tw-reviews .tw-section-header h2 {
  font-size: clamp(1.8rem, 3vw, 2.5rem) !important;
  font-weight: 800 !important;
  color: #0d1b3e !important;
  margin-bottom: 10px !important;
}
.tw-reviews .tw-green { color: #57d6e2 !important; }
.tw-reviews .tw-section-sub { color: #5a6a85 !important; }
/* Reviews premium — customizer.css */
.tw-reviews__cta a {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  text-decoration: none !important;
  box-shadow: 0 6px 24px rgba(87,214,226,0.3) !important;
}

/* ---- BUSINESS SECTION ---- */
.tw-business {
  background: linear-gradient(135deg, #071224 0%, #0d2040 100%) !important;
  padding: 50px 0 !important;
}
.tw-business__inner {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}
.tw-business__content .tw-section-badge { margin-bottom: 16px; }
.tw-business__content h2 {
  font-size: clamp(1.8rem, 3vw, 2.5rem) !important;
  font-weight: 800 !important;
  color: #fff !important;
  line-height: 1.2 !important;
  margin-bottom: 16px !important;
}
.tw-business__content .tw-green { color: #57d6e2 !important; }
.tw-business__content > p {
  color: rgba(255,255,255,0.7) !important;
  font-size: 1rem !important;
  line-height: 1.75 !important;
  margin-bottom: 32px !important;
}
.tw-business__features {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 20px !important;
  margin-bottom: 36px !important;
}
.tw-business__feature {
  background: rgba(255,255,255,0.06) !important;
  border: 1px solid rgba(255,255,255,0.1) !important;
  border-radius: 14px !important;
  padding: 18px !important;
}
.tw-business__feature-icon {
  width: 40px !important;
  height: 40px !important;
  background: rgba(87,214,226,0.15) !important;
  border-radius: 10px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #57d6e2 !important;
  font-size: 1rem !important;
  margin-bottom: 12px !important;
}
.tw-business__feature h4 {
  font-size: 0.95rem !important;
  font-weight: 700 !important;
  color: #fff !important;
  margin-bottom: 4px !important;
}
.tw-business__feature p {
  font-size: 0.82rem !important;
  color: rgba(255,255,255,0.6) !important;
  line-height: 1.5 !important;
  margin: 0 !important;
}
.tw-business__cta {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  background: linear-gradient(135deg, #57d6e2, #29a0ac) !important;
  color: #fff !important;
  padding: 16px 32px !important;
  border-radius: 50px !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  box-shadow: 0 8px 28px rgba(87,214,226,0.3) !important;
}
.tw-business__image {
  border-radius: 24px !important;
  overflow: hidden !important;
  box-shadow: 0 20px 60px rgba(0,0,0,0.3) !important;
}
.tw-business__image img {
  width: 100% !important;
  height: 460px !important;
  object-fit: cover !important;
  display: block !important;
}

/* ---- FAQ SECTION ---- */
.tw-faq {
  background: #f7faff !important;
  padding: 50px 0 !important;
}
.tw-faq__inner {
  max-width: 900px !important;
  margin: 0 auto !important;
}
.tw-faq .tw-section-header {
  text-align: center;
  margin-bottom: 48px;
}
.tw-faq .tw-section-header h2 {
  font-size: clamp(1.8rem, 3vw, 2.4rem) !important;
  font-weight: 800 !important;
  color: #0d1b3e !important;
  margin-bottom: 10px !important;
}
.tw-faq .tw-green { color: #57d6e2 !important; }
.tw-faq .tw-section-sub { color: #5a6a85 !important; font-size: 1rem !important; }
.tw-faq__item {
  background: #fff !important;
  border: 1px solid rgba(87,214,226,0.15) !important;
  border-radius: 16px !important;
  margin-bottom: 12px !important;
  overflow: hidden !important;
  transition: box-shadow 0.2s !important;
}
.tw-faq__item:hover {
  box-shadow: 0 4px 20px rgba(87,214,226,0.1) !important;
}
.tw-faq__question {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 20px 24px !important;
  cursor: pointer !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: #0d1b3e !important;
}
.tw-faq__question span { flex: 1; }
.tw-faq__icon {
  color: #57d6e2 !important;
  font-size: 0.9rem !important;
  transition: transform 0.2s !important;
  flex-shrink: 0 !important;
  margin-left: 12px !important;
}
.tw-faq__item.open .tw-faq__icon { transform: rotate(45deg) !important; }
.tw-faq__answer {
  padding: 0 24px 20px !important;
  color: #5a6a85 !important;
  font-size: 0.93rem !important;
  line-height: 1.75 !important;
  display: none;
}
.tw-faq__item.open .tw-faq__answer { display: block; }

/* ---- CTA SECTION ---- */
.tw-cta {
  background: linear-gradient(135deg, #0b1d3a 0%, #0d2545 60%, #063d4f 100%) !important;
  padding: 50px 0 !important;
  text-align: center !important;
  position: relative !important;
  overflow: hidden !important;
}
.tw-cta::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url('https://images.unsplash.com/photo-1451187580459-43490279c0fa?w=1400&auto=format&fit=crop&q=60') center/cover no-repeat;
  opacity: 0.06;
}
.tw-cta__inner {
  max-width: 700px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
.tw-cta__inner .tw-section-badge {
  margin-bottom: 20px;
  background: rgba(87,214,226,0.15) !important;
  color: #57d6e2 !important;
  border-color: rgba(87,214,226,0.4) !important;
}
.tw-cta__inner h2 {
  font-size: clamp(1.8rem, 3.5vw, 2.8rem) !important;
  font-weight: 800 !important;
  color: #fff !important;
  line-height: 1.2 !important;
  margin-bottom: 14px !important;
}
.tw-cta__inner .tw-green { color: #57d6e2 !important; }
.tw-cta__inner > p {
  color: rgba(255,255,255,0.75) !important;
  font-size: 1.05rem !important;
  line-height: 1.7 !important;
  margin-bottom: 36px !important;
}
.tw-cta__form {
  display: flex !important;
  gap: 10px !important;
  max-width: 520px !important;
  margin: 0 auto 28px !important;
}
.tw-cta__input {
  flex: 1 !important;
  background: rgba(255,255,255,0.12) !important;
  border: 1.5px solid rgba(255,255,255,0.25) !important;
  border-radius: 12px !important;
  color: #fff !important;
  padding: 15px 20px !important;
  font-size: 1rem !important;
}
.tw-cta__input::placeholder { color: rgba(255,255,255,0.5) !important; }
.tw-btn, .tw-btn--primary {
  background: linear-gradient(135deg, #57d6e2, #29a0ac) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 12px !important;
  padding: 15px 28px !important;
  font-weight: 700 !important;
  font-size: 0.95rem !important;
  cursor: pointer !important;
  white-space: nowrap !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  box-shadow: 0 6px 24px rgba(87,214,226,0.35) !important;
}
.tw-cta__trust {
  display: flex !important;
  justify-content: center !important;
  flex-wrap: wrap !important;
  gap: 8px 20px !important;
}
.tw-cta__trust-item {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  color: rgba(255,255,255,0.7) !important;
  font-size: 0.83rem !important;
  font-weight: 500 !important;
}
.tw-cta__trust-item i { color: #57d6e2 !important; font-size: 13px !important; }

/* ---- RESPONSIVE BREAKPOINTS ---- */
@media (max-width: 1100px) {
  .tw-hero__inner { flex-direction: column !important; padding: 0 20px !important; min-height: auto !important; }

  .tw-hero__content { max-width: 100% !important; }

  .tw-hero__right { width: 100% !important; }

  .tw-family__inner, .tw-why__inner, .tw-coverage__inner, .tw-business__inner { grid-template-columns: 1fr !important; gap: 40px !important; }

  .tw-family { padding: 40px 0 !important; }

  .tw-packages { padding: 40px 0 !important; }

  .tw-why, .tw-coverage, .tw-how, .tw-tech, .tw-reviews, .tw-business, .tw-faq, .tw-cta { padding: 40px 0 !important; }

}
@media (max-width: 991px) {
  .tw-about-grid {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
    padding: 0 20px !important;
  }
}

@media (max-width: 768px) {
  .tw-inner-hero { padding-left: 16px !important; padding-right: 16px !important; }
  .tw-inner-hero--split .tw-inner-hero__inner { grid-template-columns: 1fr !important; gap: 28px !important; }
  .tw-inner-hero__panel { grid-template-columns: 1fr 1fr !important; }
  .tw-inner-cta__inner { flex-direction: column !important; align-items: flex-start !important; text-align: left !important; }
  .tw-inner-cta__actions { width: 100% !important; justify-content: flex-start !important; }
  .tw-inner-section { padding: 40px 0 !important; }
  .tw-inner-section__inner { padding: 0 16px !important; }
  .tw-inner-section__header { margin-bottom: 32px !important; }
  .tw-about-values { grid-template-columns: 1fr !important; gap: 16px !important; }
  .tw-team-grid { grid-template-columns: 1fr !important; gap: 16px !important; }
  .tw-inner-cta { padding: 40px 16px !important; }
  .tw-inner-cta__actions { flex-direction: column !important; align-items: stretch !important; }
  .tw-inner-cta .tw-btn--primary,
  .tw-inner-cta .tw-btn--phone { width: 100% !important; justify-content: center !important; }
  .tw-contact-grid { padding: 0 16px !important; gap: 32px !important; }
}

@media (max-width: 640px) {
  .tw-hero__inner { padding: 0 16px !important; }

  .tw-hero__search-form { flex-direction: column !important; }

  .tw-hero__stats-row { grid-template-columns: 1fr 1fr !important; }

  .tw-family, .tw-packages, .tw-why, .tw-coverage, .tw-how, .tw-tech, .tw-reviews, .tw-business, .tw-faq, .tw-cta { padding: 36px 0 !important; }

  .tw-family__content { overflow: visible !important; word-break: break-word !important; overflow-wrap: break-word !important; max-width: 100% !important; }

  .tw-how__steps { grid-template-columns: 1fr !important; }

  .tw-tech__grid { grid-template-columns: 1fr !important; }

  .tw-tech__card { overflow: visible !important; word-break: break-word !important; }

  .tw-stats__inner { grid-template-columns: 1fr 1fr !important; }

  .tw-coverage__stats { grid-template-columns: 1fr 1fr !important; }

  .tw-coverage__form-row { flex-direction: column !important; gap: 10px !important; }

  .tw-coverage__input { width: 100% !important; min-width: 0 !important; }

  .tw-coverage__submit { width: 100% !important; }

  .tw-business__features { grid-template-columns: 1fr !important; }

  .tw-cta__form { flex-direction: column !important; }

  .tw-cta__input { width: 100% !important; min-width: 0 !important; }

  .tw-pkg-tabs { flex-wrap: wrap !important; justify-content: center !important; gap: 8px !important; }

  .tw-pkg-cta { padding: 10px 18px !important; font-size: 0.85rem !important; }

}

/* === TARGETED FIXES: Nav border + Button size only === */
.tw-nav-link--active::after,.current-menu-item > .tw-nav-link::after,.current-menu-ancestor > .tw-nav-link::after{width:calc(100% - 28px)!important;left:14px!important;}
.tw-pkg-card{text-align:left!important;}
.tw-pkg-cta{text-align:center!important;}