/* ThreeTel Site Styles (cleaned + de-duplicated) */

/* =========================
   Core variables + base
   ========================= */
:root{
  /* Brand */
  --teal:#0b6b6b;
  --blue:#2bb0d8;
  --orange:#ff9a2f;

  /* Base UI */
  --bg:#ffffff;
  --page-bg:#f6fafb;
  --text:#0b0f0f;

  /* Checkout UI tokens */
  --card-bg:#fff;
  --page-bg:#f7f8fa;
  --muted:#667085;
  --border:rgba(16,24,40,.12);
  --shadow:0 10px 25px rgba(16,24,40,.08);
  --radius:16px;
  --radius-sm:12px;
  --focus:#009FC1;
  --accent:#FF8300;
  --success:#2e7d32;
  --danger:#d92d20;
}

*{ box-sizing:border-box; }

body{
  margin:0;
  font-family: Arial, Helvetica, sans-serif;
  color:var(--text);
  background:var(--page-bg);
}

.container{
  max-width:1200px;
  margin:0 auto;
  padding:0 18px;
}

/* =========================
   Header
   ========================= */
.site-header{
  background:#fff;
  border-bottom:1px solid rgba(0,0,0,.08);
  position:sticky;
  top:0;
  z-index:50;
}

.header-inner{
  display:flex;
  align-items:center;
  gap:16px;
  padding:12px 0;
}

.logo img{ height:42px; width:auto; display:block; }

.main-nav ul,
.nav-list{
  list-style:none;
  display:flex;
  gap:14px;
  padding:0;
  margin:0;
  align-items:center;
}

.main-nav a,
.nav-list a{
  text-decoration:none;
  color:var(--teal);
  font-weight:700;
  padding:10px 10px;
  border-radius:10px;
}

.main-nav a:hover,
.nav-list a:hover{
  background:rgba(0,159,193,.10);
}

.btn-nav{
  background:var(--orange);
  color:#fff !important;
}

/* Mobile Nav toggle */
.nav-toggle{
  display:none;
  background:none;
  border:0;
  cursor:pointer;
  padding:8px;
}

.nav-toggle span{
  display:block;
  width:24px;
  height:2px;
  margin:5px 0;
  background: var(--teal);
  transition: transform .25s ease, opacity .25s ease;
}

/* Mobile */

/* (Removed old mobile dropdown nav block to prevent blank drawer) */


/* Dropdown (Services menu) */
.has-dropdown{ position:relative; }
.has-dropdown > a{
  display:flex;
  align-items:center;
  gap:6px;
}
.dropdown{
  position:absolute;
  top:100%;
  left:0;
  background:#fff;
  min-width:220px;
  border-radius:10px;
  box-shadow:0 12px 30px rgba(0,0,0,.12);
  padding:8px 0;
  list-style:none;
  opacity:0;
  visibility:hidden;
  transform:translateY(8px);
  transition:all .2s ease;
  z-index:100;
}
.has-dropdown:hover .dropdown{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}
.dropdown li a{
  display:block;
  padding:10px 16px;
  color:#0b0f0f;
  text-decoration:none;
  font-size:14px;
}
.dropdown li a:hover{
  background:rgba(0,159,193,.08);
  color:var(--blue);
}
.dropdown .disabled{
  padding:10px 16px;
  font-size:14px;
  color:#999;
  cursor:not-allowed;
}
.dropdown .disabled small{
  font-size:12px;
  color:#bbb;
}
.dropdown .disabled:hover{ background:none; }

/* Cart badge */
.nav-cart{ position:relative; font-weight:700; }
.nav-cart .cart-badge{
  display:inline-block;
  margin-left:6px;
  padding:2px 7px;
  border-radius:999px;
  font-size:12px;
  line-height:1.2;
  background:#111;
  color:#fff;
}

/* =========================
   Social Icons (Header + Footer)
   ========================= */
.tt-header__social{
  display:flex;
  gap:10px;
  align-items:center;
  margin-left:auto;
}

.tt-social{
  width:36px;
  height:36px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(0,0,0,.10);
  transition: all .25s ease;
  text-decoration:none;
}

.tt-social svg{
  width:18px;
  height:18px;
  fill:#fff;
}

/* Header icons on white header */
.site-header .tt-social{ background: rgba(4,39,39,.10); }
.site-header .tt-social svg{ fill: var(--teal); }

