/*
Theme Name: Uncode Child
Description: Child theme for Uncode theme
Author: Undsgn™
Author URI: http://www.undsgn.com
Template: uncode
Version: 1.0.0
Text Domain: uncode
*/

/* ========================================
   ROQUEBUS - Tourist Bus Service Theme
   Design System Implementation
   ======================================== */

/* Google Fonts Import */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

/* ========================================
   CSS Custom Properties (Variables)
   ======================================== */
:root {
    /* Brand Colors */
    --roquebus-primary: #056a9c;
    --roquebus-secondary: #b7efff;
    --roquebus-dark: #063953;
    --roquebus-text-secondary: #015179;
    --roquebus-text-body: #1d1d1b;
    --roquebus-bg-light: #d4f1f9;
    --roquebus-bg-hero: #e0f8ff;
    --roquebus-bg-footer: #1a2d3d;
    --roquebus-white: #ffffff;
    --roquebus-stop-bg: #f5f7f7;
    --roquebus-dark-gray: #25272b;
	--white: #FFFFFF;

    /* Typography */
    --roquebus-font-family: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    --roquebus-font-weight-regular: 400;
    --roquebus-font-weight-medium: 500;
    --roquebus-font-weight-semibold: 600;
    --roquebus-font-weight-bold: 700;
    --roquebus-font-weight-extrabold: 800;

    /* Layout */
    --roquebus-content-width: 1350px;
    --roquebus-card-width: 315px;
    --roquebus-gap: 30px;
    --roquebus-max-width: 1920px;

    /* Border Radius */
    --roquebus-radius: 10px;
    --roquebus-radius-card: 15px;

    /* Shadows */
    --roquebus-shadow-card: 0 4px 15px rgba(6, 106, 156, 0.1);
    --roquebus-shadow-button: 0 2px 8px rgba(5, 106, 156, 0.2);
}

/* ========================================
   Global Typography & Body Styles
   ======================================== */
body {
    font-family: var(--roquebus-font-family) !important;
    font-weight: var(--roquebus-font-weight-medium);
    font-size: 17px;
    line-height: 1.6;
    color: var(--roquebus-text-body);
    background-color: var(--roquebus-bg-light) !important;
}

/* Headings */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
    font-family: var(--roquebus-font-family) !important;
    font-weight: var(--roquebus-font-weight-extrabold) !important;
    color: var(--roquebus-dark) !important;
}

/* Paragraphs */
p {
    font-family: var(--roquebus-font-family);
    font-weight: var(--roquebus-font-weight-medium);
    font-size: 17px;
    color: var(--roquebus-text-body);
}

/* Strong/Bold text */
strong, b {
    font-weight: var(--roquebus-font-weight-bold);
}

#masthead {
    padding-top: 0;
    padding-bottom: 0;
}

/* ========================================
   Custom Button Styles
   ======================================== */

/* Primary Button */
.roquebus-btn-primary,
.roquebus-btn-primary.btn,
a.roquebus-btn-primary {
    display: inline-block;
    background-color: var(--roquebus-primary);
    color: var(--roquebus-white) !important;
    font-family: var(--roquebus-font-family);
    font-weight: var(--roquebus-font-weight-bold);
    font-size: 18px;
    padding: 13px 25px;
    border-radius: var(--roquebus-radius);
    border: none;
    text-decoration: none;
    text-align: center;
    cursor: pointer;
    transition: all 0.3s ease;
    box-shadow: var(--roquebus-shadow-button);
}

.roquebus-btn-primary:hover,
.roquebus-btn-primary.btn:hover,
a.roquebus-btn-primary:hover,
.btn-roquebus-primary:not(.btn-hover-nobg):not(.icon-animated):hover,
.btn-roquebus-primary:not(.btn-flat):not(.btn-hover-nobg):not(.icon-animated):not(.btn-text-skin):hover{
    background-color: #044d72 !important;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(5, 106, 156, 0.3);
    color: var(--roquebus-white) !important;
}

.roquebus-btn-primary:active {
    transform: translateY(0);
}

/* Secondary Button */
.roquebus-btn-secondary,
.roquebus-btn-secondary.btn,
a.roquebus-btn-secondary {
    display: inline-block;
    background-color: var(--roquebus-secondary);
    color: var(--roquebus-text-secondary) !important;
    font-family: var(--roquebus-font-family);
    font-weight: var(--roquebus-font-weight-bold);
    font-size: 18px;
    padding: 10px 25px;
    border-radius: var(--roquebus-radius);
    border: none;
    text-decoration: none;
    text-align: center;
    cursor: pointer;
    transition: all 0.3s ease;
}

.roquebus-btn-secondary:hover,
.roquebus-btn-secondary.btn:hover,
a.roquebus-btn-secondary:hover,
.btn-roquebus-secondary:not(.btn-flat):not(.btn-hover-nobg):not(.icon-animated):not(.btn-text-skin):hover {
    background-color: #9fe6ff !important;
    color: var(--roquebus-dark) !important;
    transform: translateY(-2px);
}

.roquebus-btn-secondary:active {
    transform: translateY(0);
}

/* ========================================
   Custom Card Styles
   ======================================== */

/* Base Card */
.roquebus-card {
    background-color: var(--roquebus-white);
    border-radius: var(--roquebus-radius-card);
    box-shadow: var(--roquebus-shadow-card);
    padding: 25px;
    width: 100%;
    max-width: var(--roquebus-card-width);
    transition: all 0.3s ease;
}

.roquebus-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 25px rgba(6, 106, 156, 0.15);
}

.roquebus-card h3,
.roquebus-card h4 {
    margin-top: 0;
    margin-bottom: 15px;
}

.roquebus-card p {
    margin-bottom: 15px;
}

/* Audio Card Variant */
.roquebus-audio-card {
    background-color: var(--roquebus-white);
    border-radius: var(--roquebus-radius);
    overflow: hidden;
    transition: all 0.3s ease;
}

.roquebus-audio-card .vc_single_image-wrapper {
    border-radius: 10px 10px 0 0;
    overflow: hidden;
}

.roquebus-audio-card .vc_column-inner {
    padding: 0 !important;
}

.roquebus-audio-card .vc_column_text_no_bg,
.roquebus-audio-card .vc_custom_heading,
.roquebus-audio-card .vc_btn3-container {
    padding-left: 20px;
    padding-right: 20px;
}

/* Audio Card Inner Elements */
.roquebus-audio-card .audio-player {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 15px;
    padding: 10px;
    background-color: var(--roquebus-bg-light);
    border-radius: var(--roquebus-radius);
}

.roquebus-audio-card .play-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    background-color: var(--roquebus-primary);
    color: var(--roquebus-white);
    border-radius: 50%;
    cursor: pointer;
    flex-shrink: 0;
}

.roquebus-audio-card .progress-bar {
    flex: 1;
    height: 6px;
    background-color: var(--roquebus-secondary);
    border-radius: 3px;
    position: relative;
}

.roquebus-audio-card .duration {
    font-size: 13px;
    color: var(--roquebus-dark);
    font-weight: var(--roquebus-font-weight-medium);
}

