/*
	Theme Name: Altran Bus
	Description: Custom designed theme using starter theme HTML5 Blank WordPress Theme
	Author: Kelley Marketing, LLC
	Author URI: https://kelleymarketing.net

	License: MIT
	License URI: http://opensource.org/licenses/mit-license.php
*/

/*------------------------------------*\
    MAIN
\*------------------------------------*/

/* global box-sizing */
*,
*:after,
*:before {
	-moz-box-sizing:border-box;
	box-sizing:border-box;

    -webkit-transition: all .6s ease;
     -moz-transition: all .6s ease;
       -o-transition: all .6s ease;
      -ms-transition: all .6s ease;
          transition: all .6s ease;
}
html {
	font-size:100%;
}
body {
	font-family: 'Oxygen', sans-serif;
	color:#000;
	margin:0;
	padding:0;
    background-color: #EEF2EC;
}
/* clear */
.clear:before,
.clear:after {
    content:' ';
    display:table;
}

.clear:after {
    clear:both;
}
.clear {
    *zoom:1;
}
img {
	max-width:100%;
	height:auto;
}
.wp-block-image img {
    border-radius: 6px;
}
a {
	color:#0D354E;
	text-decoration:underline;
}
a:hover {
	text-decoration: none;
}
a:focus {
	outline:0;
}
a:hover,
a:active {
	outline:0;
}
a.green-button, .green-button a {
    color: #fff;
    text-transform: uppercase;
    text-align: center;
    display: inline-block;
    margin:0px auto;
    text-decoration:none;
    background-color: #93C16F;
    padding:15px 60px;
    border-radius: 6px;
    font-size:16px;
    line-height: 1.2em;
    font-weight:700;
	word-break: keep-all!important;
}
a.green-button:hover, .green-button a:hover {
	background-color: #8DD554;
}
a.red-button, .red-button a {
    color: #fff;
    text-transform: uppercase;
    font-weight: 700;
    text-align: center;
    display: inline-block;
    margin:0px auto;
    text-decoration:none;
    background-color: rgb(156, 35, 35);
    padding:15px 60px;
    border-radius: 6px;
    font-size:16px;
	line-height: 1.2em;
	word-break: keep-all!important;
}
a.red-button:hover, .red-button a:hover {
	background-color: rgb(213, 45, 45);
}
input:focus {
	outline:0;
	border:1px solid #04A4CC;
}

.hide-mobile {display: inherit;}

hr {
    margin:30px auto;
    width:90%;
    border:none;
    border-top:2px dotted #BDBDBD;
}

/*------------------------------------*\
    STRUCTURE
\*------------------------------------*/

/* container */
.container {
	max-width:1200px;
	width: 92%;
	margin:0 auto;
	position:relative;
}

.admin-bar #top-nav-wrap {
  top: 32px;
}

#schedule-a-ride-mobile {
	display: none;
}

#top-nav-wrap {
    background-color: #687F83;
    border-bottom: 2px solid #FFDC5C;
    min-height: 40px;
    box-sizing:content-box;
}
.top-nav {
	display: flex;
	align-items: center;
    flex-wrap: wrap;
    justify-content: center;
}
.top-nav a.facebook-icon {
    color: #fff;
    font-size: 24px;
    margin:0;
    line-height: 1em;
}
.top-nav .schedule-a-ride {
    font-family: 'Montserrat', sans-serif;
    font-size: 18px;
    line-height: 1em;
    margin:0 5px 0 20px;
    font-weight: 700;
    color: #FFDC5C;
}
.top-nav .twentyfour-hour-notice {
    color: #fff;
    font-size: 12px;
    line-height: 1em;
    font-weight: 400;
}
.top-nav nav {
	margin-left: auto;
}
header {
    background-color: #fff;
    height: 110px;

}
#header {
    -webkit-box-shadow: 0px 3px 6px 0px rgba(0,0,0,0.16);
    -moz-box-shadow: 0px 3px 6px 0px rgba(0,0,0,0.16);
    box-shadow: 0px 3px 6px 0px rgba(0,0,0,0.16); 
}
#header .container {
    display: flex;
    align-items: center;
    height: 110px;
        flex-wrap: wrap;
    justify-content: center;
}
#header-logo {
	margin-right:20px;
}
#header-logo img {
    max-width: 260px;
    height: auto;
}
#header-main-nav {
    margin-left:auto;
}

