/*
Theme Name: Infinity Child Theme
Description: A child theme of Divi
Author: ISG
Template: Divi
*/



.awesome_bull {
  list-style: none;
  padding: 0 0 15px 35px !important;
  font-size: 18px;
}
.awesome_bull .awesome_icon {
  margin-left: -35px;
  width: 35px;
  text-align: center;
  font-size: 16px;
}
.awesome_bull li {
  line-height: 1.2;
  padding-bottom: 10px;
}
.awesome_bull li:last-child {
  padding-bottom: 0;
}

.gt-current-lang {
  display: none !important;
}
a.glink span {
  font-size: inherit !important;
  vertical-align: bottom !important;
}
.gtrans_link {
  align-items: center !important;
  justify-content: center;
}


sup {
  font-size: 0.5em !important; vertical-align: super !important; bottom: 0 !important;
}
sub {
  font-size: 0.5em !important; vertical-align: sub !important; bottom: 0 !important;
}

/*show hide Spanish/English stuff*/
.forspanish, :lang(es) .forenglish {
	display: none
}
.forenglish, :lang(es) .forspanish, .logged-in .forspanish, .logged-in .forenglish {
	display: block;
}


footer {
  z-index: 99;
  position: relative;
}
header {
  position: relative;
  z-index: 999;
}

.logged-in header {
    z-index: 1;
}

/*ct logic*/
.ct-no .orderbtn, .ct-yes .telbtn {
  display: none !important;
}
.ct-no .ctabar .telbtn, .ct-yes .ctabar .orderbtn {
  width: 100% !important;
}

/*ab test logic*/
.abtest .forcontrol, .forabtest {
  display: none !important;
}
.abtest .forabtest, .logged-in .forabtest {
  display: block !important;
}

.ctabar {
  text-align: center;
  font-size: 24px;
  font-weight: 900;
  position: fixed;
  width: 100%;
  bottom: 0;
}
.ctabar a {
  color: #ffffff;
  padding: 30px 0;
  cursor: pointer;
  display: inline-flex;
  justify-content: center;
  vertical-align: bottom;
  line-height: 1;
  letter-spacing:.02em;
}
.ctabar .telbtn.telside {
  width: 65%;
  background-color: #2760F0;
}
.ctaorder {
  width: 35%;
  background-color: #F66608;
}

.popups .fa.fa-circle-xmark, .clickpop{
  cursor: pointer;
}
.popups {
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 999999;
  align-items: center;
  justify-content: center;
  background-color: rgba(15,15,15,0.8) !important;
  display: none;
  height: 100vh;
  width: 100%;
  max-width: 100%;
  padding: 0 !important;
}
.popups .closepopup {
  cursor: pointer;
}
.logged-in .popups {
  display: flex;
  position: inherit;
  z-index: 1;
}

/* HERO CTA BUTTON */
.hero-cta-wrap {
  display:flex;
  align-items:center;
  gap:28px;
  flex-wrap:wrap;
}

.hero-cta-btn {
  height:46px;
  background:#F66608;
  color:#ffffff;
 padding:0 26px;
  border-radius:26px;
  font-size:16px;
  font-family:"Regular", Arial, sans-serif;
  font-weight:700; /* Regular */
  text-decoration:none;
 display:inline-flex;       
  align-items:center;        
  justify-content:center;   
  transition:all .25s ease;
  cursor:pointer;
  box-shadow:0 4px 12px rgba(0,0,0,.18);
}

.hero-cta-btn:hover{
  background:#e35c05;
  transform:translateY(-1px);
}

.hero-divider{
  width:1px;
  height:48px;
  background:rgba(255,255,255,.35);
}

.hero-phone-block{
  line-height:1.35;
}

.hero-phone-label{
  font-family:"Regular", Arial, sans-serif;
  font-weight:700; /* Regular */
  font-size:14px;
  color:#ffffff;
  opacity:.85;
	line-height:1.35;
	
}