/* Footer icons */
.tt-footer .tt-social{ background: rgba(255,255,255,.08); }
.tt-footer .tt-social svg{ fill:#fff; }

/* Hover colors */
.tt-social--fb:hover{ background:#1877f2; }
.tt-social--ig:hover{ background: linear-gradient(45deg,#f58529,#dd2a7b,#8134af); }
.tt-social--wa:hover{ background:#25D366; }

/* Accessibility focus */
.tt-social:focus-visible,
.tt-footer a:focus-visible{
  outline:2px solid var(--blue);
  outline-offset:3px;
  border-radius:12px;
}

/* Mobile: slightly smaller icons */
@media (max-width: 560px){
  .tt-social{ width:32px; height:32px; border-radius:10px; }
  .tt-social svg{ width:16px; height:16px; }
}

/* =========================
   Global content
   ========================= */
.content{ padding:34px 0; }
.content h2{ color:var(--teal); margin:0 0 10px; }
.content p{ line-height:1.65; max-width:900px; }

/* Buttons */
.btn-primary{
  display:inline-block;
  background:var(--blue);
  color:#fff;
  text-decoration:none;
  padding:12px 16px;
  border-radius:12px;
  font-weight:800;
}

.btn-secondary{
  display:inline-block;
  background:#fff;
  color:var(--teal);
  text-decoration:none;
  padding:12px 16px;
  border-radius:12px;
  font-weight:900;
  border:1px solid rgba(0,0,0,.14);
}
.btn-secondary:hover{ border-color: rgba(0,159,193,.45); }

/* =========================
   HERO (background image version)
   ========================= */
.hero{
  background:
    linear-gradient(90deg, rgba(4,39,39,.72), rgba(4,39,39,.18)),
    url("../images/home.jpg") center/cover no-repeat;
  padding:80px 0;
}

.hero-inner{ max-width:800px; }

.hero h1{
  margin:0 0 10px;
  font-size:40px;
  line-height:1.1;
  color:#fff;
  text-shadow:0 6px 18px rgba(0,0,0,.35);
}

.hero p{
  margin:0 0 18px;
  font-size:18px;
  opacity:.92;
  color:#fff;
  text-shadow:0 6px 18px rgba(0,0,0,.35);
}

.hero .btn-primary{ background: var(--orange); }

@media (max-width: 700px){
  .hero{
    background:
      linear-gradient(180deg, rgba(4,39,39,.78), rgba(4,39,39,.28)),
      url("../images/home.jpg") center/cover no-repeat;
    padding:56px 0;
  }
  .hero h1{ font-size:34px; }
}

@media (max-width: 520px){
  .hero h1{ font-size:30px; }
}

.hero-content{ max-width:520px; }

.hero-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.16);
  color:#fff;
  border:1px solid rgba(255,255,255,.22);
  font-weight:800;
  font-size:13px;
  margin-bottom:12px;
  backdrop-filter: blur(6px);
}

/* ==================================
   HERO EYEBROW — Make "THREETEL HOME" prominent
   ================================== */

.hero-eyebrow{
  font-size: 14px;        /* was 13 */
  font-weight: 900;
  letter-spacing: .10em;
  padding: 7px 14px;      /* bigger pill */
}



.hero-icon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--orange);
  transform: translateY(1px);
}

.hero-icon svg{
  width:18px;
  height:18px;
  display:block;
}
.hero-icon svg path{
  fill: var(--orange);
  stroke:#ffffff;
  stroke-width:1.5;
  paint-order: stroke fill;
  filter: drop-shadow(0 1px 2px rgba(0,0,0,.45));
}

.hero-price{
  font-size:28px;
  font-weight:800;
  margin:10px 0 14px;
  color:#fff;
  animation: pricePulse 2.2s ease-in-out infinite;
  transform-origin:left center;
}
.hero-price span{
  font-size:14px;
  font-weight:500;
  opacity:.85;
}

@keyframes pricePulse{
  0%, 100% { transform: translateY(0) scale(1); }
  50%      { transform: translateY(-1px) scale(1.03); }
}

.hero-features{
  list-style:none;
  padding:0;
  margin:0 0 20px;
}
.hero-features li{
  margin:6px 0;
  padding-left:18px;
  position:relative;
  color:#fff;
  font-size:15px;
}
.hero-features li::before{
  content:"✓";
  position:absolute;
  left:0;
  color:var(--orange);
  font-weight:800;
}

.hero-note{
  margin:6px 0 14px;
  font-size:13px;
  color:rgba(255,255,255,.9);
}
.hero-note a{
  color:var(--orange);
  font-weight:800;
  text-decoration:underline;
}
.hero-note a:hover{ opacity:.85; }

/* Hero variants */
.hero--plans{
  background:
    linear-gradient(90deg, rgba(4,39,39,.72), rgba(4,39,39,.18)),
    url("../images/plans_img.jpg") center/cover no-repeat;
}
.hero--features{
  background:
    linear-gradient(90deg, rgba(4,39,39,.78), rgba(4,39,39,.22)),
    url("../images/home.jpg") center/cover no-repeat;
}
.hero--how{
  background:
    linear-gradient(90deg, rgba(4,39,39,.78), rgba(4,39,39,.22)),
    url("../images/home.jpg") center/cover no-repeat;
}
.hero--faq{
  background:
    linear-gradient(90deg, rgba(4,39,39,.78), rgba(4,39,39,.22)),
    url("../images/home.jpg") center/cover no-repeat;
}
.hero--contact{
  background:
    linear-gradient(90deg, rgba(4,39,39,.78), rgba(4,39,39,.22)),
    url("../images/home.jpg") center/cover no-repeat;
}

/* =============================
   HERO WITH REAL IMAGE (CONTROLLED HEIGHT)
   (Use with: <div class="hero-img"> <img class="hero-img-bg"> ... )
   ============================= */
.hero-img{
  position:relative;
  overflow:hidden;
  background:#042727;
  height:clamp(320px, 38vw, 520px);
}

.hero-img-bg{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center 25%;
  display:block;
}

.hero-overlay{
  position:absolute;
  inset:0;
  background: linear-gradient(90deg, rgba(4,39,39,.85), rgba(4,39,39,.35));
}

.hero-img .hero-inner{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
}

/* Mobile: slightly taller + safe crop */
@media (max-width: 768px){
  .hero-img{ height:360px; }
  .hero-img-bg{ object-position:center 20%; }
}

/* =========================
   Reasons
   ========================= */
.reasons{
  padding:46px 0;
  background:#fff;
}

.reasons-head{
  max-width:850px;
  margin-bottom:18px;
}

.reasons-head h2{
  margin:0 0 8px;
  color:var(--teal);
  font-size:28px;
}

.reasons-head p{
  margin:0;
  opacity:.78;
  line-height:1.6;
}

.reasons-grid{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:14px;
  margin-top:18px;
}

.reason-card{
  grid-column:span 4;
  padding:18px;
  border-radius:16px;
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 10px 28px rgba(0,0,0,.06);
  background:#fff;
  position:relative;
  overflow:hidden;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.reason-card:hover{
  transform:translateY(-4px);
  box-shadow:0 18px 40px rgba(0,0,0,.10);
  border-color: rgba(0,159,193,.35);
}
.reason-card:hover .reason-icon{ transform:scale(1.06); }

.reason-card h3{
  margin:10px 0 8px;
  color:var(--teal);
  font-size:18px;
}

.reason-card p{
  margin:0;
  opacity:.82;
  line-height:1.55;
}

.reason-icon{
  width:40px;
  height:40px;
  border-radius:12px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  background: rgba(0,159,193,.12);
  color: var(--blue);
  transition: transform .25s ease;
}

.reason-card--accent{
  border-color: rgba(255,131,0,.35);
  background: linear-gradient(180deg, rgba(255,131,0,.10), rgba(0,159,193,.06));
}

.reason-link{
  display:inline-block;
  margin-top:10px;
  font-weight:900;
  color:var(--orange);
  text-decoration:none;
}
.reason-link:hover{ text-decoration:underline; opacity:.9; }

@media (max-width: 980px){
  .reason-card{ grid-column: span 6; }
}
@media (max-width: 620px){
  .reason-card{ grid-column: span 12; }
  .reasons-head h2{ font-size:24px; }
}

/* =========================
   Plans
   ========================= */
.plans{
  padding:46px 0;
  background:#f7fafa;
}

.plans-head{
  max-width:850px;
  margin-bottom:16px;
}
.plans-head h2{
  margin:0 0 8px;
  color:var(--teal);
  font-size:28px;
}
.plans-head p{
  margin:0;
  opacity:.78;
  line-height:1.6;
}
.plans-head a{
  color:var(--orange);
  font-weight:900;
  text-decoration:none;
}
.plans-head a:hover{ text-decoration:underline; }

.plans-grid{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:16px;
  margin-top:18px;
}

.plan-card{
  grid-column:span 4;
  background:#fff;
  border-radius:18px;
  padding:22px;
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 14px 36px rgba(0,0,0,.08);
  position:relative;
  overflow:hidden;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.plan-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 44px rgba(0,0,0,.10);
  border-color: rgba(0,159,193,.35);
}

.plan-card h3{
  margin:0 0 10px;
  color:var(--teal);
  font-size:18px;
}

.plan-price{
  font-size:32px;
  font-weight:900;
  color:var(--teal);
  margin-bottom:14px;
}
.plan-price span{
  font-size:14px;
  font-weight:500;
  opacity:.7;
}

.plan-features{
  list-style:none;
  padding:0;
  margin:0 0 16px;
}
.plan-features li{
  margin:8px 0;
  font-size:15px;
  line-height:1.4;
}
.plan-features li::before{
  content:"✓";
  color:var(--orange);
  font-weight:900;
  margin-right:8px;
}

.plan-cta{ width:100%; text-align:center; }

.plan-footnote{
  margin-top:10px;
  font-size:12px;
  opacity:.7;
  text-align:center;
}

.plan-card--featured{
  border-color: rgba(255,131,0,.45);
  background: linear-gradient(180deg, rgba(255,131,0,.08), rgba(0,159,193,.05));
}

.plan-badge{
  position:absolute;
  top:14px;
  right:14px;
  background:var(--orange);
  color:#fff;
  font-size:11px;
  font-weight:900;
  padding:4px 8px;
  border-radius:999px;
}

.plans-trust{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:14px;
  margin-top:18px;
}
.plans-trust__item{
  grid-column: span 4;
  background:#fff;
  border-radius:16px;
  padding:16px;
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 10px 28px rgba(0,0,0,.06);
}
.plans-trust__item strong{
  display:block;
  color:var(--teal);
  margin-bottom:6px;
}
.plans-trust__item span{ opacity:.78; }

.plans-note{
  margin-top:18px;
  font-size:13px;
  opacity:.7;
  text-align:center;
}

@media (max-width: 980px){
  .plan-card{ grid-column: span 6; }
  .plans-trust__item{ grid-column: span 6; }
}
@media (max-width: 620px){
  .plan-card{ grid-column: span 12; }
  .plans-trust__item{ grid-column: span 12; }
  .plans-head h2{ font-size:24px; }
}

/* =========================
   Features Page
   ========================= */
.features{
  padding:46px 0;
  background:#fff;
}

.features-head{
  max-width:850px;
  margin-bottom:16px;
}
.features-head h2{
  margin:0 0 8px;
  color:var(--teal);
  font-size:28px;
}
.features-head p{
  margin:0;
  opacity:.78;
  line-height:1.6;
}

.features-grid{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:14px;
  margin-top:18px;
}

.feature-card{
  grid-column:span 3;
  padding:16px;
  border-radius:16px;
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 10px 28px rgba(0,0,0,.06);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.feature-card:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 40px rgba(0,0,0,.10);
  border-color: rgba(0,159,193,.35);
}

.feature-icon{
  width:44px;
  height:44px;
  border-radius:14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:18px;
  background: rgba(0,159,193,.12);
}

.feature-card h3{
  margin:10px 0 8px;
  color:var(--teal);
  font-size:16px;
}
.feature-card p{
  margin:0;
  opacity:.82;
  line-height:1.5;
  font-size:14px;
}

/* Highlight section */
.feature-highlight{
  padding:46px 0;
  background:#f7fafa;
}
.feature-highlight__inner{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:16px;
  align-items:stretch;
}
.feature-highlight__text{
  grid-column: span 7;
  background:#fff;
  border-radius:18px;
  padding:22px;
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 14px 36px rgba(0,0,0,.06);
}
.feature-highlight__text h2{ margin:0 0 10px; color:var(--teal); }
.feature-highlight__text p{
  margin:0 0 14px;
  opacity:.82;
  line-height:1.6;
}

.feature-bullets{
  list-style:none;
  padding:0;
  margin:0 0 16px;
}
.feature-bullets li{ margin:8px 0; }
.feature-bullets li::before{
  content:"✓";
  color:var(--orange);
  font-weight:900;
  margin-right:8px;
}

.feature-highlight__card{
  grid-column: span 5;
  border-radius:18px;
  padding:22px;
  background: linear-gradient(180deg, rgba(255,131,0,.10), rgba(0,159,193,.06));
  border:1px solid rgba(255,131,0,.28);
  box-shadow:0 14px 36px rgba(0,0,0,.06);
  display:grid;
  gap:12px;
}
.feature-mini{
  background: rgba(255,255,255,.72);
  border:1px solid rgba(0,0,0,.06);
  border-radius:16px;
  padding:14px;
}
.feature-mini strong{
  display:block;
  color:var(--teal);
  margin-bottom:4px;
}
.feature-mini span{ opacity:.78; }

/* CTA */
.feature-cta{
  padding:46px 0;
  background:#fff;
}
.feature-cta__inner{
  border-radius:18px;
  padding:26px;
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 14px 36px rgba(0,0,0,.06);
  background: linear-gradient(120deg, rgba(0,159,193,.10), rgba(255,131,0,.08));
}
.feature-cta__inner h2{ margin:0 0 8px; color:var(--teal); }
.feature-cta__inner p{ margin:0 0 16px; opacity:.82; }
.feature-cta__actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

@media (max-width: 980px){
  .feature-card{ grid-column: span 6; }
  .feature-highlight__text{ grid-column: span 12; }
  .feature-highlight__card{ grid-column: span 12; }
}
@media (max-width: 620px){
  .feature-card{ grid-column: span 12; }
  .features-head h2{ font-size:24px; }
}

/* =========================
   How It Works
   ========================= */
.how{
  padding:46px 0;
  background:#fff;
}

.how-head{
  max-width:850px;
  margin-bottom:16px;
}
.how-head h2{
  margin:0 0 8px;
  color:var(--teal);
  font-size:28px;
}
.how-head p{
  margin:0;
  opacity:.78;
  line-height:1.6;
}

.how-grid{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:14px;
  margin-top:18px;
}

.how-step{
  grid-column: span 3;
  padding:18px;
  border-radius:16px;
  background:#fff;
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 10px 28px rgba(0,0,0,.06);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.how-step:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 40px rgba(0,0,0,.10);
  border-color: rgba(0,159,193,.35);
}

.how-num{
  width:42px;
  height:42px;
  border-radius:14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  color:#fff;
  background: var(--blue);
}

.how-step h3{
  margin:10px 0 8px;
  color:var(--teal);
  font-size:16px;
}
.how-step p{
  margin:0;
  opacity:.82;
  line-height:1.5;
  font-size:14px;
}
.how-link{
  display:inline-block;
  margin-top:10px;
  font-weight:900;
  color:var(--orange);
  text-decoration:none;
}
.how-link:hover{ text-decoration:underline; opacity:.9; }

/* Callout */
.how-callout{
  padding:46px 0;
  background:#f7fafa;
}
.how-callout__inner{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:16px;
  align-items:stretch;
}
.how-callout__card{
  grid-column: span 7;
  background:#fff;
  border-radius:18px;
  padding:22px;
  border:1px solid rgba(0,0,0,.06);
  box-shadow:0 14px 36px rgba(0,0,0,.06);
}
.how-callout__card h2{ margin:0 0 10px; color:var(--teal); }
.how-callout__card p{
  margin:0 0 14px;
  opacity:.82;
  line-height:1.6;
}

.how-bullets{
  list-style:none;
  padding:0;
  margin:0 0 16px;
}
.how-bullets li{ margin:8px 0; }
.how-bullets li::before{
  content:"✓";
  color:var(--orange);
  font-weight:900;
  margin-right:8px;
}

.how-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}

.how-callout__side{
  grid-column: span 5;
  border-radius:18px;
  padding:22px;
  background: linear-gradient(180deg, rgba(255,131,0,.10), rgba(0,159,193,.06));
  border:1px solid rgba(255,131,0,.28);
  box-shadow:0 14px 36px rgba(0,0,0,.06);
  display:grid;
  gap:12px;
}

.how-mini{
  background: rgba(255,255,255,.72);
  border:1px solid rgba(0,0,0,.06);
  border-radius:16px;
  padding:14px;
}
.how-mini strong{
  display:block;
  color:var(--teal);
  margin-bottom:4px;
}
.how-mini span{ opacity:.78; }

@media (max-width: 980px){
  .how-step{ grid-column: span 6; }
  .how-callout__card{ grid-column: span 12; }
  .how-callout__side{ grid-column: span 12; }
}
@media (max-width: 620px){
  .how-step{ grid-column: span 12; }
  .how-head h2{ font-size:24px; }
}

/* =========================
   Setup Guide + Video
   ========================= */
.setup{
  padding:46px 0;
  background:#fff;
}

.setup-inner{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:18px;
  align-items:center;
}

.setup-text{ grid-column: span 6; }
.setup-text h2{ margin:0 0 10px; color:var(--teal); }
.setup-text p{ margin:0 0 14px; line-height:1.6; opacity:.82; }

.setup-steps{ margin:0; padding-left:18px; }
.setup-steps li{ margin:10px 0; line-height:1.5; }
.setup-steps strong{ color:var(--teal); }

.setup-visual{
  grid-column: span 6;
  background:#fff;
  border-radius:18px;
  padding:16px;
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 14px 36px rgba(0,0,0,.08);
}
.setup-visual img{ width:100%; height:auto; display:block; }

.setup-video{
  padding:40px 0;
  background:#f7fafa;
}
.video-wrap{
  position:relative;
  padding-bottom:56.25%;
  height:0;
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 16px 40px rgba(0,0,0,.12);
}
.video-wrap iframe{
  position:absolute;
  top:0; left:0;
  width:100%; height:100%;
  border:0;
}

@media (max-width: 900px){
  .setup-text,
  .setup-visual{ grid-column: span 12; }
}

/* How Help CTA */
.how-help{
  padding:46px 0;
  background:#fff;
}
.how-help__inner{
  text-align:center;
  max-width:820px;
}
.how-help__inner h2{ margin:0 0 8px; color:var(--teal); }
.how-help__inner p{ margin:0 0 16px; opacity:.82; }
.how-help__actions{
  display:flex;
  gap:12px;
  justify-content:center;
  flex-wrap:wrap;
}

/* =========================
   FAQ
   ========================= */
.faq{
  padding:46px 0;
  background:#fff;
}

.faq-head{
  max-width:900px;
  margin-bottom:16px;
}
.faq-head h2{
  margin:0 0 8px;
  color:var(--teal);
  font-size:28px;
}
.faq-head p{
  margin:0 0 12px;
  opacity:.78;
  line-height:1.6;
}

.faq-search input{
  width:100%;
  max-width:640px;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.18);
  outline:none;
}
.faq-search input:focus{
  border-color: var(--blue);
  box-shadow:0 0 0 4px rgba(0,159,193,.18);
}