.roquebus-audio-card .parada-number {
    color: var(--roquebus-primary);
    font-weight: var(--roquebus-font-weight-bold);
    font-size: 14px;
    margin-bottom: 8px;
}

/* Card Grid Container */
.roquebus-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(var(--roquebus-card-width), 1fr));
    gap: var(--roquebus-gap);
    width: 100%;
    max-width: var(--roquebus-content-width);
    margin: 0 auto;
}

/* 4-Column Card Grid */
.roquebus-card-grid-4 {
    display: grid;
    grid-template-columns: repeat(4, var(--roquebus-card-width));
    gap: var(--roquebus-gap);
    width: 100%;
    max-width: var(--roquebus-content-width);
    margin: 0 auto;
    justify-content: center;
}

/* Radius */
.radius-10,
.radius-10 .uncell:first-of-type {
    border-radius: var(--roquebus-radius);
}

p, li, dt, dd, dl, address, label, small, pre, code, span.tab-excerpt{
    margin: 10px 0 0 0;
}

/* ========================================
   Header & Navigation Overrides
   ======================================== */

/* Main Menu */
.menu-wrapper nav ul li a,
.menu-primary nav ul li a {
    font-family: var(--roquebus-font-family) !important;
    font-weight: var(--roquebus-font-weight-bold) !important;
    font-size: 17px !important;
    color: var(--roquebus-dark) !important;
}

.menu-wrapper nav ul li a:hover,
.menu-primary nav ul li a:hover {
    color: var(--roquebus-primary) !important;
}

/* Header Background */
.site-header {
    background-color: var(--roquebus-white) !important;
}

/* Sticky Menu */
.menu-sticky .site-header {
    background-color: var(--roquebus-white) !important;
    box-shadow: 0 2px 10px rgba(6, 57, 83, 0.1);
}

/* Logo Container */
.logo-container {
    padding: 10px 0;
}

/* ========================================
   Footer Overrides
   ======================================== */
.site-footer,
footer.site-footer {
    background-color: var(--roquebus-bg-footer) !important;
    color: var(--roquebus-white);
}

.site-footer h1,
.site-footer h2,
.site-footer h3,
.site-footer h4,
.site-footer h5,
.site-footer h6 {
    color: var(--roquebus-white) !important;
}

.site-footer a {
    color: var(--roquebus-secondary);
    text-decoration: none;
}

.site-footer a:hover {
    color: var(--roquebus-white);
}

/* Footer Widget Areas */
.footer-last {
    background-color: var(--roquebus-bg-footer) !important;
}

/* ========================================
   Section Backgrounds
   ======================================== */

/* Light Background Section */
.roquebus-bg-light,
.roquebus-section-light {
    background-color: var(--roquebus-bg-light) !important;
}

/* Hero Background Section */
.roquebus-bg-hero,
.roquebus-section-hero {
    background-color: var(--roquebus-bg-hero) !important;
    color: var(--roquebus-text-body);
}

.roquebus-bg-hero h1,
.roquebus-bg-hero h2,
.roquebus-bg-hero h3,
.roquebus-section-hero h1,
.roquebus-section-hero h2,
.roquebus-section-hero h3 {
    color: var(--roquebus-dark) !important;
}

.roquebus-bg-hero p,
.roquebus-section-hero p {
    color: var(--roquebus-text-body);
}

/* Footer Background Section */
.roquebus-bg-footer,
.roquebus-section-footer {
    background-color: var(--roquebus-bg-footer) !important;
    color: var(--roquebus-white);
}

/* White Background Section */
.roquebus-bg-white {
    background-color: var(--roquebus-white) !important;
}

/* ========================================
   Route Stops List Styles
   ======================================== */
.roquebus-route-list ol,
.roquebus-route-stops,
.roquebus-stops-list {
    list-style: none;
    padding: 0;
    margin: 0;
    counter-reset: stop-counter;
}

.roquebus-route-list ol li,
.roquebus-route-stops li,
.roquebus-stops-list li {
    position: relative;
    padding: 20px 20px 20px 55px;
    margin-bottom: 10px;
    font-family: var(--roquebus-font-family);
    font-weight: var(--roquebus-font-weight-bold);
    font-size: 20px;
    color: #000000;
    counter-increment: stop-counter;
    background-color: var(--roquebus-stop-bg);
    border-radius: 10px 0 0 10px;
    line-height: 30px;
}

.roquebus-route-list ol li:before,
.roquebus-route-stops li:before,
.roquebus-stops-list li:before {
    content: counter(stop-counter);
    position: absolute;
    left: 15px;
    top: 50%;
    transform: translateY(-50%);
    width: 30px;
    height: 30px;
    background-color: var(--roquebus-primary);
    color: var(--roquebus-white);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: var(--roquebus-font-weight-bold);
    font-size: 14px;
}

.roquebus-route-list .route-icon {
    display: inline-block;
    padding: 2px 8px;
    background-color: var(--roquebus-secondary);
    color: var(--roquebus-text-secondary);
    border-radius: 4px;
    font-size: 12px;
    font-weight: var(--roquebus-font-weight-bold);
    margin-left: 8px;
}

/* ========================================
   Audio Player Styling
   ======================================== */
.roquebus-audio-player {
    background-color: var(--roquebus-white);
    border-radius: var(--roquebus-radius);
    padding: 30px 20px 10px;
    margin: 15px 0;
}

.roquebus-audio-player .audio-player-wrapper {
    display: flex;
    align-items: center;
    gap: 15px;
}

.roquebus-audio-player .audio-play-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 50px;
    height: 50px;
    background-color: var(--roquebus-primary);
    color: var(--roquebus-white);
    border-radius: 50%;
    border: none;
    cursor: pointer;
    flex-shrink: 0;
    transition: background-color 0.3s ease;
}

.roquebus-audio-player .audio-play-btn:hover {
    background-color: #044d72;
}

.roquebus-audio-player .audio-play-btn .play-icon {
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 8px 0 8px 14px;
    border-color: transparent transparent transparent var(--roquebus-white);
    margin-left: 3px;
}

.roquebus-audio-player .audio-progress-bar {
    flex: 1;
    height: 8px;
    background-color: var(--roquebus-secondary);
    border-radius: 4px;
    position: relative;
    overflow: hidden;
}

.roquebus-audio-player .audio-progress {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 0%;
    background-color: var(--roquebus-primary);
    border-radius: 4px;
    transition: width 0.1s linear;
}

.roquebus-audio-player .audio-time {
    font-size: 16px;
    font-weight: var(--roquebus-font-weight-bold);
    color: var(--roquebus-dark-gray);
    white-space: nowrap;
    line-height: 65px;
}

.roquebus-audio-player audio {
    width: 100%;
    max-width: 100%;
}

/* ========================================
   Language Selector
   ======================================== */
.roquebus-language-selector {
    text-align: center;
    padding: 15px 0;
}

.roquebus-language-selector h3 {
    margin-bottom: 15px;
}

.roquebus-language-selector .language-options {
    display: flex;
    gap: 15px;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
}