.hero-phone-number{
  font-size:20px;
  font-family:"Regular", Arial, sans-serif;
  font-weight:700; /* Regular Bold */
  display:flex;
  align-items:center;
  letter-spacing:.02em;
  gap:8px;
}

.hero-phone-number a{
  color:#ffffff;
  text-decoration:none;
}

.hero-phone-number a:hover{
  text-decoration:underline;
}

/* ICON */

.hero-phone-icon{
  color:#F66608;
  font-size:18px;
}

/* MOBILE */

@media (max-width:768px){

  .hero-divider{
    display:none;
  }

  .hero-cta-wrap{
    flex-direction:column;
    align-items:flex-start;
    gap:14px;
  }

}
/* HERO CTA BUTTON END */

/* PILL PHONE BUTTON */
.phone-pill-btn {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  border: 2px solid #F66608;
  border-radius: 999px;
  background-color: transparent;
  padding: 6px 16px 6px 6px;
  gap: 10px;
  transition: all 0.25s ease;
}

.phone-pill-btn:hover {
  transform: translateY(-1px);
}

/* ICON */
.phone-pill-btn .phone-pill-icon {
  width: 34px;
  height: 34px;
  min-width: 34px;
  border-radius: 50%;
  background: #F66608;
  display: flex;
  align-items: center;
  justify-content: center;
}

.phone-pill-btn .phone-pill-icon i {
  color: #ffffff;
  font-size: 14px;
  line-height: 1;
}

/* TEXT BASE */
.phone-pill-btn .phone-pill-text {
  font-size: 16px;
  font-family: "Regular", Arial, sans-serif;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1;
  white-space: nowrap;
}

/* COLORS */
.phone-pill-white .phone-pill-text {
  color: #ffffff;
}

.phone-pill-blue .phone-pill-text {
  color: #002864;
}

.phone-pill-blue {
  border-color: #F66608;
}

/* FILLED VERSION */
.phone-pill-filled {
  background-color: #F66608;
  border-color: #F66608;
}

.phone-pill-filled .phone-pill-text {
  color: #ffffff;
}

/* Icon flips for contrast */
.phone-pill-filled .phone-pill-icon {
  background-color: #ffffff;
}

.phone-pill-filled .phone-pill-icon i {
  color: #F66608;
}

.phone-pill-filled:hover {
  background-color: #d95500;
  border-color: #d95500;
}

/* PILL PHONE BUTTON END */

/* HERO LIST */

.hero-feature-list{
  list-style-type: none !important;
  padding: 0 !important;
  margin-top:0px;
}

.hero-feature-list li{
  position:relative;
  padding-left:32px;
  margin-bottom:12px;
  font-size:18px;
  font-weight:400;
}

.hero-feature-list li:last-child{

  margin-bottom:30px;
}

/* FONT AWESOME PLUS ICON */

.hero-feature-list li::before{
  content:"\2b";
  font-family:"Font Awesome 6 Pro";
  font-weight:300; /* light */
  position:absolute;
  left:0;
  top:0px;
  color:#F66608;
  font-size:18px;
  text-align:center;
  opacity:.92;
}
/* HERO LIST END */

/* ADDRESS LOOKUP */

.service-finder-wrapper{
display:flex;
justify-content:center;
width:100%;
}

.service-finder{
display:flex;
gap:14px;
align-items:center;
max-width:900px;
width:100%;
}

/* FIELDS */

.address-input{
  height:46px;
  border:2px solid #d8d8d8;
  border-radius:14px;
  padding-left:22px !important;
  padding-right:16px;
  font-size:15px;
  background:#ffffff;
  outline:none;
  transition:border .2s ease;
  box-sizing:border-box;
}
.address-input::placeholder{
  color:#8c8c8c;
  opacity:1;
}

/* FIELD WIDTHS */

.address-input.street{
flex:3;
}

.address-input.ste{
flex:1;
max-width:100px;
}

.address-input.zip{
flex:1;
max-width:150px;
}