.faq-list{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:14px;
  margin-top:16px;
}

.faq-item{
  grid-column: span 12;
  background:#fff;
  border-radius:16px;
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 10px 28px rgba(0,0,0,.06);
  overflow:hidden;
}

.faq-item summary{
  list-style:none;
  cursor:pointer;
  padding:16px 18px;
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
  color:var(--teal);
  font-weight:900;
}
.faq-item summary::-webkit-details-marker{ display:none; }

.faq-icon{
  width:34px;
  height:34px;
  border-radius:12px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background: rgba(0,159,193,.12);
  color: var(--teal);
  font-size:18px;
  flex:0 0 auto;
}

.faq-body{
  padding:0 18px 16px;
  opacity:.86;
  line-height:1.65;
}

.faq-actions{ margin-top:10px; }
.faq-link{
  color:var(--orange);
  font-weight:900;
  text-decoration:none;
}
.faq-link:hover{ text-decoration:underline; }

/* =========================
   Contact Page
   ========================= */
.contact-modern{
  padding:46px 0;
  background:#fff;
}

.contact-modern__grid{
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  gap:24px;
}

.contact-info{ grid-column: span 5; }
.contact-info h2{ margin:0 0 8px; color:var(--teal); }
.contact-info p{ margin:0 0 16px; opacity:.82; }

.contact-card{
  padding:14px 16px;
  border-radius:16px;
  border:1px solid rgba(0,0,0,.08);
  background:#fff;
  box-shadow:0 10px 26px rgba(0,0,0,.06);
  margin-bottom:12px;
}
.contact-card strong{
  display:block;
  color:var(--teal);
  margin-bottom:4px;
}
.contact-card p{
  margin:0;
  opacity:.85;
  line-height:1.55;
}

.contact-form{
  grid-column: span 7;
  padding:22px;
  border-radius:20px;
  border:1px solid rgba(0,0,0,.08);
  box-shadow:0 14px 36px rgba(0,0,0,.08);
  background:#fff;
}
.contact-form h2{ margin:0 0 6px; color:var(--teal); }
.contact-form p{ margin:0 0 14px; opacity:.8; }

.contact-form__inner{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.form-row{
  display:flex;
  gap:12px;
}

.contact-form input,
.contact-form textarea{
  width:100%;
  padding:12px 14px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.18);
  outline:none;
  font-family: inherit;
}
.contact-form input:focus,
.contact-form textarea:focus{
  border-color: var(--blue);
  box-shadow:0 0 0 4px rgba(0,159,193,.18);
}

.contact-form textarea{ resize:vertical; }

@media (max-width: 900px){
  .contact-info,
  .contact-form{ grid-column: span 12; }
  .form-row{ flex-direction:column; }
}

.form-success{
  padding:12px 14px;
  background: rgba(0,159,193,.12);
  border:1px solid rgba(0,159,193,.35);
  border-radius:14px;
  margin-bottom:12px;
  font-weight:800;
}

.contact-map{ padding:16px; }
.contact-map iframe{
  width:100%;
  height:220px;
  border:0;
  border-radius:14px;
  margin-top:8px;
}
.contact-map strong{ font-size:14px; }

.contact-chat{
  margin-top:20px;
  padding:16px;
  border-radius:18px;
  background: linear-gradient(135deg, rgba(0,159,193,.12), rgba(255,131,0,.12));
  border:1px solid rgba(0,0,0,.06);
}
.contact-chat h3{ margin:0 0 6px; color:var(--teal); }

.recaptcha-placeholder{
  padding:14px;
  border-radius:14px;
  border:1px dashed rgba(0,0,0,.25);
  text-align:center;
  opacity:.6;
  font-size:14px;
}
.g-recaptcha{ margin:10px 0 14px; }

/* =========================
   Terms Accordion (simple)
   ========================= */
.terms-accordion{ max-width:900px; margin:0 auto; }