.roquebus-language-selector .language-option {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 18px;
    background-color: var(--roquebus-white);
    color: var(--roquebus-dark);
    border: 2px solid var(--roquebus-primary);
    border-radius: var(--roquebus-radius);
    text-decoration: none;
    font-weight: var(--roquebus-font-weight-bold);
    font-size: 14px;
    cursor: pointer;
    transition: all 0.3s ease;
}

.roquebus-language-selector .language-option:hover,
.roquebus-language-selector .language-option.active {
    background-color: var(--roquebus-primary);
    color: var(--roquebus-white);
    border-color: var(--roquebus-primary);
}

/* Audioguia List Items (expandable) */
.roquebus-audioguia-list-item {
    background-color: var(--roquebus-bg-hero);
    border-radius: 4px;
    padding: 2px 25px;
    font-weight: var(--roquebus-font-weight-bold);
    font-size: 17px;
    color: #000000;
}

.roquebus-audioguia-list-item.active {
    color: var(--roquebus-primary);
}

/* Language Flag Icons */
.roquebus-lang-flag,
.roquebus-flag {
    width: 24px;
    height: 16px;
    display: inline-block;
    margin-right: 5px;
    vertical-align: middle;
}

/* ========================================
   Ficha (Detail Page) Content
   ======================================== */
.roquebus-ficha-content {
    background-color: var(--roquebus-white);
    border-radius: var(--roquebus-radius);
    overflow: hidden;
}

.roquebus-ficha-content .vc_column-inner {
    padding: 0 50px;
}

.roquebus-ficha-title {
    font-size: 60px !important;
    line-height: 56px !important;
    margin-bottom: 5px;
}

.roquebus-ficha-subtitle {
    font-size: 30px !important;
    color: var(--roquebus-text-body) !important;
    font-weight: var(--roquebus-font-weight-bold) !important;
    line-height: 25px !important;
}

/* ========================================
   Pagination Controls
   ======================================== */
.roquebus-pagination {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 0;
}

.roquebus-pagination .pagination-controls {
    display: flex;
    gap: 10px;
    align-items: center;
}

.roquebus-pagination .pagination-arrow {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background-color: var(--roquebus-white);
    color: var(--roquebus-dark);
    border: 2px solid var(--roquebus-secondary);
    border-radius: var(--roquebus-radius);
    text-decoration: none;
    font-weight: var(--roquebus-font-weight-bold);
    cursor: pointer;
    transition: all 0.3s ease;
}

.roquebus-pagination .pagination-arrow:hover {
    background-color: var(--roquebus-primary);
    color: var(--roquebus-white);
    border-color: var(--roquebus-primary);
}

.roquebus-pagination .pagination-numbers {
    font-weight: var(--roquebus-font-weight-bold);
    color: var(--roquebus-dark);
    font-size: 16px;
    padding: 0 10px;
}

/* ========================================
   SDG/ODS Cards
   ======================================== */
.roquebus-sdg-card,
.roquebus-ods-card {
    background-color: var(--roquebus-white);
    border-radius: var(--roquebus-radius-card);
    padding: 20px;
    text-align: center;
    box-shadow: var(--roquebus-shadow-card);
    transition: all 0.3s ease;
}

.roquebus-sdg-card:hover,
.roquebus-ods-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 8px 25px rgba(6, 106, 156, 0.15);
}

.roquebus-sdg-card img,
.roquebus-ods-card img {
    max-width: 100%;
    height: auto;
    margin-bottom: 15px;
}

.roquebus-sdg-card h4,
.roquebus-ods-card h4 {
    font-size: 16px;
    margin-bottom: 10px;
}

/* SDG Grid */
.roquebus-sdg-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 20px;
    margin: 30px 0;
}

/* ODS inline label (number + title) */
.roquebus-ods-inline {
    display: flex;
    align-items: center;
    gap: 15px;
    color: var(--roquebus-text-body);
}

.roquebus-ods-inline-number {
    width: 40px;
    font-size: 40px;
    line-height: 45px;
    font-weight: var(--roquebus-font-weight-extrabold);
    margin: 0;
}

.roquebus-ods-inline-title {
    max-width: 234px;
    font-size: 20px;
    line-height: 25px;
    font-weight: var(--roquebus-font-weight-semibold);
    margin: 0;
    text-transform: uppercase;
}

@media (max-width: 767px) {
    .roquebus-ods-inline-number {
        width: 34px;
        font-size: 34px;
        line-height: 38px;
    }

    .roquebus-ods-inline-title {
        max-width: 100%;
        font-size: 18px;
        line-height: 23px;
    }
}

/* ========================================
   Feature Items
   ======================================== */
.roquebus-feature-item {
    text-align: center;
}

/* ========================================
   Info Cards (Tickets Section)
   ======================================== */
.roquebus-info-card {
    border-radius: var(--roquebus-radius-card);
    box-shadow: var(--roquebus-shadow-card);
    height: 100%;
}

.roquebus-info-card h4 {
    margin-bottom: 5px;
}

/* Schedule Panel */
.roquebus-schedule-panel {
    border-radius: var(--roquebus-radius-card);
    box-shadow: var(--roquebus-shadow-card);
    height: 100%;
}

/* Tickets Panel */
.roquebus-tickets-panel {
    border-radius: var(--roquebus-radius-card);
    box-shadow: var(--roquebus-shadow-card);
    height: 100%;
}

/* Brochure Bar */
.roquebus-brochure-bar {
    display: flex;
    align-items: center;
}

.roquebus-brochure-bar .vc_column-inner {
    display: flex;
    align-items: center;
}

/* Map Screenshot */
.roquebus-map-screenshot img {
    border-radius: var(--roquebus-radius-card);
    box-shadow: var(--roquebus-shadow-card);
}

/* ========================================
   Sponsor Logos
   ======================================== */
.roquebus-sponsors {
    background-color: var(--roquebus-white);
}

.roquebus-sponsors img {
    max-height: 60px;
    width: auto;
    opacity: 0.7;
    transition: opacity 0.3s ease;
}

.roquebus-sponsors img:hover {
    opacity: 1;
}

/* ========================================
   Utility Classes
   ======================================== */

/* Text Alignment */
.roquebus-text-center {
    text-align: center;
}

.roquebus-text-left {
    text-align: left;
}

.roquebus-text-right {
    text-align: right;
}

/* Text Colors */
.roquebus-text-primary {
    color: var(--roquebus-primary) !important;
}

.roquebus-text-dark {
    color: var(--roquebus-dark) !important;
}

.roquebus-text-white {
    color: var(--roquebus-white) !important;
}

/* Container */
.roquebus-container {
    max-width: var(--roquebus-content-width);
    margin: 0 auto;
    padding: 0 20px;
}

/* Heading Overrides */
.roquebus-heading-dark {
    color: var(--roquebus-dark) !important;
}

/* Intro Text */
.roquebus-text-intro {
    font-size: 18px;
    line-height: 1.7;
}

/* ========================================
   Responsive Adjustments
   ======================================== */

