﻿/* TODO: file too big; non-cohesive. CHOP CHOP!*/

html {
    background-color: #c4c4c4; /*cannot do this for the editor as it makes the my tours page look ugly ????? */
}

@font-face {
    font-family: realWayFont;
    src: url(/fonts/Raleway-Regular.ttf) format('truetype');  
}

.margin10{
	margin: 10px;
}
body {
    font-family: realWayFont;
    background-color: #c4c4c4; /*cannot do this for the editor as it makes the my tours page look ugly ????? */
}

/* Includes header, body-content and footer */
#wholepage {
    /* Needed for sticky-footer */
    display: flex;
    min-height: 100vh;
    flex-direction: column;
}

/* Wrapping element, does not include the footer */
.body-content {
    background-color: #c4c4c4; /*cannot do this for the editor as it makes the my tours page look ugly ????? */
    /* flex is needed for sticky-footer */
    flex: 1;
    height: auto;
    /*background-color: silver;*/
}

/* Set some basic padding to keep content from hitting the bottom edge */
.body-content-padded-bottom {
    padding-bottom: 1em;
}

/* Set some basic padding to keep content from hitting the side edges */
.body-content-padded-sides {
    padding-left: 1em;
    padding-right: 1em;
}

.keob-footer {
    background-color: #edeff0;
    padding-top: 1em;
    padding-bottom: 1em;
}

/* Otherwise Home button shows vertically uncentered on small screens */
/*.navbar-nav > li > .navbar-brand-keob-home {
    padding-top: 15px;
}*/

.navbar-nav > li > a.navbar-brand {
    display: flex;
    align-items: center; /* Esto centra verticalmente el contenido */
}


.navbar{
    font-size:16px;
}

/* Añadir una franja debajo del elemento seleccionado */
.main-navbar-nav .active a {
    background-color: transparent;
    border-bottom: 5px solid #f5bf42; /* Cambia el color según lo desees */
    margin-bottom: -5px; /* Ajusta el espaciado según lo necesites */
}
.navbar-nav.main-navbar-nav > li.active > a {
    background-color: transparent !important;
}

.indexTourMetaItemContainer {
	margin-top: 2px;
	margin-bottom:8px;
	height: 32px
}

.indexTourMetaItem {
	margin-left: 10px;
	vertical-align: bottom;
	height: 32px;
}

/* TODO LK: Use more specific selectors instead, e.g. ".selector-keob-restricted select". 
   "Undoing" max-width seems difficult if you do not want any width restriction. 
 */
select {
	max-width: 270px;
}

/* Highlite code portions with a different font */
code {
    font-family: Courier New, Courier, monospace;
}

/* --------------- */
/*   Image shadow  */
/* --------------- */
.img-shadow {
	/*filter: gray; 
	-webkit-filter: grayscale(1); /* Google Chrome, Safari 6+ & Opera 15+ */
	-webkit-box-shadow: 0 2px 6px 2px rgba(0,0,0,0.6);
	-moz-box-shadow: 0 2px 6px 2px rgba(0,0,0,0.6);
	box-shadow: 0 2px 6px 2px rgba(0,0,0,0.6);
	/*margin-bottom: 20px;*/
}

.img-shadow:hover {
	/*filter: none; 
	-webkit-filter: grayscale(0);*/
	-webkit-box-shadow: 0 2px 6px 2px rgba(0,0,0,1);
	-moz-box-shadow: 0 2px 6px 2px rgba(0,0,0,1);
	box-shadow: 0 2px 6px 2px rgba(0,0,0,1);
}

/* Carousel */
.carousel-caption p {
	font-size: 20px;
	line-height: 1.4;
}

/* Hide/rearrange for smaller screens */
@media screen and (max-width: 767px) {
	/* Hide captions */
	.carousel-caption {
		display: none;
	}
}

.img-cover-maps-infowindow {
    width: 300px;
    height: auto;
}

p {
	margin-top: 15px;
}

/* used e.g. in dialogs for buttons container */
.basic-padding-top {
    padding-top: 8px;
}

table {
	margin: auto;
	margin-top: 10px;
	margin-bottom: 10px;
	border-collapse: collapse;
	text-align: center;
}

.leftRightBorder {
	/*border-right: 1px solid black;*/
	border-left: 1px solid black;
	padding: 1px;
}
        
#apitable {
	margin-left: 0;
	margin-top: 40px;
}

#apitable td, #apitable th {
    padding: 3px 10px 3px 0;
	border-bottom: 1px solid black;
	text-align: left;
}