.terms-item{
  width:100%;
  background:#fff;
  border:1px solid #e5e7eb;
  padding:16px 20px;
  margin-top:12px;
  font-size:16px;
  font-weight:600;
  display:flex;
  justify-content:space-between;
  align-items:center;
  cursor:pointer;
  border-radius:10px;
}
.terms-item:hover{ background:#f9fafb; }

.terms-toggle{
  font-size:20px;
  font-weight:700;
}

.terms-panel{
  display:none;
  padding:16px 20px;
  border-left:3px solid #6366f1;
  background:#fafafa;
  border-radius:0 0 10px 10px;
}

/* =========================
   Checkout (GoDaddy-style)
   ========================= */
.tt-checkout{
  padding:28px 0 48px;
  background: var(--page-bg);
}

.tt-checkout .container{ max-width:1120px; }

.tt-checkout__title{
  font-size:28px;
  line-height:1.2;
  margin:0 0 6px;
  letter-spacing:-.2px;
}
.tt-checkout__subtitle{
  margin:0 0 18px;
  color:var(--muted);
  font-size:14px;
}

.tt-grid{
  display:grid;
  grid-template-columns: 1.45fr .85fr;
  gap:18px;
  align-items:start;
}

.tt-card{
  background:var(--card-bg);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  overflow:hidden;
}

.tt-card__inner{ padding:18px; }

.tt-card__header{ padding:18px 18px 0; }
.tt-card__heading{
  margin:0;
  font-size:16px;
  letter-spacing:-.1px;
}
.tt-card__desc{
  margin:6px 0 0;
  color:var(--muted);
  font-size:13px;
}

/* Sections inside form */
.tt-section{
  padding:16px 18px;
  border-top:1px solid var(--border);
}
.tt-section:first-child{ border-top:0; }

.tt-section__title{
  margin:0 0 12px;
  font-size:14px;
  color:#101828;
  font-weight:700;
}
.tt-section__note{
  margin:-6px 0 12px;
  font-size:13px;
  color:var(--muted);
}

/* Form fields */
.tt-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.tt-field{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.tt-label{
  font-size:13px;
  color:#101828;
  font-weight:600;
}
.tt-label small{
  color:var(--muted);
  font-weight:500;
}

.tt-input, .tt-select{
  height:44px;
  border-radius:12px;
  border:1px solid var(--border);
  padding:0 12px;
  font-size:14px;
  background:#fff;
  outline:none;
  transition:border-color .15s ease, box-shadow .15s ease;
}
.tt-input:focus, .tt-select:focus{
  border-color: rgba(0,159,193,.75);
  box-shadow: 0 0 0 4px rgba(0,159,193,.15);
}

.tt-help{
  font-size:12.5px;
  color:var(--muted);
  line-height:1.35;
}
.tt-error{
  font-size:12.5px;
  color:var(--danger);
  line-height:1.35;
}

/* Slim verification status */
.tt-verify{
  margin-top:10px;
  margin-bottom:14px;
  font-size:13px;
  font-weight:400;
  color:var(--muted);
  display:flex;
  align-items:center;
  gap:8px;
}
.tt-verify--ok{ color:var(--success); }
.tt-verify__pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(46,125,50,.25);
  background: rgba(46,125,50,.06);
  font-size:12.5px;
  font-weight:500;
}

/* Toggles */
.tt-toggle{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:8px;
}
.tt-radio{
  border:1px solid var(--border);
  border-radius:12px;
  padding:10px 12px;
  display:flex;
  align-items:center;
  gap:8px;
  cursor:pointer;
  user-select:none;
  background:#fff;
}
.tt-radio input{ accent-color: var(--focus); }

/* Buttons */
.tt-actions{
  padding:16px 18px;
  border-top:1px solid var(--border);
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:space-between;
}
.tt-btn{
  height:44px;
  border-radius:12px;
  border:1px solid var(--border);
  padding:0 14px;
  background:#fff;
  cursor:pointer;
  font-weight:700;
  font-size:14px;
}
.tt-btn--primary{
  border-color: rgba(0,159,193,.35);
  background: linear-gradient(180deg, rgba(0,159,193,.18), rgba(0,159,193,.10));
}
.tt-btn--primary:hover{ box-shadow:0 10px 20px rgba(0,159,193,.12); }

.tt-btn--accent{
  border-color: rgba(255,131,0,.35);
  background: linear-gradient(180deg, rgba(255,131,0,.18), rgba(255,131,0,.10));
}

/* Order summary */
.tt-summary__line{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:10px 0;
  border-top:1px dashed var(--border);
  font-size:14px;
}
.tt-summary__line:first-child{ border-top:0; }
.tt-summary__label{ color:var(--muted); }
.tt-summary__value{ font-weight:700; }

.tt-summary__total{
  margin-top:8px;
  padding-top:12px;
  border-top:1px solid var(--border);
  display:flex;
  justify-content:space-between;
  font-size:15px;
}
.tt-summary__total .tt-summary__value{ font-size:16px; }

/* Alerts */
.tt-alert{
  border:1px solid rgba(217,45,32,.25);
  background: rgba(217,45,32,.06);
  color:#7a1f1a;
  border-radius:14px;
  padding:12px 14px;
  font-size:13px;
  margin:0 0 14px;
}

/* Porting fields wrapper */
.tt-porting{
  margin-top:12px;
  padding-top:12px;
  border-top:1px dashed var(--border);
}

/* Checkout enhancements (kept) */
h1{
  margin:0 0 6px;
  font-size:28px;
  letter-spacing:-.2px;
}
.hint{
  opacity:.75;
  font-size:14px;
  line-height:1.35;
}
.verified-msg{
  margin:0;
  color:var(--success);
  font-weight:500;
  font-size:14px;
}

/* Tooltip (ⓘ) */
.tip{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:18px;
  height:18px;
  border-radius:999px;
  border:1px solid rgba(16,24,40,.18);
  font-size:12px;
  color:var(--muted);
  cursor:help;
  margin-left:6px;
  user-select:none;
}
.tip:hover::after{
  content:attr(data-tip);
  position:absolute;
  left:50%;
  bottom:130%;
  transform:translateX(-50%);
  width:max-content;
  max-width:260px;
  padding:10px 12px;
  border-radius:12px;
  background:#101828;
  color:#fff;
  font-size:12.5px;
  line-height:1.35;
  box-shadow:0 12px 22px rgba(16,24,40,.25);
  z-index:50;
  white-space:normal;
}
.tip:hover::before{
  content:"";
  position:absolute;
  left:50%;
  bottom:118%;
  transform:translateX(-50%);
  border:7px solid transparent;
  border-top-color:#101828;
}

/* Order Summary (alt classes) */
.summary-row{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:10px 0;
  border-top:1px dashed rgba(16,24,40,.12);
  font-size:14px;
}
.summary-row:first-child{ border-top:0; }
.summary-label{ color:var(--muted); }
.summary-val{ font-weight:700; color:#101828; }
.summary-total{
  margin-top:8px;
  padding-top:12px;
  border-top:1px solid rgba(16,24,40,.12);
  display:flex;
  justify-content:space-between;
  font-size:15px;
}

/* Trust badges (SVG) */
.trust{
  margin-top:14px;
  padding-top:12px;
  border-top:1px dashed rgba(16,24,40,.12);
  display:flex;
  flex-direction:column;
  gap:10px;
}
.trust-item{
  display:flex;
  align-items:flex-start;
  gap:10px;
  color:var(--muted);
  font-size:13px;
  line-height:1.35;
}
.ico{
  width:18px;
  height:18px;
  flex:0 0 18px;
  margin-top:2px;
  color: var(--blue);
}
.trust-title{
  font-weight:600;
  color:#101828;
}

/* Mobile */
@media (max-width: 980px){
  .tt-grid{ grid-template-columns:1fr; }
}
@media (max-width: 640px){
  .tt-checkout{ padding:18px 0 38px; }
  .tt-card__inner, .tt-section, .tt-actions{ padding:14px; }
  .tt-row{ grid-template-columns:1fr; gap:10px; }
  .tt-input, .tt-select{ height:46px; }
  .tt-actions{
    flex-direction:column;
    align-items:stretch;
  }
  .tt-btn{ width:100%; }
}

/* =========================
   Footer
   ========================= */
.tt-footer{
  background:#0b4e57;
  color:#f5f7f7;
  margin-top:40px;
  padding:44px 0 18px;
}
.tt-footer__inner{
  max-width:1200px;
  margin:0 auto;
  padding:0 18px;
  display:grid;
  grid-template-columns: 1.2fr 1fr 1fr 1fr;
  gap:22px;
}
.tt-footer__logo{ height:40px; width:auto; display:block; }
.tt-footer__text{
  margin:12px 0 0;
  opacity:.85;
  line-height:1.5;
  max-width:360px;
}
.tt-footer__title{ margin:6px 0 10px; font-weight:800; font-size:16px; }
.tt-footer__links{ list-style:none; padding:0; margin:0; }
.tt-footer__links li{ margin:8px 0; }
.tt-footer__links a{ color:#f5f7f7; opacity:.85; text-decoration:none; }
.tt-footer__links a:hover{ opacity:1; text-decoration:underline; }

.tt-footer__social{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.tt-footer__bottom{
  max-width:1200px;
  margin:18px auto 0;
  padding:14px 18px 0;
  border-top:1px solid rgba(255,255,255,.12);
  font-size:14px;
  opacity:.85;
}

@media (max-width: 900px){
  .tt-footer__inner{ grid-template-columns:1fr 1fr; }
}
@media (max-width: 520px){
  .tt-footer__inner{ grid-template-columns:1fr; }
}

/* =============================
   HERO IMAGE (element image: NO face cropping) — shared for Plans/Cart/Checkout
   ============================= */
.hero-img{position:relative; overflow:hidden; background:#042727; height:auto;}
.hero-img-bg{width:100%; height:auto; display:block;}
.hero-overlay{position:absolute; inset:0; background:linear-gradient(90deg, rgba(4,39,39,.85), rgba(4,39,39,.35));}
.hero-img .hero-inner{position:absolute; inset:0; display:flex; align-items:center;}
@media (max-width: 768px){
  .hero-img-bg{min-height:260px; object-fit:contain; background:#042727;}
}


/* =========================================================
   HOMEPAGE POLISH (moderate + powerful) — Jan 2026
   Paste-at-end overrides so it applies across pages
   ========================================================= */

/* Global: compact heroes (applies to all pages) */
.hero{
  padding: clamp(40px, 6vw, 56px) 0;
}
.hero h1{
  font-size: clamp(36px, 4vw, 52px);
  font-weight: 900;
  letter-spacing: -0.5px;
  text-shadow: 0 4px 10px rgba(0,0,0,.65), 0 10px 30px rgba(0,0,0,.45);
}
.hero p{
  font-size: 20px;
  font-weight: 500;
  max-width: 640px;
  text-shadow: 0 3px 8px rgba(0,0,0,.6);
}

/* Make CTA row look right in hero as well */
.hero .feature-cta__actions{
  margin-top: 14px;
}

/* Ensure any real-image hero is not too tall */
.hero-img{
  height: clamp(260px, 28vw, 420px);
}
.hero-img-bg{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center; /* hard-center */
}

/* Mobile refinement */
@media (max-width: 768px){
  .hero{ padding: 34px 0; }
  .hero p{ font-size: 18px; }
  .hero-img{ height: 260px; }
}

/* Subtle trust strip under hero */
.home-strip{
  background: var(--page-bg);
  border-bottom: 1px solid rgba(0,0,0,.05);
}
.home-strip__inner{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  padding: 14px 0;
}
.home-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.08);
  background: rgba(43,176,216,.10);
  color: var(--teal);
  font-weight: 800;
  font-size: 13px;
}

/* Plans: make "Most Popular" stand out */
.plan-badge--popular{
  background: var(--blue);
}

/* Testimonials */
.testimonials{
  padding: 46px 0;
  background: #fff;
}
.testimonials-head{
  max-width: 850px;
  margin-bottom: 16px;
}
.testimonials-head h2{
  margin:0 0 8px;
  color: var(--teal);
  font-size: 28px;
}
.testimonials-head p{
  margin:0;
  opacity:.78;
  line-height:1.6;
}
.testimonials-grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 14px;
  margin-top: 18px;
}
.testimonial-card{
  grid-column: span 4;
  background:#fff;
  border-radius: 18px;
  padding: 18px;
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: 0 14px 36px rgba(0,0,0,.06);
  position: relative;
  overflow: hidden;
}
.testimonial-card::before{
  content:"“";
  position:absolute;
  top:10px;
  right:14px;
  font-size: 42px;
  opacity: .12;
  color: var(--teal);
  font-weight: 900;
}
.testimonial-quote{
  margin:0 0 12px;
  line-height:1.65;
  opacity:.88;
}
.testimonial-meta{
  display:flex;
  gap:10px;
  align-items:baseline;
}
.testimonial-meta strong{ color: var(--teal); }
.testimonial-meta span{ color: var(--muted); font-size: 13px; }

@media (max-width: 980px){
  .testimonial-card{ grid-column: span 6; }
}
@media (max-width: 620px){
  .testimonial-card{ grid-column: span 12; }
  .testimonials-head h2{ font-size: 24px; }
}

/* Final CTA band */
.home-cta{
  padding: 46px 0;
  background: #f7fafa;
}
.home-cta__inner{
  border-radius: 20px;
  padding: 26px;
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 14px 36px rgba(0,0,0,.06);
  background: linear-gradient(120deg, rgba(0,159,193,.12), rgba(255,131,0,.10));
}
.home-cta__inner h2{
  margin:0 0 8px;
  color: var(--teal);
}
.home-cta__inner p{
  margin:0 0 16px;
  opacity:.82;
  line-height:1.6;
}
.home-cta__actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
/* =========================
   MOBILE DROPDOWN (Services)
   ========================= */
@media (max-width: 900px){

  /* Make Services row full width + tap-friendly */
  .has-dropdown > a{
    width:100%;
    justify-content:space-between;
  }

  /* Dropdown becomes an accordion in mobile */
  .has-dropdown .dropdown{
    position:static;
    min-width:unset;
    box-shadow:none;
    border-radius:0;
    padding:0;
    margin:0;

    opacity:1;
    visibility:visible;
    transform:none;

    max-height:0;
    overflow:hidden;
    transition:max-height .25s ease;
    border-top:1px solid rgba(0,0,0,.06);
    background:#fff;
  }

  /* When opened */
  .has-dropdown.dd-open .dropdown{
    max-height:260px; /* enough for items */
  }

  /* Indent submenu items */
  .dropdown li a,
  .dropdown .disabled{
    padding-left:28px !important;
  }

  /* Disabled items layout (keep your style but aligned) */
  .dropdown .disabled span{
    display:block;
  }
}
/* =========================================
   CLEAN + MODERN DROPDOWN ALIGN (DESKTOP+MOBILE)
   Paste at end of style.css
   ========================================= */

/* Make ALL top nav links behave the same (prevents "jump") */
.main-nav a,
.nav-list a{
  display:flex;
  align-items:center;
  gap:8px;
  white-space:nowrap;
}

/* Anchor dropdown to the Services item correctly */
.has-dropdown{
  position:relative;
}

/* Desktop dropdown: aligned under Services, consistent width */
@media (min-width: 901px){
  .has-dropdown .dropdown{
    top: calc(100% + 10px);
    left: 0;                 /* align with Services link */
    right: auto;
    min-width: 240px;
    padding: 8px 0;

    border: 1px solid rgba(16,24,40,.10);
    border-radius: 14px;
    box-shadow: 0 18px 45px rgba(0,0,0,.14);

    opacity: 0;
    visibility: hidden;
    transform: translateY(8px);
    transition: opacity .18s ease, transform .18s ease, visibility .18s ease;
    z-index: 120;
  }

  .has-dropdown:hover .dropdown{
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
  }

  /* If dropdown is near the right edge, keep it inside screen */
  .main-nav .has-dropdown:last-child .dropdown{
    left: auto;
    right: 0;
  }
}

/* Mobile dropdown stays accordion (no side shift) */
@media (max-width: 900px){
  .has-dropdown > a{
    width:100%;
    justify-content:space-between; /* caret stays right */
  }

  .has-dropdown .dropdown{
    position: static;
    min-width: unset;
    border: 0;
    box-shadow: none;
    border-radius: 0;
    padding: 0;
    margin: 0;

    opacity: 1;
    visibility: visible;
    transform: none;

    max-height: 0;
    overflow: hidden;
    transition: max-height .25s ease;
    border-top: 1px solid rgba(0,0,0,.06);
    background:#fff;
  }

  .has-dropdown.dd-open .dropdown{
    max-height: 300px;
  }

  .dropdown li a,
  .dropdown .disabled{
    padding-left: 30px !important; /* modern indent */
  }
}
/* =========================================
   CLEAN ALIGN MENU (Ooma-style) - Mobile + Desktop
   ========================================= */

/* Make every top-level link consistent */
.nav-list > li > a{
  display:flex;
  align-items:center;
  justify-content:space-between; /* text left, arrow/right items right */
  gap:10px;
  width:100%;
}

/* Desktop: dropdown stays under Services */
@media (min-width: 901px){
  .nav-list > li > a{ justify-content:flex-start; }
  .has-dropdown > a{ justify-content:flex-start; }
  .has-dropdown > a svg{ margin-left:6px; }

  .has-dropdown{ position:relative; }
  .has-dropdown .dropdown{
    left:0;
    right:auto;
  }
}

/* Mobile: submenu is full-width accordion, perfectly aligned */
@media (max-width: 900px){
  .has-dropdown .dropdown{
    width:100%;
  }
  .dropdown li a,
  .dropdown .disabled{
    padding-left:28px !important;
  }

  /* Nice caret rotate */
  .has-dropdown > a svg{
    transition: transform .2s ease;
  }
  .has-dropdown.dd-open > a svg{
    transform: rotate(180deg);
  }
}



/* =========================================================
   NAV (FINAL CLEAN FIX) — prevents submenu "right panel" + aligns Services
   Paste at VERY END of style.css
   ========================================================= */
@media (max-width: 900px){
  /* Top level items: same look for all */
  .nav-list > li > a{
    display:flex !important;
    align-items:center !important;
    justify-content:flex-start !important;
    gap:10px !important;
    padding:14px 18px !important;
    width:100% !important;
  }

  /* Only dropdown trigger uses space-between (text left, caret right) */
  .has-dropdown > a{
    justify-content:space-between !important;
  }

  /* Submenu must NOT be absolute on mobile (this fixes "submenu on right") */
  .has-dropdown .dropdown{
    position:static !important;
    left:auto !important;
    right:auto !important;
    top:auto !important;
    transform:none !important;
    box-shadow:none !important;
    border-radius:0 !important;

    width:100% !important;
    padding:0 !important;
    margin:0 !important;

    opacity:1 !important;
    visibility:visible !important;

    max-height:0 !important;
    overflow:hidden !important;
    transition:max-height .25s ease !important;
    border-top:1px solid rgba(0,0,0,.06) !important;
    background:#fff !important;
  }

  .has-dropdown.dd-open .dropdown{
    max-height:320px !important;
  }

  .dropdown li a,
  .dropdown .disabled{
    padding:12px 18px 12px 34px !important; /* neat indent */
  }

  /* stop hover-open on mobile */
  .has-dropdown:hover .dropdown{
    max-height:0 !important;
  }
}

/* Desktop stays hover-based and aligned under Services */
@media (min-width: 901px){
  .has-dropdown{ position:relative; }
  .dropdown{
    left:0 !important;
    right:auto !important;
  }
}

/* =========================================================
   MOBILE MENU (Ooma-style drawer) — FINAL OVERRIDE v6
   If you still see a blank drawer:
   - Forces font-size/line-height
   - Forces z-index stacking so list can't hide behind overlays
   - Forces pointer-events + display for all menu items
   ========================================================= */
@media (max-width: 900px){

  .tt-header__social{ display:none !important; }

  .header-inner{
    display:flex !important;
    align-items:center !important;
    justify-content:space-between !important;
    gap:14px !important;
  }
  .logo{ margin-right:auto !important; }
  .nav-toggle{ margin-left:auto !important; }

  .main-nav{
    display:block !important;
    pointer-events:auto !important;

    position: fixed !important;
    inset: 0 !important;
    background: #fff !important;
    z-index: 99999 !important;

    transform: translateX(100%) !important;
    transition: transform .25s ease !important;

    padding: 0 !important;
    margin: 0 !important;
    overflow: hidden !important;
  }
  .main-nav.open{ transform: translateX(0) !important; }

  .nav-drawer-head{
    position: relative !important;
    z-index: 3 !important;

    display:flex !important;
    height: 56px !important;
    align-items:center !important;
    justify-content:flex-end !important;
    padding: 0 14px !important;
    border-bottom: 1px solid rgba(0,0,0,.08) !important;
    background:#fff !important;
  }
  .nav-close{
    border:0 !important;
    background:transparent !important;
    font-size: 34px !important;
    line-height: 1 !important;
    cursor:pointer !important;
    padding: 6px 10px !important;
    border-radius: 10px !important;
  }

  /* HARD FORCE: show menu list + items */
  #navList{
    position: relative !important;
    z-index: 2 !important;

    display:block !important;
    visibility: visible !important;
    opacity: 1 !important;

    list-style:none !important;
    margin: 0 !important;
    padding: 8px 0 18px 0 !important;

    height: calc(100vh - 56px) !important;
    overflow:auto !important;
    background:#fff !important;
  }
  #navList > li{
    display:block !important;
    visibility: visible !important;
    opacity: 1 !important;
  }
  #navList a,
  #navList a:visited{
    display:flex !important;
    visibility: visible !important;
    opacity: 1 !important;

    color:#0b0f0f !important;
    text-decoration:none !important;

    font-size: 16px !important;
    line-height: 1.2 !important;
    font-weight: 600 !important;

    align-items:center !important;
    justify-content:flex-start !important;
    text-align:left !important;

    padding: 16px 18px !important;
    width:100% !important;
    gap: 10px !important;
  }

  #navList li{ border-top: 1px solid rgba(0,0,0,.06) !important; }

  .has-dropdown > a svg{ margin-left:auto !important; }

  .has-dropdown .dropdown{
    display:block !important;

    position: static !important;
    width:100% !important;
    margin:0 !important;
    padding:0 !important;

    max-height: 0 !important;
    overflow: hidden !important;
    transition: max-height .25s ease !important;

    border-top: 1px solid rgba(0,0,0,.06) !important;
    background:#fff !important;
    box-shadow:none !important;
    border-radius:0 !important;
  }
  .has-dropdown.dd-open .dropdown{ max-height: 520px !important; }

  .dropdown li a,
  .dropdown .disabled{
    display:flex !important;
    justify-content:flex-start !important;
    text-align:left !important;
    padding: 12px 18px 12px 34px !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    color:#0b0f0f !important;
  }

  body.nav-open{ overflow:hidden !important; }
}
/* Hide mobile drawer header + close button on desktop */
.nav-drawer-head { display: none; }