#content-wrap {
    margin: 25px 0 0 0;
}

#content-wrap a {
		/* These are technically the same, but use both */
  overflow-wrap: break-word;
  word-wrap: break-word;

  -ms-word-break: break-all;
  /* This is the dangerous one in WebKit, as it breaks things wherever */
  word-break: break-all;
  /* Instead use this non-standard one: */
  word-break: break-word;
}

.sidebar .widget_text, .sidebar .widget_maxmegamenu {
    background-color: #fff;
    border-radius: 6px;
    padding: 25px;
    margin-bottom:35px;
}

#footer {
    background-color: #5B554C;
    text-align: center;
}
#footer .container {
    background-image: url(img/footer-bkgrd.png);
    background-repeat: no-repeat;
    background-position: left bottom;
}
#footer .container .group {
    padding:20px 0;
}
#copyright-wrap {
    background-color: #687F83;
    padding:12px 0;
}




/*------------------------------------*\
    PAGES
\*------------------------------------*/

/* Homepage */

#hero-wrap {
	width: 100%;
	height: 530px;
	position: relative;
	margin:20px auto 0;
	background-image: url(https://www.altranbus.com/wp-content/uploads/2026/04/Top-Menu-Buses.png);
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	text-align: center;
}
#paint-swoosh{
	position: absolute;
	bottom: 25px;
	padding:0 4%;
	width: 100%;
	z-index: 1;
}
#hero-text {
	font-family: 'Montserrat', sans-serif;
	font-size:42px;
	line-height: 1.3em;
	margin:0 auto;
	color: #93C16F;
	font-weight: 700;
	text-align: center;
	position: absolute;
	z-index: 100;
	bottom:35px;
	padding:0 4%;
	width: 100%;
}

.homepage h1 {
    font-size:28px;
}

#kind-of-transportation-wrap {
    background-color: rgba(214,186,126,.3);
    padding:35px 0;
}

#transportation-buttons {
    display: flex;
    flex-wrap: wrap;
    justify-content:space-between;
}
.transportation-button-container {

}
.transportation-button-container img {
    border: 2px solid #93C16F;
    border-radius: 6px;
}

#pr-shuttle-service-wrap {
	padding:30px 0;
}
#pr-shuttle-service {
	display: flex;
	align-items:center;
	justify-content:space-between;
}
#pr-shuttle-service div {
	width: 48%;
}
#pr-shuttle-service-left {
	border-top:3px dashed #FFDC5C;
	border-bottom:3px dashed #FFDC5C;
	padding:30px 0;
}
#pr-shuttle-service-right {
	
}

/* Table for Fare and Authority Board */

.table-layout {
	border: 1px solid #666;
	border-collapse: collapse;
	margin:15px auto;
	font-size:15px;
	line-height:1.4em;
	background-color:#ccc;
	width:80%;
}
.table-layout td {
	padding:10px;
	border:1px solid #666;
	text-align: left;
}
.table-layout tr:nth-child(even) {background-color: #FBFBFB;}

/* Table for Backpacker */
.backpacker .table-layout {
	width:100%;
}
.route-title {
	background-color:#000;
	color:#fff;
	font-weight:700;
	text-transform:uppercase;
}
.table-layout th {
	font-size:16px;
	padding:6px;
}

/* Contact Form 7 form */
div.wpcf7 {
    width: 100%;
    margin:0;
    font-size:16px;
    font-family: 'Roboto', sans-serif;
}
.wpcf7 label {
    display: block;
    margin-bottom:3px;
}
.wpcf7 input, .wpcf7 textarea {
    width: 100%;
    padding:8px;
    font-size:14px;
    margin-top:3px;
    margin-bottom:15px;
    border: 1px solid #666;
    border-radius: 3px;
}
.wpcf7 p{
    margin-bottom:10px;
}
.wpcf7 input.wpcf7-submit {
    width: auto;
    display: block;
    padding:20px 50px;
    background-color: #007791;
    -webkit-border-radius: 4px; 
    -moz-border-radius: 4px; 
    border-radius: 4px;
    border: none;
    font-size: 16px;
    text-transform: uppercase;
    color: #fff;
    font-weight: 700;
    margin:0;
}
.wpcf7 input.wpcf7-submit:hover {
    background-color: #0aadd1;
}
.wpcf7 .required {color:red;}



/*------------------------------------*\
    TYPOGRAPHY
\*------------------------------------*/

h1, h2, h3, h4, h5, h6 {
    font-family: 'Montserrat', sans-serif;
    font-weight: 700;
    margin: 0;
    line-height: 1.3em;
    color: #5B554C;
}
h1 {
    margin:0 0 16px 0;
    font-size:36px;
}
h2 {
    margin:25px 0 10px 0;
    font-size:32px;
}
h3 {
    margin:20px 0 8px 0;
    font-size:28px;
}
h4 {
    margin:20px 0 6px 0;
    font-size:24px;
}
h5 {
    margin:15px 0 6px 0;
    font-size:20px;
}
h6 {
    margin:15px 0 6px 0;
    font-size:18px;
}
p {
    font-size: 16px;
    line-height: 1.5em;
    color: #000;
    font-family: 'Oxygen', sans-serif;
    margin:8px 0 15px 0;
}

#content-wrap ul {
    list-style-type: none;
    padding-left: 20px;
}
#content-wrap li {
	line-height:1.4em;
	position: relative;
	padding-left: 20px;
	margin-bottom: 10px
}
#content-wrap li:before {
	content: '\f00c';
	font-family: 'FontAwesome';
    position: absolute;
    top: 0;
    left: 0;
}