/* Tablets and smaller */
@media (max-width: 1024px) {
    .roquebus-card-grid-4 {
        grid-template-columns: repeat(2, 1fr);
        max-width: 100%;
    }

    .roquebus-card {
        max-width: 100%;
    }
}

/* Mobile devices */
@media (max-width: 768px) {
    body {
        font-size: 16px;
    }

    h1 {
        font-size: 28px;
    }

    h2 {
        font-size: 24px;
    }

    h3 {
        font-size: 20px;
    }

    .roquebus-card-grid,
    .roquebus-card-grid-4 {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .roquebus-btn-primary,
    .roquebus-btn-secondary {
        width: 100%;
        padding: 15px 20px;
    }

    .roquebus-container {
        padding: 0 15px;
    }

    .roquebus-language-selector .language-options {
        flex-wrap: wrap;
        justify-content: center;
    }

    .roquebus-pagination {
        flex-direction: column;
        gap: 15px;
    }

    .roquebus-brochure-bar .vc_column-inner {
        justify-content: center;
        text-align: center;
    }

    .roquebus-sdg-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 15px;
    }
}

/* Small mobile devices */
@media (max-width: 480px) {
    .roquebus-btn-primary,
    .roquebus-btn-secondary {
        font-size: 16px;
        padding: 12px 18px;
    }

    .roquebus-card {
        padding: 20px;
    }

    .roquebus-sdg-grid {
        grid-template-columns: 1fr;
    }
}

/* ========================================
   Print Styles
   ======================================== */
@media print {
    .roquebus-btn-primary,
    .roquebus-btn-secondary,
    .roquebus-language-selector,
    .roquebus-pagination {
        display: none;
    }

    .roquebus-card {
        box-shadow: none;
        border: 1px solid #ccc;
        page-break-inside: avoid;
    }
}

/* ========================================
   Accessibility Improvements
   ======================================== */

/* Focus States */
.roquebus-btn-primary:focus,
.roquebus-btn-secondary:focus,
.roquebus-language-selector .language-option:focus,
.roquebus-pagination .pagination-arrow:focus {
    outline: 3px solid var(--roquebus-primary);
    outline-offset: 2px;
}

/* Skip to Content Link */
.roquebus-skip-to-content {
    position: absolute;
    top: -40px;
    left: 0;
    background: var(--roquebus-primary);
    color: var(--roquebus-white);
    padding: 8px;
    text-decoration: none;
    z-index: 100;
}

.roquebus-skip-to-content:focus {
    top: 0;
}

/* ========================================
   Botones
   ======================================== */
.btn{
	font-size: 1.125rem !important;
}

.btn-roquebus-primary{
	color: var(--white)
}


/* ========================================
   Contact Form 7 — ROQUEBUS Design
   Figma node 839:1384

   Estructura HTML esperada:
   <div class="roquebus-contact-form-wrapper">
       [contact-form-7 id="…"]
   </div>

   CF7 genera:
   <div class="wpcf7">
     <form class="wpcf7-form">
       <div class="form-group">
         <label>…</label>
         <span class="wpcf7-form-control-wrap" data-name="…">
           <input class="wpcf7-form-control …" />
         </span>
       </div>
     </form>
   </div>
   ======================================== */

/* ---- Wrapper — caja blanca redondeada ---- */
.roquebus-contact-form-wrapper {
    background-color: var(--roquebus-white) !important;
    border-radius: var(--roquebus-radius);
    padding: 70px 60px 20px;
    width: 100%;
    box-sizing: border-box;
}