/* Show it only on mobile */
@media (max-width: 900px){
  .nav-drawer-head { display: flex; }
}
/* ===== MOBILE MENU BLANK FIX (forces list visible when drawer is open) ===== */
@media (max-width: 900px){
  .main-nav.open #navList,
  .main-nav.open .nav-list{
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;

    position: relative !important;
    z-index: 2 !important;

    height: calc(100vh - 56px) !important;
    overflow: auto !important;

    max-height: none !important;   /* <-- kills the old max-height:0 rule */
  }

  .main-nav.open .nav-list li{ display:block !important; }
  .main-nav.open .nav-list a{ display:flex !important; }
}


/* ===== MOBILE NAV TOGGLE VISIBILITY FIX =====
   Ensures the hamburger appears on small screens (some blocks were removed during cleanup).
*/
.nav-toggle{ display:none; } /* desktop default */
@media (max-width: 900px){
  .nav-toggle{ display:inline-flex !important; }
}

/* ===== HAMBURGER ICON (3 lines – modern mobile style) ===== */

/* Base button */
.nav-toggle{
  width: 44px;
  height: 44px;
  padding: 10px;
  border-radius: 10px;
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  gap: 6px;                 /* space between lines */
  background: transparent;
}

/* The 3 lines */
.nav-toggle span{
  display: block;
  width: 100%;
  height: 2px;              /* line thickness */
  background: var(--teal);
  border-radius: 2px;
  transition: transform .25s ease, opacity .25s ease;
}

