/*! HTML5 Boilerplate v4.3.0 | MIT License | http://h5bp.com/ */

/*
 * What follows is the result of much research on cross-browser styling.
 * Credit left inline and big thanks to Nicolas Gallagher, Jonathan Neal,
 * Kroc Camen, and the H5BP dev community and team.
 */

/* ==========================================================================
   Base styles: opinionated defaults
   ========================================================================== */

html,
button,
input,
select,
textarea {
    color: #222;
}

html {
    font-size: 1em;
    line-height: 1.4;
}

/*
 * Remove text-shadow in selection highlight: h5bp.com/i
 * These selection rule sets have to be separate.
 * Customize the background color to match your design.
 */

::-moz-selection {
    background: #b3d4fc;
    text-shadow: none;
}

::selection {
    background: #b3d4fc;
    text-shadow: none;
}

/*
 * A better looking default horizontal rule
 */

hr {
    display: block;
    height: 1px;
    border: 0;
    border-top: 1px solid #ccc;
    margin: 1em 0;
    padding: 0;
}

/*
 * Remove the gap between images, videos, audio and canvas and the bottom of
 * their containers: h5bp.com/i/440
 */

audio,
canvas,
img,
video {
    vertical-align: middle;
}

/*
 * Remove default fieldset styles.
 */

fieldset {
    border: 0;
    margin: 0;
    padding: 0;
}

/*
 * Allow only vertical resizing of textareas.
 */

textarea {
    resize: vertical;
}

/* ==========================================================================
   Browse Happy prompt
   ========================================================================== */

.browsehappy {
    margin: 0.2em 0;
    background: #ccc;
    color: #000;
    padding: 0.2em 0;
}

/* ==========================================================================
   Author's custom styles
   ========================================================================== */
/* Codigo XYZ */

body{
    font:normal 13px/20px 'Open Sans', sans-serif; 
    color:#666;
}
strong{
    font-family:'Open Sans Bold', sans-serif; 
}
em{
    font-family:'Open Sans Italic', sans-serif; 
}
h1{
    font-size:1.3em;
    margin: 1em 0;
}
h2{
    font-size:1.1em;
    margin: 1em 0;
}
a{
    color: #666;
    text-decoration: none;
}
a:hover{
    color: #ff6e3d;
    text-decoration:underline;
}
p{
    text-align:justify;
}
div{
    display:block;
}

img {
    max-width: 100%;
    vertical-align: middle;
    border: 0;
}

.container {
    margin:0 auto;
    padding-left: 15px;
    padding-right: 15px;
}

.col2 {
    width: 100%;
    clear: both;
    margin-right: 5%;
    height: 150px;
} .col2 h1, .col2 .parallax-info p{margin: 0.5em;}
.col2 .parallax-info{padding: 1em 0;}
.col2 img {position: relative; }
.col2 .parallax-info{display: none;}
.col2.img{min-height: 300px; text-align: center;}
.col2.img img{max-width: none;}
.col2 .parallax-main header h2 {font-size: 2em;}

.row {
    margin-left: -15px;
    margin-right: -15px;
}
.slide {
    width: 100%;
    height: 100%;
    position: relative;
    padding: 50px 0;
    background-color: #fff;
}
.active{
    color: #ff6e3d;
}

.cover{
    background-size: cover;
    background-position: center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
}

.fixed {background-attachment: fixed;}

.auto {
    background-position: center;
    background-size: auto;
    -webkit-background-size: auto;
    -moz-background-size: auto;
    -o-background-size: auto;
}
.center, .center p{
    text-align:center !important;
}
.btn-cta {
    border: 1px solid #C0C0C0;
    border-radius: 3px;
    padding: 10px 20px;
    color: #000;
    font-weight: 300;
    text-transform: uppercase;
    cursor: pointer;
    background-color: transparent;
    -webkit-transition: background-color 0.3s;
    -moz-transition: background-color 0.3s;
    -o-transition: background-color 0.3s;
    -ms-transition: background-color 0.3s;
    transition: background-color 0.3s;
}
.btn-cta:hover {
    text-decoration: none;
    background-color: #4D4D4D;
    color: #FFF;
}
.gray{
    background-color:#f2f2f2;
}