.label-apicall {
    padding: 5px 10px;
    margin-right: 8px;
    border-radius: 4px;
}

.label-apicall-get {
    color: green;
    border: 1px solid green;
}

.label-apicall-post {
    color: blue;
    border: 1px solid blue;
}

.label-apicall-put {
    color: orange;
    border: 1px solid orange;
}

.label-apicall-delete {
    color: red;
    border: 1px solid red;
}


.embedCode {
	color: #337ab7;
}

.embedCode:hover {
	text-decoration: underline;
	cursor: pointer;
}

.photo .bottomalign {
	background-color: #000000;
	width: 100%;
	line-height: 40px;
	display: block;
	color: white;
	margin: auto;
	position: relative;
	bottom: 40px;
	opacity: .75;
	margin-bottom: -40px;
}

.photo .topalign {
	background-color: #820909;
	width: 30%;
	line-height: 40px;
	display: block;
	color: white;
	margin: auto;
	position: absolute;
	top: 0;
	opacity: .75;
}

.topAlignRight a{
	text-decoration:none;
	color:white;
}
.photo .topAlignRight {
	background-color: #333;
	line-height: 40px;
	display: block;
	color: white;
	/*margin: auto;*/
	position: absolute;
	top: 0;
	right: 15px;
	opacity: .75;
	width: 90px;
}

.img-profile-restricted-width {
    max-width: 168px;
}

.slider-selection {
	background: #ddd;
}

.slider-handle {
	background: #777;
}

#admindata {
	height: 200px
}

.dd-margin-bottom {
    margin-bottom: 0.5em;
}

/* Used e.g. in sidebar filter */
.form-margin-bottom {
    margin-bottom: 16px;
}

/* Dropdown Button */
.dropbtn {
    cursor: pointer;
}

/* The container <div> - needed to position the dropdown content */
.dropdown {
    position: relative;
    display: inline-block;
}

/* Tour Options Dropdown Content (Hidden by Default) */
.dropdown-content-tour-options {
    min-width: 180px;
}


.dropdown-content {
    display: none;
    position: absolute;
    right: 0;
    background-color: #f9f9f9;
    box-shadow: 0 8px 16px 0 rgba(0,0,0,0.2);
    z-index: 1;
}

    /* Links inside the dropdown */
    .dropdown-content a {
        color: black;
        padding: 8px 16px;
        text-decoration: none;
        display: block;
    }

        /* Change color of dropdown links on hover */
        .dropdown-content a:hover {
            background-color: #f1f1f1;
        }

/* Show the dropdown menu on hover */
.dropdown:hover .dropdown-content {
    display: block;
}

/* Change the background color of the dropdown button when the dropdown content is shown */
.dropdown:hover .dropbtn {
    background-color: #ebebeb;
}

.keob-header-dropdown li a {
    padding-top: 10px;
    padding-bottom: 10px;
}

.container-instructions li {
    margin-top: 16px;
}

[data-braintree-id="toggle"] {
	display: none;
}

.btn-text-black {
    color: #000;
}

.btn-borderless {
    border: 0;
    outline: 0;
}

/* Display red asterisk to the right of the required input form labels */
.form-group.required .control-label:after {
    content: "*";
    color: red;
    position: relative;
    top: 4px;
    margin-left: 2px;
    font-size: 22px;
}

/* ---------------------------------------- */
/*                 About page               */
/* ---------------------------------------- */

.buttons {
    text-align: center;
    margin-top: 45px;
}

.custom-button {
    display: inline-block !important;
    text-align: center;
    text-transform: uppercase;
    padding: 13px 35px;
    border-radius: 3px;
    margin: 10px;
    border: medium none;
}

.yellow-btn {
    background: rgba(255, 255, 255, 0.15);
    border: 1px solid #FFDD00;
    color: #FFF;
    -webkit-transition: all 0.3s ease-in-out;
    transition: all 0.3s ease-in-out;
}

    .yellow-btn:hover,
    .yellow-btn:focus,
    .yellow-btn.active,
    .yellow-btn:active,
    .yellow-btn:active:focus, 
    .open .dropdown-toggle.yellow-btn {
        color: #212121;
        background-color: #fd0;
        border-color: #fd0;
    }

.rb_logo {
    padding-bottom: 190px;
    max-width: 80%;
}

.intro-text {
    text-align: center;
    color: #FFF;
    line-height: 65px;
    z-index: 0;
    text-transform: uppercase;
    font-size: 55px;
    float: none;
}

.header-content-wrap {
    padding: 10% 0px 290px;
}