/* Mobile only */
@media (max-width: 900px){
  .nav-toggle{
    display: inline-flex !important;
  }
}
/* Animate hamburger → X when menu open */
.main-nav.open ~ .nav-toggle span:nth-child(1){
  transform: translateY(8px) rotate(45deg);
}
.main-nav.open ~ .nav-toggle span:nth-child(2){
  opacity: 0;
}
.main-nav.open ~ .nav-toggle span:nth-child(3){
  transform: translateY(-8px) rotate(-45deg);
}
/* ===== FORCE HAMBURGER ICON VISIBLE (FINAL OVERRIDE) ===== */
.nav-toggle{
  display: none;                 /* desktop default */
  width: 44px;
  height: 44px;
  padding: 10px;
  border: 0;
  background: transparent;
  border-radius: 10px;
  color: #0b0f0f;                /* visible line color */
}

@media (max-width: 900px){
  .nav-toggle{
    display: inline-flex !important;
    flex-direction: column;
    justify-content: center;
    gap: 6px;
  }
}

.nav-toggle span{
  display: block !important;
  width: 24px !important;        /* line length */
  height: 2px !important;        /* line thickness */
  background: currentColor !important;
  border-radius: 2px;
  opacity: 1 !important;
  transform: none !important;
}
/* ===== HAMBURGER ICON (always visible) – uses pseudo elements ===== */
@media (max-width: 900px){
  .nav-toggle{
    display:inline-flex !important;
    width:44px;
    height:44px;
    padding:0;
    border:0;
    background:transparent;
    border-radius:10px;
    position:relative;
    align-items:center;
    justify-content:center;
    color:#042727; /* line color */
  }

  /* hide the spans so they can't conflict */
  .nav-toggle span{ display:none !important; }

  /* draw 3 lines */
  .nav-toggle::before{
    content:"";
    position:absolute;
    left:10px;
    right:10px;
    height:2px;
    background:currentColor;
    top:14px;
    border-radius:2px;
    box-shadow: 0 7px 0 currentColor, 0 14px 0 currentColor;
  }
}
/* ===== HAMBURGER -> X ANIMATION (pseudo-element version) ===== */
@media (max-width: 900px){
  .nav-toggle{ transition: transform .2s ease; }

  /* when menu open, turn the 3-line icon into X */
  body.nav-open .nav-toggle::before{
    top: 22px;                 /* center */
    box-shadow: none;          /* remove extra lines */
    transform: rotate(45deg);
  }

  body.nav-open .nav-toggle::after{
    content:"";
    position:absolute;
    left:10px;
    right:10px;
    height:2px;
    background: currentColor;
    top:22px;
    border-radius:2px;
    transform: rotate(-45deg);
  }
}
/* ===== DRAWER + LINKS ANIMATION POLISH ===== */
@media (max-width: 900px){
  .main-nav{ transition: transform .25s ease; }

  /* links fade/slide in nicely */
  .main-nav .nav-list > li{
    opacity: 0;
    transform: translateX(10px);
    transition: opacity .25s ease, transform .25s ease;
  }
  .main-nav.open .nav-list > li{
    opacity: 1;
    transform: translateX(0);
  }
}
/* ===== GoDaddy-style mobile menu spacing + chevrons animation ===== */

@media (max-width: 900px){

  /* Typography + spacing (GoDaddy-ish) */
  .main-nav .nav-list{
    padding: 10px 8px 18px;
  }
  .main-nav .nav-list > li{
    border-top: 1px solid rgba(0,0,0,.06);
  }
  .main-nav .nav-list > li:first-child{
    border-top: 0;
  }
  .main-nav .nav-list a{
    font-size: 16px;
    line-height: 1.2;
    padding: 14px 14px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  .main-nav .nav-list a:active{
    transform: scale(.99);
  }

  /* Drawer header area (close button alignment) */
  .nav-drawer-head{
    height: 56px;
    display:flex;
    align-items:center;
    justify-content:flex-end;
    padding: 10px 12px;
    border-bottom: 1px solid rgba(0,0,0,.08);
  }

  /* Dropdown submenu spacing */
  .has-dropdown .dropdown{
    padding: 6px 8px 10px;
    margin: 0;
  }
  .has-dropdown .dropdown li{
    border-top: 0;
  }
  .has-dropdown .dropdown a{
    font-size: 15px;
    padding: 12px 14px;
    opacity: .95;
  }

  /* Chevron animation (rotate when open) */
  .dropdown-toggle svg{
    transition: transform .2s ease;
    opacity: .85;
  }
  .has-dropdown.dd-open > .dropdown-toggle svg{
    transform: rotate(180deg);
  }

  /* Smooth submenu accordion */
  .has-dropdown .dropdown{
    max-height: 0;
    overflow: hidden;
    transition: max-height .25s ease;
  }
  .has-dropdown.dd-open .dropdown{
    max-height: 420px;
  }

  /* Accessible focus ring */
  .main-nav a:focus-visible,
  .main-nav button:focus-visible{
    outline: 2px solid rgba(0,159,193,.55);
    outline-offset: 3px;
  }
}

/* Keep background locked when menu open */
body.nav-open{ overflow:hidden; }


/* ===============================
   HERO SPLIT (MacTel-like, lighter)
   =============================== */
.hero-split{
  background: linear-gradient(120deg, rgba(43,176,216,.10), rgba(255,154,47,.08));
  padding: clamp(6px, 2vw, 12px) 0;
}
.hero-split-inner{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 36px;
  align-items:center;
}

/* Left content */
.hero-text h1{ color: var(--teal); text-shadow:none; }
.hero-text p{ color: var(--text); opacity:.85; text-shadow:none; }
.hero-text .hero-eyebrow{ color: var(--teal); opacity:.85; }
.hero-text .hero-badge{
  background: rgba(43,176,216,.14);
  border: 1px solid rgba(43,176,216,.28);
  color: var(--teal);
  backdrop-filter:none;
}
.hero-text .hero-price{ color: var(--teal); animation:none; }
.hero-text .hero-features li{ color: var(--text); }
.hero-text .hero-features li::before{ color: var(--orange); }

.hero-split .btn-primary{ background: var(--orange); }
.hero-split .btn-secondary{ border-color: var(--teal); color: var(--teal); }

/* Right image (crop-safe for faces) */
.hero-image{
  border-radius:24px;
  overflow:hidden;
  box-shadow: 0 22px 55px rgba(0,0,0,.14);
}
.hero-image img{
  width:100%;
  height:100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  object-position: center 20%;
  display:block;
}

/* Tablet/Mobile */
@media (max-width: 900px){
  .hero-split-inner{ grid-template-columns: 1fr; gap: 24px; }
  .hero-image{ order:-1; }
  .hero-image img{ aspect-ratio: 16 / 10; object-position: center 18%; }
}
@media (max-width: 520px){
  .hero-split{ padding: 40px 0; }
  .hero-image img{ aspect-ratio: 16 / 11; object-position: center 16%; }
}

/* ===============================
   Footer + sections: a bit lighter
   =============================== */
.tt-footer{
  background: linear-gradient(180deg, #0b4e57 0%, #083f46 100%);
}
/* ===============================
   TOP BAR (MacTel-style)
   =============================== */

.top-bar{
  background: linear-gradient(
    90deg,
    #e9f7fb,
    #fff4e8
  );
  border-bottom: 1px solid rgba(0,0,0,.06);
  font-size: 13px;
}

.top-bar-inner{
  display:flex;
  justify-content:flex-end;
  align-items:center;
  min-height:34px;
}

.top-bar-right{
  display:flex;
  align-items:center;
  gap:18px;
}

.top-link{
  color: var(--teal);
  text-decoration:none;
  font-weight:600;
  opacity:.9;
  white-space:nowrap;
}

.top-link:hover{
  opacity:1;
  text-decoration:underline;
}

.cart-count{
  font-weight:800;
  margin-left:2px;
}

.top-link--btn{
  padding:6px 12px;
  border-radius:999px;
  background: rgba(255,154,47,.18);
  border:1px solid rgba(255,154,47,.35);
  color: var(--teal);
  font-weight:800;
}

/* Mobile: hide top bar (MacTel does this too) */
@media (max-width: 900px){
  .top-bar{
    display:none;
  }
}
/* ==================================
   HERO IMAGE BLEND (MacTel-style)
   ================================== */

.hero-image{
  position: relative;
}

.hero-image img{
  width:100%;
  height:auto;
  display:block;
  border-radius:22px;
  box-shadow: 0 18px 45px rgba(0,0,0,.10);
}

/* Soft blend overlay */
.hero-image::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;

  /* Fade image edges into hero background */
  background:
    linear-gradient(
      90deg,
      rgba(255,255,255,.90) 0%,
      rgba(255,255,255,.40) 18%,
      rgba(255,255,255,.00) 42%
    ),
    linear-gradient(
      180deg,
      rgba(255,255,255,.25) 0%,
      rgba(255,255,255,.00) 30%,
      rgba(255,255,255,.00) 70%,
      rgba(255,255,255,.25) 100%
    );

  border-radius:22px;
}
/* =========================
   HOMEPAGE HERO (Features-style)
   ========================= */
.hero--index{
  padding: 0; /* we will control height via min-height */
}

.hero--index .container{
  min-height: clamp(320px, 34vw, 460px);
  display:flex;
  align-items:center;
}

/* small pill on top like MacTel/Features page */
.hero-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 12px;
  border-radius:999px;
  background: rgba(255,255,255,.18);
  border: 1px solid rgba(255,255,255,.22);
  color:#fff;
  font-weight:800;
  font-size:12px;
  margin-bottom:10px;
  backdrop-filter: blur(6px);
}

