@media (max-width: 1600px) {
	.container {
		width: 100%;
		padding-left: 20px !important;
		padding-right: 20px !important;
	}
}




@media (max-width: 1024px) {
	.header-right {
		z-index: 999999999;
		position: relative;
	}
	#main {
		padding: 10px 0px;
	}
	.responsive-menus.responsified span.toggler {
		background: unset;
		padding:unset;
		color: #000;
		box-shadow: unset;
		text-align: right;
		border-radius: unset;
		outline: unset;
		font-size: 18px;
		z-index: 9999999999;
	}
	nav {
		background-color: #30499a;
	}
	body #page p {
		font-size: 16px;
		line-height: 28px;
	}
	.responsive-menus.responsified .responsive-menus-simple li a {
		padding: 15px 20px;
		border-bottom-color: #000;
		text-align: right;
	}
	.home-section-video h1 {
		font-size: 40px;
	}
	.home-section-video h3 {
		font-size: 25px;
	}
	.unit-tabs .tab-label {
		font-size: 18px;
	}
	.tab-panels .unit-tab-content h4 {
		font-size: 35px;
		margin-top: 0px;
	}
	.tab-panels .unit-tab-content p, .tab-panels .unit-tab-content ul {
		font-size: 16px;
		line-height: 28px;
	}
	.tab-panels .unit-tab-content h5 {
		font-size: 30px;
	}
	.tab-panels .unit-tab-content a {
		font-size: 22px;
		padding: 8px 15px;
	}
	.home-section-features {
		background-image: none;
	}
	.home-section-features-title-wrapper h3 {
		font-size: 30px;
	}
	.home-section-features .home-feature-block {
		width: 50%;
		border-left: unset;
		border-top: unset;
		border-bottom: 1px solid #ccc;
		border-right: 1px solid #ccc;
	}
	.footer-about h3 {
		font-size: 30px;
	}
	.footer-about {
		background-size: auto 100%;
		padding: 20px 0px;
	}
	.product-page-title {
		font-size: 30px;
	}
	.product-page-left .product-page-left-content .product-page-price {
		font-size: 30px;
		margin-bottom: 20px;
	}
	.product-page-left .product-page-left-content .product-page-features-title {
		font-size: 18px;
	}
	.product-page-left .product-page-left-content p, .product-page-left .product-page-left-content ul {
		font-size: 16px;
		line-height: 28px;
	}
	.product-page-left .product-page-left-content ul li {
		margin-bottom: 0px;
	}
	.product-page-right .commerce-order-item-add-to-cart-form label {
		font-size: 18px;
	}
	.product-page-right .commerce-order-item-add-to-cart-form select {
		width: 100%;
	}
	.product-page-right .commerce-order-item-add-to-cart-form .form-date {
		width: 100%;
	}
	.product-page-right .commerce-order-item-add-to-cart-form #edit-submit {
		width: 100%;
		font-size: 18px;
	}
	.product-page-right .commerce-order-item-add-to-cart-form .form-item-field-insurance-consent-value small {
		width: 80%;
	}
	.product-page-right .commerce-order-item-add-to-cart-form #edit-field-insurance-consent-value {
		top: -20px;
	}
	.location-page-left {
		width: 100%;
		margin-right: 0px;
		float: none;
	}
	.location-page-right {
		width: 100%;
		margin-left: 0px;
		float: none;
	}
	.google-reviews-wrapper .google-review-block {
		width: 90%;
		margin-left: 5%;
	}
	.commerce-checkout-flow .form-wrapper__login-option {
		width: 100%;
		margin-left: 0px;
		margin-right: 0px;
		float: none;
		margin-bottom: 20px;
	}
	.commerce-checkout-flow .form-wrapper__login-option {
		width: 100%;
		margin-left: 0px;
		margin-right: 0px;
		float: none;
	}
	.commerce-checkout-flow #edit-login-returning-customer-submit, .commerce-checkout-flow #edit-login-register-register, .webform-submission-waiting-list-form-form .form-submit {
		width: 100%;
	}
}









@media (max-width: 768px) {
	body {
		overflow-x: hidden;
	}
	.home-slider .home-slider-content {
		padding: 80px 0px;
	}
	.home-slider-slogan-top {
		font-size: 40px;
	}
	.home-slider-slogan-bottom {
		font-size: 53px;
	}
	.home-section-video-left {
		width: 100%;
		margin-right: 0px;
	}
	#home-page-video {
		width: 80%;
		margin-left: 10%;
		margin-right: 10%;
	}
	.home-section-unit-tabs {
		overflow-x: scroll;
	}
	.unit-tabs {
		width: 150%;
	}
	.footer-about {
		background-image: none;
	}
	.footer-about .footer-about-content {
		text-align: center;
		padding-left: 0px;
	}
	.footer-logo {
		width: 20%;
		margin-left: 40%;
	}
	.footer-nav-right {
		width: 100%;
	}
	.footer-nav-right .footer-nav-top a {
		display: block;
		width: 100%;
		text-align: center;
		margin: 0px 0px 20px 0px;
	}
	.header-links a.content-button {
		display: none;
	}
	#page header .header-links a.header-tel {
		margin-right: 0px;
	}
	header .site-logo {
		width: 15%;
	}
	header .header-right {
		width: 55%;
	}
	.product-page-left {
		width: 100%;
		margin-bottom: 20px;
	}
	.product-page-right {
		width: 100%;
	}
	.product-page-right .product-page-image img {
		width: 40%;
		margin-left: 30%;
	}
	body.page-node-3 #block-storage-unit-theme-content {
		width: 100%;
		margin-right: 0px;
	}
	body.page-node-3 #block-storage-unit-theme-webform {
		width: 100%;
		margin-left: 0px;
		margin-right: 0px;
	}
	.unit-type-btn {
		font-size: 18px;
	}
	.location-page-left .get-directions-form-wrapper .directions-input {
		width: 53%;
		font-size: 16px;
	}
	.location-page-left .get-directions-form-wrapper .directions-submit {
		width: 45%;
		font-size: 16px;
	}
	#home-page-google-map {
		width: 100%;
		margin-left: 0px;
	}
	#home-page-google-map iframe {
		height: 300px;
	}
}