/* Menú superior */
#nav-main{
    width:100%;
    height:70px;
    position: relative;
    background-color: #f9f9f9;
    font-size: 18px;
    line-height: 1.6em;
    text-align: center;
    /*overflow:hidden;*/
    box-sizing:border-box;
    /*border-bottom:1px solid #464646;*/
    z-index:999;
    box-shadow: 1px 1px 1px rgba(0,0,0,0.2);
    -webkit-box-shadow: 1px 1px 1px rgba(0,0,0,0.2);
}
    #nav-main .menu{
        width: 100%;
        height: 100%;
        position: relative;
        margin: 0 auto;
    }
    #nav-main #logo-container{
        width:100%;
        height: 100%;
        float:none;
        position: relative;
        text-align:left;
    }
        #nav-main #logo-container img{
            height: 70px;
            cursor:pointer;
            margin-left: 15px;
        }
    #navigation{
        width:100%;
        height: auto;
        background-color:#000;
        float:none; 
        padding:0;
        margin:0;
        display:none;
    }
        #navigation ul{
            padding:0;
            margin:0;
        }
        #navigation ul li{
            color: #FFF;
            height:45px;
            position: relative;
            text-align:left;
            padding:0 2em;
        }
        #navigation ul > li {
            float: none;
        }
        #navigation ul > li > a {
            color: rgba(255,255,255,0.7);
            line-height: 16px;
            font-size: 13px;
            display: block;
            /*height: 18px;*/
            padding:1em 0;
            border-bottom:1px solid #4f4e4e;
        }
        #navigation ul > li:last-child > a {
            border-bottom:none;
        }
        #navigation ul > li > a:hover, #navigation .active a, #navigation > li:hover > a{
            color:#fff;
            text-decoration:none;
        }

.naranja{color:#ff6e3d;} .azul{color:#0b95ff;} .gris{color: #a3a3a3;}

#mobile-menu-button {
    position: absolute;
    top: 0;
    right: 0.5em;
    width: 40px;
    height: 70px;
    line-height: 65px;
    text-align: center;
    font-size: 30px;
    cursor: pointer;
    color: #343434;
}
    .fa {
        display: inline-block;
        font-family: 'FontAwesome';
        font-style: normal;
        font-weight: normal;
        line-height: 1;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale;
    }

#headerbg{
    position: relative;
    width:100%;
    height:300px;
    /*border-top:#ddd 1px solid;*/
    border-bottom:#ddd 1px solid;
    background-color: #000;
    z-index: -1;
}
    #fondo1, #fondo2, .overlay, .fondo-estatico {width:100%; height:100%; position: absolute; left: 0; top: 0;}
    #fondo1 {z-index: 2; opacity: 0;}
    #fondo2 {z-index: 1; display: none;}
    #header{display:block; position:absolute; left: 0; top: 0px; width:100%; height: 300px; text-align: center; z-index: 3; }

    #fondo-paquetes{
        background:url(../img/slider/foto_ejemplo7.jpg) no-repeat;
        background-size: cover;
        background-position:center;
    }
    #fondo-noticias{
        background:url(../img/slider/foto_ejemplo8.jpg) no-repeat;
        background-size: cover;
        background-position:center;
    }
    #fondo-servicios{
        background:url(../img/slider/foto_ejemplo2.jpg) no-repeat;
        background-size: cover;
        background-position:center;
    }
    #fondo-contacto{
        background:url(../img/slider/foto_ejemplo3.jpg) no-repeat;
        background-size: cover;
        background-position:center;
    }