.sidebar .widget_text h3, .sidebar .widget_maxmegamenu h3 {
    text-align: center;
    text-transform: uppercase;
    font-size:20px;
    line-height: 1.2em;
    font-weight: 700;
    border-bottom:1px solid #687F83;
    padding:0 0 2px 0;
    width: 100%;
    color: #D95D2F;
    margin:0 0 10px 0;
}
.sidebar .widget_text p, .sidebar .widget_maxmegamenu p {
    font-size: 15px;
    line-height: 1.4em;
    margin-bottom:10px;
    color: #5B554C;
    text-align: center;
}
.sidebar .widget_text p:last-of-type {
    margin-bottom:0;
}
.sidebar .widget_text .red-notice {
    color: #B23044;
    font-weight: 700;
    font-size: 18px;
    line-height: 1.3em;
}
.sidebar .widget_text .pictured-rocks-green {
    color:  #687F83;
    font-family:'Montserrat', sans-serif;
    font-size: 16px;
    line-height: 1.4em;
    font-weight: 400;
}
.sidebar .widget_text .pictured-rocks-green span {
    font-weight: 700;
    font-size: 20px;
}
.sidebar a.brown-button {
    color: #fff;
    text-transform: uppercase;
    font-weight: 700;
    text-align: center;
    display: inline-block;
    margin:0 auto;
    text-decoration:none;
    background-color: #5B554C;
    padding:10px 20px;
    border-radius: 6px;
}
.sidebar .widget_media_image {
	margin-left:auto;
	margin-right:auto;
	text-align:center;
}

#footer .widget_text h4 {
    font-size: 20px;
    color: #fff;
    text-transform: uppercase;
    margin:0 0 10px 0;
}
#footer .widget_text p{
    color: #fff;
    margin:0 0 12px 0;
}
#footer .widget_text p:last-of-type {
    margin-bottom:0;
}
#footer .widget_text .miners-castle-footer {
    border-radius: 6px;
}
#footer a, #copyright-wrap a {
    color:#fff;
    text-decoration: none;
}
#footer .widget_text a:hover, #copyright-wrap a:hover {
    text-decoration: underline;
}
#copyright-wrap p {
    margin: 0 auto;
    font-size: 12px;
    line-height: 1.3em;
    text-align: center;
    color: #fff;
}

#kind-of-transportation-wrap h2{
    font-size: 28px;
    text-align: center;
    line-height: 1.3em;
    margin:0 0 15px;
    font-weight: bold;
    color: #5B554C;
}
.transportation-button-container h5{
    text-align: center;
    font-family: 'Montserrat', sans-serif;
    font-size:20px;
    line-height: 1em;
    font-weight: 700;
    color: #5B554C;
    text-transform: uppercase;
    margin:0;
}