/* ---- Form layout ---- */
.roquebus-contact-form-wrapper .wpcf7-form {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

/* CF7 genera <p> automáticos — eliminar su espacio */
.roquebus-contact-form-wrapper .wpcf7-form > p {
    margin: 0 !important;
    padding: 0 !important;
}

/* ---- Título de sección ---- */
.roquebus-contact-form-wrapper .form-section-title p{
    font-family: var(--roquebus-font-family) !important;
    font-weight: var(--roquebus-font-weight-extrabold) !important;
    font-size: 30px !important;
    line-height: 30px;
    color: var(--roquebus-dark) !important;
    margin: 0 !important;
    padding: 0;
}

/* ---- Form group (cada campo) ---- */
.roquebus-contact-form-wrapper .form-group {
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: 100%;
}

/* Reset márgenes globales del tema dentro del form */
.roquebus-contact-form-wrapper p,
.roquebus-contact-form-wrapper label,
.roquebus-contact-form-wrapper span,
.roquebus-contact-form-wrapper small {
    margin: 0 !important;
}

.roquebus-contact-form-wrapper label{
    font-size: 20px !important;
    line-height: 27px !important;
    font-weight: 600 !important;
    margin-bottom: 15px !important;
}

/* ---- CLAVE: el <span> wrapper de CF7 debe ser block + 100% ---- */
.roquebus-contact-form-wrapper .wpcf7-form-control-wrap {
    display: block !important;
    width: 100% !important;
}

/* ---- Labels ---- */
.roquebus-contact-form-wrapper .form-group > label {
    font-family: var(--roquebus-font-family) !important;
    font-weight: var(--roquebus-font-weight-semibold) !important;
    font-size: 20px !important;
    line-height: 27px !important;
    color: var(--roquebus-dark) !important;
    display: block;
    margin: 0 !important;
    padding: 0;
}

/* ---- Inputs (text, email, tel) ---- */
.roquebus-contact-form-wrapper input.wpcf7-form-control[type="text"],
.roquebus-contact-form-wrapper input.wpcf7-form-control[type="email"],
.roquebus-contact-form-wrapper input.wpcf7-form-control[type="tel"],
.roquebus-contact-form-wrapper input.wpcf7-form-control[type="url"],
.roquebus-contact-form-wrapper input.wpcf7-form-control[type="number"] {
    display: block !important;
    width: 100% !important;
    height: 60px !important;
    padding: 0 20px !important;
    margin: 0 !important;
    font-family: var(--roquebus-font-family) !important;
    font-size: 16px !important;
    font-weight: var(--roquebus-font-weight-regular) !important;
    color: var(--roquebus-text-body) !important;
    background-color: var(--roquebus-white) !important;
    border: 1px solid #a3cbdf !important;
    border-radius: 8px !important;
    box-sizing: border-box !important;
    outline: none !important;
    box-shadow: none !important;
    transition: border-color 0.25s ease, box-shadow 0.25s ease;
    -webkit-appearance: none;
    appearance: none;
}

/* ---- Textarea ---- */
.roquebus-contact-form-wrapper textarea.wpcf7-form-control {
    display: block !important;
    width: 100% !important;
    min-height: 133px !important;
    padding: 15px 20px !important;
    margin: 0 !important;
    font-family: var(--roquebus-font-family) !important;
    font-size: 16px !important;
    font-weight: var(--roquebus-font-weight-regular) !important;
    color: var(--roquebus-text-body) !important;
    background-color: var(--roquebus-white) !important;
    border: 1px solid #a3cbdf !important;
    border-radius: 8px !important;
    box-sizing: border-box !important;
    outline: none !important;
    box-shadow: none !important;
    resize: vertical;
    transition: border-color 0.25s ease, box-shadow 0.25s ease;
    -webkit-appearance: none;
    appearance: none;
}

/* ---- Focus ---- */
.roquebus-contact-form-wrapper input.wpcf7-form-control:focus,
.roquebus-contact-form-wrapper textarea.wpcf7-form-control:focus {
    border-color: var(--roquebus-primary) !important;
    box-shadow: 0 0 0 3px rgba(5, 106, 156, 0.12) !important;
}

/* ---- Placeholder ---- */
.roquebus-contact-form-wrapper .wpcf7-form-control::placeholder {
    color: #9ab8c9;
    opacity: 1;
}

/* ---- Acceptance / Checkbox ---- */

/* El wrapper de acceptance NO necesita ser block 100% */
.roquebus-contact-form-wrapper .wpcf7-acceptance {
    margin-top: 5px;
}

/* El list-item y su label interno: layout horizontal */
.roquebus-contact-form-wrapper .wpcf7-acceptance .wpcf7-list-item {
    display: block !important;
    margin: 0 !important;
}

.roquebus-contact-form-wrapper .wpcf7-acceptance .wpcf7-list-item label,
.roquebus-contact-form-wrapper .wpcf7-checkbox .wpcf7-list-item label {
    display: inline-grid !important;
    grid-template-columns: 25px auto !important;
    column-gap: 10px !important;
    align-items: start !important;
    margin: 0 !important;
    padding: 0 !important;
    font-family: 'Inter', sans-serif !important;
    font-weight: 400 !important;
    font-size: 20px !important;
    line-height: 28px !important;
    color: var(--roquebus-dark) !important;
    cursor: pointer;
}

/* Checkbox input — 25×25, borde gris #e0e0e0 */
.roquebus-contact-form-wrapper input[type="checkbox"] {
    width: 25px !important;
    height: 25px !important;
    min-width: 25px !important;
    min-height: 25px !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 2px solid #e0e0e0 !important;
    border-radius: 4px !important;
    cursor: pointer;
    accent-color: var(--roquebus-primary);
    -webkit-appearance: auto;
    appearance: auto;
}

/* Texto del checkbox — Inter Regular 20px, una sola línea */
.roquebus-contact-form-wrapper .wpcf7-list-item-label {
    font-family: 'Inter', sans-serif !important;
    font-weight: 400 !important;
    font-size: 20px !important;
    line-height: 28px !important;
    color: var(--roquebus-dark) !important;
    cursor: pointer;
    white-space: nowrap;
}

/* ---- Botón Enviar ---- */
.roquebus-contact-form-wrapper .wpcf7-submit {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    width: 154px;
    min-height: 50px;
    padding: 13px 25px !important;
    margin: 0 !important;
    background-color: var(--roquebus-primary) !important;
    color: var(--roquebus-white) !important;
    font-family: var(--roquebus-font-family) !important;
    font-weight: var(--roquebus-font-weight-bold) !important;
    font-size: 18px !important;
    line-height: normal !important;
    text-transform: uppercase;
    letter-spacing: 0 !important;
    border: none !important;
    border-radius: var(--roquebus-radius) !important;
    cursor: pointer;
    box-shadow: var(--roquebus-shadow-button);
    transition: background-color 0.25s ease, transform 0.2s ease, box-shadow 0.25s ease;
}

.roquebus-contact-form-wrapper .wpcf7-submit:hover {
    background-color: #044d72 !important;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(5, 106, 156, 0.3);
}

.roquebus-contact-form-wrapper .wpcf7-submit:active {
    transform: translateY(0);
}

/* ---- Validación ---- */
.roquebus-contact-form-wrapper .wpcf7-not-valid-tip {
    display: block;
    font-family: var(--roquebus-font-family);
    font-size: 14px;
    font-weight: var(--roquebus-font-weight-medium);
    color: #dc3545;
    margin-top: 6px;
}

.roquebus-contact-form-wrapper .wpcf7-not-valid {
    border-color: #dc3545 !important;
}

/* ---- Mensajes de respuesta ---- */
.roquebus-contact-form-wrapper .wpcf7-response-output {
    padding: 15px 20px !important;
    border-radius: 8px !important;
    font-family: var(--roquebus-font-family);
    font-size: 15px;
    font-weight: var(--roquebus-font-weight-medium);
    margin: 10px 0 0 !important;
}

.roquebus-contact-form-wrapper .wpcf7 form.sent .wpcf7-response-output {
    background-color: #d4edda !important;
    border-color: #28a745 !important;
    color: #155724 !important;
}

.roquebus-contact-form-wrapper .wpcf7 form.failed .wpcf7-response-output,
.roquebus-contact-form-wrapper .wpcf7 form.invalid .wpcf7-response-output {
    background-color: #f8d7da !important;
    border-color: #dc3545 !important;
    color: #721c24 !important;
}

/* Ocultar spinner */
.roquebus-contact-form-wrapper .wpcf7-spinner {
    display: none !important;
}

/* ---- Responsive: Tablet ---- */
@media (max-width: 991px) {
    .roquebus-contact-form-wrapper {
        padding: 50px 40px 20px;
    }
}

/* ---- Responsive: Móvil ---- */
@media (max-width: 767px) {
    .roquebus-contact-form-wrapper {
        padding: 35px 20px 20px;
    }

    .roquebus-contact-form-wrapper .form-section-title p {
        font-size: 24px !important;
        line-height: 28px;
    }

    .roquebus-contact-form-wrapper .form-group > label {
        font-size: 18px !important;
    }

    .roquebus-contact-form-wrapper input.wpcf7-form-control[type="text"],
    .roquebus-contact-form-wrapper input.wpcf7-form-control[type="email"],
    .roquebus-contact-form-wrapper input.wpcf7-form-control[type="tel"],
    .roquebus-contact-form-wrapper input.wpcf7-form-control[type="url"],
    .roquebus-contact-form-wrapper input.wpcf7-form-control[type="number"] {
        height: 50px !important;
    }

    .roquebus-contact-form-wrapper textarea.wpcf7-form-control {
        min-height: 110px !important;
    }

    .roquebus-contact-form-wrapper .wpcf7-list-item-label {
        font-size: 17px !important;
    }

    .roquebus-contact-form-wrapper .wpcf7-submit {
        width: 100% !important;
    }
}

/* ========================================
   End of ROQUEBUS Custom Styles
   ======================================== */

/* ==== Descargar folleto ==== */   
.descargar-folleto > .row-parent {
    background-color: var(--roquebus-bg-hero);
    border-radius: 10px;
}

/* ==== Compra de tickets y horarios ==== */
.roquebus-buy-tickets-item .uncell:first-of-type{
    padding: 20px;
}

.roquebus-buy-tickets-item p {
    font-size: 20px;
    line-height: 25px;
    font-weight: var(--roquebus-font-weight-medium);
}

.roquebus-buy-tickets-item.buy .uncell:first-of-type {
    padding: 2rem 5.313rem 1.5rem 5.313rem;
}

.roquebus-buy-tickets-item.horarios .uncell:first-of-type{
    padding: 2rem 2rem 1.5rem 2rem;
}

.roquebus-buy-tickets-item.horarios .uncont:first-of-type {
    display: flex;
    flex-direction: column;
    height: 100%;
}

.roquebus-buy-tickets-item.horarios .btn-container {
    margin-top: auto !important;
    padding-left: 4rem;
}

/* ==== Bloque horario (WPBakery text block) ==== */
.roquebus-schedule,
.roquebus-schedule.d-flex {
    display: flex;
    flex-wrap: wrap;
    gap: 52px;
    align-items: flex-start;
}

.roquebus-schedule-col {
    min-width: 170px;
}

.roquebus-schedule-title {
    margin: 0 0 3px;
    font-family: var(--roquebus-font-family) !important;
    font-size: 24px !important;
    line-height: 1.2 !important;
    font-weight: var(--roquebus-font-weight-extrabold) !important;
    color: var(--roquebus-dark);
}

.roquebus-schedule-lines {
    margin: 0;
    font-family: var(--roquebus-font-family);
    font-size: 20px;
    line-height: 35px;
    font-weight: var(--roquebus-font-weight-medium);
    color: var(--roquebus-text-body);
}

@media (max-width: 767px) {
    .roquebus-schedule,
    .roquebus-schedule.d-flex {
        gap: 20px;
    }

    .roquebus-schedule-col {
        min-width: 0;
        width: 100%;
    }

    .roquebus-schedule-title {
        font-size: 22px;
    }

    .roquebus-schedule-lines {
        font-size: 18px;
        line-height: 31px;
    }
}

/* ==== Acordeon paradas (WPBakery) ==== */
.roquebus-stops-accordion.wpb_accordion .wpb_accordion_wrapper,
.roquebus-stops-accordion.vc_tta.vc_tta-accordion .vc_tta-panels {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.roquebus-stops-accordion.wpb_accordion .wpb_accordion_header,
.roquebus-stops-accordion.vc_tta.vc_tta-accordion .vc_tta-panel .vc_tta-panel-heading {
    margin: 0;
    border: 0;
    border-radius: 10px;
    background: var(--roquebus-stop-bg);
    overflow: hidden;
}

.roquebus-stops-accordion.wpb_accordion .wpb_accordion_header a,
.roquebus-stops-accordion.vc_tta.vc_tta-accordion .vc_tta-panel-title > a {
    position: relative;
    display: block;
    margin: 0;
    padding: 25px 65px 25px 70px;
    font-family: var(--roquebus-font-family) !important;
    font-size: 20px !important;
    line-height: 30px !important;
    font-weight: var(--roquebus-font-weight-bold) !important;
    color: #000000 !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    text-decoration: none;
}

.roquebus-stops-accordion.wpb_accordion .panel .wpb_accordion_header a::before,
.roquebus-stops-accordion.wpb_accordion .panel .wpb_accordion_header a::before{
    content: url('/wp-content/uploads/2026/03/distance.svg');
    display: block;
    position: absolute;
    left: 20px;
    top: 50%;
    height: 35px;
    transform: translateY(-50%);
}

.roquebus-stops-accordion.wpb_accordion .panel:first-child .wpb_accordion_header a::before,
.roquebus-stops-accordion.wpb_accordion .panel:last-child .wpb_accordion_header a::before{
    content: url('/wp-content/uploads/2026/03/salida.svg');
    height: 40px;
}

.roquebus-stops-accordion.wpb_accordion .panel .wpb_accordion_header a span::after{
    right: 20px;
}

.roquebus-stops-accordion .panel:has(> .panel-collapse.show) .panel-title > a > span::after,
.roquebus-stops-accordion .panel:has(> .panel-collapse.in) .panel-title > a > span::after {
  transform: translateY(-50%) rotate(90deg);
}

.roquebus-stops-accordion.wpb_accordion .wpb_accordion_section:first-child .wpb_accordion_header a::after,
.roquebus-stops-accordion.vc_tta.vc_tta-accordion .vc_tta-panel:first-child .vc_tta-panel-title > a::after,
.roquebus-stops-accordion.vc_tta.vc_tta-accordion .vc_tta-panel:first-child .vc_tta-panel-title > a::after {
    display: none;
}

.roquebus-stops-accordion.wpb_accordion .panel .panel-collapse .panel-body{
    padding: 36px;
}

.roquebus-stops-accordion .ui-icon,
.roquebus-stops-accordion .vc_tta-controls-icon {
    display: none !important;
}


.roquebus-stops-accordion .wpb_accordion_section .wpb_accordion_content > .wpb_wrapper,
.roquebus-stops-accordion .vc_tta-panel-body {
    padding: 0 0 0 0;
}

.roquebus-stops-accordion .roquebus-audioguides a {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-height: 29px;
    padding: 2px 14px 2px 44px;
    border-radius: 4px;
    background: var(--roquebus-bg-hero);
    font-family: var(--roquebus-font-family);
    font-size: 17px;
    line-height: 25px;
    font-weight: var(--roquebus-font-weight-bold);
    color: #000000;
    text-decoration: none;
}

.contact-number .icon-box-content{
    vertical-align: middle;
}

:is(.audioguias-home, .roquebus-audioguias) > .grid-wrapper.grid-inner-padding.half-gutter{
    padding-left: 0 !important;
    padding-right: 0 !important;
}

:is(.audioguias-home, .roquebus-audioguias) .isotope-container.grid-container {
    display: flex !important;
    flex-wrap: wrap;
    align-items: stretch;
    height: auto !important;
    row-gap: 20px !important;
}

:is(.audioguias-home, .roquebus-audioguias) .isotope-container.grid-container > .tmb .t-entry-cf-detail-descripcion-corta {
    color: #1D1D1B !important;
    font-size: 17px;
    line-height: 24px;
    font-weight: 400;
}

:is(.audioguias-home, .roquebus-audioguias) .isotope-container.grid-container > .tmb .t-entry-excerpt {
    margin-bottom: 5px !important;
}

:is(.audioguias-home, .roquebus-audioguias) .isotope-container.grid-container > .tmb .t-entry-title {
    margin-bottom: 3px !important;
}

:is(.audioguias-home) .isotope-container.grid-container > .tmb {
    display: flex;
    position: unset !important;
    margin: 0 !important;
    height: var(--roquebus-audioguia-card-height, 465px) !important;
}

:is(.roquebus-audioguias) .isotope-container.grid-container > .tmb {
    display: flex;
    position: unset !important;
    margin: 0 !important;
    height: var(--roquebus-audioguia-card-height, 590px) !important;
}

html[lang="es-ES"] :is(.roquebus-audioguias) .isotope-container.grid-container > .tmb {
    display: flex;
    position: unset !important;
    margin: 0 !important;
    height: var(--roquebus-audioguia-card-height, 590px) !important;
}

html[lang="en-US"] :is(.roquebus-audioguias) .isotope-container.grid-container > .tmb {
    display: flex;
    position: unset !important;
    margin: 0 !important;
    height: var(--roquebus-audioguia-card-height, 645px) !important;
}

:is(.roquebus-audioguias) .isotope-container.grid-container > .tmb {
    padding-right: 20px !important;
}

:is(.audioguias-home, .roquebus-audioguias) .isotope-container.grid-container > .tmb .t-entry-excerpt p{
    color: #1D1D1B !important;
    font-size: 20px !important;
    line-height: 25px !important;
    font-weight: var(--roquebus-font-weight-bold) !important;
}

:is(.audioguias-home, .roquebus-audioguias) .isotope-container.grid-container > .tmb .t-inside {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
    border-radius: 10px;
}

:is(.audioguias-home, .roquebus-audioguias) .isotope-container.grid-container > .tmb .t-entry-text {
    display: flex;
    flex: 1 1 auto;
}

:is(.audioguias-home, .roquebus-audioguias) .isotope-container.grid-container > .tmb .t-entry-text-tc {
    padding: 12px 18px 25px 18px !important;
    display: flex;
    width: 100%;
}

:is(.audioguias-home, .roquebus-audioguias) .isotope-container.grid-container > .tmb .t-entry {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
}

:is(.audioguias-home, .roquebus-audioguias) .roquebus-home-audio {
    margin: 0 0 12px !important;
}

:is(.audioguias-home, .roquebus-audioguias) .roquebus-home-audio > audio {
    display: none;
}

:is(.audioguias-home, .roquebus-audioguias) .roquebus-home-audio .mejs-container {
    display: none !important;
}

:is(.audioguias-home, .roquebus-audioguias) .roquebus-audio-ui {
    display: flex;
    align-items: flex-end;
    gap: 16px;
    padding: 4px 0;
}

:is(.audioguias-home, .roquebus-audioguias) .roquebus-audio-toggle {
    width: 42px;
    height: 42px;
    border: 3px solid #25272b;
    border-radius: 50%;
    background: transparent;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    padding: 0;
}

:is(.audioguias-home, .roquebus-audioguias) .roquebus-audio-toggle .icon {
    width: 0;
    height: 0;
    border-top: 8px solid transparent;
    border-bottom: 8px solid transparent;
    border-left: 12px solid #25272b;
    margin-left: 3px;
}

:is(.audioguias-home, .roquebus-audioguias) .roquebus-audio-toggle.is-playing .icon {
    width: 11px;
    height: 14px;
    border: 0;
    margin-left: 0;
    position: relative;
}

:is(.audioguias-home, .roquebus-audioguias) .roquebus-audio-toggle.is-playing .icon::before,
:is(.audioguias-home, .roquebus-audioguias) .roquebus-audio-toggle.is-playing .icon::after {
    content: '';
    position: absolute;
    top: 0;
    width: 3px;
    height: 14px;
    background: #25272b;
}

:is(.audioguias-home, .roquebus-audioguias) .roquebus-audio-toggle.is-playing .icon::before {
    left: 1px;
}

:is(.audioguias-home, .roquebus-audioguias) .roquebus-audio-toggle.is-playing .icon::after {
    right: 1px;
}

:is(.audioguias-home, .roquebus-audioguias) .roquebus-audio-meta {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

:is(.audioguias-home, .roquebus-audioguias) .roquebus-audio-progress {
    width: 100%;
    height: 5px;
    border: 0;
    background: #d9d9d9;
    border-radius: 999px;
    padding: 0;
    cursor: pointer;
    position: relative;
    overflow: hidden;
}

:is(.audioguias-home, .roquebus-audioguias) .roquebus-audio-progress-fill {
    display: block;
    height: 100%;
    width: 0;
    background: #25272b;
}

:is(.audioguias-home, .roquebus-audioguias) .roquebus-audio-time {
    margin: 0;
    font-family: var(--roquebus-font-family);
    font-size: 16px;
    line-height: 1;
    font-weight: var(--roquebus-font-weight-bold);
    color: #25272b;
}

/* Global player style for any converted audio block */
.roquebus-home-audio {
    margin: 0 0 12px !important;
}

.roquebus-home-audio > audio,
.roquebus-home-audio .mejs-container {
    display: none !important;
}

.roquebus-audio-ui {
    display: flex;
    align-items: flex-end;
    gap: 16px;
    padding: 4px 0;
}

.roquebus-audio-toggle {
    width: 42px;
    height: 42px;
    border: 3px solid #25272b;
    border-radius: 50%;
    background: transparent;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    padding: 0;
}

.roquebus-audio-toggle .icon {
    width: 0;
    height: 0;
    border-top: 8px solid transparent;
    border-bottom: 8px solid transparent;
    border-left: 12px solid #25272b;
    margin-left: 3px;
}

.roquebus-audio-toggle.is-playing .icon {
    width: 11px;
    height: 14px;
    border: 0;
    margin-left: 0;
    position: relative;
}

.roquebus-audio-toggle.is-playing .icon::before,
.roquebus-audio-toggle.is-playing .icon::after {
    content: '';
    position: absolute;
    top: 0;
    width: 3px;
    height: 14px;
    background: #25272b;
}

.roquebus-audio-toggle.is-playing .icon::before {
    left: 1px;
}

.roquebus-audio-toggle.is-playing .icon::after {
    right: 1px;
}

.roquebus-audio-meta {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.roquebus-audio-progress {
    width: 100%;
    height: 5px;
    border: 0;
    background: #d9d9d9;
    border-radius: 999px;
    padding: 0;
    cursor: pointer;
    position: relative;
    overflow: hidden;
}

.roquebus-audio-progress-fill {
    display: block;
    height: 100%;
    width: 0;
    background: #25272b;
}

.roquebus-audio-time {
    margin: 0;
    font-family: var(--roquebus-font-family);
    font-size: 16px;
    line-height: 1;
    font-weight: var(--roquebus-font-weight-bold);
    color: #25272b;
}

/* Figma footer navigation (prev/next + counter + CTA) */
.row-container.row-navigation.row-navigation-light {
    background: var(--roquebus-bg-hero) !important;
}

.row-container.row-navigation.row-navigation-light .row.row-parent.style-light.limit-width {
    max-width: 900px;
    margin: 0 auto;
    padding: 0 22px 35px;
}

.roquebus-post-navigation {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    min-height: 50px;
}

.roquebus-post-navigation .navigation {
    display: flex;
    align-items: center;
    gap: 10px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.roquebus-post-navigation .navigation > li {
    margin: 0;
    width: auto !important;
    float: none !important;
    flex: 0 0 auto;
}

.roquebus-post-navigation .btn,
.roquebus-post-navigation .btn-link {
    padding: 0 !important;
    margin: 0 !important;
    min-height: 0 !important;
    line-height: 1 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

.roquebus-nav-arrow-link {
    display: inline-flex;
    width: 37px;
    height: 37px;
    align-items: center;
    justify-content: center;
    color: #000000 !important;
    text-decoration: none;
}

.roquebus-nav-arrow-link i {
    font-size: 28px;
    line-height: 1;
}

.roquebus-nav-counter {
    min-width: 70px;
    text-align: center;
    white-space: nowrap;
    font-family: var(--roquebus-font-family);
    font-size: 23px;
    line-height: 31px;
    font-weight: var(--roquebus-font-weight-bold);
    color: #000000;
}

.roquebus-nav-all-wrap {
    margin-left: auto;
}

.roquebus-nav-all-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 50px;
    padding: 13px 25px;
    border-radius: 10px;
    background: var(--roquebus-primary);
    color: #ffffff !important;
    text-decoration: none;
    font-family: var(--roquebus-font-family);
    font-size: 18px;
    line-height: 1.2;
    font-weight: var(--roquebus-font-weight-bold);
    letter-spacing: 0;
    text-transform: uppercase;
    white-space: nowrap;
}

.roquebus-visually-hidden {
    position: absolute !important;
    width: 1px !important;
    height: 1px !important;
    padding: 0 !important;
    margin: -1px !important;
    overflow: hidden !important;
    clip: rect(0, 0, 0, 0) !important;
    white-space: nowrap !important;
    border: 0 !important;
}

:is(.audioguias-home, .roquebus-audioguias) .isotope-container.grid-container > .tmb .btn-container{
    margin-top: auto !important;
}

:is(.audioguias-home, .roquebus-audioguias) .isotope-container.grid-container > .tmb .btn-container .btn {
    display: inline-block;
    background-color: var(--roquebus-secondary) !important;
    color: var(--roquebus-text-secondary) !important;
    font-family: var(--roquebus-font-family) !important;
    font-weight: var(--roquebus-font-weight-bold) !important;
    font-size: 18px !important;
    line-height: 1.2 !important;
    padding: 12px 25px !important;
    border-radius: var(--roquebus-radius);
    border: none !important;
    text-decoration: none;
    text-align: center;
    cursor: pointer;
    transition: all 0.3s ease;
    letter-spacing: normal;
}

:is(.audioguias-home, .roquebus-audioguias) .isotope-container.grid-container > .tmb .btn-container .btn:hover,
:is(.audioguias-home, .roquebus-audioguias) .isotope-container.grid-container > .tmb .btn-container .btn:focus {
    background-color: #9fe6ff !important;
    color: var(--roquebus-dark) !important;
    transform: translateY(-2px);
}

footer .menu-item.wpml-ls-slot-5{
	display:none !important;
	visibility: hidden !important;
}

@media (max-width: 1199px) {
    :is(.audioguias-home, .roquebus-audioguias) .isotope-container.grid-container > .tmb {
        width: calc((100% - 30px) / 2) !important;
        height: var(--roquebus-audioguia-card-height-md, 400px) !important;
    }
}

@media (max-width: 767px) {
    :is(.audioguias-home, .roquebus-audioguias) .isotope-container.grid-container {
        gap: 20px;
    }

    :is(.audioguias-home, .roquebus-audioguias) .isotope-container.grid-container > .tmb {
        width: 100% !important;
        height: auto !important;
    }
}

@media (max-width: 767px) {
    .roquebus-stops-accordion.wpb_accordion .wpb_accordion_header a,
    .roquebus-stops-accordion.vc_tta.vc_tta-accordion .vc_tta-panel-title > a {
        font-size: 18px !important;
        line-height: 26px !important;
        padding: 16px 16px 16px 46px;
    }

    .roquebus-stops-accordion.wpb_accordion .wpb_accordion_header a::before,
    .roquebus-stops-accordion.vc_tta.vc_tta-accordion .vc_tta-panel-title > a::before {
        left: 14px;
    }

    .roquebus-stops-accordion.wpb_accordion .wpb_accordion_header a::after,
    .roquebus-stops-accordion.vc_tta.vc_tta-accordion .vc_tta-panel-title > a::after {
        left: 20px;
    }
}

@media (max-width: 991px) {
    .roquebus-post-navigation {
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 14px;
    }

    .roquebus-post-navigation .navigation {
        justify-content: center;
    }

    .roquebus-nav-all-wrap {
        margin-left: 0;
        display: flex;
        justify-content: center;
    }

    .pb-0 > .row {
        padding-bottom: 0 !important;
    }

    .pb-20 > .row {
        padding-bottom: 20px !important;
    }

    .roquebus-stops-accordion.wpb_accordion .wpb_accordion_header a, .roquebus-stops-accordion.vc_tta.vc_tta-accordion .vc_tta-panel-title > a{
        padding: 16px 16px 16px 70px;
    }

    .roquebus-stops-accordion.wpb_accordion .panel .panel-collapse .panel-body{
        padding: 20px 24px !important;
    }

    .descargar-folleto > .row {
        margin-left: 0 !important;
    }

    .descargar-folleto .btn-container {
        display: block !important;
        width: 100% !important;
        padding-top: 20px !important;
    }

    .descargar-folleto .btn-container .btn {
        font-size: 1rem !important;
        line-height: 1.2;
        display: block !important;
        width: 100% !important;
        max-width: none !important;
        margin: 0 !important;
        transform: none !important;
    }

    .row>* {
        padding-right: 0 !important;
        padding-left: 0 !important;
    }

    .row {
        margin-left: 0 !important; 
        margin-right: 0 !important;
    }

    .p-0 .uncell {
        padding: 0 !important;
    }

    #masthead:not(.menu-absolute) {
        height: 100% !important;
    }

    .roquebus-buy-tickets-item.horarios .btn-container,
    .roquebus-buy-tickets-item.horarios .btn-container.btn-inline {
        display: block !important;
        width: 100% !important;
        padding-left: 0 !important;
        margin-top: 15px !important;
    }

    .roquebus-buy-tickets-item.horarios .btn-container .btn {
        font-size: 1rem !important;
        line-height: 1.2;
        display: block !important;
        width: 100% !important;
        max-width: none !important;
        margin: 0 !important;
        transform: none !important;
    }

    .roquebus-buy-tickets-item.buy .uncell:first-of-type{
        padding: 2rem;
    }

    .roquebus-buy-tickets-item.buy .btn-container .btn,
    .bloque-audioguias-home .btn-container > a ,
    .roquebus-audioguias .btn-container > a,
    .audioguias-cabecera-btns .btn-container > a,
    .bloque-btn-cabecera-home .btn-container > a,
    .btn-container > a {
        font-size: 1rem !important;
        line-height: 1.2;
        display: block !important;
        width: 100% !important;
        max-width: none !important;
        margin: 0 !important;
        transform: none !important;
    }

    .roquebus-audioguias .isotope-container {
        margin-right: 0 !important;
    }

    :is(.roquebus-audioguias) .isotope-container.grid-container > .tmb {
        padding-right: 0 !important;
    }

    .pt-20 > .row {
        padding-top: 20px !important;
    }

    .pb-50 > .row {
        padding-bottom: 50px !important;
    }

    .fontheight-56{
        line-height: 44px !important;
    }

    .fontheight-45{
        line-height: 36px !important;
    }

    #main-logo img{
        width: 80px !important;
    }

    footer .uncode-single-media-wrapper img {
        width: 120px !important;
    }
}