#destacados-slide{
    padding: 30px 0;
    margin-top:-175px;
}
    #detacados{
        position: relative;
    }
    #destacados-header, #paquetes-header{
        width:100%;
        height:70px;
    }
        #destacados-header h1, #paquetes-header h1{
            font-size:1.6em;
            text-transform: uppercase;
            font-weight:bold;
            margin:0 auto;
            text-align:center;
        }
        #destacados-header h1{
            color:#FFF;
        }
        #paquetes-header h1{
            color:#666;
        }
        #paquetes-header p{
            text-align:center;
            font-weight:bold;
            font-size:1.2em;
        }
    #galeria-destacados, #galeria-paquetes{
        width:980px;
        /*min-height: 240px;*/
        position: relative;
        margin:0 auto;
    }
    .destacados-main{
        background-color:#000;
    }
    .destacados-title{
        width:100%;
        height:auto;
        color:#FFF;
    }
        .destacados-title h2{
            width:150px;
            display:block;
            float:left;
            padding: 1.1em;
            font-size: 1.2em;
            margin:0;
            text-align:left;
        }
        .destacados-title h2 a{
            color:#FFF;
        }
        .destacados-title h2 a:hover{
            text-decoration:underline;
        }
        .destacados-title p{
            width:60px;
            display:block;
            float:right;
            font-weight:bold;
            padding: 1.1em;
            font-size: 1.2em;
            margin:0;
            text-align:right;
            color:#2EA0DB;
        }
    #destacados-slide .container, #paquetes-slide .container{
        padding:0;
    }
    .item, .item2{
        width: 285px; 
        position: absolute;
        color: #FFF;
        text-align: center;
        overflow:hidden;
        float: left;
        margin-bottom:20px;
        /*border:1px solid #b9b9b9;*/
        box-shadow: 0 0 1px 1px #ddd;
    }
    .item3{
        width: 100%; 
        background-color:#FFF;
        margin-bottom:25px;
    }
    .noticias-main{
        width:100%;
        min-height:200px;
    }
    .noticias-main .titulo{
        text-align:center;
        font-size:1.6em;
    }
    .noticias-main .noticia{
        font-size: 1.15em;
        font-style: italic;
    }
    .noticias-main .cycle-slide{
        width:100%;
        height:100px;
    }
    .paquetes-title, .paquetes-info{
        width:100%;
        height:auto;
        background-color:#fff;
    }
    .paquetes-title{
        color:#666;
        border-bottom:1px solid #eee;
    }
    .paquetes-info{
        color:#868686;
    }
    .paquetes-title h2{
        text-align:center;
        font-size:1.2em;
        margin:0;
        padding:1em 0;
    }
    .paquetes-info p{
        margin:0;
        padding:10px 20px;
    }
    .servicios-main{
        padding:1em 1.6em;
        width:100%;
        float:none;
    }
        .servicios-main-header{
            height:70px;
        }
            .servicios-main-header p{
                font-size:1.7em;
                text-align:center;
                font-weight: bold;
                /*color:#000;*/
            }
        .servicios-main-main{
            height:auto;
            padding-bottom:1em;
        }
        .servicios-header{
            height:120px;
            text-align:center;
        } .servicios-header.svh2{height: 80px;}
            .servicios-header h1{
                font-size:1.2em;
                text-align:center;
                color:#666;;
            }

            .servicios-header h2{
                text-align: left;
                font-size: 1.2em;
                margin-top: 1.8em;
            }
        .servicios-main-main .contenido p{
            font-size:1.2em;
            line-height:1.6em;
        }
        .servicios-header .general_color{
            color: #2EA0DB;
            font-size: 40px;
        }
    .contact-form{
        padding:1em 1.6em;
    }
    .contact-header h2{color:#fff; font-size: 2em;}
    .contact-form .form-two, .contact-form .form-one{
        width:100%;
        height:35px;
        position: relative;
        margin:1em 0;
        text-align:center;
    }
    .contact-main p{font-weight: bold; font-size: 1.2em;}
    .contact-form .form-one{
        margin:0 0 1em;
        height:70px;
    }
    .contact-form p{
        text-align: center;
    }
    .contact-form .form-one p{
        font-size: 0.9em;
    }
        .contact-form .label-form, .contact-form .input-form{
            float:left;
            height:100%;
        }
        .contact-form .label-form{
            font-size: 13px;
            width:33%;
            border: 1px solid #2EA0DB;
            background-color: #2EA0DB;
            color: #FFF;
        }
        .contact-form .input-form{
            width:65%;
            border: 1px solid #AFAFAF;
            background-color:#FFF;
        }
            .input-form input, .input-form textarea{
                width: 99%;
                height: 85%;
                border: none;
            }
            .input-form textarea{
                width: 98%;
                resize:none;
            }
            .form-one input[type="submit"] {
                border: 1px solid #AFAFAF;
                background-color: #fff;
                color: #660000;
                padding: 0.5em 2em;
            }
            .form-two label {
                display: block;
                margin-top: 6px;
            }
            .form-one label {
                display: block;
                margin-top: 22px;
            }
/* Pagina Paquetes Turísticos */
.foto-paquete{
    width:100%;
    height:auto;
    float:none;
    position: relative;
}
    .foto-paquete img{
        width:100%;
        height:auto;
    }
.info-paquete{
    width:100%;
    height:auto;
    float:none;
    position: relative;
}
    .info-paquete .paquetes-title h2{
        width:60%;
        float:left;
        text-align:left;
        padding:14px 20px;
    }
    .info-paquete .paquetes-title h3{
        width:15%;
        float:right;
        text-align:right;
        padding:14px 20px;
        margin:0;
    }
.princ-paquete{
    max-height:400px;
}
.paquete-info p{
    padding:0 40px;
    font-size:1.1em
}
#paquete-turistico .cycle-slideshow{
    width: 75%;
}