#pr-shuttle-service-left h3{
margin:0;
margin-bottom:6px;
text-align: center;
font-size:26px;
color: #687F83;
font-weight: 400;
line-height: 1.2em;
}
#pr-shuttle-service-left h4{
margin:0;
margin-bottom:14px;
text-align: center;
color:#3F4F52;
font-size:32px;
font-weight: 700px;
text-transform: uppercase;
line-height: 1.2em;
}
#pr-shuttle-service-left p{
margin:0 0 15px 0;
font-size: 15px;
line-height: 1.4em;
}
#pr-shuttle-service-left p:last-of-type {
	margin:0;
}

/*------------------------------------*\
    RESPONSIVE
\*------------------------------------*/

@media only screen and (max-width: 1100px) {
	.facebook-icon, .schedule-a-ride, .twentyfour-hour-notice {display: none;}
	.top-nav {display: inherit;}
	.top-nav nav {margin:auto;}
	.transportation-button-container {width: 22%;margin:0 1%;height: auto;}
	#schedule-a-ride-mobile {
		display: inherit;
		text-align: center;
		background-color: #586D71;
		padding:4px;
		color: #FFDC5C;
		font-size: 14px;
		line-height: 1.2em;
		font-weight: 700;
		font-family:'Montserrat', sans-serif;
	}
	#schedule-a-ride-mobile span {color: #fff;font-size: 12px; font-weight: 400;}
	}

@media only screen and (max-width: 1044px) {
    #header-logo img {max-width: 200px;}

}

@media only screen and (max-width: 980px) {
   #header-logo,  #header-main-nav {display: block;margin:0 0 10px 0;width:100%; text-align: center;}
   header {height: inherit;padding:5px 0;display: block;}
   #header .container {height: inherit;}
   #hero-wrap {height: 400px;}
}

@media only screen and (max-width: 800px) {
   #hero-wrap {height: 300px;}
   #hero-text {font-size: 32px;}
}

@media only screen and (max-width: 600px) {
	.transportation-button-container {width: 48%;margin:0 1%;height: auto;}
	#pr-shuttle-service {flex-direction:column;}
	#pr-shuttle-service div {width: 100%;margin:0 auto;}
	#pr-shuttle-service-left {order:1;}
	#pr-shuttle-service-right {order:-1;}
	.hide-mobile {display: none;}

	#header-logo {display: none;}
	#header-main-nav {display: block;width: 100%;margin:0;}
	#mega-menu-wrap-main-menu {border:none;display:block;padding:0;}
	li.mega-menu-item-81 {display: none!important;}
	.backpacker .sidebar .widget_maxmegamenu {
		display:none;
	}
	
	.wp-block-image .alignright, .wp-block-image .alignleft, .wp-block-image .aligncenter {display:block;float:none;margin:0 auto;width:100%;text-align:center;}
	#footer .widget_text p {font-size:14px;}
	#content-wrap ul {padding-left:10px;}
}

@media only screen and (max-width: 500px) {
	#header-logo img {max-width: 165px;}
	.mega-menu-item-31 {display: block!important;margin:0 auto!important;width:100%!important;}
	.mega-menu-item-31 a.mega-menu-link {text-align: center!important;}
	#hero-wrap {height: 200px;}
	#paint-swoosh img {display:none;}
	#hero-text {font-size: 20px;background-color:rgba(255,255,255,0.8);bottom:10px;}
	#pr-shuttle-service-left h3 {font-size:20px;}
	#pr-shuttle-service-left h4 {font-size:24px;}
}

@media only screen and (max-width: 375px) {
	#header-main-nav .mega-toggle-label {display: none!important;}
	li.mega-menu-item-81 {display: inherit!important;}
	.table-layout td {
		font-size:13px;
		line-height:1.3em;
		padding:1.5%;
	}
	.table-layout th {
		font-size:14px;
		padding:1.5%;
	}
	#kind-of-transportation-wrap {padding:15px 0;}
	.transportation-button-container h5 {font-size:16px;}
	.transportation-button-container {
		width:46%;
		margin:0 1% 2%;
	}
}

/*  Grid system */
@media only screen and (max-width: 600px) {
	.col {  margin: 1% 0 2% 0%!important; }
    
    .span_1_of_12, .span_2_of_12, .span_3_of_12, .span_4_of_12, .span_5_of_12, .span_6_of_12, .span_7_of_12, .span_8_of_12, .span_9_of_12, .span_10_of_12, .span_11_of_12, .span_12_of_12 {
	width: 100%!important; 
	}
}