.header-content-wrap {
    background: rgba(0, 0, 0, 0.5);      
    position: relative;
    -webkit-box-shadow: 0px 5px 11px 0px rgba(50, 50, 50, 0.08);
    box-shadow: 0px 5px 11px 0px rgba(50, 50, 50, 0.08);
    padding: 30px 0 210px;
}

.home-header-wrap {
    overflow: hidden;
    position: relative;
}

#parallax_move {
    width: 100%;
    height: 1000px;
    background-size: cover;
    margin-left: -60px;
    position: absolute;
    z-index: 0;
    transform-style: preserve-3d;
    backface-visibility: hidden;
}

#parallax_move .layer {
    background-size: cover;
    width: 100%;
    height: 100%;
    background-position: top center;
}

    #parallax_move .layer1 {
        background-image: url("/images/about/portada.jpg");
        width: 150%;
        transform-style: preserve-3d;
        backface-visibility: hidden;
        position: relative;
        display: block;
        left: 0px;
        top: 0px;
    }

    #parallax_move .layer2 {
        background-image: url("/images/about/paralax.png");
        width: 120%;
        transform-style: preserve-3d;
        backface-visibility: hidden;
        position: absolute;
        display: block;
        left: 0px;
        top: 0px;
    }

/* ---------------------------------------- */
/*      Displayed tours count               */
/* ---------------------------------------- */

.marginright10{
	margin-right:10px;
}

.tours-filter-message-text {
    margin-top: 2px;
}

/* ---------------------------------------- */
/*      Search form                         */
/* ---------------------------------------- */

/* Code related to search button sticking to the search form input control */
.add-on .input-group-btn > .btn {
    border-left-width: 0;
    left: -2px;
    -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
    -moz-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
    box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
}
/* Search button: stop the glowing blue shadow */
.add-on .form-control:focus {
    -webkit-box-shadow: none;
    -moz-box-shadow: none;
    box-shadow: none;
    border-color: #cccccc;
}

/* ---------------------------------------- */
/*      Tour gallery                        */
/* ---------------------------------------- */

.tour-item-container {
    text-align: center;
    margin-top: 15px;
}

.tour-item-img-container {
    min-height: 80px;
}

.icon-tour-info-admin {
    margin: 2px;
}

/* Highlight admin-only buttons text color */
.btn-admin-only,
.dropdown-content a.btn-admin-only,
.btn-admin-only a, 
.admin-only {
    color: #ef6c00;
}

/* ---------------------------------------- */
/*      Contact page                        */
/* ---------------------------------------- */

.contact-icon {
    margin-right: 16px;
}

.contact-line-no-icon {
    margin-left: 32px;
}

.social-links {
    list-style: none;
    padding-left: 0;
    padding-right: 0;
}

    .social-links li {
        display: inline;
    }

        .social-links li a {
            color: #5a5a5a;
        }

/* ---------------------------------------- */
/*      Software page                       */
/* ---------------------------------------- */
/* Software page - app category title area, e.g. VR Solutions */
.promo-app-category-title {
    background-color: #edeff0;
}

    .promo-app-category-title h3 {
        padding-top: 5px;
        padding-bottom: 5px;
    }

.promo-app-item-title-text {
    margin-left: 64px;
}

.promo-app-item-title-text-first-line {
    margin-top: 4px;
}

/* Software page - single app area */
.promo-app-item {
    padding-top: 16px;
    padding-bottom: 16px;
}

.promo-app-item-title {
    font-size: unset;
}

/* The short functionality description of a specific app */
.promo-app-item-description {
    padding-top: 16px;
    padding-bottom: 16px;
}

/* Google Play Store badge */
.promo-app-item-download-button-playstore img {
    width: 161px;
    height: 61px;
}

/* Apple App Store badge */
.promo-app-item-download-button-appstore img {
    height: 42px;
    margin: 10px;
}

/* Amazon Appstore badge */
.promo-app-item-download-button-amazon img {
    margin: 10px;
}

/* Download from our website button */
.promo-app-item-download-button-keob {
    margin: 10px;
}

/*
.promo-app-item-download-buttons {
    text-align: center;
}
*/

.agency-item {
    margin-top: 15px;
    margin-bottom: 15px;
}

/* ---------------------------------------- */
/*              Team page                   */
/* ---------------------------------------- */

.team-member-item {
    margin-bottom: 20px;
    text-align: center;
}

.img-highlight-border,
.team-member-img {
    border: 8px solid #ececec;
}

.team-member-img {
    margin-bottom: 5px;
}

.img-highlight-border:hover, 
.team-member-img:hover {  
    border-color: #fd0;
}