#pagination{
    width: 100%;
    height: 30px;
    margin: 0 auto;
    text-align: center;
    background-color: #FFF;
    padding: 6px 0 0;
}
    #pagination a{
        font-weight:bold;
        padding:5px 5px;
        margin-left: 5px;
        border:1px solid #FFF;
        color: #666;
    }
    #pagination .selected, #pagination a:hover{
        background:#FFF;
        color:#666;
    }

@media (min-width: 380px){
    .destacados-slide .container, #paquetes-slide .container{
        padding:0 15px;
    }
}
@media (min-width: 490px){
    .contact-form .label-form{
        width:26%;
    }
    .contact-form .input-form{
        width:72%;
    }
    #paquete-turistico .cycle-slideshow{
        width: 65%;
    }
}
@media (min-width: 550px){
    .foto-paquete{
        width:35%;
        float:left;
    }
    .info-paquete{
        width:65%;
        float:left;
    }
    .paquete-info p{
        padding:0 100px;
    }
}
@media (min-width: 670px){
    #nav-main{
        height:135px;
        font-weight: bold;
    }
        #nav-main #logo-container{
            width:15%;
            height:135px;
            float:left;
        }
        #nav-main #logo-container img{
            width:auto;
            height: 135px;
            /*padding: 0.25em 0;*/
            float:left;
        }
        #navigation{
            width:85%;
            height: 135px;
            float:left; 
            background:none;
            display:block !important;
            visibility: visible;
        }
            #navigation ul {
                width:100%;
                height:100%;
                /*margin-left:4em;*/
            }
            #navigation ul > li {
                height:100%;
                float: left;
                margin-left: 5px;
                padding: 0 0.65em;
            }
            #navigation ul > li > a {
                color:#666;
                font-size: 0.7em;
                height: 18px;
                padding:8.4em 0 0;
                border-bottom:none;
            }
            #navigation ul > li > a:hover {
                color:#2EA0DB;
            }

    #mobile-menu-button {
        display:none;
    }
    #destacados{
        margin:0 auto;
    }
    #paquete-turistico .cycle-slideshow{
        width: 60%;
    }
}
@media (min-width: 768px){
    #nav-main{
        height:170px;
    }
        #nav-main #logo-container{
            width:20%;
            height:170px;
        }
        #nav-main #logo-container img{
            height: 169px;
            margin-left: 30px;
        }
        #navigation{
            width:78%;
            height: 170px;
        }
            #navigation ul > li {
                padding: 0 0.75em;
            }
            #navigation ul > li > a {
                padding:10.8em 0 0;
            }
    #headerbg{
        height:640px;
    }
    #header{
        height: 640px;
    }
    .servicios-header{
        height:110px;
        text-align:center;
    }
    .servicios-main{
        float:left;
        width:28%;
        padding: 1em 1.5em;
    }
        .servicios-main-main{
            height:350px;
        } .servicios-main-main.svm2{height: 320px;}
        .servicios-main-main .contenido p{
            text-align:left;
        }
}
@media (min-width: 980px){
    .container {
        max-width: 980px;
    }
    #nav-main .menu{
        width: 980px;
        height: 100%;
        position: relative;
        margin: 0 auto;
    }
        #navigation ul > li {
            padding: 0 1em;
        }
            #navigation ul > li > a {
                font-size: 0.75em;
                padding:10em 0 0;
            }
    #destacados{
        width:980px;
    }
    .servicios-main{
        width:29%;
        padding: 1em 1.5em;
    }
        .servicios-main-main{
            height:325px;
        }
    .servicios-main-main.svm2{height: 300px;}
    .contact-info{
        width:33%;
        float:left;
    }
    .contact-form .form-two{
        width:50%;
        float:left;
    }
}
@media (min-width: 1200px){

    .servicios-header{
        height:100px;
        text-align:center;
    }
    .servicios-main{
        width:30%;
        padding: 1em 1.4em;
    }
    .container{
        max-width: 1170px;
    }
    .servicios-main-main{
        height:300px;
    } .servicios-main-main.svm2{height: 260px;}
        .servicios-main-main .contenido p{
            text-align:justify;
        }
        .social-main-main .contenido p{
            text-align:justify;
        }
    .paquete-info p{
        padding:0 150px;
    }
}