/*------------------------------------*\
    GRID
\*------------------------------------*/

/*  SECTIONS  */
.section {
    clear: both;
    padding: 0px;
    margin: 0px;
}

/*  COLUMN SETUP  */
.col {
    display: block;
    float:left;
    margin: 1% 0 1% 3%;
}
.col:first-child { margin-left: 0; }


/*  GROUPING  */
.group:before,
.group:after {
    content:"";
    display:table;
}
.group:after {
    clear:both;
}
.group {
    zoom:1; /* For IE 6/7 */
}



/*  GRID OF TWELVE  */
.span_12_of_12 {
	width: 100%;
}

.span_11_of_12 {
  	width: 91.41%;
}
.span_10_of_12 {
  	width: 82.83%;
}

.span_9_of_12 {
  	width: 74.25%;
}

.span_8_of_12 {
  	width: 65.66%;
}

.span_7_of_12 {
  	width: 57.08%;
}

.span_6_of_12 {
  	width: 48.5%;
}

.span_5_of_12 {
  	width: 39.91%;
}

.span_4_of_12 {
  	width: 31.33%;
}

.span_3_of_12 {
  	width: 22.75%;
}

.span_2_of_12 {
  	width: 14.16%;
}

.span_1_of_12 {
  	width: 5.583%;
}



/*------------------------------------*\
    MISC
\*------------------------------------*/

::selection {
	background:#04A4CC;
	color:#FFF;
	text-shadow:none;
}
::-webkit-selection {
	background:#04A4CC;
	color:#FFF;
	text-shadow:none;
}
::-moz-selection {
	background:#04A4CC;
	color:#FFF;
	text-shadow:none;
}

/*------------------------------------*\
    WORDPRESS CORE
\*------------------------------------*/

.alignnone {
	margin:5px 20px 20px 0;
}
.aligncenter,
div.aligncenter {
	display:block;
	margin:5px auto 5px auto;
}
.alignright {
	float:right;
	margin:5px 0 20px 20px;
}
.alignleft {
	float:left;
	margin:5px 20px 20px 0;
}
a img.alignright {
	float:right;
	margin:5px 0 20px 20px;
}
a img.alignnone {
	margin:5px 20px 20px 0;
}
a img.alignleft {
	float:left;
	margin:5px 20px 20px 0;
}
a img.aligncenter {
	display:block;
	margin-left:auto;
	margin-right:auto;
}
.wp-caption {
	background:#FFF;
	border:1px solid #F0F0F0;
	max-width:96%;
	padding:5px 3px 10px;
	text-align:center;
}
.wp-caption.alignnone {
	margin:5px 20px 20px 0;
}
.wp-caption.alignleft {
	margin:5px 20px 20px 0;
}
.wp-caption.alignright {
	margin:5px 0 20px 20px;
}
.wp-caption img {
	border:0 none;
	height:auto;
	margin:0;
	max-width:98.5%;
	padding:0;
	width:auto;
}
.wp-caption .wp-caption-text,
.gallery-caption {
	font-size:11px;
	line-height:17px;
	margin:0;
	padding:0 4px 5px;
}
.sticky {

}
.bypostauthor {

}

/*------------------------------------*\
    PRINT
\*------------------------------------*/

@media print {
	* {
		background:transparent !important;
		color:#000 !important;
		box-shadow:none !important;
		text-shadow:none !important;
	}
	a,
	a:visited {
		text-decoration:underline;
	}
	a[href]:after {
		content:" (" attr(href) ")";
	}
	abbr[title]:after {
		content:" (" attr(title) ")";
	}
	.ir a:after,
	a[href^="javascript:"]:after,
	a[href^="#"]:after {
		content:"";
	}
	pre,blockquote {
		border:1px solid #999;
		page-break-inside:avoid;
	}
	thead {
		display:table-header-group;
	}
	tr,img {
		page-break-inside:avoid;
	}
	img {
		max-width:100% !important;
	}
	@page {
		margin:0.5cm;
	}
	p,
	h2,
	h3 {
		orphans:3;
		widows:3;
	}
	h2,
	h3 {
		page-break-after:avoid;
	}
}