@media (max-width: 480px) {
	.home-slider-slogan-top {
		font-size: 25px;
	}
	.home-slider-slogan-bottom {
		font-size: 33px;
	}
	#page .home-slider .content-button {
		font-size: 22px;
	}
	.unit-tabs {
		width: 200%;
	}
	.home-section-features-title-wrapper a {
		display: none;
	}
	.home-section-features-title-wrapper h3 {
		font-size: 25px;
		width: 100%;
		text-align: center;
	}
	.home-section-features .home-feature-block {
		width: 100%;
	}
	.footer-about h3 {
		font-size: 25px;
	}
	.product-page-title {
		font-size: 25px;
	}
	.product-page-right .product-page-image img {
		width: 50%;
		margin-left: 25%;
	}
}


















































/* =========================================
   MOBILE: tabs left (20%) + panel right (80%)
   (No DOM changes, no right-float needed)
   ========================================= */
@media (max-width: 768px) {

  .home-section-unit-tabs { overflow-x: visible !important; }
  .unit-tabs { display: block !important; width: 100% !important; }

  /* hide radios but keep them accessible */
  .unit-tabs > input[type="radio"] {
    position: absolute !important;
    left: -9999px !important;
  }

  /* Left column: stack labels in a single float column */
  .unit-tabs .tab-label {
    float: left !important;
    width: 20% !important;
    box-sizing: border-box !important;
    display: block !important;
    clear: left !important;             /* one label per row */
    text-align: left !important;
    padding: 20px 12px !important;
    font-size: 16px !important;
    background-color: #30499a !important;
    color: #fff !important;
    border-right: 1px solid #ccc !important;
    border-bottom: 1px solid #fff !important;
  }

  /* Right column: block with BFC so it ignores the left floats' height */
  .unit-tabs .tab-panels {
    float: none !important;             /* <-- key change */
    width: auto !important;
    margin-left: 20% !important;        /* reserve the left rail */
    box-sizing: border-box !important;
    padding: 20px !important;
    border: 1px solid #ccc !important;
    border-left: 1px solid #ccc; !important;
    overflow: hidden !important;        /* creates a BFC so it aligns at the top */
  }

  /* internal stacking */
  .tab-panels .unit-tab-image,
  .tab-panels .unit-tab-content {
    float: none !important;
    width: 100% !important;
    margin: 0 !important;
  }
  .tab-panels .unit-tab-image {
  	width: 40% !important;
  	margin-left: 30% !important;
  	margin-bottom: 10px !important;
  }

  .tab-panels .unit-tab-content h4 { margin: 20px 0 16px !important; font-size: 22px !important; }
  .tab-panels .unit-tab-content p,
  .tab-panels .unit-tab-content ul { font-size: 16px !important; line-height: 26px !important; }
  .tab-panels .unit-tab-content h5 { font-size: 26px !important; margin: 18px 0 12px !important; }
  .tab-panels .unit-tab-content a { font-size: 18px !important; padding: 8px 12px !important; }

  .unit-type-btn { width: 50% !important; font-size: 14px !important; }

  /* active tab */
  .unit-tabs > input[type="radio"]:checked + .tab-label {
    background-color: #3a9de8 !important;
    color: #fff !important;
  }

  /* clearfix for the overall component */
  .unit-tabs::after { content: ""; display: table; clear: both; }
}

/* Very small phones: give labels more breathing room */
@media (max-width: 480px) {
  .unit-tabs .tab-label { width: 35% !important; font-size: 16px !important; padding: 10px 12px !important; }
  .unit-tabs .tab-panels { margin-left: 35% !important; padding: 16px !important; }

    /* Left column: stack labels in a single float column */
  .unit-tabs .tab-label {
    float: left !important;
    width: 25% !important;
    box-sizing: border-box !important;
    display: block !important;
    clear: left !important;             /* one label per row */
    text-align: left !important;
    padding: 20px 12px !important;
    font-size: 14px !important;
    background-color: #30499a !important;
    color: #fff !important;
    border-right: 1px solid #ccc !important;
    border-bottom: 1px solid #fff !important;
  }

  /* Right column: block with BFC so it ignores the left floats' height */
  .unit-tabs .tab-panels {
    float: none !important;             /* <-- key change */
    width: auto !important;
    margin-left: 25% !important;        /* reserve the left rail */
    box-sizing: border-box !important;
    padding: 20px !important;
    border: 1px solid #ccc !important;
    border-left: 1px solid #ccc; !important;
    overflow: hidden !important;        /* creates a BFC so it aligns at the top */
  }
}