/* ---------------------------------------- */
/*      Tour Details page                   */
/* ---------------------------------------- */
/* these colors are used to color the availability dot in tour details view. */
.green-color {
    color: #4caf50;
}
.red-color {
    color: #f44336;
}
.orange-color {
    color: #ff9800;
}

/* ---------------------------------------- */
/*      Tour Assets page                   */
/* ---------------------------------------- */

.margin-top-assets {
    margin-top: 10px;
}

.display-inline {
    display: inline;
}

.iframe-assets {
    margin: 15px;
}

/* ---------------------------------------- */
/*      Spinner / Overlay                   */
/* ---------------------------------------- */
/* Absolute Center Spinner */
.loading {
    position: fixed;
    z-index: 999;
    height: 2em;
    width: 2em;
    overflow: visible;
    margin: auto;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
}

    /* Transparent Overlay */
    .loading:before {
        content: '';
        display: block;
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background-color: #000;
        background-color: rgba(0,0,0,0.3);
    }

    /* :not(:required) hides these rules from IE9 and below */
    .loading:not(:required) {
        /* hide "loading..." text */
        font: 0/0 a;
        color: transparent;
        text-shadow: none;
        background-color: transparent;
        border: 0;
    }

        .loading:not(:required):after {
            content: '';
            display: block;
            font-size: 10px;
            width: 1em;
            height: 1em;
            margin-top: -0.5em;
            -webkit-animation: spinner 1500ms infinite linear;
            -moz-animation: spinner 1500ms infinite linear;
            -o-animation: spinner 1500ms infinite linear;
            animation: spinner 1500ms infinite linear;
            border-radius: 0.5em;
            -webkit-box-shadow: rgba(0, 0, 0, 0.75) 1.5em 0 0 0, rgba(0, 0, 0, 0.75) 1.1em 1.1em 0 0, rgba(0, 0, 0, 0.75) 0 1.5em 0 0, rgba(0, 0, 0, 0.75) -1.1em 1.1em 0 0, rgba(0, 0, 0, 0.5) -1.5em 0 0 0, rgba(0, 0, 0, 0.5) -1.1em -1.1em 0 0, rgba(0, 0, 0, 0.75) 0 -1.5em 0 0, rgba(0, 0, 0, 0.75) 1.1em -1.1em 0 0;
            -moz-box-shadow: rgba(0, 0, 0, 0.75) 1.5em 0 0 0, rgba(0, 0, 0, 0.75) 1.1em 1.1em 0 0, rgba(0, 0, 0, 0.75) 0 1.5em 0 0, rgba(0, 0, 0, 0.75) -1.1em 1.1em 0 0, rgba(0, 0, 0, 0.5) -1.5em 0 0 0, rgba(0, 0, 0, 0.5) -1.1em -1.1em 0 0, rgba(0, 0, 0, 0.75) 0 -1.5em 0 0, rgba(0, 0, 0, 0.75) 1.1em -1.1em 0 0;
            box-shadow: rgba(0, 0, 0, 0.75) 1.5em 0 0 0, rgba(0, 0, 0, 0.75) 1.1em 1.1em 0 0, rgba(0, 0, 0, 0.75) 0 1.5em 0 0, rgba(0, 0, 0, 0.75) -1.1em 1.1em 0 0, rgba(0, 0, 0, 0.75) -1.5em 0 0 0, rgba(0, 0, 0, 0.75) -1.1em -1.1em 0 0, rgba(0, 0, 0, 0.75) 0 -1.5em 0 0, rgba(0, 0, 0, 0.75) 1.1em -1.1em 0 0;
        }

#floating-panel {
    position: absolute;
    top: 10px;
    left: 142px;
    margin-right: 25px;
    max-width: 220px;
    z-index: 5;
    background-color: #fff;
    padding: 5px;
    border: 1px solid #aaa;
    border-radius: 2px;
    text-align: center;
    font-family: 'Roboto','sans-serif';
    line-height: 24px;
}

/* ---------------------------------------- */
/*      Animation                           */
/* ---------------------------------------- */