/* optional: slightly wider readable block */
.hero--index .hero-inner{
  max-width: 780px;
}
/* ==================================
   HERO (Option C: Image + Cards)
   Matches ThreeTel style (light, friendly)
   ================================== */

.hero-cards{
  padding: clamp(26px, 4vw, 46px) 0;
  background:
    radial-gradient(900px 420px at 18% 18%, rgba(43,176,216,.16), rgba(43,176,216,0) 60%),
    radial-gradient(760px 360px at 82% 20%, rgba(255,154,47,.16), rgba(255,154,47,0) 62%),
    linear-gradient(180deg, #f6fafb, #fff);
  border-bottom: 1px solid rgba(0,0,0,.06);
}

.hero-cards-inner{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 28px;
  align-items: flex-start;;
}

.hero-cards-copy h1{
  margin: 10px 0 10px;
  color: var(--teal);
  font-size: clamp(32px, 3.8vw, 50px);
  line-height: 1.06;
}

.hero-cards-sub{
  margin: 0 0 14px;
  font-size: 18px;
  opacity: .86;
  max-width: 640px;
}

.hero-cards-price{
  font-size: 48px;          /* bigger */
  font-weight: 950;
  padding: 8px 12px;
}

.hero-cards-price span{
  font-size: 14px;
  font-weight: 800;
  opacity: .8;
}


.hero-cards-actions{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items:center;
}

.hero-cards-note{
  margin-top: 10px;
  font-size: 12px;
  opacity: .7;
}

.hero-cards-media{
  border-radius: 18px;
  overflow:hidden;
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 18px 40px rgba(0,0,0,.10);
}
.hero-cards-media img{
  width:100%;
  height:auto;
  display:block;
}

/* Feature cards */
.hero-cards-grid{
  margin-top: 14px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.hero-mini{
  display:flex;
  gap: 10px;
  align-items:flex-start;
  padding: 12px 12px;
  border-radius: 16px;
  background: rgba(255,255,255,.85);
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 10px 22px rgba(0,0,0,.06);
}

.hero-mini-ico{
  width: 34px;
  height: 34px;
  border-radius: 12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(43,176,216,.14);
  border: 1px solid rgba(43,176,216,.22);
  font-size: 16px;
  flex: 0 0 auto;
}

.hero-mini-title{
  font-weight: 900;
  color: var(--teal);
  font-size: 14px;
  line-height: 1.1;
}

.hero-mini-desc{
  font-size: 12px;
  opacity: .78;
  margin-top: 3px;
  line-height: 1.25;
}

/* Responsive */
@media (max-width: 980px){
  .hero-cards-inner{
    grid-template-columns: 1fr;
  }
  .hero-cards-media{
    max-width: 780px;
  }
}

@media (max-width: 560px){
  .hero-cards-grid{
    grid-template-columns: 1fr;
  }
  .hero-cards-sub{
    font-size: 16px;
  }
}
/* =========================
   HERO IMAGE ROTATOR
   ========================= */

.hero-rotator{
  position:relative;
  overflow:hidden;
}

.hero-rotator img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  opacity:0;
  transition: opacity 1.2s ease-in-out;
}

.hero-rotator img.active{
  opacity:1;
  position:relative;
}

/* Mobile: disable rotation (clarity first) */
@media (max-width: 900px){
  .hero-rotator img{
    position:relative;
    opacity:1 !important;
  }
  .hero-rotator img:not(:first-child){
    display:none;
  }
}
/* ==================================
   FEATURES PAGE — Match Home Card Style
   ================================== */

/* Page section spacing (optional, safe) */
.features-section{
  padding: 34px 0;
}

/* Cards grid wrapper (works with most existing grids) */
.features-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

@media (max-width: 980px){
  .features-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px){
  .features-grid{ grid-template-columns: 1fr; }
}


/* ==================================
   FEATURES PAGE — Home-style polish
   ================================== */

/* Card layout = icon left, text right */
.feature-card{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding:14px;
}

/* Icon pill (match home hero cards) */
.feature-icon{
  width:38px;
  height:38px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:16px;
  background: rgba(43,176,216,.14);
  border: 1px solid rgba(43,176,216,.22);
  flex: 0 0 auto;
}

/* Text block */
.feature-body h3{
  margin:0 0 4px;
  font-size:14px;
  font-weight:900;
  color: var(--teal);
  line-height:1.2;
}

.feature-body p{
  margin:0;
  font-size:12px;
  line-height:1.35;
  opacity:.78;
}
/* ==================================
   FEATURES: Make cards match Homepage mini-cards
   Paste at VERY END of style.css
   ================================== */

.features .feature-card{
  display:flex;
  gap:12px;
  align-items:flex-start;
  padding:14px;
}

.features .feature-icon{
  width:38px;
  height:38px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:16px;
  background: rgba(43,176,216,.14);
  border: 1px solid rgba(43,176,216,.22);
  flex: 0 0 auto;
  margin:0; /* important: remove top spacing */
}

.features .feature-body{
  flex:1 1 auto;
  min-width:0;
}

.features .feature-body h3{
  margin:0 0 4px;
  font-size:14px;
  font-weight:900;
  color: var(--teal);
  line-height:1.2;
}

.features .feature-body p{
  margin:0;
  font-size:12px;
  line-height:1.35;
  opacity:.78;
}
/* ==================================
   FINAL OVERRIDE: Features page cards like Home
   (Paste at VERY END of style.css)
   ================================== */

/* Make the section feel like Home */
.features{
  padding: 44px 0;
  background: var(--page-bg, #f6fafb);
}

/* Force a clean grid (4/2/1) */
.features .features-grid{
  display:grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 14px !important;
  margin-top: 18px;
}

@media (max-width: 980px){
  .features .features-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (max-width: 560px){
  .features .features-grid{
    grid-template-columns: 1fr !important;
  }
}

/* Force Home-style mini cards */
.features .feature-card{
  grid-column: auto !important;           /* cancels span-3 system */
  display:flex !important;
  gap:12px;
  align-items:flex-start;
  padding:14px !important;
  border-radius:18px;
  background: rgba(255,255,255,.90);
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 10px 22px rgba(0,0,0,.06);
}

/* Keep your hover feeling (optional) */
.features .feature-card:hover{
  transform: translateY(-3px);
  box-shadow: 0 18px 40px rgba(0,0,0,.10);
}

/* Icon pill like Home */
.features .feature-icon{
  width:38px !important;
  height:38px !important;
  border-radius:14px !important;
  display:flex !important;
  align-items:center;
  justify-content:center;
  font-size:16px;
  background: rgba(43,176,216,.14);
  border: 1px solid rgba(43,176,216,.22);
  flex: 0 0 auto;
  margin:0 !important;
}

.features .feature-body{ flex:1 1 auto; min-width:0; }

.features .feature-body h3{
  margin:0 0 4px !important;
  font-size:14px;
  font-weight:900;
  color: var(--teal);
  line-height:1.2;
}

.features .feature-body p{
  margin:0 !important;
  font-size:12px;
  line-height:1.35;
  opacity:.78;
}
/* ==================================
   FEATURES PAGE — Make cards match INDEX hero cards
   ================================== */

/* Softer section background like home */
.features{
  background: var(--page-bg, #f6fafb);
  padding: 48px 0;
}

/* Give grid a bit more breathing room */
.features .features-grid{
  gap: 16px !important;
  margin-top: 18px;
}

/* Make each card feel premium (like index) */
.features .feature-card{
  padding: 16px !important;
  border-radius: 18px !important;
  background: rgba(255,255,255,.92) !important;
  border: 1px solid rgba(0,0,0,.06) !important;
  box-shadow: 0 12px 26px rgba(0,0,0,.07) !important;
  transition: transform .18s ease, box-shadow .18s ease;
  min-height: 92px; /* makes them feel consistent */
}

/* Hover like index */
.features .feature-card:hover{
  transform: translateY(-3px);
  box-shadow: 0 18px 40px rgba(0,0,0,.11) !important;
}

/* Icon pill closer to index style */
.features .feature-icon{
  width: 40px !important;
  height: 40px !important;
  border-radius: 14px !important;
  background: rgba(43,176,216,.14) !important;
  border: 1px solid rgba(43,176,216,.22) !important;
}

/* Slightly larger / clearer typography */
.features .feature-body h3{
  font-size: 15px !important;
  margin-bottom: 5px !important;
}

.features .feature-body p{
  font-size: 13px !important;
  opacity: .80 !important;
}
/* ==================================
   HERO PRICE — Stronger emphasis
   ================================== */

.hero-cards-price{
  font-size: 38px;           /* bigger */
  font-weight: 900;
  color: var(--teal);
  line-height: 1;
}

.hero-cards-price span{
  font-size: 14px;
  font-weight: 700;
  opacity: .75;
}

/* subtle highlight behind price */
.hero-cards-price{
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  padding: 6px 10px;
  background: rgba(43,176,216,.10);
  border-radius: 10px;
  border: 1px solid rgba(43,176,216,.18);
}
/* ==================================
   HERO CTA — Primary emphasis
   ================================== */

.hero-cards-actions .btn-primary{
  padding: 12px 22px;
  font-size: 15px;
  font-weight: 800;
  border-radius: 10px;
  box-shadow: 0 10px 22px rgba(255,131,0,.28);
}

/* Hover feels premium */
.hero-cards-actions .btn-primary:hover{
  transform: translateY(-1px);
  box-shadow: 0 14px 30px rgba(255,131,0,.38);
}

/* Secondary button softer */
.hero-cards-actions .btn-secondary{
  font-weight: 700;
  opacity: .9;
}
/* ==================================
   HERO price meta + trust line
   ================================== */

.hero-price-meta{
  margin-top: 8px;
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
}

.hero-popular{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border-radius:999px;
  background: rgba(255,154,47,.16);
  border: 1px solid rgba(255,154,47,.30);
  color: var(--teal);
  font-weight: 900;
  font-size: 12px;
}

.hero-popular::before{
  content:"★";
  font-weight: 900;
}

.hero-nocc{
  font-size: 12px;
  font-weight: 700;
  opacity: .78;
}

/* On very small screens stack nicely */
@media (max-width: 520px){
  .hero-price-meta{ gap:8px; }
  .hero-nocc{ width:100%; }
}
/* CTA subtle pop animation */
.cta-pop{
  animation: ctaPop .75s ease-out both;
}

@keyframes ctaPop{
  0%   { transform: translateY(6px); opacity: 0; }
  60%  { transform: translateY(-1px); opacity: 1; }
  100% { transform: translateY(0); opacity: 1; }
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  .cta-pop{ animation: none; }
}
.hero-features--home{
  margin: 12px 0 14px;
  padding: 0;
  list-style: none;
  
}

.hero-features--home li{
  margin: 6px 0;
  padding-left: 26px;
  position: relative;
  font-weight: 700;
  opacity: .9;
  
}
.hero-features--home li{ color:#000; opacity:1; }

.hero-features--home li::before{
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--orange);
  font-weight: 900;
}
/* ==================================
   HERO Product name (MacTelHome-style)
   ================================== */


.hero-product{ font-size:38px; font-weight:950; }
.hero-product .brand{ color: var(--blue); }
.hero-product .plan{ color: var(--teal); }

/* Ensure rotator has height (images are absolute) */
.hero-cards-media .hero-rotator{
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
}

.hero-cards-media .hero-rotator img{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: opacity 1.2s ease-in-out;
}

.hero-cards-media .hero-rotator img.active{
  opacity: 1;
}


/* Mobile scale */
@media (max-width: 520px){
  .hero-product{ font-size: 30px; }
}
/* ==================================
   BLACK OUTSIDE FRAME (site wrapper)
   ================================== */

html, body{
  height: 100%;
}

body{
  background: #000; /* outside margin */
}

/* White page area */
.site-wrapper{
  background: #fff;
  min-height: 100vh;
}

/* Optional: give a premium "floating page" look */
@media (min-width: 1100px){
  .site-wrapper{
    max-width: 1400px;    /* adjust if you want */
    margin: 0 auto;
    box-shadow: 0 0 0 1px rgba(255,255,255,.04),
                0 0 70px rgba(0,0,0,.55);
  }
}
/* ==================================
   MOBILE HERO POLISH
   ================================== */
@media (max-width: 900px){
  .hero-cards{
    padding: 26px 0;
  }

  .hero-cards-inner{
    gap: 18px;
  }

  .hero-kicker{
    font-size: 10px;
    letter-spacing: .10em;
    margin-bottom: 8px;
  }

  .hero-product{
    font-size: 30px; /* was big */
    margin-bottom: 10px;
  }

  .hero-cards-price{
    font-size: 40px;
    padding: 8px 10px;
  }

  .hero-price-meta{
    margin-top: 10px;
  }

  .hero-features--home li{
    font-size: 13px;
    margin: 6px 0;
  }

  .hero-cards-actions{
    margin-top: 12px;
  }

  /* Make right side less tall on mobile */
  .hero-cards-media .hero-rotator{
    aspect-ratio: 16 / 10;
  }
}

@media (max-width: 520px){
  .hero-cards-price{
    font-size: 36px;
  }
  .hero-cards-actions .btn-primary,
  .hero-cards-actions .btn-secondary{
    width: 100%;
    text-align: center;
  }
}
/* ==================================
   FAQ AI STYLE
   ================================== */

.faq-ai{ padding: 44px 0; }
.faq-ai-head h2{ margin: 0 0 6px; }
.faq-ai-head p{ margin: 0 0 18px; opacity: .85; }

.faq-ai-panel{
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 18px;
  background: rgba(255,255,255,.75);
  backdrop-filter: blur(10px);
  box-shadow: 0 18px 50px rgba(0,0,0,.06);
  padding: 18px;
}

.faq-ai-search{
  display:flex;
  gap:10px;
  align-items:center;
}

.faq-ai-search input{
  flex:1;
  height: 46px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.10);
  padding: 0 14px;
  outline: none;
  background: #fff;
}

.faq-ai-search input:focus{
  border-color: rgba(0,159,193,.55);
  box-shadow: 0 0 0 4px rgba(0,159,193,.12);
}

.faq-ai-chips{
  display:flex;
  flex-wrap: wrap;
  gap:10px;
  margin-top: 12px;
}

.faq-chip{
  border: 1px solid rgba(0,0,0,.08);
  background: #fff;
  border-radius: 999px;
  padding: 8px 12px;
  font-size: 13px;
  cursor: pointer;
  user-select:none;
  transition: transform .12s ease, box-shadow .12s ease;
}

.faq-chip:hover{
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(0,0,0,.06);
}

.faq-chip.is-active{
  border-color: rgba(0,159,193,.45);
  box-shadow: 0 0 0 4px rgba(0,159,193,.10);
}

.faq-ai-answer{
  margin-top: 14px;
  border-radius: 16px;
  padding: 14px;
  background: linear-gradient(120deg, rgba(0,159,193,.10), rgba(255,131,0,.08));
  border: 1px solid rgba(0,0,0,.06);
}

.faq-ai-answer-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom: 8px;
}

.faq-ai-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-weight: 800;
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.75);
  border: 1px solid rgba(0,0,0,.06);
}