/* INPUT FOCUS */

.address-input:focus{
border-color:#F66608;
}


/* BUTTON */

.availability-btn{
  height:46px;
  background:#F66608;
  color:#ffffff;
  padding:0 26px;
  border-radius:26px;
	border:none;
  font-size:16px;
  font-family:"Regular", Arial, sans-serif;
  font-weight:700; /* Regular */
  text-decoration:none;
  display:inline-flex;       
  align-items:center;        
  justify-content:center;   
  transition:all .25s ease;
  cursor:pointer;
 
}

.availability-btn:hover{
	 background:#e35c05;
  transform:translateY(-1px);
}


@media (max-width:768px){

.service-finder{
flex-direction:column;
}

.address-input,
.availability-btn{
width:100%;
}

}
/* ADDRESS LOOKUP END */
/* PLAN CARDS */

.featured-plan-badge{
  display:table;
  background:#2760F0;
  color:#ffffff;
  font-size:12px;
  font-weight:700;
  letter-spacing:.08em;
  line-height:1.3;
  text-align:center;
  text-transform:uppercase;
  padding:15px 20px 10px 20px;
  border-radius:24px;
  max-width:max-content;
}

/* plan card LIST */

.card-feature-list{
  list-style-type: none !important;
  padding: 0 !important;
  margin-top:0px;
}

.card-feature-list li{
  position:relative;
  padding-left:32px;
  margin-bottom:12px;
  font-size:17px;
  font-weight:400;
}
.card-feature-list li:first-child{
	margin-top:20px;
}
.card-feature-list li:last-child{

  margin-bottom:40px;
}

/* FONT AWESOME PLUS ICON */

.card-feature-list li::before{
  content:"\2b";
  font-family:"Font Awesome 6 Pro";
  font-weight:300; /* light */
  position:absolute;
  left:0;
  top:0px;
  color:#F66608;
  font-size:15px;
  text-align:center;
}
/* plan card LIST END */

/* TV TOGGLE */

.tv-toggle-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  padding: 12px 0;
  font-family: Arial, sans-serif;
}

.tv-toggle-label {
  font-size: 20px;
  font-weight: 500; /* medium */
  color: #000000;
  white-space: nowrap;
}

/* Toggle */
.tv-toggle {
  position: relative;
  display: inline-block;
  width: 72px;
  height: 34px;
  flex: 0 0 auto;
}

.tv-toggle input {
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none; /* visual only */
}

.tv-toggle-slider {
  position: absolute;
  inset: 0;
  background-color: #1458cc;
  border-radius: 999px;
}

/* Knob */
.tv-toggle-slider:before {
  content: "";
  position: absolute;
  height: 26px;
  width: 26px;
  left: 4px;
  top: 4px;
  background-color: #f2f1f0;
  border-radius: 50%;
  box-shadow: 0 1px 2px rgba(0,0,0,0.15);
}

/* Static state (left position like your screenshot) */
.tv-toggle input:checked + .tv-toggle-slider:before {
  transform: translateX(0);
}

/* If devs need the "right" state later:
.tv-toggle input:not(:checked) + .tv-toggle-slider:before {
  transform: translateX(38px);
}
*/

/* Mobile */
@media (max-width: 767px) {
  .tv-toggle-wrap {
    gap: 10px;
  }

  .tv-toggle-label {
    font-size: 16px;
    text-align: center;
  }
}
/* TV TOGGLE END */

/*for desktop site*/
@media screen and (min-width: 981px) {

}
 
/**Mobile site**/
 @media screen and (max-width: 980px) {
.nowword {
  display: none;
}
.mobile_nav.opened .mobile_menu_bar::before {
  content: "M" !important;
  font-family: ETmodules !important;
}
#mobile_menu1 {
  text-align: center;
}
}

/* Phone site */
@media only screen and (max-width: 767px) {
.ctabar {
  font-size: 16px;
}
.ctabar a {
  width: 50% !important;
  padding: 24px 0;
}
}