@-webkit-keyframes spinner {
    0% {
        -webkit-transform: rotate(0);
        -moz-transform: rotate(0);
        -ms-transform: rotate(0);
        -o-transform: rotate(0);
        transform: rotate(0);
    }

    100% {
        -webkit-transform: rotate(360deg);
        -moz-transform: rotate(360deg);
        -ms-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

@-moz-keyframes spinner {
    0% {
        -webkit-transform: rotate(0);
        -moz-transform: rotate(0);
        -ms-transform: rotate(0);
        -o-transform: rotate(0);
        transform: rotate(0);
    }

    100% {
        -webkit-transform: rotate(360deg);
        -moz-transform: rotate(360deg);
        -ms-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

@-o-keyframes spinner {
    0% {
        -webkit-transform: rotate(0);
        -moz-transform: rotate(0);
        -ms-transform: rotate(0);
        -o-transform: rotate(0);
        transform: rotate(0);
    }

    100% {
        -webkit-transform: rotate(360deg);
        -moz-transform: rotate(360deg);
        -ms-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

@keyframes spinner {
    0% {
        -webkit-transform: rotate(0);
        -moz-transform: rotate(0);
        -ms-transform: rotate(0);
        -o-transform: rotate(0);
        transform: rotate(0);
    }

    100% {
        -webkit-transform: rotate(360deg);
        -moz-transform: rotate(360deg);
        -ms-transform: rotate(360deg);
        -o-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

/* ---------------------------------------- */
/*      Smaller screens                     */
/* ---------------------------------------- */
@media (max-width: 768px) {

    /* Search form specifics for smaller screens */

    /* otherwise default padding from .navbar-form is applied and we have already too much spacing */
    .keob-search-form {
        padding-top: 0;
        padding-bottom: 0;
    }

        /* Create some space to the words "Back to full list" on smaller screens. */
        .keob-search-form .input-group {
            padding-bottom: 8px;
        }

    .rb_logo {
        padding-bottom: 100px;
    }

}

/* ---------------------------------------- */
/*      Larger screens                      */
/* ---------------------------------------- */
@media (min-width: 768px) {

    /* Prevent page body shifting to the left when Bootstrap dialog is open */
    body.modal-open {
        margin-right: -15px;
    }

    /* Search form specifics for larger screens */

    /* otherwise default padding from .navbar-form is applied and UI becomes messy */
    .keob-search-form {
        padding: 0;
    }

    /* Define min-width for the search area, so that it fully displays the placeholder. 
        Inline-block needed so that on large screens a second html element maybe position to the side of the search bar on the same line.*/
    .keob-search-form-control {
        display: inline-block;
        min-width: 260px;
    }

    /* Create some space to the words "Back to full list" on larger screens. */
    .keob-search-form .input-group {
        padding-right: 8px;
    }

    /* Tour Options Dropdown Content (Hidden by Default) */
    .dropdown-content-tour-options {
        min-width: 250px;
    }
}

/* THE FOLLOWING IS COPIED FROM Wordpress */

@media (min-width: 768px) and (max-width: 1024px) {

    /* TOP BAR ELEMENTS */

    /* HOME */
    .intro {
        margin-top: 40%;
        line-height: 55px;
        font-size: 45px;
    }

    /* ABOUT US */
    .big-intro {
        text-align: center !important;
    }

    .about-us .column {
        margin-bottom: 40px;
    }

}

@media (max-width: 992px) {

    .intro-text {
        font-size: 45px;
        line-height: 55px;
    }

    .section-header h2 {
        font-size: 35px;
    }

    .section-header {
        padding-bottom: 30px;
    }

    .focus, .works, .about-us, .features, .packages, .products, .testimonial, .contact-us {
        padding-top: 60px;
        padding-bottom: 60px;
    }

    .about-us .big-intro {
        text-align: center;
    }

}

@media (max-width: 767px) {

    /* HOME */

    .intro {
        line-height: 8vh;
        font-size: 6.5vw;
    }

    .intro-text {
        font-size: 41px;
        line-height: 49px;
    }

    .focus-box {
        margin-bottom: 75px;
    }

    .section-header {
        float: left;
        width: 100%;
    }

    /* ABOUT US */
    .big-intro {
        text-align: center !important;
        font-size: 8vw !important;
    }

}

@media (max-width: 480px) {

    /* HOME */
    .intro {
        margin-top: 60%;
        line-height: 6vh;
        font-size: 6.5vw;
    }

    .intro-text {
        font-size: 32px;
        line-height: 37px;
    }

    #floating-panel {
        top: 223px;
        left: 10px;
    }

}

@media (max-width: 320px) {
    .intro {
        line-height: 25px;
        font-size: 7vw;
    }

    .intro-text {
        font-size: 22px;
        line-height: 30px;
    }

}

/* Not really expected, this is even more narrow than iphone 5 etc. Added just to make sure not to cover Google trademark */
@media (max-width: 310px) {

    #floating-panel {
        top: 197px;
    }

        #floating-panel input {
            max-width: 100px;
        }
}