.faq-ai-confidence{
  font-size: 13px;
  opacity: .85;
}

.faq-ai-q{
  font-weight: 900;
  margin: 6px 0;
  font-size: 16px;
}

.faq-ai-a{
  line-height: 1.55;
  margin: 0;
}

.faq-ai-actions{
  display:flex;
  gap:10px;
  flex-wrap: wrap;
  margin-top: 12px;
}

.faq-ai-matches{ margin-top: 18px; }
.faq-ai-matches-head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:10px;
  margin-bottom: 10px;
}

.faq-ai-count{ font-size: 13px; opacity: .75; }

.faq-ai-list{
  display:grid;
  gap:10px;
}

details.faq-item-modern{
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 14px;
  background:#fff;
  padding: 2px 0;
}

details.faq-item-modern summary{
  padding: 14px 14px;
}

.faq-body-modern{
  padding: 0 14px 14px;
  opacity: .95;
}

.faq-ai-footer{ margin-top: 12px; }
.faq-ai-tip{ font-size: 13px; opacity: .75; }

.sr-only{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

@media (max-width: 520px){
  .faq-ai-search{ flex-direction: column; align-items: stretch; }
  .faq-ai-search input{ width:100%; }
}
.hero-video-frame{
  width:100%;
  aspect-ratio:16 / 9;
  border-radius:18px;
  overflow:hidden;
  background:#000;
  box-shadow:0 20px 50px rgba(0,0,0,.15);
}

.hero-video-frame iframe{
  width:100%;
  height:100%;
  border:0;
}