/* ==========================================================================
   Helper classes
   ========================================================================== */

/*
 * Image replacement
 */

.ir {
    background-color: transparent;
    border: 0;
    overflow: hidden;
    /* IE 6/7 fallback */
    *text-indent: -9999px;
}

.ir:before {
    content: "";
    display: block;
    width: 0;
    height: 150%;
}

/*
 * Hide from both screenreaders and browsers: h5bp.com/u
 */

.hidden {
    display: none !important;
    visibility: hidden;
}

/*
 * Hide only visually, but have it available for screenreaders: h5bp.com/v
 */

.visuallyhidden {
    border: 0;
    clip: rect(0 0 0 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
}

/*
 * Extends the .visuallyhidden class to allow the element to be focusable
 * when navigated to via the keyboard: h5bp.com/p
 */

.visuallyhidden.focusable:active,
.visuallyhidden.focusable:focus {
    clip: auto;
    height: auto;
    margin: 0;
    overflow: visible;
    position: static;
    width: auto;
}

/*
 * Hide visually and from screenreaders, but maintain layout
 */

.invisible {
    visibility: hidden;
}

/*
 * Clearfix: contain floats
 *
 * For modern browsers
 * 1. The space content is one way to avoid an Opera bug when the
 *    `contenteditable` attribute is included anywhere else in the document.
 *    Otherwise it causes space to appear at the top and bottom of elements
 *    that receive the `clearfix` class.
 * 2. The use of `table` rather than `block` is only necessary if using
 *    `:before` to contain the top-margins of child elements.
 */

.clearfix:before,
.clearfix:after {
    content: " "; /* 1 */
    display: table; /* 2 */
}

.clearfix:after {
    clear: both;
}

/*
 * For IE 6/7 only
 * Include this rule to trigger hasLayout and contain floats.
 */

.clearfix {
    *zoom: 1;
}

/* ==========================================================================
   EXAMPLE Media Queries for Responsive Design.
   These examples override the primary ('mobile first') styles.
   Modify as content requires.
   ========================================================================== */

@media only screen and (min-width: 35em) {
    /* Style adjustments for viewports that meet the condition */
}

@media print,
       (-o-min-device-pixel-ratio: 5/4),
       (-webkit-min-device-pixel-ratio: 1.25),
       (min-resolution: 120dpi) {
    /* Style adjustments for high resolution devices */
}

/* ==========================================================================
   Print styles.
   Inlined to avoid required HTTP connection: h5bp.com/r
   ========================================================================== */

@media print {
    * {
        background: transparent !important;
        color: #000 !important; /* Black prints faster: h5bp.com/s */
        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) ")";
    }

    /*
     * Don't show links for images, or javascript/internal links
     */

    .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; /* h5bp.com/t */
    }

    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;
    }
}
