.wpcf7 .screen-reader-response {
position: absolute;
overflow: hidden;
clip: rect(1px, 1px, 1px, 1px);
clip-path: inset(50%);
height: 1px;
width: 1px;
margin: -1px;
padding: 0;
border: 0;
word-wrap: normal !important;
}
.wpcf7 .hidden-fields-container {
display: none;
}
.wpcf7 form .wpcf7-response-output {
margin: 2em 0.5em 1em;
padding: 0.2em 1em;
border: 2px solid #00a0d2; }
.wpcf7 form.init .wpcf7-response-output,
.wpcf7 form.resetting .wpcf7-response-output,
.wpcf7 form.submitting .wpcf7-response-output {
display: none;
}
.wpcf7 form.sent .wpcf7-response-output {
border-color: #46b450; }
.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output {
border-color: #dc3232; }
.wpcf7 form.spam .wpcf7-response-output {
border-color: #f56e28; }
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output {
border-color: #ffb900; }
.wpcf7-form-control-wrap {
position: relative;
}
.wpcf7-not-valid-tip {
color: #dc3232; font-size: 1em;
font-weight: normal;
display: block;
}
.use-floating-validation-tip .wpcf7-not-valid-tip {
position: relative;
top: -2ex;
left: 1em;
z-index: 100;
border: 1px solid #dc3232;
background: #fff;
padding: .2em .8em;
width: 24em;
}
.wpcf7-list-item {
display: inline-block;
margin: 0 0 0 1em;
}
.wpcf7-list-item-label::before,
.wpcf7-list-item-label::after {
content: " ";
}
.wpcf7-spinner {
visibility: hidden;
display: inline-block;
background-color: #23282d; opacity: 0.75;
width: 24px;
height: 24px;
border: none;
border-radius: 100%;
padding: 0;
margin: 0 24px;
position: relative;
}
form.submitting .wpcf7-spinner {
visibility: visible;
}
.wpcf7-spinner::before {
content: '';
position: absolute;
background-color: #fbfbfc; top: 4px;
left: 4px;
width: 6px;
height: 6px;
border: none;
border-radius: 100%;
transform-origin: 8px 8px;
animation-name: spin;
animation-duration: 1000ms;
animation-timing-function: linear;
animation-iteration-count: infinite;
}
@media (prefers-reduced-motion: reduce) {
.wpcf7-spinner::before {
animation-name: blink;
animation-duration: 2000ms;
}
}
@keyframes spin {
from {
transform: rotate(0deg);
}
to {
transform: rotate(360deg);
}
}
@keyframes blink {
from {
opacity: 0;
}
50% {
opacity: 1;
}
to {
opacity: 0;
}
}
.wpcf7 [inert] {
opacity: 0.5;
}
.wpcf7 input[type="file"] {
cursor: pointer;
}
.wpcf7 input[type="file"]:disabled {
cursor: default;
}
.wpcf7 .wpcf7-submit:disabled {
cursor: not-allowed;
}
.wpcf7 input[type="url"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"] {
direction: ltr;
}
.wpcf7-reflection > output {
display: list-item;
list-style: none;
}
.wpcf7-reflection > output[hidden] {
display: none;
}.superbaddons-blog-feed-one .wp-block-post-featured-image{min-width:40%!important;width:40%}.superbaddons-blog-feed-one .wp-block-query-pagination-numbers>a,.superbaddons-blog-feed-one .wp-block-query-pagination-numbers>span{border:1px solid var(--wp--preset--color--mono-3);border-radius:3px;padding:5px 10px}.superbaddons-blog-feed-one .wp-block-query-pagination-numbers>span.current{opacity:.5}.superbaddons-blog-feed-one .wp-block-query-pagination-numbers>span.page-numbers.dots{border:0;padding:5px 4px}@media only screen and (max-width:750px){.superbaddons-blog-feed-one .wp-block-post-featured-image{min-width:100%!important;width:100%}.superbaddons-blog-feed-one .has-post-thumbnail .wp-block-group{-ms-flex-wrap:wrap!important;flex-wrap:wrap!important}.superbaddons-blog-feed-one .wp-block-query-pagination-numbers{display:none}}.superbaddons-has-blur-backdrop{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);-moz-backdrop-filter:blur(10px);-ms-backdrop-filter:blur(10px)}.superbaddons-has-box-shadow{-webkit-box-shadow:0 2px 4px 0 rgba(0,0,0,.15);-moz-box-shadow:0 2px 4px 0 rgba(0,0,0,.15);box-shadow:0 2px 4px 0 rgba(0,0,0,.15)}.superbaddons-is-relative-position{position:relative!important}.superbaddons-is-absolute-position-bottom{bottom:0!important;left:0!important;position:absolute!important;right:0!important;width:100%!important}.superbaddons-pagination-numbers>a,.superbaddons-pagination-numbers>span{border:1px solid var(--wp--preset--color--mono-3);border-radius:3px;padding:5px 10px;text-decoration:none}.superbaddons-pagination-numbers>span.page-numbers.dots{border:0;padding:5px 4px}@media only screen and (max-width:750px){.superbthemes-features-005 .is-content-justification-center{justify-content:left}}@media screen and (min-width:768px) and (max-width:1024px){.superb-addons-hide-on-tablet{display:none!important}}@media screen and (max-width:768px){.superb-addons-hide-on-mobile{display:none!important}}.has-superb-addons-text-align-justify{display:inline-block;text-align:justify}.wp-block-navigation.has-superb-addons-overlay-menu-justification .wp-block-navigation__responsive-container-content .wp-block-navigation__container,.wp-block-navigation.has-superb-addons-overlay-menu-justification .wp-block-navigation__responsive-container-content .wp-block-navigation__container .wp-block-navigation-submenu{align-items:var(--superb-addons-overlay-menu-justification,inherit)!important;text-align:var(--superb-addons-overlay-menu-text-align,inherit)!important}.wp-block-navigation.superb-addons-overlay-menu-justification-left{--superb-addons-overlay-menu-justification:start;--superb-addons-overlay-menu-text-align:left}.wp-block-navigation.superb-addons-overlay-menu-justification-center{--superb-addons-overlay-menu-justification:center;--superb-addons-overlay-menu-text-align:center}.wp-block-navigation.superb-addons-overlay-menu-justification-right{--superb-addons-overlay-menu-justification:end;--superb-addons-overlay-menu-text-align:right}.wp-block-navigation.superb-addons-overlay-menu-justification-stretch{--superb-addons-overlay-menu-justification:stretch;--superb-addons-overlay-menu-text-align:left}.wp-block-navigation.is-superb-addons-submenu-layout-card .wp-block-navigation__responsive-container:not(.has-modal-open.is-menu-open) .has-child .wp-block-navigation-submenu__toggle[aria-expanded=true]~.wp-block-navigation__submenu-container{border-radius:8px;border-style:solid;border-width:1px;box-shadow:0 10px 20px 0 rgba(0,0,0,.05);padding:10px}.wp-block-navigation.is-superb-addons-submenu-layout-card .wp-block-navigation__responsive-container:not(.has-modal-open.is-menu-open) .has-child .wp-block-navigation-submenu__toggle[aria-expanded=true]~.wp-block-navigation__submenu-container a,.wp-block-navigation.is-superb-addons-submenu-layout-card .wp-block-navigation__responsive-container:not(.has-modal-open.is-menu-open) .has-child .wp-block-navigation-submenu__toggle[aria-expanded=true]~.wp-block-navigation__submenu-container button{line-height:130%;padding:10px 20px}.wp-block-navigation.is-superb-addons-submenu-layout-card .wp-block-navigation__responsive-container:not(.has-modal-open.is-menu-open) .has-child .wp-block-navigation-submenu__toggle[aria-expanded=true]~.wp-block-navigation__submenu-container li{border-radius:8px;width:100%}.wp-block-navigation.is-superb-addons-submenu-layout-card .wp-block-navigation__responsive-container:not(.has-modal-open.is-menu-open) .wp-block-navigation-submenu__toggle[aria-expanded=true]~.wp-block-navigation__submenu-container li:hover{background-color:rgba(0,0,0,.03)}:root { --yatra-container-max-width: 1300px;
--yatra-container-padding: 20px;
--yatra-container-padding-md: 24px;
--yatra-container-padding-lg: 32px; --yatra-bg-page: #f9fafb;
--yatra-bg-white: #ffffff;
--yatra-bg-gray-50: #f9fafb;
--yatra-bg-gray-100: #f3f4f6;
--yatra-text-primary: #1f2937;
--yatra-text-secondary: #4b5563;
--yatra-text-muted: #6b7280;
--yatra-text-light: #9ca3af;
--yatra-border-color: #e5e7eb;
--yatra-border-light: #f3f4f6;
--yatra-primary: #3b82f6;
--yatra-primary-dark: #2563eb;
--yatra-primary-light: #60a5fa;
--yatra-success: #10b981;
--yatra-warning: #f59e0b;
--yatra-error: #ef4444;
--yatra-star: #fbbf24; --yatra-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
--yatra-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px -1px rgba(0, 0, 0, 0.1);
--yatra-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -2px rgba(0, 0, 0, 0.1);
--yatra-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.1); --yatra-radius-sm: 6px;
--yatra-radius: 8px;
--yatra-radius-md: 12px;
--yatra-radius-lg: 16px;
--yatra-radius-xl: 24px; --yatra-space-xs: 4px;
--yatra-space-sm: 8px;
--yatra-space-md: 16px;
--yatra-space-lg: 24px;
--yatra-space-xl: 32px;
--yatra-space-2xl: 48px; --yatra-font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif;
--yatra-font-size-xs: 12px;
--yatra-font-size-sm: 13px;
--yatra-font-size-base: 15px;
--yatra-font-size-md: 16px;
--yatra-font-size-lg: 18px;
--yatra-font-size-xl: 20px;
--yatra-font-size-2xl: 24px;
--yatra-font-size-3xl: 30px;
--yatra-font-size-4xl: 36px;
} .yatra-page {
width: 100%;
min-height: 100vh;
background: var(--yatra-bg-page);
font-family: var(--yatra-font-family);
color: var(--yatra-text-primary);
line-height: 1.6;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
} .yatra-container {
width: 100%;
max-width: var(--yatra-container-max-width);
margin-left: auto;
margin-right: auto;
padding-left: var(--yatra-container-padding);
padding-right: var(--yatra-container-padding);
} .yatra-container-fluid {
width: 100%;
padding-left: var(--yatra-container-padding);
padding-right: var(--yatra-container-padding);
}
.yatra-container-fluid > .yatra-container-inner {
max-width: var(--yatra-container-max-width);
margin-left: auto;
margin-right: auto;
} .yatra-container-narrow {
max-width: 900px;
} .yatra-container-wide {
max-width: 1400px;
} .yatra-section {
padding-top: var(--yatra-space-xl);
padding-bottom: var(--yatra-space-xl);
}
.yatra-section-sm {
padding-top: var(--yatra-space-lg);
padding-bottom: var(--yatra-space-lg);
}
.yatra-section-lg {
padding-top: var(--yatra-space-2xl);
padding-bottom: var(--yatra-space-2xl);
} .yatra-page-header {
background: var(--yatra-bg-white);
border-bottom: 1px solid var(--yatra-border-color);
padding: var(--yatra-space-lg) 0;
}
.yatra-page-title {
font-size: var(--yatra-font-size-3xl);
font-weight: 700;
color: var(--yatra-text-primary);
margin: 0 0 var(--yatra-space-sm) 0;
}
.yatra-page-subtitle {
font-size: var(--yatra-font-size-base);
color: var(--yatra-text-muted);
margin: 0;
} .yatra-content {
padding: var(--yatra-space-lg) 0;
} .yatra-content-with-sidebar {
display: grid;
grid-template-columns: 1fr 320px;
gap: var(--yatra-space-xl);
}
.yatra-content-main {
min-width: 0;
}
.yatra-content-sidebar {
position: relative;
}
.yatra-sidebar-sticky {
position: sticky;
top: 100px;
} .yatra-content-with-sidebar.yatra-sidebar-left {
grid-template-columns: 280px 1fr;
} .yatra-card {
background: var(--yatra-bg-white);
border-radius: var(--yatra-radius-md);
box-shadow: var(--yatra-shadow);
overflow: hidden;
}
.yatra-card-bordered {
box-shadow: none;
border: 1px solid var(--yatra-border-color);
}
.yatra-card-header {
padding: var(--yatra-space-lg);
border-bottom: 1px solid var(--yatra-border-color);
}
.yatra-card-body {
padding: var(--yatra-space-lg);
}
.yatra-card-footer {
padding: var(--yatra-space-lg);
border-top: 1px solid var(--yatra-border-color);
background: var(--yatra-bg-gray-50);
} .yatra-grid {
display: grid;
gap: var(--yatra-space-lg);
}
.yatra-grid-2 {
grid-template-columns: repeat(2, 1fr);
}
.yatra-grid-3 {
grid-template-columns: repeat(3, 1fr);
}
.yatra-grid-4 {
grid-template-columns: repeat(4, 1fr);
}
.yatra-grid-auto {
grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
} @media (min-width: 640px) {
:root {
--yatra-container-padding: var(--yatra-container-padding-md);
}
}
@media (min-width: 1024px) {
:root {
--yatra-container-padding: var(--yatra-container-padding-lg);
}
}
@media (max-width: 1024px) {
.yatra-content-with-sidebar {
grid-template-columns: 1fr;
}
.yatra-content-with-sidebar.yatra-sidebar-left {
grid-template-columns: 1fr;
}
.yatra-content-sidebar {
order: -1;
}
.yatra-grid-4 {
grid-template-columns: repeat(3, 1fr);
}
}
@media (max-width: 768px) {
.yatra-grid-3,
.yatra-grid-4 {
grid-template-columns: repeat(2, 1fr);
}
.yatra-page-title {
font-size: var(--yatra-font-size-2xl);
}
}
@media (max-width: 480px) {
.yatra-grid-2,
.yatra-grid-3,
.yatra-grid-4 {
grid-template-columns: 1fr;
}
} .yatra-text-center { text-align: center; }
.yatra-text-left { text-align: left; }
.yatra-text-right { text-align: right; }
.yatra-mb-0 { margin-bottom: 0; }
.yatra-mb-sm { margin-bottom: var(--yatra-space-sm); }
.yatra-mb-md { margin-bottom: var(--yatra-space-md); }
.yatra-mb-lg { margin-bottom: var(--yatra-space-lg); }
.yatra-mb-xl { margin-bottom: var(--yatra-space-xl); }
.yatra-mt-0 { margin-top: 0; }
.yatra-mt-sm { margin-top: var(--yatra-space-sm); }
.yatra-mt-md { margin-top: var(--yatra-space-md); }
.yatra-mt-lg { margin-top: var(--yatra-space-lg); }
.yatra-mt-xl { margin-top: var(--yatra-space-xl); }
.yatra-hidden { display: none !important; }
.yatra-visible { display: block !important; } .yatra-loading {
position: relative;
pointer-events: none;
}
.yatra-loading::after {
content: '';
position: absolute;
top: 50%;
left: 50%;
width: 24px;
height: 24px;
margin: -12px 0 0 -12px;
border: 2px solid var(--yatra-border-color);
border-top-color: var(--yatra-primary);
border-radius: 50%;
animation: yatra-spinner 0.8s linear infinite;
}
@keyframes yatra-spinner {
to { transform: rotate(360deg); }
} .yatra-booking-page {
width: 100%;
min-height: 100vh;
}
.yatra-single-trip {
width: 100%;
min-height: 100vh;
}
.yatra-listing-container,
.yatra-booking-container,
.yatra-trip-container,
.yatra-horizontal-search-container,
.yatra-similar-section-container {
width: 100%;
max-width: var(--yatra-container-max-width, 1300px);
margin-left: auto;
margin-right: auto;
}
.yatra-traveler-selector .yatra-quantity-controls {
gap: 6px;
}
.yatra-traveler-selector .yatra-quantity-btn,
.yatra-traveler-selector .yatra-qty-btn {
width: 32px;
height: 32px;
min-width: 32px;
border-radius: 10px;
border: 1px solid #e5e7eb;
background: #ffffff;
color: #0f172a;
display: inline-flex;
align-items: center;
justify-content: center;
box-shadow: 0 1px 2px rgba(0,0,0,0.05);
transition: background 0.15s ease, border-color 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease;
}
.yatra-traveler-selector .yatra-quantity-btn:hover:not(:disabled),
.yatra-traveler-selector .yatra-qty-btn:hover:not(:disabled) {
background: #f8fafc;
border-color: #cbd5e1;
transform: translateY(-1px);
box-shadow: 0 6px 16px rgba(15, 23, 42, 0.08);
}
.yatra-traveler-selector .yatra-quantity-btn:active:not(:disabled),
.yatra-traveler-selector .yatra-qty-btn:active:not(:disabled) {
transform: translateY(0);
box-shadow: 0 2px 6px rgba(15, 23, 42, 0.10);
}
.yatra-traveler-selector .yatra-quantity-btn:disabled,
.yatra-traveler-selector .yatra-qty-btn:disabled {
opacity: 0.45;
cursor: not-allowed;
transform: none;
box-shadow: none;
}
.yatra-traveler-selector .yatra-quantity-btn svg,
.yatra-traveler-selector .yatra-qty-btn svg {
width: 16px;
height: 16px;
stroke-width: 2.25;
}  .yatra-sticky-nav-price {
display: flex;
flex-direction: column;
align-items: flex-end;
gap: 2px;
padding: 8px 16px;
margin-left: auto;
min-width: 140px;
text-align: right;
}
.yatra-sticky-nav-price-label {
font-size: 10px;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.5px;
color: var(--yatra-text-muted);
line-height: 1.2;
}
.yatra-sticky-nav-price-amount {
display: flex;
align-items: center;
gap: 4px;
font-size: 18px;
font-weight: 700;
color: var(--yatra-primary);
line-height: 1.2;
}
.yatra-sticky-nav-price-amount svg {
width: 16px;
height: 16px;
flex-shrink: 0;
}
.yatra-sticky-nav-price-note {
font-size: 10px;
font-weight: 400;
color: var(--yatra-text-muted);
line-height: 1.2;
}
@media (max-width: 768px) {
.yatra-sticky-nav-price {
min-width: 120px;
padding: 6px 12px;
}
.yatra-sticky-nav-price-amount {
font-size: 16px;
}
}:root {
--yatra-listing-list-media-width: max(380px, min(560px, 52%)); --yatra-listing-list-row-gap: 24px;
}  .yatra-listing-page {
width: 100%;
min-height: 100vh;
padding: 50px 0;
}
.yatra-listing-wrapper {
padding-top: 0;
} .yatra-listing-container {
width: 100%;
max-width: var(--yatra-container-max-width, 1300px);
margin-left: auto;
margin-right: auto;
padding: var(--yatra-space-lg, 24px) var(--yatra-container-padding, 20px);
}   .yatra-rating-filter {
display: flex;
flex-direction: column;
gap: 8px;
}
.yatra-rating-option {
display: flex;
align-items: center;
gap: 8px;
padding: 4px 0;
cursor: pointer;
transition: all 0.2s ease;
}
.yatra-rating-option:hover {
background: rgba(59, 130, 246, 0.05);
border-radius: 4px;
padding-left: 4px;
padding-right: 4px;
}
.yatra-rating-option input[type="checkbox"] {
margin: 0;
width: 16px;
height: 16px;
accent-color: #3b82f6;
}
.yatra-stars-display {
display: flex;
align-items: center;
gap: 2px;
}
.yatra-star.filled {
fill: #fbbf24;
}
.yatra-star.empty {
fill: #e5e7eb;
}
.yatra-rating-label {
font-size: 13px;
color: #374151;
margin-left: 4px;
font-weight: 400;
}
.yatra-rating-option:hover .yatra-rating-label {
color: #1f2937;
} @media (max-width: 768px) {
.yatra-star {
width: 12px;
height: 12px;
}
.yatra-rating-label {
font-size: 12px;
}
} .yatra-results-header {
display: flex;
justify-content: space-between;
align-items: flex-start;
gap: 20px;
margin-bottom: 28px;
padding-bottom: 20px;
border-bottom: 1px solid #e2e8f0;
}
.yatra-results-info h1 {
font-size: clamp(1.375rem, 2.5vw, 1.75rem);
font-weight: 700;
color: #0f172a;
letter-spacing: -0.02em;
margin-bottom: 8px;
line-height: 1.25;
}
.yatra-listing-archive-lede {
font-size: 0.9375rem;
line-height: 1.55;
color: #64748b;
margin: 0 0 10px 0;
max-width: 42rem;
}
.yatra-archive-listing-lede {
font-size: 0.9375rem;
line-height: 1.55;
color: #64748b;
margin: 0 0 8px 0;
max-width: 42rem;
}
.yatra-archive-listing-results {
font-size: 0.8125rem;
color: #475569;
margin: 0 0 2px 0;
}
.yatra-archive-card-excerpt {
display: -webkit-box;
-webkit-line-clamp: 3;
-webkit-box-orient: vertical;
overflow: hidden;
line-clamp: 3;
margin: 0 0 8px 0;
font-size: 0.875rem;
line-height: 1.45;
color: #4b5563;
}
.yatra-results-count {
font-size: 14px;
line-height: 1.5;
color: #475569;
margin-top: 4px;
}
.yatra-results-count strong {
color: #0f172a;
font-weight: 600;
}
.yatra-results-controls {
display: flex;
align-items: center;
gap: 12px;
flex-wrap: wrap;
background: #f8fafc;
border: 1px solid #e5e7eb;
border-radius: 12px;
padding: 10px 12px;
}
.yatra-sort-control {
display: flex;
align-items: center;
gap: 8px;
}
.yatra-sort-control label {
font-size: 14px;
font-weight: 500;
color: #374151;
white-space: nowrap;
}
.yatra-sort-control select {
padding: 9px 14px;
border: 1px solid #d1d5db;
border-radius: 10px;
background: #ffffff;
font-size: 14px;
color: #374151;
cursor: pointer;
transition: all 0.2s ease;
min-width: 180px;
}
.yatra-sort-control select:hover {
border-color: #9ca3af;
}
.yatra-sort-control select:focus {
outline: none;
border-color: #3b82f6;
box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
} .yatra-view-toggle {
display: inline-flex;
align-items: stretch;
background: #e2e8f0;
border-radius: 10px;
padding: 3px;
gap: 0;
border: 1px solid #cbd5e1;
}
.yatra-view-btn {
display: flex;
align-items: center;
justify-content: center;
min-width: 40px;
min-height: 36px;
padding: 8px 12px;
border: none;
background: transparent;
border-radius: 8px;
cursor: pointer;
transition: background 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
color: #64748b;
font-weight: 500;
}
.yatra-view-btn:hover:not(.active) {
background: rgba(255, 255, 255, 0.45);
color: #334155;
}
.yatra-view-btn:focus-visible {
outline: none;
box-shadow: 0 0 0 2px #ffffff, 0 0 0 4px #3b82f6;
}
.yatra-view-btn.active {
background: #ffffff;
color: #1d4ed8;
box-shadow: 0 1px 3px rgba(15, 23, 42, 0.12), 0 0 0 1px #93c5fd;
}
.yatra-view-btn svg {
width: 18px;
height: 18px;
flex-shrink: 0;
} .yatra-trip-grid:not(.list-view):not(.yatra-list-view),
.yatra-listing-content-full .yatra-trip-grid:not(.list-view):not(.yatra-list-view),
.yatra-listing-page .yatra-destination-grid:not(.list-view),
.yatra-listing-page .yatra-activity-grid:not(.list-view),
.yatra-listing-page .yatra-category-grid:not(.list-view) {
display: grid;
gap: 24px;
grid-template-columns: 1fr;
transition: all 0.3s ease;
}
.yatra-trip-grid:not(.list-view):not(.yatra-list-view),
.yatra-listing-content-full .yatra-trip-grid:not(.list-view):not(.yatra-list-view) {
margin-bottom: 32px;
}
@media (min-width: 768px) {
.yatra-trip-grid:not(.list-view):not(.yatra-list-view),
.yatra-listing-content-full .yatra-trip-grid:not(.list-view):not(.yatra-list-view),
.yatra-listing-page .yatra-destination-grid:not(.list-view),
.yatra-listing-page .yatra-activity-grid:not(.list-view),
.yatra-listing-page .yatra-category-grid:not(.list-view) {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
}
@media (min-width: 1024px) { .yatra-listing-content:not(.yatra-listing-content-full) .yatra-trip-grid:not(.list-view):not(.yatra-list-view) {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
.yatra-listing-content-full .yatra-trip-grid:not(.list-view):not(.yatra-list-view) {
grid-template-columns: repeat(3, minmax(0, 1fr));
}
.yatra-listing-page .yatra-destination-grid:not(.list-view),
.yatra-listing-page .yatra-activity-grid:not(.list-view),
.yatra-listing-page .yatra-category-grid:not(.list-view) {
grid-template-columns: repeat(3, minmax(0, 1fr));
}
}
.yatra-trip-card {
background: #ffffff;
border-radius: 12px;
overflow: hidden;
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
transition: all 0.3s ease;
cursor: pointer;
display: flex;
flex-direction: column;
height: 100%;
}
.yatra-trip-card:hover {
transform: translateY(-4px);
box-shadow: 0 8px 25px rgba(0, 0, 0, 0.15);
}
.yatra-trip-card-image {
position: relative;
width: 100%;
height: 240px;
overflow: hidden;
}
.yatra-trip-card-image img {
width: 100%;
height: 100%;
object-fit: cover;
}
.yatra-trip-content {
padding: 20px;
display: flex;
flex-direction: column;
gap: 12px;
flex: 1;
}
.yatra-trip-title {
font-size: 1.25rem;
font-weight: 600;
color: #1f2937;
margin: 0;
line-height: 1.4;
-webkit-line-clamp: 2;
line-clamp: 2;
display: -webkit-box;
-webkit-box-orient: vertical;
overflow: hidden;
} .yatra-trip-grid.list-view,
.yatra-trip-grid.yatra-list-view {
display: grid;
grid-template-columns: 1fr;
gap: var(--yatra-listing-list-row-gap);
align-content: start;
}
.yatra-trip-grid.list-view .yatra-trip-card {
display: flex;
flex-direction: row;
height: auto;
min-height: 240px;
max-height: none;
}
.yatra-trip-grid.list-view .yatra-trip-card-image {
width: var(--yatra-listing-list-media-width);
min-width: var(--yatra-listing-list-media-width);
height: auto;
min-height: 240px;
flex-shrink: 0;
align-self: stretch;
}
.yatra-trip-grid.list-view .yatra-trip-content {
flex: 1;
padding: 20px;
display: flex;
flex-direction: column;
justify-content: space-between;
gap: 12px;
}
.yatra-trip-grid.list-view .yatra-trip-title {
font-size: 1.1rem;
margin-bottom: 8px;
-webkit-line-clamp: 1;
line-clamp: 1;
}
.yatra-trip-grid.list-view .yatra-trip-destinations {
margin: -8px -20px 12px -20px;
padding: 12px 20px;
background: #f8fafc;
width: calc(100% + 40px);
border-radius: 0;
} .yatra-trip-info-row {
display: flex;
align-items: center;
gap: 12px;
flex-wrap: wrap;
margin-bottom: 10px;
}
.yatra-info-badge {
display: flex;
align-items: center;
gap: 4px;
font-size: 0.75rem;
color: #6b7280;
background: #f3f4f6;
padding: 4px 8px;
border-radius: 6px;
font-weight: 500;
}
.yatra-info-badge svg {
width: 12px;
height: 12px;
color: #9ca3af;
}
.yatra-trip-duration,
.yatra-trip-difficulty {
display: flex;
align-items: center;
gap: 6px;
font-size: 0.875rem;
color: #6b7280;
}
.yatra-trip-activities {
display: flex;
flex-wrap: wrap;
gap: 6px;
margin-bottom: 10px;
}
.yatra-tag {
background: #e0e7ff;
color: #3730a3;
padding: 3px 8px;
border-radius: 12px;
font-size: 0.7rem;
font-weight: 500;
text-decoration: none;
transition: background-color 0.2s ease, color 0.2s ease;
}
.yatra-tag:hover {
background: #c7d2fe;
color: #312e81;
text-decoration: none;
}
.yatra-activity-tag {
background: #f3f4f6;
color: #374151;
padding: 4px 8px;
border-radius: 6px;
font-size: 0.75rem;
font-weight: 500;
}
.yatra-trip-rating {
display: flex;
align-items: center;
gap: 8px;
margin-bottom: 3px;
}
.yatra-rating-stars {
display: flex;
align-items: center;
gap: 4px;
}
.yatra-rating-value {
font-size: 0.875rem;
font-weight: 600;
color: #1f2937;
}
.yatra-reviews-count {
font-size: 0.75rem;
color: #9ca3af;
}
.yatra-rating-text {
font-size: 0.875rem;
color: #6b7280;
}
.yatra-trip-footer {
margin-top: auto;
display: flex;
justify-content: space-between;
align-items: center;
padding-top: 16px;
}
.yatra-trip-card-price {
display: flex;
flex-direction: column;
align-items: flex-start;
}
.yatra-trip-price {
font-size: 1.25rem;
font-weight: 700;
color: #059669;
}
.yatra-original-price {
font-size: 0.875rem;
color: #9ca3af;
text-decoration: line-through;
margin-left: 8px;
}
.yatra-view-details-btn {
background: #2563eb;
color: #ffffff;
padding: 10px 20px;
border-radius: 8px;
text-decoration: none;
font-weight: 500;
transition: all 0.2s ease;
}
.yatra-view-details-btn:hover {
background: #1d4ed8;
transform: translateY(-1px);
} .yatra-trip-grid:not(.list-view) .yatra-trip-destinations {
margin: -14px -20px 12px -20px;
padding: 12px 20px;
background: #f8fafc;
width: calc(100% + 40px);
} @media (max-width: 767px) {
.yatra-trip-grid:not(.list-view):not(.yatra-list-view),
.yatra-listing-content-full .yatra-trip-grid:not(.list-view):not(.yatra-list-view),
.yatra-listing-page .yatra-destination-grid:not(.list-view),
.yatra-listing-page .yatra-activity-grid:not(.list-view),
.yatra-listing-page .yatra-category-grid:not(.list-view) {
gap: 16px;
}
.yatra-trip-grid.list-view .yatra-trip-card {
flex-direction: column;
min-height: auto;
}
.yatra-trip-grid.list-view .yatra-trip-card-image {
width: 100%;
min-width: 100%;
height: 200px;
min-height: 200px;
}
.yatra-trip-grid.list-view .yatra-trip-destinations {
margin: -14px -20px 12px -20px;
width: calc(100% + 40px);
}
.yatra-trip-footer {
flex-direction: column;
align-items: stretch;
gap: 12px;
}
.yatra-view-details-btn {
width: 100%;
text-align: center;
}
} .yatra-trip-categories-compact {
display: flex;
align-items: center;
gap: 6px;
margin-bottom: 12px;
font-size: 0.75rem;
color: #6b7280;
}
.yatra-category-icon {
display: flex;
align-items: center;
color: #9ca3af;
}
.yatra-category-link {
color: #6b7280;
text-decoration: none;
transition: color 0.2s ease;
}
.yatra-category-link:hover {
color: #374151;
text-decoration: none;
} .yatra-discount-badge {
position: absolute;
top: 12px;
left: 12px;
background: #dc2626;
color: #ffffff;
padding: 4px 8px;
border-radius: 6px;
font-size: 0.75rem;
font-weight: 600;
z-index: 2;
}
.yatra-favorite-btn {
position: absolute;
top: 12px;
right: 12px;
background: rgba(255, 255, 255, 0.9);
border: none;
border-radius: 50%;
width: 36px;
height: 36px;
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
transition: all 0.2s ease;
z-index: 2;
}
.yatra-favorite-btn:hover {
background: #ffffff;
transform: scale(1.1);
}
.yatra-difficulty-overlay {
position: absolute;
bottom: 12px;
right: 12px;
background: rgba(0, 0, 0, 0.8);
color: #ffffff;
padding: 6px 10px;
border-radius: 6px;
font-size: 0.75rem;
font-weight: 500;
display: flex;
align-items: center;
gap: 4px;
z-index: 2;
} .yatra-trip-grid.list-view .yatra-trip-info-row {
margin-bottom: 8px;
}
.yatra-trip-grid.list-view .yatra-trip-activities {
margin-bottom: 8px;
}
.yatra-trip-grid.list-view .yatra-trip-rating {
margin-bottom: 10px;
}
.yatra-trip-grid.list-view .yatra-trip-categories-compact {
margin-bottom: 10px;
}
.yatra-trip-grid.list-view .yatra-trip-footer {
margin-top: auto;
padding-top: 12px;
}
.yatra-trip-grid.list-view .yatra-trip-price {
font-size: 1.1rem;
}
@media (max-width: 768px) {
.yatra-trip-grid.list-view .yatra-trip-card {
grid-template-columns: 1fr;
grid-auto-rows: auto;
}
.yatra-trip-grid.list-view .yatra-trip-card-image {
width: 100%;
height: 200px;
}
} @media (max-width: 768px) {
.yatra-results-controls {
flex-direction: column;
align-items: stretch;
gap: 12px;
}
.yatra-sort-control {
justify-content: space-between;
}
.yatra-sort-control select {
min-width: auto;
flex: 1;
}
}
.yatra-sort-control select:focus {
outline: none;
border-color: #3b82f6;
box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
} .yatra-listing-wrapper--overlay-host {
position: relative;
} .yatra-listing-loading-overlay {
position: absolute;
inset: 0;
z-index: 40;
display: flex;
align-items: center;
justify-content: center;
background: rgba(255, 255, 255, 0.82);
backdrop-filter: blur(2px);
opacity: 0;
visibility: hidden;
pointer-events: none;
transition: opacity 0.2s ease, visibility 0.2s ease;
}
.yatra-listing-loading-overlay.yatra-listing-loading-overlay--visible {
opacity: 1;
visibility: visible;
pointer-events: auto;
}
.yatra-listing-loading-card {
text-align: center;
padding: 24px 32px;
background: #fff;
border-radius: 12px;
box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12);
border: 1px solid #e5e7eb;
}
.yatra-listing-loading-spinner {
display: inline-block;
width: 36px;
height: 36px;
border: 3px solid #e5e7eb;
border-top-color: #3b82f6;
border-radius: 50%;
animation: yatra-listing-spin 0.75s linear infinite;
margin-bottom: 12px;
}
@keyframes yatra-listing-spin {
to {
transform: rotate(360deg);
}
}
.yatra-listing-loading-text {
margin: 0;
font-size: 14px;
color: #374151;
font-weight: 500;
}
.yatra-listing-layout {
display: flex;
gap: 28px;
align-items: flex-start;
}
.yatra-filter-sidebar {
flex-shrink: 0;
}
.yatra-listing-content {
flex: 1;
min-width: 0;
} .yatra-listing-content-full {
width: 100%;
}
.yatra-listing-content-full .yatra-trip-grid {
margin-bottom: 32px;
}
.yatra-listing-content-full .yatra-trip-grid.list-view {
display: grid;
grid-template-columns: 1fr;
gap: var(--yatra-listing-list-row-gap);
}
.yatra-listing-content-full .yatra-trip-grid.list-view .yatra-trip-card,
.yatra-trip-grid.yatra-list-view .yatra-trip-card {
flex-direction: row;
max-height: none;
}
.yatra-listing-content-full .yatra-trip-grid.list-view .yatra-trip-image {
width: var(--yatra-listing-list-media-width);
min-width: var(--yatra-listing-list-media-width);
height: auto;
min-height: 240px;
flex-shrink: 0;
align-self: stretch;
} .yatra-filter-sidebar {
width: 100%;
max-width: 320px;
background: #fff;
border-radius: 12px;
padding: 24px;
height: auto;
border: 1px solid #e5e7eb;
box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
overflow: visible;
box-sizing: border-box;
}
.yatra-filter-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 24px;
padding-bottom: 16px;
border-bottom: 1px solid #e2e8f0;
}
.yatra-filter-header h2 {
font-size: 15px;
font-weight: 700;
color: #0f172a;
letter-spacing: -0.01em;
margin: 0;
}
.yatra-clear-filters {
font-size: 13px;
color: #1d4ed8;
background: #eff6ff;
border: 1px solid #bfdbfe;
border-radius: 8px;
cursor: pointer;
padding: 6px 12px;
font-weight: 600;
font-family: inherit;
line-height: 1.2;
transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
appearance: none;
-webkit-appearance: none;
}
.yatra-clear-filters:hover {
color: #1e40af;
background: #dbeafe;
border-color: #93c5fd;
text-decoration: none;
}
.yatra-filter-section {
margin-bottom: 24px;
border-bottom: 1px solid #f3f4f6;
padding-bottom: 20px; overflow: visible;
width: 100%;
box-sizing: border-box;
}
.yatra-filter-section:last-child {
border-bottom: none;
margin-bottom: 0;
padding-bottom: 0;
}
.yatra-filter-title {
display: flex;
justify-content: space-between;
align-items: center;
cursor: pointer;
font-size: 15px;
font-weight: 600;
color: #111827;
margin-bottom: 16px;
user-select: none;
padding: 4px 0;
transition: color 0.2s;
}
.yatra-filter-actions {
display: flex;
align-items: center;
gap: 8px;
}
.yatra-clear-section {
display: inline-flex;
align-items: center;
justify-content: center;
color: #94a3b8;
cursor: pointer;
padding: 4px;
border-radius: 6px;
transition: color 0.2s ease, background-color 0.2s ease;
text-decoration: none;
width: 28px;
height: 28px;
}
.yatra-clear-section:hover {
color: #dc2626;
background-color: #fef2f2;
}
.yatra-clear-section:active {
transform: scale(0.95);
}
.yatra-clear-section svg {
width: 14px;
height: 14px;
stroke-width: 2;
}
.yatra-filter-title-content {
display: flex;
align-items: center;
gap: 10px;
}
.yatra-filter-icon {
width: 18px;
height: 18px;
flex-shrink: 0;
color: #6b7280;
transition: color 0.2s;
}
.yatra-filter-title:hover .yatra-filter-icon {
color: #3b82f6;
}
.yatra-filter-title:hover {
color: #3b82f6;
}
.yatra-filter-arrow {
transition: transform 0.2s;
color: #6b7280;
flex-shrink: 0;
}
.yatra-filter-section.open .yatra-filter-arrow {
transform: rotate(180deg);
color: #3b82f6;
}
.yatra-filter-content {
display: block;
overflow: visible;
width: 100%;
box-sizing: border-box;
padding: 16px 0;
} .yatra-filter-content .yatra-attribute-item {
display: flex;
flex-direction: column;
align-items: stretch;
width: 100%;
min-width: 0;
box-sizing: border-box;
margin-bottom: 16px;
padding: 14px 16px;
background: #fff;
border: 1px solid #e5e7eb;
border-radius: 8px;
}
.yatra-filter-content .yatra-attribute-item:last-child {
margin-bottom: 0;
}
.yatra-filter-content .yatra-attribute-label {
display: flex;
align-items: center;
gap: 10px;
margin-bottom: 12px;
flex-shrink: 0;
max-width: 100%;
}
.yatra-filter-content .yatra-attribute-icon {
width: 18px;
height: 18px;
flex-shrink: 0;
display: inline-flex;
align-items: center;
justify-content: center;
}
.yatra-filter-content .yatra-attribute-icon img {
width: 18px !important;
height: 18px !important;
object-fit: contain !important;
display: block;
}
.yatra-filter-content .yatra-attribute-icon svg {
width: 18px !important;
height: 18px !important;
color: #6b7280;
}
.yatra-filter-content .yatra-attribute-name {
font-size: 14px;
font-weight: 600;
color: #374151;
line-height: 1.5;
overflow-wrap: break-word;
word-break: break-word;
}
.yatra-filter-content .yatra-attribute-content {
width: 100%;
max-width: 100%;
min-width: 0;
display: block;
flex: 1 1 auto;
}
.yatra-filter-content .yatra-attribute-content input.yatra-filter-input {
width: 100% !important;
max-width: 100% !important;
min-width: 0 !important;
box-sizing: border-box !important;
}
.yatra-filter-content .yatra-input-group {
width: 100%;
display: flex;
flex-direction: column;
gap: 12px;
}
.yatra-filter-content .yatra-input-group input {
width: 100% !important;
max-width: 100% !important;
min-width: 0 !important;
box-sizing: border-box !important;
} .dark .yatra-filter-content .yatra-attribute-item {
background: #1f2937;
border-color: #374151;
}
.dark .yatra-filter-content .yatra-attribute-icon svg {
color: #9ca3af;
}
.dark .yatra-filter-content .yatra-attribute-name {
color: #e5e7eb;
}
.yatra-filter-section:not(.open) .yatra-filter-content {
display: none;
} .yatra-filter-content {
transition: all 0.3s ease;
}
.yatra-filter-section.open .yatra-filter-content {
animation: slideDown 0.3s ease;
}
@keyframes slideDown {
from {
opacity: 0;
max-height: 0;
}
to {
opacity: 1;
max-height: 500px;
}
} .yatra-filters-loading {
position: relative;
pointer-events: none;
opacity: 0.6;
}
.yatra-filters-loading::after {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: rgba(255, 255, 255, 0.8);
display: flex;
align-items: center;
justify-content: center;
z-index: 10;
} .yatra-price-range {
display: flex;
flex-direction: column;
gap: 24px;
overflow: visible;
}
.yatra-price-inputs {
display: flex;
align-items: center;
gap: 16px;
padding: 0;
}
.yatra-price-input-group {
flex: 1;
display: flex;
flex-direction: column;
gap: 8px;
}
.yatra-price-input-label {
font-size: 12px;
font-weight: 500;
color: #6b7280;
margin-bottom: 4px;
}
.yatra-price-inputs input {
width: 100%;
padding: 10px 12px;
border: 1px solid #cbd5e1;
border-radius: 8px;
font-size: 14px;
font-weight: 500;
color: #1e293b;
background: #fff;
transition: border-color 0.2s ease, box-shadow 0.2s ease;
text-align: left;
}
.yatra-price-inputs input:hover {
border-color: #94a3b8;
}
.yatra-price-inputs input:focus {
outline: none;
border-color: #3b82f6;
box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15);
}
.yatra-price-inputs input::placeholder {
color: #9ca3af;
font-weight: 400;
}
.yatra-price-separator {
color: #64748b;
font-weight: 600;
font-size: 14px;
margin-top: 28px;
flex-shrink: 0;
align-self: flex-end;
padding-bottom: 10px;
} body .yatra-filter-sidebar .yatra-price-range .yatra-price-slider {
position: relative !important;
height: 36px !important;
margin: 12px 0 10px !important;
padding: 0 6px !important;
box-sizing: border-box !important;
background: transparent !important;
border: none !important;
border-radius: 0 !important;
overflow: visible !important;
}
body .yatra-filter-sidebar .yatra-price-range .yatra-price-slider-track {
position: absolute !important;
z-index: 0 !important;
width: calc(100% - 16px) !important;
height: 6px !important;
left: 8px !important;
top: 50% !important;
transform: translateY(-50%) !important;
background: #e5e7eb !important;
border-radius: 3px !important;
box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.08) !important;
pointer-events: none !important;
}
body .yatra-filter-sidebar .yatra-price-range .yatra-price-slider-range {
position: absolute !important;
z-index: 1 !important;
height: 6px !important;
top: 50% !important;
transform: translateY(-50%) !important;
background: linear-gradient(90deg, #3b82f6 0%, #2563eb 100%) !important;
border-radius: 3px !important;
box-shadow: 0 2px 6px rgba(59, 130, 246, 0.28) !important;
pointer-events: none !important;
}
body .yatra-filter-sidebar .yatra-price-range .yatra-price-slider input[type="range"] {
position: absolute !important;
left: 0 !important;
width: 100% !important;
max-width: none !important;
min-width: 0 !important;
height: 6px !important;
margin: 0 !important;
padding: 0 !important;
border: 0 !important;
background: transparent !important;
-webkit-appearance: none !important;
appearance: none !important;
pointer-events: none !important;
top: 50% !important;
transform: translateY(-50%) !important;
cursor: pointer !important;
box-sizing: border-box !important;
} body .yatra-filter-sidebar .yatra-price-range .yatra-price-slider .yatra-range-min {
z-index: 3;
}
body .yatra-filter-sidebar .yatra-price-range .yatra-price-slider .yatra-range-max {
z-index: 4;
}
body .yatra-filter-sidebar .yatra-price-range .yatra-price-slider input[type="range"]::-webkit-slider-runnable-track {
height: 6px !important;
background: transparent !important;
border-radius: 3px !important;
}
body .yatra-filter-sidebar .yatra-price-range .yatra-price-slider input[type="range"]::-webkit-slider-thumb {
-webkit-appearance: none !important;
appearance: none !important;
width: 20px !important;
height: 20px !important;
border-radius: 50% !important;
background: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%) !important;
border: 3px solid #3b82f6 !important;
cursor: grab !important;
pointer-events: all !important;
box-shadow: 0 3px 8px rgba(59, 130, 246, 0.3), 0 1px 3px rgba(0, 0, 0, 0.1) !important;
margin-top: -7px !important;
}
body .yatra-filter-sidebar .yatra-price-range .yatra-price-slider input[type="range"]::-webkit-slider-thumb:hover {
transform: scale(1.06) !important;
box-shadow: 0 4px 12px rgba(59, 130, 246, 0.35) !important;
}
body .yatra-filter-sidebar .yatra-price-range .yatra-price-slider input[type="range"]::-webkit-slider-thumb:active {
cursor: grabbing !important;
}
body .yatra-filter-sidebar .yatra-price-range .yatra-price-slider input[type="range"]::-moz-range-track {
height: 6px !important;
background: transparent !important;
border-radius: 3px !important;
}
body .yatra-filter-sidebar .yatra-price-range .yatra-price-slider input[type="range"]::-moz-range-thumb {
width: 20px !important;
height: 20px !important;
border-radius: 50% !important;
background: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%) !important;
border: 3px solid #3b82f6 !important;
cursor: grab !important;
pointer-events: all !important;
box-shadow: 0 3px 8px rgba(59, 130, 246, 0.3), 0 1px 3px rgba(0, 0, 0, 0.1) !important;
}
body .yatra-filter-sidebar .yatra-price-range .yatra-price-slider input[type="range"]::-moz-range-thumb:hover {
transform: scale(1.06) !important;
}
.yatra-price-display {
font-size: 14px;
font-weight: 600;
color: #334155;
text-align: center;
padding: 10px 0 4px;
margin-top: 4px;
letter-spacing: 0.01em;
} .yatra-checkbox-group {
display: flex;
flex-direction: column;
gap: 12px;
width: 100%;
box-sizing: border-box;
} .yatra-filter-collapsible.has-more:not(.is-expanded) .yatra-filter-option-more {
display: none;
}
.yatra-filter-show-more-toggle {
margin-top: 2px;
padding: 6px 12px;
align-self: flex-start;
background: transparent;
border: none;
color: #3b82f6;
font-size: 13px;
font-weight: 500;
cursor: pointer;
border-radius: 6px;
font-family: inherit;
line-height: 1.3;
text-align: left;
}
.yatra-filter-show-more-toggle:hover {
background: rgba(59, 130, 246, 0.08);
color: #2563eb;
}
.yatra-filter-collapsible.is-expanded .yatra-filter-show-more-label {
display: none;
}
.yatra-filter-collapsible:not(.is-expanded) .yatra-filter-show-less-label {
display: none;
}
.yatra-checkbox-label {
display: flex;
align-items: center;
gap: 12px;
cursor: pointer;
font-size: 14px;
color: #374151;
transition: all 0.2s ease;
padding: 8px 12px;
border-radius: 8px;
margin: -4px -12px;
width: calc(100% + 24px);
box-sizing: border-box;
word-wrap: break-word;
overflow: hidden;
}
.yatra-checkbox-label:hover {
background: rgba(59, 130, 246, 0.05);
color: #1e293b;
}
.yatra-checkbox-label input[type="checkbox"] {
width: 16px;
height: 16px;
cursor: pointer;
accent-color: #3b82f6;
margin: 0;
flex-shrink: 0;
}
.yatra-checkbox-label span:not(.yatra-filter-count) {
flex: 1;
}
.yatra-filter-count {
margin-left: auto;
font-size: 12px;
color: #9ca3af;
font-weight: 500;
}
.yatra-rating-display {
display: flex;
align-items: center;
gap: 6px;
flex: 1;
}
.yatra-rating-display svg {
flex-shrink: 0;
} .yatra-listing-content {
min-width: 0;
}
.yatra-trip-card {
background: white;
border-radius: 12px;
overflow: hidden;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
transition: transform 0.2s, box-shadow 0.2s;
cursor: pointer;
display: flex;
flex-direction: column;
height: 100%;
}
.yatra-trip-card:hover {
transform: translateY(-2px);
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}
.yatra-trip-grid.list-view .yatra-trip-card {
flex-direction: row;
max-height: none;
}
.yatra-destination-card {
background: #fff;
border-radius: 12px;
overflow: hidden;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
transition: transform 0.2s, box-shadow 0.2s;
cursor: pointer;
display: flex;
flex-direction: column;
}
.yatra-destination-grid.list-view .yatra-destination-card {
flex-direction: row;
align-items: stretch;
max-height: none;
min-height: 240px;
width: 100%;
}
.yatra-activity-grid.list-view .yatra-activity-card {
flex-direction: row;
align-items: stretch;
max-height: none;
min-height: 240px;
width: 100%;
}
.yatra-destination-grid.list-view .yatra-destination-image,
.yatra-activity-grid.list-view .yatra-activity-image {
width: var(--yatra-listing-list-media-width);
min-width: var(--yatra-listing-list-media-width);
height: auto;
min-height: 240px;
flex-shrink: 0;
align-self: stretch;
}
.yatra-destination-grid.list-view .yatra-destination-content {
padding: 20px;
flex: 1;
display: flex;
flex-direction: column;
justify-content: space-between;
}
.yatra-trip-card:hover {
transform: translateY(-2px);
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}
.yatra-trip-image {
position: relative;
width: 100%;
height: 220px;
overflow: hidden;
background: #e5e7eb;
flex-shrink: 0;
}
.yatra-trip-grid.list-view .yatra-trip-image,
.yatra-trip-grid.yatra-list-view .yatra-trip-image {
width: var(--yatra-listing-list-media-width);
min-width: var(--yatra-listing-list-media-width);
height: auto;
min-height: 240px;
flex-shrink: 0;
align-self: stretch;
}
.yatra-trip-image img {
width: 100%;
height: 100%;
object-fit: cover;
}
.yatra-discount-badge {
position: absolute;
top: 12px;
left: 12px;
background: #ef4444;
color: #fff;
padding: 4px 10px;
border-radius: 4px;
font-size: 12px;
font-weight: 600;
z-index: 2;
}
.yatra-favorite-btn {
position: absolute !important;
top: 12px !important;
right: 12px !important;
width: 40px !important;
height: 40px !important;
background: #ffffff !important;
border: 1px solid rgba(0, 0, 0, 0.1) !important;
border-radius: 50% !important;
cursor: pointer !important;
display: flex !important;
align-items: center !important;
justify-content: center !important;
color: #6b7280 !important;
transition: all 0.2s !important;
z-index: 100 !important;
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15) !important;
padding: 0 !important;
margin: 0 !important;
opacity: 1 !important;
visibility: visible !important;
}
.yatra-favorite-btn:hover {
background: #ffffff !important;
color: #ef4444 !important;
transform: scale(1.1) !important;
border-color: #ef4444 !important;
box-shadow: 0 4px 12px rgba(239, 68, 68, 0.3) !important;
}
.yatra-favorite-btn svg {
width: 20px !important;
height: 20px !important;
stroke-width: 2 !important;
display: block !important;
}
.yatra-favorite-btn.saved,
.yatra-favorite-btn.is-saved {
background: #ffffff !important;
color: #ef4444 !important;
border-color: #ef4444 !important;
}
.yatra-favorite-btn.saved svg,
.yatra-favorite-btn.is-saved svg {
fill: #ef4444 !important;
stroke: #ef4444 !important;
}
.yatra-favorite-btn.saved:hover,
.yatra-favorite-btn.is-saved:hover {
background: #fee2e2 !important;
color: #dc2626 !important;
border-color: #dc2626 !important;
}
.yatra-trip-content {
padding: 20px;
display: flex;
flex-direction: column;
flex: 1;
}
.yatra-trip-grid.list-view .yatra-trip-content,
.yatra-trip-grid.yatra-list-view .yatra-trip-content {
padding: 24px;
}
.yatra-trip-meta {
display: flex;
align-items: center;
gap: 8px;
margin-bottom: 12px;
font-size: 13px;
color: #6b7280;
flex-wrap: wrap;
}
.yatra-trip-separator {
color: #d1d5db;
}
.yatra-trip-title {
font-size: 18px;
font-weight: 600;
color: #1f2937;
margin-bottom: 12px;
line-height: 1.4;
}
.yatra-trip-highlights {
display: flex;
flex-wrap: wrap;
gap: 6px;
margin-bottom: 12px;
}
.yatra-highlight-badge {
padding: 4px 10px;
background: #eff6ff;
color: #1e40af;
border-radius: 4px;
font-size: 12px;
font-weight: 500;
text-decoration: none;
transition: all 0.2s ease;
}
a.yatra-highlight-link {
cursor: pointer;
}
a.yatra-highlight-link:hover {
background: #dbeafe;
color: #1d4ed8;
text-decoration: none;
}
.yatra-rating-stars {
display: flex;
align-items: center;
gap: 4px;
}
.yatra-rating-value {
font-size: 14px;
font-weight: 600;
color: #1f2937;
}
.yatra-reviews-count {
font-size: 13px;
}
.yatra-trip-footer {
display: flex;
align-items: center;
justify-content: space-between;
margin-top: auto;
padding-top: 16px;
border-top: 1px solid #f3f4f6;
}
.yatra-trip-price {
display: flex;
flex-direction: row;
}
.yatra-original-price {
text-decoration: line-through;
text-decoration-thickness: 2px;
text-decoration-color: #ef4444;
color: #6b7280;
font-size: 0.95rem;
font-weight: 500;
background: rgba(239, 68, 68, 0.08);
padding: 1px 4px;
border-radius: 3px;
border: 1px solid rgba(239, 68, 68, 0.15);
line-height: 1;
}
.yatra-current-price {
font-size: 22px;
font-weight: 700;
color: #3b82f6;
line-height: 1;
}
.yatra-price-note {
font-size: 11px;
color: #9ca3af;
margin-top: 4px;
} .yatra-trip-card {
background: #ffffff;
border-radius: 12px;
overflow: hidden;
transition: all 0.3s ease;
height: 100%;
display: flex;
flex-direction: column;
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}
.yatra-trip-card:hover {
box-shadow: 0 10px 25px rgba(0, 0, 0, 0.1);
transform: translateY(-2px);
} .yatra-trip-card-image {
position: relative;
width: 100%;
height: 280px;
overflow: hidden;
background: #f8fafc;
}
.yatra-trip-card-image img {
width: 100%;
height: 100%;
object-fit: cover;
} .yatra-discount-badge {
position: absolute;
top: 12px;
left: 12px;
background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
color: white;
padding: 4px 8px;
border-radius: 12px;
font-size: 0.75rem;
font-weight: 600;
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
z-index: 2;
} .yatra-trip-destinations {
background: #f8fafc;
padding: 10px 16px;
display: flex;
align-items: center;
gap: 6px;
} .yatra-trip-grid.list-view .yatra-trip-destinations {
margin: 8px -16px 8px -16px;
padding: 10px 20px;
background: #f8fafc;
width: calc(100% + 32px);
border-radius: 0;
}
.yatra-trip-destinations .location-icon {
color: #6366f1;
flex-shrink: 0;
}
.yatra-trip-destinations .destination-link {
color: #374151;
text-decoration: none;
font-size: 0.875rem;
font-weight: 500;
transition: color 0.2s ease;
}
.yatra-trip-destinations .destination-link:hover {
color: #6366f1;
text-decoration: none;
}
.yatra-trip-destinations .yatra-trip-card-location-text {
color: #374151;
font-size: 0.875rem;
font-weight: 500;
}
.yatra-trip-traveler-types {
display: flex;
align-items: flex-start;
gap: 8px;
margin: 0 0 12px 0;
padding-top: 10px;
border-top: 1px solid #f1f5f9;
}
.yatra-trip-traveler-types-icon {
color: #6366f1;
flex-shrink: 0;
margin-top: 2px;
}
.yatra-trip-traveler-types-inner {
display: flex;
flex-direction: column;
gap: 6px;
min-width: 0;
}
.yatra-trip-traveler-types-label {
font-size: 0.65rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.05em;
color: #64748b;
}
.yatra-trip-traveler-types-pills {
display: flex;
flex-wrap: wrap;
gap: 6px;
}
.yatra-traveler-tier-pill {
display: inline-block;
padding: 3px 10px;
border-radius: 999px;
font-size: 0.75rem;
font-weight: 500;
background: #eef2ff;
color: #4338ca;
border: 1px solid #c7d2fe;
} .yatra-trip-content {
padding: 16px;
}
.yatra-trip-title {
font-size: 1.25rem;
font-weight: 600;
color: #1f2937;
margin-bottom: 12px;
line-height: 1.4;
display: -webkit-box;
-webkit-line-clamp: 2;
line-clamp: 2;
-webkit-box-orient: vertical;
overflow: hidden;
}
.yatra-trip-title-link {
color: inherit;
text-decoration: none;
transition: color 0.2s ease;
}
.yatra-trip-title-link:hover {
color: #2563eb;
text-decoration: none;
}
.yatra-trip-card-meta {
display: flex;
flex-wrap: wrap;
align-items: center;
gap: 8px;
margin: -4px 0 12px 0;
}
.yatra-trip-type-chip {
display: inline-block;
padding: 2px 10px;
border-radius: 6px;
font-size: 0.7rem;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.04em;
background: #f1f5f9;
color: #475569;
}
.yatra-trip-primary-category-chip {
display: inline-block;
padding: 2px 10px;
border-radius: 6px;
font-size: 0.75rem;
font-weight: 500;
background: #eff6ff;
color: #1d4ed8;
text-decoration: none;
border: 1px solid #bfdbfe;
transition: background-color 0.2s ease, color 0.2s ease;
}
.yatra-trip-primary-category-chip:hover {
background: #dbeafe;
color: #1e40af;
}
.yatra-trip-primary-category-chip--text {
border-style: dashed;
cursor: default;
} .yatra-trip-info-row {
display: flex;
align-items: center;
gap: 8px;
margin-bottom: 16px;
flex-wrap: wrap;
}
.yatra-info-badge {
display: inline-flex;
align-items: center;
gap: 4px;
padding: 4px 8px;
background: #f3f4f6;
color: #374151;
border-radius: 12px;
font-size: 0.75rem;
font-weight: 500;
}
.yatra-info-badge.duration {
background: #dbeafe;
color: #1d4ed8;
}
.yatra-info-badge svg {
width: 12px;
height: 12px;
} .yatra-trip-activities {
display: flex;
flex-wrap: wrap;
gap: 6px;
margin-bottom: 16px;
align-items: center;
} .yatra-trip-categories-compact {
display: flex;
align-items: center;
gap: 6px;
margin-bottom: 16px;
}
.yatra-category-icon {
width: 16px;
height: 16px;
display: flex;
align-items: center;
justify-content: center;
color: #6366f1;
flex-shrink: 0;
}
.yatra-category-icon svg {
width: 14px;
height: 14px;
}
.yatra-categories-text {
font-size: 0.8rem;
color: #6b7280;
line-height: 1.2;
}
.yatra-category-link {
color: #6b7280;
text-decoration: none;
transition: color 0.2s ease;
}
.yatra-category-link:hover {
color: #6366f1;
text-decoration: none;
}
.yatra-tag {
display: inline-block;
padding: 5px 12px;
border-radius: 16px;
font-size: 0.8rem;
font-weight: 500;
text-decoration: none; transition: background-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
border: 1px solid transparent;
box-shadow: 0 0 0 rgba(29, 78, 216, 0);
}
.yatra-tag.activity-tag {
background: #eff6ff;
color: #1d4ed8;
border-color: #bfdbfe;
}
.yatra-tag.activity-tag:hover {
background: #dbeafe;
color: #1e40af;
text-decoration: none;
box-shadow: 0 2px 8px rgba(29, 78, 216, 0.14);
} .yatra-difficulty-overlay {
position: absolute;
bottom: 12px;
right: 12px;
background: rgba(34, 197, 94, 0.9);
color: white;
padding: 6px 10px;
border-radius: 16px;
font-size: 0.75rem;
font-weight: 600;
display: flex;
align-items: center;
gap: 4px;
backdrop-filter: blur(4px);
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}
.yatra-difficulty-overlay svg {
width: 14px;
height: 14px;
opacity: 0.9;
}
.yatra-difficulty-overlay .difficulty-icon {
width: 14px;
height: 14px;
} .yatra-rating-stars {
display: flex;
align-items: center;
gap: 4px;
}
.yatra-rating-value {
font-weight: 600;
color: #1f2937;
font-size: 0.875rem;
}
.yatra-reviews-count {
color: #6b7280;
font-size: 0.8rem;
} .yatra-trip-footer {
display: flex;
align-items: center;
justify-content: space-between;
padding-top: 12px;
}
.yatra-trip-price {
font-size: 1.125rem;
font-weight: 700;
color: #2563eb;
display: flex;
align-items: baseline;
gap: 8px;
flex-wrap: wrap;
} .yatra-favorite-btn {
position: absolute;
top: 12px;
right: 12px;
background: rgba(255, 255, 255, 0.9);
border: none;
border-radius: 50%;
width: 36px;
height: 36px;
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
transition: all 0.2s ease;
color: #6b7280;
z-index: 2;
}
.yatra-favorite-btn:hover {
background: rgba(255, 255, 255, 1);
transform: scale(1.1);
color: #ef4444;
}
.yatra-favorite-btn.saved {
color: #ef4444;
background: rgba(255, 255, 255, 1);
}
.yatra-favorite-btn.loading {
opacity: 0.6;
cursor: not-allowed;
}
.yatra-favorite-btn:disabled {
opacity: 0.6;
cursor: not-allowed;
} .yatra-listing-pagination {
display: flex;
justify-content: center;
align-items: center;
gap: 8px;
margin-top: 40px;
} .yatra-trip-listing .yatra-listing-content > .yatra-listing-pagination--trip-content {
width: 100%;
margin-top: 24px;
flex-wrap: wrap;
}
.yatra-pagination-btn {
padding: 8px 16px;
border: 1px solid #e5e7eb;
background: #fff;
border-radius: 6px;
cursor: pointer;
font-size: 14px;
transition: all 0.2s;
color: #374151;
}
.yatra-pagination-btn:hover:not(:disabled) {
border-color: #3b82f6;
color: #3b82f6;
}
.yatra-pagination-btn.active {
border-color: #3b82f6;
background: #3b82f6;
color: #fff;
font-weight: 600;
}
.yatra-pagination-btn:disabled {
opacity: 0.5;
cursor: not-allowed;
}
.yatra-pagination-btn.disabled {
opacity: 0.5;
cursor: default;
pointer-events: none;
}
a.yatra-pagination-btn,
span.yatra-pagination-btn.disabled {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 6px;
}
.yatra-pagination-btn .yatra-btn-icon {
width: 0.875rem;
height: 0.875rem;
flex-shrink: 0;
} .yatra-btn .yatra-btn-icon {
width: 1.125rem;
height: 1.125rem;
flex-shrink: 0;
}
.yatra-archive-card-cta.yatra-btn {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 0.5rem;
text-decoration: none !important;
}
.yatra-destination-content .yatra-archive-card-cta.yatra-btn,
.yatra-activity-content .yatra-archive-card-cta.yatra-btn,
.yatra-category-content .yatra-archive-card-cta.yatra-btn {
width: 100%;
margin-top: 4px;
box-sizing: border-box;
}
.yatra-category-content .yatra-archive-card-cta.yatra-btn:disabled {
opacity: 0.55;
cursor: not-allowed;
}
.yatra-trip-footer .yatra-archive-card-cta.yatra-btn {
padding: 10px 18px;
font-size: 14px;
white-space: nowrap;
flex-shrink: 0;
} .yatra-destination-listing .yatra-results-controls .yatra-view-toggle,
.yatra-taxonomy-page .yatra-results-controls .yatra-view-toggle {
margin-left: 8px;
}
.yatra-destination-listing .yatra-results-controls .yatra-view-btn.active,
.yatra-taxonomy-page .yatra-results-controls .yatra-view-btn.active {
background: #ffffff !important;
color: #1d4ed8 !important;
box-shadow: 0 1px 3px rgba(15, 23, 42, 0.12), 0 0 0 1px #93c5fd !important;
}
.yatra-destination-listing .yatra-results-controls .yatra-view-btn:not(.active),
.yatra-taxonomy-page .yatra-results-controls .yatra-view-btn:not(.active) {
color: #64748b !important;
background: transparent !important;
opacity: 1;
} @media (max-width: 1024px) {
.yatra-listing-layout {
display: grid;
grid-template-columns: minmax(220px, 280px) 1fr;
gap: 20px;
}
}
@media (max-width: 768px) {
.yatra-listing-container {
padding: 16px;
}
.yatra-search-form {
flex-wrap: wrap;
}
.yatra-search-field {
min-width: calc(50% - 6px);
}
.yatra-search-btn {
width: 100%;
justify-content: center;
}
.yatra-results-header {
flex-direction: column;
align-items: flex-start;
gap: 16px;
}
.yatra-results-controls {
width: 100%;
justify-content: space-between;
}
.yatra-listing-layout {
display: grid;
grid-template-columns: 1fr;
}
.yatra-filter-sidebar {
position: static;
margin-bottom: 24px;
max-width: none;
}
.yatra-trip-grid:not(.list-view):not(.yatra-list-view),
.yatra-listing-content-full .yatra-trip-grid:not(.list-view):not(.yatra-list-view),
.yatra-listing-page .yatra-destination-grid:not(.list-view),
.yatra-listing-page .yatra-activity-grid:not(.list-view),
.yatra-listing-page .yatra-category-grid:not(.list-view) {
grid-template-columns: 1fr;
}
.yatra-trip-grid.list-view .yatra-trip-card,
.yatra-listing-content-full .yatra-trip-grid.list-view .yatra-trip-card {
flex-direction: column;
max-height: none;
}
.yatra-trip-grid.list-view .yatra-trip-image,
.yatra-listing-content-full .yatra-trip-grid.list-view .yatra-trip-image {
width: 100%;
height: 220px;
}
.yatra-destination-grid.list-view .yatra-destination-card,
.yatra-activity-grid.list-view .yatra-activity-card,
.yatra-category-grid.list-view .yatra-category-card {
flex-direction: column;
max-height: none;
min-height: auto;
}
.yatra-destination-grid.list-view .yatra-destination-image,
.yatra-activity-grid.list-view .yatra-activity-image,
.yatra-category-grid.list-view .yatra-category-image {
width: 100%;
min-width: 100%;
height: 220px;
min-height: 220px;
}
.yatra-destination-grid.list-view .yatra-destination-stats,
.yatra-activity-grid.list-view .yatra-activity-stats {
flex-direction: column;
gap: 12px;
}
.yatra-destination-grid.list-view .yatra-destination-stat,
.yatra-activity-grid.list-view .yatra-activity-stat {
border-right: none;
border-bottom: 1px solid #e5e7eb;
padding-bottom: 12px;
justify-content: flex-start;
}
.yatra-destination-grid.list-view .yatra-destination-stat:last-child,
.yatra-activity-grid.list-view .yatra-activity-stat:last-child {
border-bottom: none;
padding-bottom: 0;
}
.yatra-destination-grid.list-view .yatra-archive-card-cta.yatra-btn,
.yatra-activity-grid.list-view .yatra-archive-card-cta.yatra-btn {
width: 100%;
}
.yatra-destination-stats,
.yatra-activity-stats {
flex-direction: row;
justify-content: space-around;
}
.yatra-trip-footer {
flex-direction: column;
align-items: flex-start;
gap: 12px;
}
} .yatra-category-header {
display: flex;
justify-content: space-between;
align-items: flex-start;
margin-bottom: 32px;
padding-bottom: 20px;
border-bottom: 1px solid #e5e7eb;
}
.yatra-category-header-content h1 {
font-size: 32px;
font-weight: 700;
color: #1f2937;
margin-bottom: 8px;
}
.yatra-category-header-content p {
font-size: 16px;
color: #6b7280;
} .yatra-destination-header {
display: flex;
justify-content: space-between;
align-items: flex-start;
margin-bottom: 32px;
padding-bottom: 20px;
border-bottom: 1px solid #e5e7eb;
}
.yatra-destination-header-content h1 {
font-size: 32px;
font-weight: 700;
color: #1f2937;
margin-bottom: 8px;
}
.yatra-destination-header-content p {
font-size: 16px;
color: #6b7280;
} .yatra-activity-header {
display: flex;
justify-content: space-between;
align-items: flex-start;
margin-bottom: 32px;
padding-bottom: 20px;
border-bottom: 1px solid #e5e7eb;
}
.yatra-activity-header-content h1 {
font-size: 32px;
font-weight: 700;
color: #1f2937;
margin-bottom: 8px;
}
.yatra-activity-header-content p {
font-size: 16px;
color: #6b7280;
} .yatra-destination-grid.list-view,
.yatra-activity-grid.list-view,
.yatra-category-grid.list-view {
display: grid;
grid-template-columns: 1fr;
gap: var(--yatra-listing-list-row-gap);
align-content: start;
}
.yatra-destination-card,
.yatra-activity-card,
.yatra-category-card {
background: #fff;
border-radius: 12px;
overflow: hidden;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
transition: all 0.3s ease;
cursor: pointer;
}
.yatra-destination-card:hover,
.yatra-activity-card:hover,
.yatra-category-card:hover {
transform: translateY(-4px);
box-shadow: 0 8px 25px rgba(0, 0, 0, 0.12);
}
.yatra-destination-image img,
.yatra-activity-image img {
transition: transform 0.4s ease;
}
.yatra-destination-image,
.yatra-activity-image,
.yatra-category-image {
position: relative;
width: 100%;
height: 300px;
overflow: hidden;
}
.yatra-destination-grid.list-view .yatra-destination-overlay h3 {
font-size: 24px;
text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}
.yatra-destination-grid.list-view .yatra-destination-content p {
font-size: 15px;
margin-bottom: 20px;
line-height: 1.7;
color: #4b5563;
}
.yatra-destination-grid.list-view .yatra-destination-stats,
.yatra-activity-grid.list-view .yatra-activity-stats {
flex-direction: row;
gap: 24px;
padding: 16px 20px;
background: #f9fafb;
border-radius: 10px;
margin-bottom: 20px;
}
.yatra-destination-grid.list-view .yatra-destination-stat,
.yatra-activity-grid.list-view .yatra-activity-stat {
flex: 1;
justify-content: center;
padding: 0;
border-right: 1px solid #e5e7eb;
}
.yatra-destination-grid.list-view .yatra-destination-stat:last-child,
.yatra-activity-grid.list-view .yatra-activity-stat:last-child {
border-right: none;
}
.yatra-destination-grid.list-view .yatra-archive-card-cta.yatra-btn,
.yatra-activity-grid.list-view .yatra-archive-card-cta.yatra-btn {
align-self: flex-start;
padding: 12px 28px;
} .yatra-activity-grid.list-view .yatra-activity-content h3 {
font-size: 22px;
margin-bottom: 10px;
color: #111827;
}
.yatra-activity-grid.list-view .yatra-activity-content p {
font-size: 15px;
margin-bottom: 20px;
line-height: 1.7;
color: #4b5563;
flex: none;
}
.yatra-category-grid.list-view .yatra-category-card {
display: flex;
flex-direction: row;
align-items: stretch;
max-height: none;
min-height: 240px;
}
.yatra-category-grid.list-view .yatra-category-image {
width: var(--yatra-listing-list-media-width);
min-width: var(--yatra-listing-list-media-width);
height: auto;
min-height: 240px;
flex-shrink: 0;
align-self: stretch;
}
.yatra-category-grid.list-view .yatra-category-content {
flex: 1;
display: flex;
flex-direction: column;
justify-content: space-between;
}
.yatra-category-grid.list-view .yatra-category-stats {
flex-direction: row;
justify-content: space-around;
margin-bottom: 16px;
}
.yatra-destination-card,
.yatra-activity-card,
.yatra-category-card {
background: #fff;
border-radius: 12px;
overflow: hidden;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
transition: all 0.3s ease;
cursor: pointer;
}
.yatra-destination-card:hover,
.yatra-activity-card:hover,
.yatra-category-card:hover {
transform: translateY(-4px);
box-shadow: 0 8px 25px rgba(0, 0, 0, 0.12);
}
.yatra-destination-image img,
.yatra-activity-image img {
transition: transform 0.4s ease;
}
.yatra-destination-image,
.yatra-activity-image,
.yatra-category-image {
position: relative;
width: 100%;
height: 300px;
overflow: hidden;
}
.yatra-destination-image img,
.yatra-activity-image img,
.yatra-category-image img {
width: 100%;
height: 100%;
object-fit: cover;
} .yatra-destination-grid.list-view .yatra-destination-image,
.yatra-activity-grid.list-view .yatra-activity-image,
.yatra-category-grid.list-view .yatra-category-image {
width: var(--yatra-listing-list-media-width);
min-width: var(--yatra-listing-list-media-width);
height: auto;
min-height: 240px;
flex-shrink: 0;
align-self: stretch;
}
.yatra-destination-overlay,
.yatra-category-overlay {
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.7) 100%);
display: flex;
align-items: flex-end;
padding: 24px;
}
.yatra-destination-overlay h3 {
font-size: 28px;
font-weight: 700;
color: #fff;
margin: 0;
}
.yatra-destination-content {
padding: 24px;
background: #fff;
}
.yatra-destination-content p {
font-size: 14px;
color: #6b7280;
margin-bottom: 16px;
line-height: 1.6;
}
.yatra-destination-stats {
display: flex;
flex-direction: column;
gap: 12px;
margin-bottom: 20px;
padding: 16px;
background: #f9fafb;
border-radius: 10px;
}
.yatra-destination-stat {
display: flex;
align-items: center;
gap: 10px;
font-size: 14px;
color: #374151;
}
.yatra-destination-stat svg {
flex-shrink: 0;
color: #6b7280;
}
.yatra-destination-stat span {
font-weight: 600;
color: #1f2937;
}
.yatra-activity-content {
padding: 24px;
background: #fff;
display: flex;
flex-direction: column;
flex: 1;
}
.yatra-activity-content h3 {
font-size: 22px;
font-weight: 600;
color: #1f2937;
margin-bottom: 12px;
}
.yatra-activity-content p {
font-size: 14px;
color: #6b7280;
margin-bottom: 16px;
line-height: 1.6;
flex: 1;
}
.yatra-activity-stats {
display: flex;
flex-direction: column;
gap: 12px;
margin-bottom: 20px;
padding: 16px;
background: #f9fafb;
border-radius: 8px;
}
.yatra-activity-stat {
display: flex;
align-items: center;
gap: 8px;
font-size: 14px;
color: #374151;
}
.yatra-activity-stat svg {
flex-shrink: 0;
}
.yatra-activity-stat span {
font-weight: 500;
}
.yatra-category-content {
padding: 24px;
}
.yatra-category-content p {
font-size: 14px;
color: #6b7280;
margin-bottom: 16px;
line-height: 1.6;
}
.yatra-category-stats {
display: flex;
flex-direction: column;
gap: 12px;
margin-bottom: 20px;
padding: 16px;
background: #f9fafb;
border-radius: 8px;
}
.yatra-category-stat {
display: flex;
align-items: center;
gap: 8px;
font-size: 14px;
color: #374151;
}
.yatra-category-stat svg {
flex-shrink: 0;
}
.yatra-category-stat span {
font-weight: 500;
}
.yatra-category-overlay {
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.7) 100%);
display: flex;
flex-direction: column;
align-items: center;
justify-content: flex-end;
padding: 24px;
text-align: center;
}
.yatra-category-overlay h3 {
font-size: 28px;
font-weight: 700;
color: #fff;
margin: 0;
}   .yatra-taxonomy-hero {
position: relative;
height: 350px;
background-size: cover; background-attachment: scroll;
background-position: center center;
border-radius: 0;
display: flex;
align-items: center;
justify-content: center;
margin-bottom: 0;
}
.yatra-taxonomy-hero-overlay {
position: absolute;
inset: 0;
background: linear-gradient(to bottom, rgba(0,0,0,0.5), rgba(0,0,0,0.8));
}
.yatra-taxonomy-hero-content {
position: relative;
z-index: 10;
text-align: center;
max-width: 800px;
padding: 0 20px;
}
.yatra-taxonomy-hero-content,
.yatra-taxonomy-hero-content * {
color: #ffffff !important;
}
.yatra-taxonomy-page .yatra-breadcrumb {
margin-bottom: 16px;
font-size: 14px;
}
.yatra-taxonomy-page .yatra-breadcrumb a {
color: rgba(255,255,255,0.9) !important;
text-decoration: none;
transition: color 0.2s ease;
}
.yatra-taxonomy-page .yatra-breadcrumb a:hover {
color: #ffffff !important;
text-decoration: underline;
}
.yatra-taxonomy-page .yatra-breadcrumb-sep {
margin: 0 8px;
color: rgba(255,255,255,0.7) !important;
}
.yatra-taxonomy-page .yatra-breadcrumb-current {
color: rgba(255,255,255,0.9) !important;
}
.yatra-taxonomy-title {
font-size: 48px;
font-weight: 700;
margin: 0 0 16px;
color: #ffffff !important;
text-shadow: 0 3px 10px rgba(0,0,0,0.6);
line-height: 1.2;
}
.yatra-taxonomy-description {
font-size: 18px;
line-height: 1.6;
color: rgba(255,255,255,0.95) !important;
margin: 0 0 20px;
}
.yatra-taxonomy-stats {
display: flex;
gap: 24px;
justify-content: center;
}
.yatra-taxonomy-trip-count {
display: flex;
align-items: center;
gap: 8px;
background: rgba(255,255,255,0.2);
backdrop-filter: blur(8px);
padding: 10px 20px;
border-radius: 50px;
font-weight: 500;
color: #ffffff !important;
}
.yatra-taxonomy-trip-count svg {
color: #ffffff !important;
stroke: #ffffff !important;
} .yatra-taxonomy-page .yatra-no-trips-found {
text-align: center;
padding: 80px 20px;
background: #f9fafb;
border-radius: 16px;
margin-top: 20px;
}
.yatra-taxonomy-page .yatra-no-trips-icon {
color: #9ca3af;
margin-bottom: 20px;
}
.yatra-taxonomy-page .yatra-no-trips-found h3 {
font-size: 24px;
font-weight: 600;
color: #111827;
margin: 0 0 12px;
}
.yatra-taxonomy-page .yatra-no-trips-found p {
color: #6b7280;
font-size: 16px;
margin: 0 0 24px;
max-width: 400px;
margin-left: auto;
margin-right: auto;
}
.yatra-btn-primary {
display: inline-block;
background: #059669;
color: #fff !important;
padding: 12px 28px;
border-radius: 8px;
font-weight: 600;
text-decoration: none;
transition: background 0.2s ease;
}
.yatra-btn-primary:hover {
background: #047857;
color: #fff !important;
} @media (max-width: 768px) {
.yatra-taxonomy-hero {
height: 280px;
}
.yatra-taxonomy-title {
font-size: 32px;
}
.yatra-taxonomy-description {
font-size: 16px;
}
} .yatra-trip-stats-row {
display: flex;
gap: 20px;
margin: 20px 0;
padding: 0;
}
.yatra-trip-stat {
display: flex;
align-items: center;
gap: 12px;
flex: 1;
min-width: 0;
}
.yatra-stat-icon {
width: 16px;
height: 16px;
border-radius: 4px;
display: flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
}
.yatra-stat-icon svg {
width: 16px;
height: 16px;
}
.yatra-stat-icon.duration {
background: linear-gradient(135deg, #3b82f6, #2563eb);
color: white;
}
.yatra-stat-icon.difficulty {
background: linear-gradient(135deg, #f59e0b, #d97316);
color: white;
}
.yatra-stat-icon.group {
background: linear-gradient(135deg, #10b981, #059669);
color: white;
}
.yatra-stat-icon.rating {
background: linear-gradient(135deg, #fbbf24, #f59e0b);
color: white;
}
.yatra-stat-content {
display: flex;
flex-direction: column;
}
.yatra-stat-value {
font-size: 16px;
font-weight: 700;
color: #1f2937;
line-height: 1;
}
.yatra-stat-label {
font-size: 12px;
color: #6b7280;
font-weight: 500;
line-height: 1;
} @media (max-width: 768px) {
.yatra-trip-stats-row {
gap: 12px;
margin: 16px 0;
}
.yatra-stat-icon {
width: 16px;
height: 16px;
}
.yatra-stat-value {
font-size: 14px;
}
.yatra-stat-label {
font-size: 11px;
}
}
@media (max-width: 480px) {
.yatra-trip-stats-row {
flex-direction: column;
gap: 8px;
padding: 8px 0;
}
.yatra-trip-stat {
justify-content: flex-start;
}
.yatra-stat-content {
flex-direction: row;
align-items: center;
gap: 4px;
}
.yatra-stat-label {
margin-top: 0;
}
} .yatra-trip-content {
padding: 20px 24px;
background: #ffffff;
} .yatra-trip-card-image {
position: relative;
overflow: hidden;
display: block;
height: 240px;
}
.yatra-trip-card-image::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: linear-gradient(to bottom, 
rgba(0, 0, 0, 0.2) 0%, 
rgba(0, 0, 0, 0.5) 100%);
z-index: 1;
pointer-events: none;
}
.yatra-trip-card-image img {
display: block;
width: 100%;
height: 100%;
object-fit: cover;
position: relative;
z-index: 0;
transition: opacity 0.3s ease;
}
.yatra-trip-card-image:hover img {
opacity: 0.9;
}
.yatra-trip-card-image .yatra-discount-badge,
.yatra-trip-card-image .yatra-group-discount-badge,
.yatra-trip-card-image .yatra-favorite-btn,
.yatra-trip-card-image .yatra-difficulty-overlay {
position: absolute;
z-index: 3;
}
.yatra-trip-title {
color: #000000 !important;
font-weight: 700;
font-size: 20px;
line-height: 1.3;
margin-bottom: 12px;
letter-spacing: -0.02em;
}
.yatra-trip-title-link {
color: #000000 !important;
text-decoration: none;
transition: all 0.2s ease;
display: block;
}
.yatra-trip-title-link:hover {
color: #000000 !important;
transform: translateY(-1px);
}
.yatra-trip-short-description {
color: #000000;
line-height: 1.6;
font-size: 14px;
margin-bottom: 16px;
} .yatra-trip-destinations,
.yatra-trip-activities,
.yatra-trip-categories {
color: #000000 !important;
margin-bottom: 14px;
padding: 8px 0;
border-bottom: 1px solid #f1f5f9;
font-size: 13px;
}
.yatra-trip-destinations:last-child,
.yatra-trip-activities:last-child,
.yatra-trip-categories:last-child {
border-bottom: none;
margin-bottom: 0;
}
.destination-link,
.activity-link,
.category-link {
color: #000000 !important;
text-decoration: none;
font-weight: 500;
transition: all 0.2s ease;
}
.destination-link:hover,
.activity-link:hover,
.category-link:hover {
color: #000000 !important;
text-decoration: underline;
background: rgba(0, 0, 0, 0.02);
padding: 2px 4px;
border-radius: 3px;
} .yatra-trip-rating-row {
color: #000000 !important;
display: flex;
align-items: center;
gap: 8px;
margin-bottom: 16px;
padding: 8px 0;
}
.yatra-rating-value {
color: #000000 !important;
font-weight: 600;
font-size: 16px;
}
.yatra-rating-count {
color: #000000 !important;
font-size: 12px;
opacity: 0.7;
} .yatra-trip-price {
color: #000000 !important;
margin-bottom: 16px;
padding: 12px 0;
}
.yatra-price-current {
color: #000000 !important;
font-weight: 800;
font-size: 24px;
line-height: 1;
}
.yatra-price-original {
color: #000000 !important;
text-decoration: line-through;
font-size: 16px;
opacity: 0.6;
margin-left: 8px;
}
.yatra-price-prefix {
color: #000000 !important;
font-size: 14px;
opacity: 0.7;
margin-right: 4px;
} .yatra-trip-stats-row {
display: flex;
flex-wrap: wrap;
gap: 20px;
padding: 16px 0;
margin: 16px 0;
}
.yatra-trip-stat {
display: flex;
align-items: center;
gap: 8px;
min-width: 0;
}
.yatra-stat-content {
display: flex;
flex-direction: column;
min-width: 0;
}
.yatra-stat-value {
color: #000000 !important;
font-weight: 600;
font-size: 14px;
line-height: 1.2;
}
.yatra-stat-label {
color: #000000 !important;
font-size: 12px;
line-height: 1.2;
margin-top: 1px;
opacity: 0.6;
} .yatra-trip-footer {
color: #475569 !important;
} .yatra-discount-badge {
background: linear-gradient(135deg, #dc2626, #b91c1c);
color: #ffffff !important;
font-weight: 600;
font-size: 12px;
padding: 4px 8px;
border-radius: 4px;
}
.yatra-group-discount-badge {
background: linear-gradient(135deg, #10b981, #059669);
color: #ffffff !important;
font-weight: 500;
font-size: 11px;
padding: 4px 8px;
border-radius: 4px;
} .yatra-favorite-btn {
color: #64748b !important;
background: rgba(255, 255, 255, 0.9);
border: 1px solid #e2e8f0;
border-radius: 6px;
padding: 6px;
transition: all 0.2s ease;
}
.yatra-favorite-btn:hover {
color: #dc2626 !important;
border-color: #dc2626;
background: rgba(255, 255, 255, 1);
}
.yatra-favorite-btn.active {
color: #dc2626 !important;
background: #fef2f2;
border-color: #dc2626;
} .yatra-difficulty-overlay {
background: rgba(59, 130, 246, 0.9);
backdrop-filter: blur(4px);
color: #ffffff !important;
font-weight: 600;
font-size: 12px;
padding: 6px 10px;
border-radius: 6px;
border: 1px solid rgba(255, 255, 255, 0.2);
box-shadow: 0 4px 12px rgba(59, 130, 246, 0.3);
} .yatra-block-editor-preview {
min-height: 48px;
}
.yatra-block-editor-preview .components-placeholder {
min-height: 120px;
} .wp-block-yatra-tour .yatra-tour-header .yatra-tour-title,
.wp-block-yatra-activity .yatra-activity-header .yatra-activity-title,
.wp-block-yatra-destination .yatra-destination-header .yatra-destination-title,
.editor-styles-wrapper .yatra-tour-header .yatra-tour-title,
.editor-styles-wrapper .yatra-activity-header .yatra-activity-title,
.editor-styles-wrapper .yatra-destination-header .yatra-destination-title,
.block-editor-block-list__layout .yatra-tour-header .yatra-tour-title,
.block-editor-block-list__layout .yatra-activity-header .yatra-activity-title,
.block-editor-block-list__layout .yatra-destination-header .yatra-destination-title {
margin: 0;
padding: 0;
color: #1f2937;
font-size: 1.875rem;
font-weight: 600;
line-height: 1.25;
letter-spacing: normal;
text-transform: none;
font-style: normal;
font-family: inherit;
}
.wp-block-yatra-tour .yatra-tour-header .yatra-tour-count,
.wp-block-yatra-activity .yatra-activity-header .yatra-activity-count,
.wp-block-yatra-destination .yatra-destination-header .yatra-destination-count,
.editor-styles-wrapper .yatra-tour-header .yatra-tour-count,
.editor-styles-wrapper .yatra-activity-header .yatra-activity-count,
.editor-styles-wrapper .yatra-destination-header .yatra-destination-count,
.block-editor-block-list__layout .yatra-tour-header .yatra-tour-count,
.block-editor-block-list__layout .yatra-activity-header .yatra-activity-count,
.block-editor-block-list__layout .yatra-destination-header .yatra-destination-count {
margin: 0;
color: #6b7280;
font-size: 0.875rem;
font-weight: 400;
line-height: 1.5;
}.yatra-stripe-container {
margin: 18px 0 0;
display: none; padding: 0;
border: none;
background: transparent;
box-shadow: none;
}
.yatra-method-switcher {
margin-bottom: 18px;
}
.yatra-method-switcher__header {
margin-bottom: 16px;
}
.yatra-label-eyebrow {
font-size: 0.75rem;
text-transform: uppercase;
letter-spacing: 0.1em;
color: #2563eb;
margin: 0 0 6px;
}
.yatra-method-switcher__title {
font-size: 1.3rem;
font-weight: 700;
color: #0f172a;
}
.yatra-method-switcher__helper {
margin: 4px 0 0;
color: #475569;
font-size: 0.92rem;
}
.yatra-method-switcher__buttons {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
gap: 10px;
}
.yatra-method-button {
display: flex;
align-items: center;
gap: 12px;
padding: 14px 12px;
border-radius: 14px;
border: 1px solid rgba(148, 163, 184, 0.4);
background: #f8fafc;
color: #0f172a;
box-shadow: 0 6px 18px rgba(15, 23, 42, 0.05);
transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
font-weight: 500;
}
.yatra-method-button .method-icon {
width: 40px;
height: 40px;
border-radius: 12px;
background: #ffffff;
display: inline-flex;
align-items: center;
justify-content: center;
color: #1e1b4b;
flex-shrink: 0;
}
.method-icon svg {
width: 22px;
height: 22px;
} .method-icon--google {
background: linear-gradient(135deg, #0f9d58, #1a73e8);
color: #fff;
}
.method-icon--google_pay {
background: #fff;
border: 1px solid #e2e8f0;
color: inherit;
}
.method-icon--google_pay svg {
width: 28px;
height: 28px;
max-width: none;
}
.method-icon--apple {
background: #0f172a;
color: #fff;
}
.method-icon--apple_pay {
background: #fff;
border: 1px solid #e2e8f0;
color: #000;
}
.method-icon--apple_pay svg {
width: 26px;
height: 26px;
max-width: none;
}
.yatra-method-button .method-content {
text-align: left;
display: flex;
flex-direction: column;
gap: 4px;
}
.yatra-method-button .method-label {
font-size: 0.9rem;
font-weight: 600;
}
.yatra-method-button .method-description {
font-size: 0.8rem;
color: #475569;
}
.method-tooltip {
position: relative;
z-index: 2;
margin-left: auto;
width: 26px;
height: 26px;
border-radius: 50%;
background: #f1f5f9;
display: inline-flex;
align-items: center;
justify-content: center;
color: #2563eb;
transition: background 0.15s ease;
flex-shrink: 0;
pointer-events: auto;
}
.method-tooltip svg {
width: 16px;
height: 16px;
}
.yatra-method-button.is-disabled .method-tooltip,
.yatra-method-button.is-pending .method-tooltip {
pointer-events: auto;
}
.method-tooltip:hover,
.method-tooltip:focus-visible {
background: #e0ecff;
}
.method-tooltip::after {
content: attr(data-tooltip);
position: absolute;
transform: translate(-50%, -8px);
left: 50%;
bottom: 100%;
background: #0f172a;
color: #fff;
padding: 8px 12px;
border-radius: 8px;
font-size: 0.75rem;
line-height: 1.35;
max-width: min(280px, 86vw);
width: max-content;
white-space: normal;
text-align: left;
box-shadow: 0 8px 24px rgba(15, 23, 42, 0.25);
opacity: 0;
pointer-events: none;
transition: opacity 0.15s ease, transform 0.15s ease;
z-index: 50;
}
.method-tooltip:hover::after,
.method-tooltip:focus-visible::after {
opacity: 1;
transform: translate(-50%, -14px);
}
.yatra-method-button.is-active {
border-color: #2563eb;
box-shadow: 0 10px 26px rgba(37, 99, 235, 0.2);
transform: translateY(-3px);
}
.yatra-method-button.is-disabled {
cursor: not-allowed;
background: #eef2f6;
border-color: #cbd5e1;
color: #64748b;
}
.yatra-method-button.is-disabled .method-label {
color: #64748b;
}
.yatra-method-button.is-disabled .method-icon {
opacity: 0.85;
}
.yatra-method-button.is-pending {
border-style: dashed;
border-color: #94a3b8;
}
.yatra-stripe-card-wrapper,
.yatra-stripe-payment-request-wrapper {
background: #fff;
border: 1px solid rgba(148, 163, 184, 0.3);
border-radius: 18px;
padding: 22px;
margin-top: 14px;
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6), 0 10px 25px rgba(15, 23, 42, 0.08);
}
.yatra-wallet-header {
display: flex;
align-items: center;
justify-content: space-between;
flex-wrap: wrap;
gap: 12px;
}
.yatra-wallet-eyebrow {
font-size: 0.75rem;
text-transform: uppercase;
letter-spacing: 0.1em;
color: #2563eb;
margin: 0;
}
.yatra-wallet-title {
font-size: 1.25rem;
margin: 0;
color: #0f172a;
}
.yatra-wallet-badges {
display: flex;
gap: 6px;
}
.wallet-badge {
padding: 6px 14px;
border-radius: 999px;
font-size: 0.8rem;
font-weight: 600;
color: #0f172a;
background: #eef2ff;
box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}
.wallet-badge--apple {
background: #0f172a;
color: #fff;
}
.wallet-badge--google {
background: linear-gradient(135deg, #1a73e8, #34a853);
color: #fff;
}
.yatra-wallet-desc {
margin: 10px 0 14px;
color: #475569;
font-size: 0.9rem;
}
.yatra-wallet-status {
margin-top: 18px;
font-size: 0.88rem;
color: #475569;
padding: 12px 14px;
border-radius: 12px;
background: #edf2ff;
}
.yatra-wallet-status.is-success {
background: #ecfdf5;
color: #047857;
}
.yatra-wallet-status.is-warning {
background: #fff7ed;
color: #9a3412;
}
.yatra-wallet-status.is-error {
background: #fef2f2;
color: #b91c1c;
}
.wallet-placeholder {
border: 1px dashed #cbd5f5;
border-radius: 14px;
padding: 16px;
color: #64748b;
text-align: center;
background: rgba(248, 250, 255, 0.8);
}
.yatra-stripe-card-element {
padding: 14px;
border: 1px solid rgba(148, 163, 184, 0.6);
border-radius: 14px;
background: #fff;
margin-bottom: 12px;
transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
.yatra-stripe-card-element--focus {
border-color: #2563eb;
box-shadow: 0 0 0 1px rgba(37, 99, 235, 0.6);
}
.yatra-stripe-card-element--invalid {
border-color: #ef4444;
}
.yatra-stripe-errors {
color: #ef4444;
font-size: 0.875rem;
line-height: 1.25rem;
margin-top: 0.5rem;
display: none;
}
.yatra-stripe-errors.visible {
display: block;
} .yatra-spinner {
display: inline-block;
width: 1em;
height: 1em;
border: 2px solid rgba(255, 255, 255, 0.3);
border-radius: 50%;
border-top-color: #fff;
animation: yatra-spin 1s ease-in-out infinite;
margin-right: 8px;
vertical-align: middle;
}
@keyframes yatra-spin {
to { transform: rotate(360deg); }
} @media (max-width: 480px) {
.yatra-stripe-card-element {
padding: 10px;
}
}.yatra-single-trip {
font-family: var(--yatra-font-family, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif);
line-height: 1.6;
color: var(--yatra-text-primary, #1a1a1a);
width: 100%;
min-height: 100vh;
} .yatra-single-trip > .yatra-trip-hero-new,
.yatra-single-trip > .yatra-trip-tags,
.yatra-single-trip > .yatra-trip-quick-facts-section,
.yatra-single-trip > .yatra-trip-container {
width: 100%;
max-width: var(--yatra-container-max-width, 1300px);
margin-left: auto;
margin-right: auto;
}
.yatra-single-trip > * {
max-width: 100%;
}
.yatra-single-trip * {
box-sizing: border-box;
}
.yatra-single-trip img {
max-width: 100%;
height: auto;
}  :root {
--yatra-section-padding: 60px;
--yatra-section-gap: 48px;
--yatra-container-padding: 20px;
--yatra-element-gap: 24px;
--yatra-small-gap: 16px;
--yatra-tiny-gap: 12px;
--yatra-mini-gap: 8px;
--yatra-micro-gap: 6px;
} @media (max-width: 768px) {
:root {
--yatra-section-padding: 40px;
--yatra-section-gap: 32px;
--yatra-container-padding: 16px;
--yatra-element-gap: 20px;
--yatra-small-gap: 12px;
--yatra-tiny-gap: 8px;
--yatra-mini-gap: 6px;
--yatra-micro-gap: 4px;
}
}
@media (max-width: 480px) {
:root {
--yatra-section-padding: 32px;
--yatra-section-gap: 24px;
--yatra-container-padding: 12px;
--yatra-element-gap: 16px;
--yatra-small-gap: 12px;
--yatra-tiny-gap: 8px;
--yatra-mini-gap: 6px;
--yatra-micro-gap: 4px;
--yatra-hero-mobile-padding-top: 12px;
--yatra-hero-mobile-padding-bottom: 16px;
}
}
@media (min-width: 481px) and (max-width: 768px) {
:root {
--yatra-hero-mobile-padding-top: 16px;
--yatra-hero-mobile-padding-bottom: 20px;
}
} .yatra-single-trip {
padding: 0;
} .yatra-single-trip > .yatra-trip-hero-new,
.yatra-single-trip > .yatra-trip-tags,
.yatra-single-trip > .yatra-trip-quick-facts-section,
.yatra-single-trip > .yatra-trip-attributes,
.yatra-single-trip > .yatra-trip-container,
.yatra-single-trip > .yatra-group-discounts-section,
.yatra-single-trip > .yatra-similar-section {
width: 100%;
max-width: var(--yatra-container-max-width, 1300px);
margin-left: auto;
margin-right: auto;
padding-left: var(--yatra-container-padding);
padding-right: var(--yatra-container-padding);
} .yatra-single-trip .yatra-reviews-section {
width: 100%;
max-width: var(--yatra-container-max-width, 1300px);
margin-left: auto;
margin-right: auto;
padding-left: var(--yatra-container-padding);
padding-right: var(--yatra-container-padding);
box-sizing: border-box;
align-self: stretch;
min-width: 0;
} .yatra-trip-hero-new {
padding-top: var(--yatra-section-padding);
padding-bottom: var(--yatra-section-gap);
}
.yatra-trip-tags {
padding-top: 0;
padding-bottom: var(--yatra-section-gap);
}
.yatra-trip-quick-facts-section,
.yatra-trip-attributes {
padding-top: 0;
padding-bottom: var(--yatra-section-gap);
background: transparent;
}
.yatra-trip-container {
padding-top: 0;
padding-bottom: var(--yatra-section-gap);
} .yatra-trip-container:has(+ .yatra-reviews-section) {
padding-bottom: 0;
} .yatra-group-discounts-section {
padding-top: 0;
padding-bottom: var(--yatra-section-gap);
} .yatra-btn {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 8px;
padding: 14px 28px;
background: #3b82f6;
color: #fff;
border: none;
border-radius: 8px;
font-size: 15px;
font-weight: 600;
cursor: pointer;
text-decoration: none;
transition: all 0.3s ease;
}
.yatra-btn svg {
flex-shrink: 0;
}
.yatra-btn:hover {
background: #2563eb;
color: #fff;
transform: translateY(-1px);
box-shadow: 0 4px 12px rgba(59, 130, 246, 0.3);
} .yatra-icon {
width: 24px;
height: 24px;
display: inline-block;
flex-shrink: 0;
}
.yatra-icon-sm {
width: 20px;
height: 20px;
}
.yatra-icon-lg {
width: 32px;
height: 32px;
}
.yatra-icon-xl {
width: 48px;
height: 48px;
}
.yatra-booking-button svg,
.yatra-booking-enquiry-button svg,
.yatra-card-book-btn svg {
display: inline-block !important;
visibility: visible !important;
opacity: 1 !important;
color: inherit !important;
stroke: currentColor !important;
fill: none !important;
}
#check-availability-btn svg,
button.yatra-booking-button svg,
button.yatra-booking-enquiry-button svg,
button.yatra-card-book-btn svg,
a.yatra-card-book-btn svg {
display: inline-block !important;
visibility: visible !important;
opacity: 1 !important;
width: 18px !important;
height: 18px !important;
flex-shrink: 0 !important;
}
#check-availability-btn svg,
button.yatra-card-book-btn svg,
button.yatra-booking-button svg {
color: #fff !important;
stroke: #fff !important;
fill: none !important;
stroke-width: 2 !important;
}
.yatra-booking-button svg path,
.yatra-booking-enquiry-button svg path,
.yatra-card-book-btn svg path {
stroke: currentColor !important;
}
#check-availability-btn svg path,
button.yatra-card-book-btn svg path,
button.yatra-booking-button svg path,
button.yatra-booking-enquiry-button svg path {
stroke: currentColor !important;
}
#check-availability-btn svg path,
button.yatra-card-book-btn svg path,
button.yatra-booking-button svg path {
stroke: #fff !important;
} .yatra-sticky-nav {
background: #fff;
border-bottom: 1px solid #e5e7eb;
box-shadow: 0 2px 8px rgba(0,0,0,0.05);
position: fixed;
top: 0;
left: 0;
right: 0;
z-index: 100;
transform: translateY(-100%);
opacity: 0;
transition: transform 0.3s ease, opacity 0.3s ease;
pointer-events: none;
} .admin-bar .yatra-sticky-nav {
top: 32px;
}
@media screen and (max-width: 782px) {
.admin-bar .yatra-sticky-nav {
top: 46px;
}
}
.yatra-sticky-nav.visible {
transform: translateY(0);
opacity: 1;
pointer-events: auto;
}
.yatra-sticky-nav-container {
max-width: var(--yatra-container-max-width, 1300px);
margin: 0 auto;
padding: 0 var(--yatra-container-padding);
display: flex;
align-items: center;
gap: var(--yatra-element-gap);
overflow-x: auto;
-webkit-overflow-scrolling: touch;
}
.yatra-sticky-nav-item {
display: flex;
align-items: center;
gap: var(--yatra-mini-gap);
padding: 16px 0;
color: #6b7280;
text-decoration: none;
font-size: 14px;
font-weight: 500;
white-space: nowrap;
border-bottom: 3px solid transparent;
transition: all 0.3s ease;
cursor: pointer;
}
.yatra-sticky-nav-item:hover,
.yatra-sticky-nav-item.active {
color: #3b82f6;
border-bottom-color: #3b82f6;
}
.yatra-sticky-nav-item svg {
width: 18px;
height: 18px;
}
.yatra-sticky-nav-price {
margin-left: auto;
display: flex;
align-items: center;
gap: 8px;
padding: 16px 0;
color: #3b82f6;
font-size: 18px;
font-weight: 700;
white-space: nowrap;
}
.yatra-sticky-nav-price svg {
width: 20px;
height: 20px;
}
.yatra-sticky-nav-cta {
margin-left: auto;
display: flex;
align-items: center;
}
.yatra-sticky-nav-cta .yatra-btn {
padding: 8px 16px;
font-size: 14px;
font-weight: 600;
white-space: nowrap;
}
.yatra-sticky-nav-cta .yatra-btn-primary {
background: #3b82f6;
color: white;
border-color: #3b82f6;
}
.yatra-sticky-nav-cta .yatra-btn-primary:hover {
background: #2563eb;
border-color: #2563eb;
color: white;
} .yatra-trip-hero-new {
max-width: 100%;
margin: 0 auto;
padding-top: var(--yatra-section-padding);
padding-bottom: var(--yatra-section-gap);
}
.yatra-hero-header {
margin-bottom: 24px;
}
.yatra-hero-breadcrumb {
display: flex;
align-items: center;
gap: 8px;
margin-bottom: 12px;
font-size: 13px;
color: #6b7280;
}
.yatra-hero-breadcrumb a {
color: #3b82f6;
text-decoration: none;
transition: color 0.2s ease;
}
.yatra-hero-breadcrumb a:hover {
color: #2563eb;
text-decoration: underline;
}
.yatra-hero-breadcrumb-separator {
color: #9ca3af;
margin: 0 4px;
}
.yatra-hero-breadcrumb-current {
color: #374151;
font-weight: 500;
}
.yatra-hero-meta {
display: flex;
align-items: center;
flex-wrap: wrap;
gap: 12px;
margin-bottom: 16px;
}
.yatra-trip-hero-title-new {
font-size: 2.5rem;
font-weight: 700;
color: #111827;
margin: 0 0 16px 0;
line-height: 1.2;
letter-spacing: -0.01em;
}
.yatra-hero-rating {
display: flex;
align-items: center;
gap: 12px;
}
.yatra-hero-location {
display: flex;
align-items: center;
gap: 6px;
color: #6b7280;
font-size: 15px;
font-weight: 500;
}
.yatra-hero-duration {
display: flex;
align-items: center;
gap: 6px;
color: #6b7280;
font-size: 15px;
font-weight: 500;
}
.yatra-rating-stars {
display: flex;
gap: 2px;
font-size: 20px;
line-height: 1;
} .yatra-rating-stars > .yatra-star,
.yatra-rating-stars .yatra-star {
display: inline-block;
font-size: 20px;
color: #d1d5db;
}
.yatra-rating-stars .yatra-star.filled {
color: var(--yatra-star, #fbbf24);
}
.yatra-no-rating .yatra-star {
color: #d1d5db;
}
.yatra-no-reviews {
color: #9ca3af;
font-style: italic;
}
.yatra-rating-stars .yatra-star.half {
background: linear-gradient(
90deg,
var(--yatra-star, #fbbf24) 50%,
#d1d5db 50%
);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
color: transparent;
}
.yatra-rating-number {
font-size: 18px;
font-weight: 700;
color: #111827;
}
.yatra-rating-text {
font-size: 14px;
color: #6b7280;
}
.yatra-hero-images {
display: grid;
grid-template-columns: 3fr 1fr;
gap: 16px;
margin-bottom: 24px;
align-items: start;
width: 100%;
}
.yatra-hero-main-image {
position: relative;
border-radius: 16px;
overflow: hidden;
background: #f3f4f6;
width: 100%;
height: 500px;
} .yatra-hero-media-badges {
position: absolute;
top: 15px;
left: 15px;
display: flex;
gap: 8px;
z-index: 10;
}
.yatra-media-badge {
display: inline-flex;
align-items: center;
gap: 4px;
background: rgba(17, 24, 39, 0.55);
color: rgba(255, 255, 255, 0.95);
padding: 4px 8px;
border-radius: 999px;
font-size: 12px;
font-weight: 500;
letter-spacing: 0.2px;
border: none;
box-shadow: none;
backdrop-filter: none;
transition: none;
cursor: default;
user-select: none;
pointer-events: none;
}
.yatra-media-badge:hover {
background: rgba(17, 24, 39, 0.55);
}
.yatra-media-badge-icon {
width: 14px !important;
height: 14px !important;
flex-shrink: 0;
}
.yatra-media-badge-icon svg {
width: 100% !important;
height: 100% !important;
display: block !important;
}
.yatra-media-badge-count {
font-weight: 600;
} .yatra-media-badge-image {
background: rgba(59, 130, 246, 0.8);
}
.yatra-media-badge-video {
background: rgba(239, 68, 68, 0.8);
}
.yatra-media-badge-youtube {
background: rgba(255, 0, 0, 0.8);
}
.yatra-media-badge-tour {
background: rgba(16, 185, 129, 0.8);
}
.yatra-media-badge-document {
background: rgba(245, 158, 11, 0.8);
} .yatra-hero-media-switcher {
position: absolute;
bottom: 15px;
left: 15px;
display: flex;
gap: 8px;
z-index: 10;
}
.yatra-media-switcher-btn {
display: flex;
align-items: center;
gap: 6px;
background: rgba(255, 255, 255, 0.9);
border: 1px solid rgba(0, 0, 0, 0.2);
color: #374151;
padding: 8px 12px;
border-radius: 20px;
font-size: 12px;
font-weight: 500;
cursor: pointer;
transition: all 0.3s ease;
backdrop-filter: blur(4px);
}
.yatra-media-switcher-btn:hover {
background: rgba(255, 255, 255, 0.95);
transform: translateY(-1px);
}
.yatra-media-switcher-btn.yatra-media-switcher-active {
background: #3b82f6;
color: white;
border-color: #3b82f6;
}
.yatra-media-switcher-icon {
width: 16px !important;
height: 16px !important;
flex-shrink: 0;
}
.yatra-media-switcher-icon svg {
width: 100% !important;
height: 100% !important;
display: block !important;
} .yatra-hero-main-img-link::before {
content: '';
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: rgba(0, 0, 0, 0.15);
z-index: 1;
pointer-events: none;
transition: background 0.3s ease;
}
.yatra-hero-main-img-link:hover::before {
background: rgba(0, 0, 0, 0.25);
} .yatra-media-overlay {
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
z-index: 5;
}
.yatra-play-button {
cursor: pointer;
transition: transform 0.3s ease;
}
.yatra-play-button:hover {
transform: scale(1.1);
}
.yatra-document-overlay {
background: rgba(0, 0, 0, 0.5);
}
.yatra-document-info {
display: flex;
align-items: center;
gap: 16px;
padding: 20px;
color: white;
text-align: left;
}
.yatra-document-icon {
flex-shrink: 0;
}
.yatra-document-details {
flex: 1;
}
.yatra-document-title {
font-size: 16px;
font-weight: 600;
margin-bottom: 4px;
line-height: 1.2;
}
.yatra-document-size {
font-size: 14px;
opacity: 0.8;
} .yatra-media-play-overlay {
pointer-events: auto;
cursor: pointer;
} .yatra-media-youtube-overlay {
background: rgba(0, 0, 0, 0.4);
display: flex;
align-items: center;
justify-content: center;
pointer-events: auto;
cursor: pointer;
}
.yatra-youtube-play-button {
cursor: pointer;
transition: all 0.3s ease;
filter: drop-shadow(0 4px 12px rgba(0, 0, 0, 0.3));
}
.yatra-youtube-play-button:hover {
transform: scale(1.15);
filter: drop-shadow(0 6px 16px rgba(0, 0, 0, 0.4));
}
.yatra-youtube-play-button svg {
display: block;
} .yatra-media-tour-overlay {
background: rgba(0, 0, 0, 0.5);
display: flex;
align-items: center;
justify-content: center;
pointer-events: auto;
cursor: pointer;
}
.yatra-tour-info {
display: flex;
flex-direction: column;
align-items: center;
gap: 16px;
padding: 24px;
color: white;
text-align: center;
background: rgba(16, 185, 129, 0.15);
border-radius: 16px;
border: 2px solid rgba(16, 185, 129, 0.4);
backdrop-filter: blur(8px);
max-width: 300px;
}
.yatra-tour-icon {
flex-shrink: 0;
filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.3));
}
.yatra-tour-details {
flex: 1;
}
.yatra-tour-type {
font-size: 15px;
opacity: 0.9;
margin-bottom: 12px;
color: rgba(255, 255, 255, 0.9);
}
.yatra-tour-action {
font-size: 14px;
font-weight: 600;
padding: 10px 20px;
background: rgba(16, 185, 129, 0.9);
border-radius: 24px;
border: 2px solid rgba(255, 255, 255, 0.3);
color: white;
transition: all 0.3s ease;
}
.yatra-tour-info:hover .yatra-tour-action {
background: rgba(16, 185, 129, 1);
transform: scale(1.05);
} @media (max-width: 768px) {
.yatra-hero-media-badges {
top: 10px;
left: 10px;
gap: 6px;
}
.yatra-media-badge {
padding: 4px 8px;
font-size: 11px;
}
.yatra-hero-media-switcher {
bottom: 10px;
left: 10px;
gap: 6px;
flex-wrap: wrap;
}
.yatra-media-switcher-btn {
padding: 6px 10px;
font-size: 11px;
}
.yatra-media-switcher-icon {
width: 14px !important;
height: 14px !important;
} .yatra-youtube-play-button svg {
width: 70px !important;
height: 70px !important;
}
.yatra-tour-info {
max-width: 250px;
padding: 20px;
gap: 12px;
}
.yatra-tour-icon svg {
width: 60px !important;
height: 60px !important;
}
.yatra-tour-title {
font-size: 18px;
}
.yatra-tour-type {
font-size: 14px;
}
.yatra-tour-action {
font-size: 13px;
padding: 8px 16px;
}
}
@media (max-width: 480px) {
.yatra-hero-media-badges {
top: 8px;
left: 8px;
gap: 4px;
}
.yatra-media-badge {
padding: 3px 6px;
font-size: 10px;
}
.yatra-hero-media-switcher {
bottom: 8px;
left: 8px;
right: 8px;
gap: 4px;
}
.yatra-media-switcher-btn {
padding: 5px 8px;
font-size: 10px;
flex: 1;
justify-content: center;
}
.yatra-media-switcher-btn span {
display: none;
}
.yatra-media-switcher-icon {
width: 16px !important;
height: 16px !important;
margin: 0;
} .yatra-youtube-play-button svg {
width: 60px !important;
height: 60px !important;
}
.yatra-tour-info {
max-width: 200px;
padding: 16px;
gap: 10px;
}
.yatra-tour-icon svg {
width: 50px !important;
height: 50px !important;
}
.yatra-tour-title {
font-size: 16px;
}
.yatra-tour-type {
font-size: 13px;
}
.yatra-tour-action {
font-size: 12px;
padding: 6px 12px;
}
} .yatra-hero-side-images {
transition: opacity 0.3s ease, width 0.3s ease;
}
.yatra-hero-side-images.yatra-media-non-image {
display: none;
} .yatra-hero-images.yatra-media-full-width .yatra-hero-main-image {
grid-column: 1 / -1;
} .yatra-hero-book-now-container {
position: absolute;
bottom: 20px;
right: 20px;
z-index: 25;
pointer-events: auto;
}
.yatra-hero-book-now-btn {
display: flex;
align-items: center;
gap: 8px;
background: #3b82f6;
color: white;
padding: 12px 20px;
border-radius: 8px;
text-decoration: none;
font-weight: 600;
font-size: 14px;
transition: all 0.3s ease;
box-shadow: 0 4px 12px rgba(59, 130, 246, 0.3);
}
.yatra-hero-book-now-btn:hover {
background: #2563eb;
transform: translateY(-2px);
box-shadow: 0 6px 20px rgba(59, 130, 246, 0.4);
} @media (max-width: 768px) {
.yatra-hero-book-now-container {
bottom: 10px;
right: 10px;
}
.yatra-hero-book-now-btn {
padding: 10px 16px;
font-size: 13px;
}
}
@media (max-width: 480px) { .yatra-hero-book-now-container {
bottom: 56px;
right: 10px;
z-index: 30;
}
}
.yatra-hero-book-now-btn.is-disabled,
.yatra-hero-book-now-btn[aria-disabled="true"] {
opacity: 0.6;
cursor: not-allowed;
pointer-events: none;
} .yatra-hero-main-img {
width: 100%;
height: 100%;
object-fit: cover;
display: block;
}
.yatra-hero-discount-tag {
position: absolute;
top: 16px;
right: 16px;
background: #ef4444;
color: #fff;
padding: 5px 10px;
border-radius: 6px;
font-size: 14px;
font-weight: 700;
text-transform: uppercase;
letter-spacing: 0.5px;
z-index: 10;
box-shadow: 0 2px 8px rgba(239, 68, 68, 0.3);
}
.yatra-hero-book-now-btn {
background: #10b981;
color: #fff;
border: none;
padding: 14px 28px;
border-radius: 8px;
font-size: 16px;
font-weight: 700;
cursor: pointer;
text-decoration: none;
display: inline-flex;
align-items: center;
justify-content: center;
gap: 8px;
transition: all 0.3s ease;
z-index: 10;
box-shadow: 0 4px 12px rgba(16, 185, 129, 0.3);
}
.yatra-hero-book-now-btn svg {
flex-shrink: 0;
}
.yatra-hero-book-now-btn:hover {
background: #059669;
transform: translateY(-2px);
box-shadow: 0 6px 16px rgba(16, 185, 129, 0.4);
color: #fff;
}
.yatra-hero-side-images {
display: flex;
flex-direction: column;
gap: 16px;
height: 500px;
align-items: stretch;
}
.yatra-side-image-item {
position: relative;
border-radius: 12px;
overflow: hidden;
background: #f3f4f6;
cursor: pointer;
transition: transform 0.3s ease;
width: 100%;
flex: 1;
min-height: 0;
display: flex;
}
.yatra-side-image-item img {
width: 100%;
height: 100%;
object-fit: cover;
display: block;
}
.yatra-side-image-item:hover {
transform: scale(1.02);
}
.yatra-favorite-btn {
position: absolute !important;
top: 12px !important;
right: 12px !important;
width: 40px !important;
height: 40px !important;
background: #ffffff !important;
border: 1px solid rgba(0, 0, 0, 0.1) !important;
border-radius: 50% !important;
display: flex !important;
align-items: center !important;
justify-content: center !important;
cursor: pointer !important;
color: #6b7280 !important;
transition: all 0.3s ease !important;
z-index: 100 !important;
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15) !important;
padding: 0 !important;
margin: 0 !important;
opacity: 1 !important;
visibility: visible !important;
}
.yatra-favorite-btn:hover {
background: #ffffff !important;
color: #ef4444 !important;
transform: scale(1.1) !important;
border-color: #ef4444 !important;
box-shadow: 0 4px 12px rgba(239, 68, 68, 0.3) !important;
}
.yatra-favorite-btn svg {
width: 20px !important;
height: 20px !important;
stroke-width: 2 !important;
display: block !important;
fill: none !important;
}
.yatra-favorite-btn svg path {
stroke: currentColor !important;
}
.yatra-view-all-photos-btn {
position: absolute;
bottom: 12px;
right: 12px;
background: #fff;
color: #111827;
border: none;
padding: 10px 16px;
border-radius: 8px;
font-size: 13px;
font-weight: 600;
cursor: pointer;
display: flex;
align-items: center;
gap: 6px;
transition: all 0.3s ease;
z-index: 10;
box-shadow: 0 2px 8px rgba(0,0,0,0.15);
}
.yatra-view-all-photos-btn:hover {
background: #f9fafb;
color: #111827;
transform: translateY(-2px);
box-shadow: 0 4px 12px rgba(0,0,0,0.2);
}
.yatra-view-all-photos-btn svg {
width: 16px;
height: 16px;
} .yatra-trip-hero {
position: relative;
width: 100%;
height: 70vh;
min-height: 600px;
max-height: 800px;
overflow: hidden;
background: linear-gradient(135deg, #1e3a8a 0%, #3b82f6 100%);
}
.yatra-trip-hero-slider {
width: 100%;
height: 100%;
position: relative;
}
.yatra-trip-hero-slide {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
opacity: 0;
transition: opacity 0.8s ease-in-out;
}
.yatra-trip-hero-slide.active {
opacity: 1;
z-index: 1;
}
.yatra-trip-hero-image {
width: 100%;
height: 100%;
object-fit: cover;
display: block;
}
.yatra-trip-hero-overlay {
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: linear-gradient(to bottom, rgba(0,0,0,0.2) 0%, rgba(0,0,0,0.6) 100%);
display: flex;
align-items: center;
justify-content: flex-start;
padding: 60px 20px;
z-index: 2;
}
.yatra-trip-hero-content {
max-width: 1200px;
width: 100%;
margin: 0 auto;
color: #fff;
position: relative;
text-align: left;
}
.yatra-trip-hero-badges {
display: flex;
flex-wrap: wrap;
gap: 12px;
margin-bottom: 20px;
justify-content: flex-start;
}
.yatra-trip-hero-badge {
display: inline-flex;
align-items: center;
gap: 6px;
padding: 8px 16px;
background: rgba(255,255,255,0.15);
backdrop-filter: blur(10px);
border-radius: 24px;
font-size: 13px;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.5px;
border: 1px solid rgba(255,255,255,0.2);
}
.yatra-trip-hero-title {
font-size: 3.75rem;
font-weight: 800;
line-height: 1.1;
margin: 0 0 20px 0;
text-shadow: 0 2px 20px rgba(0,0,0,0.4);
letter-spacing: -0.02em;
text-align: left;
}
.yatra-trip-hero-subtitle {
font-size: 1.375rem;
font-weight: 400;
opacity: 0.95;
margin: 0 0 32px 0;
max-width: 800px;
line-height: 1.6;
text-align: left;
}
.yatra-trip-hero-actions {
display: flex;
gap: 16px;
flex-wrap: wrap;
margin: 0;
justify-content: flex-start;
}
.yatra-hero-button {
padding: 14px 32px;
border-radius: 8px;
font-size: 16px;
font-weight: 600;
text-decoration: none;
display: inline-flex;
align-items: center;
gap: 8px;
transition: all 0.3s ease;
border: 2px solid transparent;
}
.yatra-hero-button-primary {
background: #fff;
color: #1e3a8a;
border-color: #fff;
}
.yatra-hero-button-primary:hover {
background: #f0f0f0;
transform: translateY(-2px);
box-shadow: 0 8px 25px rgba(0,0,0,0.2);
}
.yatra-hero-button-secondary {
background: transparent;
color: #fff;
border-color: rgba(255,255,255,0.5);
}
.yatra-hero-button-secondary:hover {
background: rgba(255,255,255,0.1);
border-color: #fff;
}
.yatra-gallery-count {
font-size: 14px;
opacity: 0.9;
font-weight: 500;
}
.yatra-hero-gallery-play {
position: absolute;
bottom: 40px;
right: 40px;
z-index: 10;
background: rgba(255,255,255,0.95);
backdrop-filter: blur(10px);
border: 2px solid rgba(255,255,255,0.3);
border-radius: 50%;
width: 80px;
height: 80px;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
gap: 4px;
cursor: pointer;
transition: all 0.3s ease;
color: #3b82f6;
box-shadow: 0 4px 20px rgba(0,0,0,0.2);
}
.yatra-hero-gallery-play:hover {
background: #fff;
transform: scale(1.1);
box-shadow: 0 6px 30px rgba(0,0,0,0.3);
}
.yatra-hero-gallery-play svg {
width: 32px;
height: 32px;
}
.yatra-hero-gallery-play span {
font-size: 11px;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.5px;
margin-top: 2px;
}
.yatra-gallery-play-btn {
cursor: pointer;
border: none;
font-family: inherit;
}
.yatra-trip-tags-container {
display: flex;
flex-wrap: wrap;
gap: var(--yatra-element-gap);
align-items: center;
}
.yatra-trip-tag {
display: flex;
align-items: center;
gap: 8px;
padding: 8px 16px;
background: #e5e7eb;
border-radius: 20px;
font-size: 14px;
}
.yatra-trip-tag-label {
color: #6b7280;
font-weight: 600;
text-transform: uppercase;
font-size: 11px;
letter-spacing: 0.5px;
}
.yatra-trip-tag-value {
color: #111827;
font-weight: 500;
}
.yatra-trip-tag-value a {
color: #059669;
text-decoration: none;
transition: color 0.2s ease;
}
.yatra-trip-tag-value a:hover {
color: #047857;
text-decoration: underline;
} .yatra-spec-sheet {
--yatra-spec-line: #d6d3d1;
border: 1px solid var(--yatra-spec-line);
border-radius: 12px;
background: #fff;
padding: 1px;
box-sizing: border-box;
overflow: hidden;
}
.yatra-spec-sheet--quick-facts {
width: 100%;
margin: 0;
} .yatra-trip-quick-facts-section .yatra-spec-sheet--quick-facts {
width: 100%;
}
.yatra-trip-attributes .yatra-spec-sheet--attributes-grid {
width: 100%;
} .yatra-spec-sheet > .yatra-trip-quick-facts,
.yatra-spec-sheet > .yatra-attributes-grid {
width: 100%;
display: grid;
grid-template-columns: repeat(auto-fit, minmax(136px, 1fr));
gap: 1px;
align-items: stretch;
padding: 0;
margin: 0;
background: var(--yatra-spec-line, #d6d3d1);
border: none;
border-radius: 11px;
overflow: hidden;
}
.yatra-spec-sheet > .yatra-attributes-grid {
grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
} .yatra-trip-quick-facts {
width: 100%;
}
.yatra-quick-fact {
display: flex;
flex-direction: row;
align-items: flex-start;
text-align: left;
gap: 12px;
padding: 14px 16px;
background: #fff;
border: none;
border-radius: 0;
transition: background-color 0.15s ease;
min-width: 0;
min-height: 100%;
box-sizing: border-box;
align-self: stretch;
}
.yatra-quick-fact:hover {
background: #fafaf9;
}
.yatra-quick-fact-icon {
width: auto;
height: auto;
min-width: 28px;
min-height: 28px;
padding: 0;
background: transparent;
border-radius: 0;
display: flex;
align-items: center;
justify-content: center;
color: #57534e;
flex-shrink: 0;
overflow: visible;
}
.yatra-quick-fact-icon svg {
display: block;
width: 22px;
height: 22px;
min-width: 22px;
min-height: 22px;
flex-shrink: 0;
overflow: visible;
opacity: 0.92;
}
.yatra-quick-fact-icon svg[fill="none"] {
stroke: currentColor;
}
.yatra-quick-fact-icon svg[fill="currentColor"] {
stroke: none;
opacity: 1;
}
.yatra-quick-fact-content {
flex: 1;
min-width: 0;
padding-top: 1px;
}
.yatra-quick-fact-label {
font-size: 11px;
color: #78716c;
text-transform: none;
letter-spacing: 0.01em;
margin-bottom: 3px;
font-weight: 500;
line-height: 1.25;
display: block;
}
.yatra-quick-fact-value {
font-size: 15px;
font-weight: 600;
color: #1c1917;
margin: 0;
line-height: 1.35;
display: block;
}
.yatra-trip-quick-facts .yatra-price-current {
color: #059669;
font-weight: 600;
}
.yatra-trip-quick-facts .yatra-price-original {
color: #94a3b8;
text-decoration: line-through;
font-weight: 400;
font-size: 0.88em;
margin-left: 4px;
}
.yatra-trip-quick-facts .yatra-rating-display {
display: flex;
align-items: center;
gap: 6px;
flex-wrap: wrap;
}
.yatra-trip-quick-facts .yatra-rating-number {
font-weight: 700;
color: #0f172a;
}
.yatra-trip-quick-facts .yatra-rating-stars {
display: inline-flex;
gap: 1px;
font-size: 0.85rem;
line-height: 1;
}
.yatra-trip-quick-facts .star-filled {
color: #fbbf24;
}
.yatra-trip-quick-facts .star-empty {
color: #cbd5e1;
}
.yatra-trip-quick-facts .yatra-review-count {
font-size: 12px;
color: #64748b;
font-weight: 500;
}
.yatra-quick-fact-price {
font-size: 15px;
font-weight: 600;
color: #1c1917;
line-height: 1.35;
margin: 0;
display: block;
}
.yatra-quick-fact-price-label {
font-size: 10px;
color: #94a3b8;
font-weight: 400;
margin-top: 2px;
display: block;
} .yatra-trip-container {
display: grid;
grid-template-columns: 1fr 400px;
gap: var(--yatra-section-gap);
align-items: start;
padding-top: 0;
} .yatra-trip-main {
min-width: 0;
} .yatra-trip-sidebar-column {
min-width: 0;
width: 100%;
}
.yatra-trip-sidebar-column .yatra-trip-sidebar {
position: sticky;
top: 0;
height: fit-content;
}
.yatra-trip-section {
background: #ffffff;
border-radius: 8px;
padding: 40px;
margin-bottom: 24px;
border: 1px solid #e5e7eb;
}
.yatra-trip-section-title {
font-size: 28px;
font-weight: 600;
color: #111827;
margin: 0 0 24px 0;
display: flex;
align-items: center;
gap: 12px;
line-height: 1.2;
}
.yatra-trip-section-title-icon {
width: 24px;
height: 24px;
color: #6b7280;
flex-shrink: 0;
} .yatra-trip-description {
font-size: 17px;
line-height: 1.8;
color: #374151;
margin-bottom: 40px;
}
.yatra-trip-description p {
margin-bottom: 20px;
}
.yatra-trip-description p:last-child {
margin-bottom: 0;
} .yatra-trip-short-description-lead {
font-size: 1.125rem;
line-height: 1.7;
color: #475569;
font-weight: 500;
margin-bottom: 24px;
padding: 20px;
background: linear-gradient(135deg, #f8fafc 0%, #f1f5f9 100%);
border-radius: 12px;
border-left: 4px solid #3b82f6;
}
@media (prefers-color-scheme: dark) {
.yatra-trip-short-description-lead {
color: #cbd5e1;
background: linear-gradient(135deg, #1e293b 0%, #334155 100%);
border-left-color: #60a5fa;
}
}
@media (max-width: 768px) {
.yatra-trip-short-description-lead {
font-size: 1rem;
padding: 16px;
margin-bottom: 20px;
}
}
.yatra-trip-highlights {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
gap: 20px;
margin-top: 40px;
}
.yatra-highlight-item {
display: flex;
align-items: flex-start;
gap: 16px;
padding: 20px;
background: #f9fafb;
border-radius: 12px;
border-left: 4px solid #3b82f6;
transition: all 0.3s ease;
}
.yatra-highlight-item:hover {
background: #f3f4f6;
transform: translateX(4px);
}
.yatra-highlight-icon {
width: 24px;
height: 24px;
color: #3b82f6;
flex-shrink: 0;
margin-top: 2px;
}
.yatra-highlight-text {
flex: 1;
font-size: 15px;
color: #111827;
margin: 0;
line-height: 1.6;
} .yatra-trip-features {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
gap: 24px;
margin-top: 32px;
}
.yatra-feature-card {
text-align: center;
padding: 24px;
background: #f9fafb;
border-radius: 12px;
border: 1px solid #e5e7eb;
transition: all 0.3s ease;
}
.yatra-feature-card:hover {
background: #fff;
border-color: #3b82f6;
box-shadow: 0 4px 12px rgba(59, 130, 246, 0.15);
transform: translateY(-4px);
}
.yatra-feature-icon {
width: 48px;
height: 48px;
margin: 0 auto 12px;
color: #3b82f6;
}
.yatra-feature-title {
font-size: 16px;
font-weight: 600;
color: #111827;
margin: 0 0 8px 0;
}
.yatra-feature-desc {
font-size: 14px;
color: #6b7280;
margin: 0;
line-height: 1.5;
}  .yatra-section-header-with-actions {
display: flex;
align-items: center;
justify-content: space-between;
gap: 20px;
margin-bottom: 24px;
flex-wrap: wrap;
}
.yatra-section-header-with-actions .yatra-trip-section-title {
margin-bottom: 0;
}
.yatra-itinerary-actions {
display: flex;
gap: 12px;
}
.yatra-toggle-all-btn {
display: inline-flex;
align-items: center;
gap: 6px;
padding: 8px 16px;
background: #fff;
border: 1px solid #e5e7eb;
border-radius: 8px;
font-size: 13px;
font-weight: 500;
color: #374151;
cursor: pointer;
transition: all 0.2s;
}
.yatra-toggle-all-btn:hover {
background: #f3f4f6;
border-color: #d1d5db;
}
.yatra-toggle-all-btn svg {
color: #6b7280;
}
.yatra-itinerary-timeline {
display: flex;
flex-direction: column;
gap: 24px;
}
.yatra-itinerary-day {
background: #fff;
border: 1px solid #e5e7eb;
border-radius: 8px;
overflow: hidden;
}
.yatra-itinerary-day-header {
display: flex;
align-items: center;
gap: 16px;
padding: 16px 20px;
background: #f9fafb;
border-bottom: 1px solid #e5e7eb;
cursor: pointer;
transition: background 0.2s ease;
}
.yatra-itinerary-day-header:hover {
background: #f3f4f6;
}
.yatra-day-badge {
font-size: 14px;
font-weight: 700;
color: #fff;
background: #3b82f6;
padding: 6px 14px;
border-radius: 6px;
white-space: nowrap;
}
.yatra-day-title {
font-size: 18px;
font-weight: 600;
color: #111827;
margin: 0;
flex: 1;
}
.yatra-day-toggle {
width: 36px;
height: 36px;
min-width: 36px;
display: flex !important;
align-items: center;
justify-content: center;
background: #fff;
border: 1px solid #e5e7eb;
border-radius: 8px;
cursor: pointer;
transition: all 0.2s;
flex-shrink: 0;
padding: 0;
}
.yatra-day-toggle:hover {
background: #f3f4f6;
border-color: #d1d5db;
}
.yatra-day-toggle .yatra-chevron-icon {
transition: transform 0.25s ease;
color: #6b7280;
width: 20px;
height: 20px;
}
.yatra-day-toggle svg {
width: 20px;
height: 20px;
color: #6b7280;
stroke: currentColor;
} .yatra-itinerary-day-content {
padding: var(--yatra-element-gap);
}
.yatra-itinerary-day:not(.is-day-expanded) .yatra-itinerary-day-content {
display: none;
}
.yatra-itinerary-day.is-day-expanded .yatra-itinerary-day-content {
display: block;
}
.yatra-itinerary-day:not(.is-day-expanded) .yatra-day-toggle .yatra-chevron-icon {
transform: rotate(-90deg);
}
.yatra-itinerary-day.is-day-expanded .yatra-day-toggle .yatra-chevron-icon {
transform: rotate(0deg);
}
.yatra-day-description {
margin-bottom: var(--yatra-element-gap);
color: #4b5563;
font-size: 15px;
line-height: 1.6;
}
.yatra-toggle-all-btn .collapse-icon {
display: none;
}
.yatra-toggle-all-btn.is-all-expanded .expand-icon {
display: none;
}
.yatra-toggle-all-btn.is-all-expanded .collapse-icon {
display: block;
} .yatra-itinerary-trip-gallery {
display: none;
} .yatra-entries-timeline {
position: relative;
padding-left: 32px;
}
.yatra-entries-timeline::before {
content: '';
position: absolute;
left: 8px;
top: 0;
bottom: 0;
width: 2px;
background: #e5e7eb;
}
.yatra-entry-item {
position: relative;
margin-bottom: 20px;
}
.yatra-entry-item:last-child {
margin-bottom: 0;
}
.yatra-entry-timeline-dot {
position: absolute;
left: -28px;
top: 20px;
width: 12px;
height: 12px;
background: var(--entry-color, #3b82f6);
border-radius: 50%;
border: 3px solid #fff;
box-shadow: 0 0 0 2px var(--entry-color, #3b82f6);
z-index: 2;
}
.yatra-entry-card {
background: #f9fafb;
border: 1px solid #e5e7eb;
border-radius: 12px;
padding: 20px;
transition: all 0.2s;
}
.yatra-entry-card:hover {
border-color: var(--entry-color, #3b82f6);
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}
.yatra-entry-header {
display: flex;
align-items: flex-start;
gap: 14px;
margin-bottom: 12px;
}
.yatra-entry-icon {
width: 40px;
height: 40px;
display: flex;
align-items: center;
justify-content: center;
border-radius: 10px;
flex-shrink: 0;
}
.yatra-entry-icon svg {
width: 20px;
height: 20px;
}
.yatra-entry-info {
flex: 1;
min-width: 0;
}
.yatra-entry-type {
font-size: 12px;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.5px;
display: block;
margin-bottom: 4px;
}
.yatra-entry-title {
font-size: 16px;
font-weight: 600;
color: #111827;
margin: 0;
}
.yatra-entry-time {
display: flex;
align-items: center;
gap: 6px;
font-size: 13px;
color: #6b7280;
background: #fff;
padding: 6px 12px;
border-radius: 6px;
border: 1px solid #e5e7eb;
white-space: nowrap;
}
.yatra-entry-time svg {
color: #9ca3af;
}
.yatra-entry-description {
font-size: 14px;
line-height: 1.6;
color: #4b5563;
margin: 0 0 12px 0;
}
.yatra-entry-cost {
display: inline-flex;
align-items: center;
gap: 6px;
padding: 6px 12px;
background: linear-gradient(135deg, #10b981 0%, #059669 100%);
border-radius: 8px;
margin-bottom: 12px;
color: white;
font-size: 14px;
font-weight: 600;
}
.yatra-entry-cost svg {
flex-shrink: 0;
color: white;
}
.yatra-entry-cost .yatra-cost-amount {
font-weight: 700;
}
.yatra-entry-cost .yatra-cost-label {
font-size: 12px;
font-weight: 500;
opacity: 0.9;
}
.yatra-entry-meta {
display: flex;
flex-wrap: wrap;
gap: 16px;
margin-bottom: 12px;
}
.yatra-entry-meta-item {
display: flex;
align-items: center;
gap: 6px;
font-size: 13px;
color: #6b7280;
}
.yatra-entry-meta-item svg {
color: #9ca3af;
}
.yatra-entry-included {
display: flex;
flex-wrap: wrap;
gap: 8px;
padding-top: 12px;
border-top: 1px solid #e5e7eb;
}
.yatra-included-tag {
display: inline-flex;
align-items: center;
gap: 4px;
font-size: 12px;
color: #059669;
background: #ecfdf5;
padding: 4px 10px;
border-radius: 4px;
}
.yatra-included-tag svg {
color: #10b981;
} .yatra-itinerary-summary .yatra-day-badge {
background: #8b5cf6;
}
.yatra-summary-content {
padding: 20px;
background: #f9fafb;
border-radius: 12px;
}
.yatra-summary-content p {
font-size: 15px;
color: #374151;
margin-bottom: 16px;
}
.yatra-summary-list {
list-style: none;
padding: 0;
margin: 0;
}
.yatra-summary-list li {
padding: 12px 0;
border-bottom: 1px solid #e5e7eb;
font-size: 14px;
color: #4b5563;
}
.yatra-summary-list li:last-child {
border-bottom: none;
}
.yatra-summary-list li strong {
color: #111827;
font-weight: 600;
}  .admin-bar .yatra-mobile-sticky-sidebar {
bottom: 32px;
}
@media screen and (max-width: 782px) {
.admin-bar .yatra-mobile-sticky-sidebar {
bottom: 46px;
}
}
.yatra-mobile-sticky-sidebar.hidden {
transform: translateY(100%);
opacity: 0;
}
.yatra-mobile-sticky-content {
display: flex;
flex-direction: column;
padding: 12px;
gap: 8px;
background: #ffffff;
min-height: auto;
padding-bottom: calc(12px + env(safe-area-inset-bottom, 0px));
position: relative;
padding-top: 14px;
padding-right: 56px; } .yatra-mobile-row-1 {
display: grid;
grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
align-items: center;
gap: 0;
width: 100%;
overflow: visible;
} .yatra-mobile-row-1 > .yatra-mobile-date-section,
.yatra-mobile-row-1 > .yatra-mobile-travelers-section {
width: 100%;
min-width: 0;
}
.yatra-mobile-row-1 .yatra-mobile-field-btn,
.yatra-mobile-row-1 .yatra-booking-field-select,
.yatra-mobile-row-1 .yatra-mobile-booking-field {
width: 100%;
}
.yatra-mobile-row-1 > .yatra-mobile-date-section .yatra-mobile-field-btn {
border-top-right-radius: 0;
border-bottom-right-radius: 0;
border-right: 0;
}
.yatra-mobile-row-1 > .yatra-mobile-travelers-section .yatra-booking-field-select,
.yatra-mobile-row-1 > .yatra-mobile-travelers-section .yatra-mobile-booking-field {
border-top-left-radius: 0;
border-bottom-left-radius: 0;
}
.yatra-mobile-row-1::-webkit-scrollbar {
display: none; } .yatra-mobile-row-2 {
display: grid;
grid-template-columns: 1fr 1fr;
align-items: center;
gap: 8px;
padding-top: 8px;
border-top: 1px solid #e5e7eb;
} .yatra-mobile-row-3 {
display: flex;
align-items: center;
justify-content: space-between;
gap: 8px;
flex-wrap: nowrap;
} .yatra-mobile-price-section {
order: 2;
}
.yatra-mobile-date-section {
order: 3;
display: flex;
align-items: center;
min-width: 0;
width: 100%;
touch-action: manipulation;
}
.yatra-mobile-travelers-section {
order: 4;
min-width: 0;
}
.yatra-mobile-action-section {
order: 6;
}
.yatra-mobile-trust-badge {
order: 7;
}
.yatra-mobile-action-buttons {
order: 8;
position: absolute;
top: 10px;
right: 10px;
z-index: 6;
} .yatra-mobile-booking-field {
display: flex;
align-items: center;
gap: 6px;
background: #f9fafb;
border: 1px solid #e5e7eb;
border-radius: 6px;
padding: 0 8px;
box-sizing: border-box;
min-width: 0;
min-height: 44px;
height: 44px;
max-height: 44px;
flex-shrink: 0;
touch-action: manipulation;
} .yatra-mobile-field-btn {
display: flex;
align-items: center;
gap: 6px;
width: 100%;
min-height: 44px;
height: 44px;
padding: 0 10px;
background: #f9fafb;
border: 1px solid #e5e7eb;
border-radius: 10px;
cursor: pointer;
box-sizing: border-box;
-webkit-tap-highlight-color: transparent;
}
.yatra-mobile-field-btn:active {
transform: translateY(0.5px);
}
.yatra-mobile-field-btn input {
pointer-events: none; }
.yatra-mobile-field-btn .yatra-mobile-datepicker-input {
width: 100% !important;
flex: 1 1 auto !important;
min-width: 0 !important;
} .yatra-mobile-field-btn .flatpickr-input,
.yatra-mobile-field-btn input.flatpickr-input,
.yatra-mobile-field-btn input.flatpickr-alt-input,
.yatra-mobile-field-btn input[type="text"] {
flex: 1 1 auto;
width: 100%;
min-width: 0;
}
.yatra-mobile-field-btn .yatra-mobile-field-icon {
width: 18px;
height: 18px;
}
.yatra-mobile-field-btn .yatra-mobile-arrow {
flex-shrink: 0;
}
.yatra-mobile-field-btn .yatra-mobile-arrow {
margin-left: auto;
} .yatra-mobile-compact-datepicker {
display: flex;
align-items: center;
gap: 4px;
background: #f9fafb;
border: 1px solid #e5e7eb;
border-radius: 6px;
padding: 0 6px;
box-sizing: border-box;
width: 100%;
max-width: 100%;
min-width: 0;
min-height: 44px;
height: 44px;
max-height: 44px;
flex-shrink: 1;
cursor: pointer;
transition: all 0.2s ease;
position: relative;
z-index: 2;
touch-action: manipulation;
-webkit-tap-highlight-color: transparent;
}
.yatra-mobile-compact-datepicker:hover {
background: #f3f4f6;
border-color: #d1d5db;
}
.yatra-mobile-compact-datepicker .yatra-mobile-field-icon {
display: flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
}
.yatra-mobile-compact-datepicker .yatra-mobile-icon {
width: 14px;
height: 14px;
}
.yatra-mobile-datepicker-input {
border: none;
background: transparent;
font-size: 14px;
line-height: 1.2;
color: #374151;
outline: none;
min-width: 0;
width: 100%;
flex: 1 1 auto;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
font-weight: 500;
cursor: pointer;
padding: 0;
margin: 0;
min-height: 0 !important;
height: auto;
max-height: 100%;
vertical-align: middle;
-webkit-appearance: none;
appearance: none;
touch-action: manipulation;
} .yatra-mobile-field-btn .yatra-mobile-datepicker-input.flatpickr-input,
.yatra-mobile-field-btn .flatpickr-input {
width: 100% !important;
flex: 1 1 auto !important;
min-width: 0 !important;
background: transparent !important;
padding: 0 !important;
margin: 0 !important;
}
.yatra-mobile-datepicker-input::placeholder {
color: #9ca3af;
}
.yatra-mobile-arrow {
width: 12px;
height: 12px;
color: #6b7280;
flex-shrink: 0;
transition: transform 0.2s ease;
}
.yatra-mobile-compact-datepicker:hover .yatra-mobile-arrow {
transform: translateY(1px);
} .yatra-mobile-date-section .yatra-booking-field-select {
display: flex;
align-items: center;
gap: 8px;
background: #f9fafb;
border: 1px solid #e5e7eb;
border-radius: 8px;
padding: 8px 12px;
min-width: 0;
flex-shrink: 0;
position: relative;
cursor: pointer;
} .yatra-mobile-travelers-section .yatra-booking-field-select {
display: flex;
align-items: center;
gap: 8px;
background: #f9fafb;
border: 1px solid #e5e7eb;
border-radius: 10px;
padding: 0 10px;
min-height: 44px;
height: 44px;
max-height: 44px;
min-width: 0;
width: 100%;
position: relative;
cursor: pointer;
}
.yatra-mobile-travelers-section .yatra-participants-display {
padding: 0;
font-size: 14px;
color: #374151;
min-width: 0;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
} .yatra-mobile-participants.active .yatra-booking-quantity-selector,
.yatra-mobile-travelers-section .yatra-booking-quantity-selector {
top: auto;
bottom: 100%;
margin-top: 0;
margin-bottom: 8px;
max-height: min(60vh, 360px);
overflow-y: auto;
}
.yatra-mobile-date-section .yatra-booking-field-icon {
display: flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
}
.yatra-mobile-date-section .yatra-booking-select {
border: none;
background: transparent;
font-size: 14px;
color: #374151;
outline: none;
min-width: 80px;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
font-weight: 500;
cursor: pointer;
flex: 1;
}
.yatra-mobile-date-section .yatra-booking-select::placeholder {
color: #9ca3af;
}
.yatra-mobile-date-section .yatra-select-arrow {
width: 16px;
height: 16px;
color: #6b7280;
flex-shrink: 0;
transition: transform 0.2s ease;
}
.yatra-mobile-date-section .yatra-booking-field-select:hover .yatra-select-arrow {
transform: translateY(1px);
} @media (max-width: 480px) {
.yatra-mobile-date-section .yatra-booking-field-select {
padding: 6px 8px;
gap: 6px;
}
.yatra-mobile-date-section .yatra-booking-select {
font-size: 12px;
min-width: 60px;
}
.yatra-mobile-date-section .yatra-select-arrow {
width: 14px;
height: 14px;
}
}
@media (max-width: 360px) {
.yatra-mobile-date-section .yatra-booking-field-select {
padding: 4px 6px;
gap: 4px;
}
.yatra-mobile-date-section .yatra-booking-select {
font-size: 11px;
min-width: 50px;
}
.yatra-mobile-date-section .yatra-select-arrow {
width: 12px;
height: 12px;
}
}
.yatra-mobile-field-icon {
display: flex;
align-items: center;
justify-content: center;
flex-shrink: 0;
}
.yatra-mobile-icon {
width: 18px;
height: 18px;
color: #6b7280;
} .yatra-mobile-field-icon svg,
.yatra-mobile-close-icon svg {
width: 18px;
height: 18px;
display: block;
stroke: currentColor;
fill: none;
}
.yatra-mobile-datepicker,
.yatra-mobile-travelers-display {
border: none;
background: transparent;
font-size: 12px;
line-height: 1.2;
color: #374151;
outline: none;
min-width: 80px;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
font-weight: 500;
}
.yatra-mobile-datepicker::placeholder {
color: #9ca3af;
} .yatra-mobile-quantity-controls {
display: flex;
align-items: center;
gap: 6px;
}
.yatra-mobile-quantity-btn {
display: flex;
align-items: center;
justify-content: center;
width: 34px;
height: 34px;
background: #f3f4f6;
border: 1px solid #d1d5db;
border-radius: 6px;
cursor: pointer;
transition: all 0.2s ease;
}
.yatra-mobile-quantity-btn:hover {
background: #e5e7eb;
border-color: #9ca3af;
}
.yatra-mobile-quantity-btn svg {
width: 14px;
height: 14px;
color: #374151;
}
.yatra-mobile-quantity-input {
width: 40px;
text-align: center;
border: none;
background: transparent;
font-size: 15px;
font-weight: 600;
color: #374151;
outline: none;
} .yatra-mobile-check-btn {
display: flex;
align-items: center;
justify-content: center;
gap: 4px;
padding: 0 10px;
box-sizing: border-box;
min-height: 36px;
height: 36px;
max-height: 36px;
font-size: 12px;
font-weight: 600;
border-radius: 6px;
border: none;
cursor: pointer;
transition: all 0.2s ease;
white-space: nowrap;
background: #3b82f6;
color: white;
box-shadow: 0 1px 3px rgba(59, 130, 246, 0.3);
flex-shrink: 0;
touch-action: manipulation;
}
.yatra-mobile-check-btn:hover {
background: #2563eb;
box-shadow: 0 2px 4px rgba(59, 130, 246, 0.4);
} .yatra-mobile-availability-compact {
background: rgba(255, 255, 255, 0.1);
border-top: 1px solid rgba(255, 255, 255, 0.2);
padding: 8px 16px;
text-align: center;
}
.yatra-mobile-availability-info {
display: flex;
align-items: center;
justify-content: center;
gap: 6px;
}
.yatra-mobile-availability-count {
font-size: 11px;
font-weight: 600;
color: rgba(255, 255, 255, 0.9);
} .yatra-mobile-price-section {
flex-shrink: 0;
position: relative;
background: #f9fafb;
border: 1px solid #e5e7eb;
border-radius: 8px;
padding: 10px 14px;
}
.yatra-mobile-price-info {
display: flex;
flex-direction: column;
align-items: flex-start;
gap: 4px;
}
.yatra-mobile-price-label {
font-size: 11px;
font-weight: 600;
color: #6b7280;
text-transform: uppercase;
letter-spacing: 0.5px;
line-height: 1;
}
.yatra-mobile-price-amount {
font-size: 18px;
font-weight: 700;
color: #111827;
line-height: 1.2;
}
.yatra-mobile-price-original {
font-size: 13px;
font-weight: 500;
color: #9ca3af;
text-decoration: line-through;
line-height: 1;
}
.yatra-mobile-contact-pricing {
color: #6b7280 !important;
font-size: 16px !important;
} .yatra-mobile-group-badge {
display: flex;
align-items: center;
justify-content: center;
width: 32px;
height: 32px;
background: #f0fdf4;
border: 1px solid #bbf7d0;
border-radius: 8px;
flex-shrink: 0;
}
.yatra-mobile-group-badge svg {
color: #16a34a;
} .yatra-mobile-discount-badge {
position: absolute;
top: -10px;
right: -10px;
background: #dc2626;
color: white;
font-size: 10px;
font-weight: 700;
padding: 3px 8px;
border-radius: 6px;
white-space: nowrap;
box-shadow: 0 2px 6px rgba(220, 38, 38, 0.3);
z-index: 1;
} .yatra-mobile-trust-badge {
display: flex;
align-items: center;
gap: 6px;
background: #f0fdf4;
border: 1px solid #bbf7d0;
border-radius: 8px;
padding: 6px 12px;
flex-shrink: 0;
}
.yatra-mobile-trust-badge svg {
color: #16a34a;
flex-shrink: 0;
}
.yatra-mobile-trust-badge span {
font-size: 12px;
font-weight: 600;
color: #15803d;
white-space: nowrap;
} .yatra-mobile-info-bar {
display: flex;
align-items: center;
justify-content: center;
gap: 16px;
background: #f9fafb;
border-top: 1px solid #e5e7eb;
padding: 8px 16px;
min-height: 32px;
} .yatra-mobile-info-section {
display: flex;
align-items: center;
gap: 12px;
flex: 1;
justify-content: center;
}
.yatra-mobile-info-item {
display: flex;
align-items: center;
gap: 4px;
font-size: 12px;
color: #6b7280;
font-weight: 500;
white-space: nowrap;
}
.yatra-mobile-info-item svg {
color: #9ca3af;
flex-shrink: 0;
}
.yatra-mobile-info-icon {
width: 12px;
height: 12px;
flex-shrink: 0;
color: #9ca3af;
} .yatra-mobile-action-section {
display: flex;
align-items: center;
gap: 6px;
flex-shrink: 0;
}
.yatra-mobile-book-btn,
.yatra-mobile-enquire-btn {
display: flex;
align-items: center;
gap: 6px;
padding: 8px 16px;
font-size: 14px;
font-weight: 600;
border-radius: 6px;
border: none;
cursor: pointer;
transition: all 0.2s ease;
white-space: nowrap;
}
.yatra-mobile-book-btn {
background: #3b82f6;
color: white;
}
.yatra-mobile-book-btn:hover {
background: #2563eb;
}
.yatra-mobile-enquire-btn {
background: #f3f4f6;
color: #374151;
border: 1px solid #d1d5db;
padding: 0 10px;
box-sizing: border-box;
min-height: 44px;
height: 44px;
max-height: 44px;
font-size: 14px;
flex-shrink: 0;
align-items: center;
justify-content: center;
touch-action: manipulation;
} .yatra-mobile-row-2 .yatra-mobile-check-btn,
.yatra-mobile-row-2 .yatra-mobile-enquire-btn {
width: 100%;
justify-content: center;
min-height: 44px;
height: 44px;
font-size: 14px;
}
@media (max-width: 480px) { .yatra-mobile-row-1 {
display: grid;
grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
align-items: center;
gap: 0;
width: 100%;
overflow-x: visible;
} .yatra-mobile-group-badge {
grid-column: 1 / -1;
justify-content: center;
}
.yatra-mobile-date-section {
max-width: none;
width: 100%;
min-width: 0;
}
.yatra-mobile-travelers-section {
width: 100%;
min-width: 0;
} }
.yatra-mobile-enquire-btn:hover {
background: #e5e7eb;
border-color: #9ca3af;
color: #111827;
}
.yatra-mobile-btn-icon {
width: 14px;
height: 14px;
flex-shrink: 0;
} .yatra-mobile-action-buttons {
display: flex;
align-items: center;
gap: 6px;
flex-shrink: 0;
} .yatra-mobile-close-btn {
display: flex;
align-items: center;
justify-content: center;
width: 44px;
height: 44px;
background: #f3f4f6;
border: 1px solid #d1d5db;
border-radius: 8px;
cursor: pointer;
transition: all 0.2s ease;
z-index: 10;
position: relative;
}
.yatra-mobile-close-btn:hover {
background: #e5e7eb;
border-color: #9ca3af;
}
.yatra-mobile-close-btn:active {
transform: scale(0.95);
}
.yatra-mobile-close-icon {
width: 18px;
height: 18px;
color: #6b7280;
}
.yatra-mobile-close-btn .yatra-mobile-close-icon {
display: block;
stroke: currentColor;
fill: none;
} .yatra-mobile-close-fallback {
display: block;
width: 18px;
height: 18px;
line-height: 18px;
text-align: center;
font-size: 22px;
font-weight: 700;
color: #6b7280;
transform: translateY(-1px);
user-select: none;
} .yatra-mobile-sticky-sidebar.user-closed {
transform: translateY(100%) !important;
opacity: 0 !important;
pointer-events: none;
}
.yatra-mobile-sidebar-details {
max-height: 0;
overflow: hidden;
transition: max-height 0.3s ease;
background: #f9fafb;
border-top: 1px solid #e5e7eb;
}
.yatra-mobile-sidebar-details.expanded {
max-height: 60vh;
overflow-y: auto;
}
.yatra-mobile-details-content {
padding: 20px;
} @media (prefers-color-scheme: dark) {
.yatra-mobile-sticky-sidebar {
background: #1f2937 !important;
border-top-color: #374151 !important;
}
.yatra-mobile-sticky-content {
background: #1f2937;
}
.yatra-mobile-booking-field {
background: #374151;
border-color: #4b5563;
}
.yatra-mobile-price-section {
background: #374151;
border-color: #4b5563;
}
.yatra-mobile-price-amount {
color: #f9fafb;
}
.yatra-mobile-price-label {
color: #9ca3af;
}
.yatra-mobile-price-original {
color: #6b7280;
}
.yatra-mobile-datepicker,
.yatra-mobile-travelers-display {
color: #e5e7eb;
}
.yatra-mobile-datepicker::placeholder {
color: #6b7280;
}
.yatra-mobile-icon {
color: #9ca3af;
}
.yatra-mobile-quantity-btn {
background: #4b5563;
border-color: #6b7280;
}
.yatra-mobile-quantity-btn:hover {
background: #6b7280;
border-color: #9ca3af;
}
.yatra-mobile-quantity-btn svg {
color: #d1d5db;
}
.yatra-mobile-quantity-input {
color: #e5e7eb;
}
.yatra-mobile-trust-badge {
background: #14532d;
border-color: #166534;
}
.yatra-mobile-trust-badge svg {
color: #22c55e;
}
.yatra-mobile-trust-badge span {
color: #86efac;
}
.yatra-mobile-close-btn {
background: #4b5563;
border-color: #6b7280;
}
.yatra-mobile-close-btn:hover {
background: #6b7280;
border-color: #9ca3af;
}
.yatra-mobile-close-icon {
color: #9ca3af;
}
.yatra-mobile-info-bar {
background: #374151;
border-top-color: #4b5563;
}
.yatra-mobile-info-item {
color: #d1d5db;
}
.yatra-mobile-info-item svg {
color: #9ca3af;
}
.yatra-mobile-enquire-btn {
background: #4b5563;
color: #e5e7eb;
border-color: #6b7280;
}
.yatra-mobile-enquire-btn:hover {
background: #6b7280;
border-color: #9ca3af;
color: #f9fafb;
}
} @media (max-width: 480px) {
.yatra-mobile-sticky-content {
padding: 8px;
gap: 6px;
padding-right: calc(8px + 56px); }
.yatra-mobile-row-1,
.yatra-mobile-row-2,
.yatra-mobile-row-3 {
gap: 6px;
}
.yatra-mobile-booking-field {
padding: 0 6px;
min-height: 34px;
height: 34px;
max-height: 34px;
}
.yatra-mobile-compact-date,
.yatra-mobile-compact-datepicker {
padding: 0 6px;
gap: 4px;
min-height: 34px;
height: 34px;
max-height: 34px;
}
.yatra-mobile-check-btn,
.yatra-mobile-enquire-btn {
min-height: 34px;
height: 34px;
max-height: 34px;
}
.yatra-mobile-price-section {
padding: 4px 6px;
}
.yatra-mobile-price-amount {
font-size: 14px;
}
.yatra-mobile-datepicker {
font-size: 11px;
min-width: 40px;
}
.yatra-mobile-check-btn,
.yatra-mobile-enquire-btn {
padding: 0 6px;
font-size: 10px;
}
.yatra-mobile-check-btn {
gap: 3px;
}
.yatra-mobile-enquire-btn {
gap: 3px;
}
.yatra-mobile-trust-badge {
padding: 2px 4px;
}
.yatra-mobile-trust-badge span {
font-size: 8px;
}
.yatra-mobile-close-btn {
width: 20px;
height: 20px;
}
.yatra-mobile-group-badge {
width: 20px;
height: 20px;
}
.yatra-mobile-group-badge svg {
width: 8px;
height: 8px;
}
} .yatra-mobile-travelers-section .yatra-booking-field-select,
.yatra-mobile-travelers-section .yatra-participants-select {
position: relative;
z-index: 2;
}
.yatra-mobile-participants .yatra-booking-quantity-selector,
.yatra-mobile-participants.active .yatra-booking-quantity-selector,
.yatra-mobile-travelers-section .yatra-booking-quantity-selector {
top: auto !important;
bottom: 100% !important;
margin-top: 0 !important;
margin-bottom: 8px !important;
z-index: 2000;
} .yatra-mobile-participants.active .yatra-booking-quantity-selector {
position: fixed !important;
left: 12px !important;
right: 12px !important;
width: auto !important;
max-width: 560px;
margin-left: auto !important;
margin-right: auto !important;
bottom: calc(92px + env(safe-area-inset-bottom, 0px)) !important;
box-sizing: border-box;
} @media (max-width: 360px) {
.yatra-mobile-sticky-content {
padding: 6px;
gap: 4px;
}
.yatra-mobile-row-1,
.yatra-mobile-row-2,
.yatra-mobile-row-3 {
gap: 4px;
}
.yatra-mobile-booking-field {
padding: 0 4px;
min-height: 32px;
height: 32px;
max-height: 32px;
}
.yatra-mobile-compact-date,
.yatra-mobile-compact-datepicker {
padding: 0 4px;
gap: 3px;
min-height: 32px;
height: 32px;
max-height: 32px;
}
.yatra-mobile-check-btn,
.yatra-mobile-enquire-btn {
min-height: 32px;
height: 32px;
max-height: 32px;
}
.yatra-mobile-price-section {
padding: 3px 4px;
}
.yatra-mobile-price-amount {
font-size: 12px;
}
.yatra-mobile-datepicker {
font-size: 10px;
min-width: 35px;
}
.yatra-mobile-check-btn,
.yatra-mobile-enquire-btn {
padding: 0 4px;
font-size: 9px;
}
.yatra-mobile-check-btn {
gap: 2px;
}
.yatra-mobile-enquire-btn {
gap: 2px;
}
.yatra-mobile-trust-badge {
display: none; }
.yatra-mobile-close-btn {
width: 18px;
height: 18px;
}
.yatra-mobile-group-badge {
width: 18px;
height: 18px;
}
.yatra-mobile-group-badge svg {
width: 6px;
height: 6px;
}
} .yatra-mobile-sticky-sidebar {
position: fixed !important;
bottom: 0 !important;
left: 0 !important;
right: 0 !important;
background: #ffffff !important;
border-top: 1px solid #e5e7eb !important;
box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1) !important;
z-index: 9999 !important;
transform: translateY(0) !important;
transition: transform 0.3s ease, opacity 0.3s ease !important;
display: block !important; visibility: visible !important; opacity: 1 !important; min-height: 70px !important; max-height: none !important;
overflow: visible !important;
} @media only screen and (min-width: 769px) {
.yatra-mobile-sticky-sidebar {
display: none !important;
visibility: hidden !important;
opacity: 0 !important;
transform: translateY(100%) !important;
}
} @media (max-width: 768px) {
.yatra-itinerary-day-header {
padding: 16px;
}
.yatra-day-title {
font-size: 16px;
}
.yatra-itinerary-day-content {
padding: 16px;
}
.yatra-entries-timeline {
padding-left: 24px;
}
.yatra-entry-header {
flex-wrap: wrap;
}
.yatra-entry-time {
width: 100%;
justify-content: flex-start;
margin-top: 8px;
}
} .yatra-trip-pricing {
display: grid;
gap: 24px;
}
.yatra-pricing-card {
border: 2px solid #e5e7eb;
border-radius: 16px;
padding: 32px;
transition: all 0.3s ease;
background: #fff;
}
.yatra-pricing-card:hover {
border-color: #3b82f6;
box-shadow: 0 8px 30px rgba(59, 130, 246, 0.15);
transform: translateY(-4px);
}
.yatra-pricing-header {
display: flex;
justify-content: space-between;
align-items: flex-start;
margin-bottom: 20px;
padding-bottom: 20px;
border-bottom: 2px solid #f3f4f6;
}
.yatra-pricing-title {
font-size: 20px;
font-weight: 700;
color: #111827;
margin: 0;
}
.yatra-pricing-amount {
font-size: 36px;
font-weight: 800;
color: #3b82f6;
margin: 0;
line-height: 1;
}
.yatra-pricing-currency {
font-size: 18px;
font-weight: 400;
color: #6b7280;
}
.yatra-pricing-details {
list-style: none;
padding: 0;
margin: 24px 0 0 0;
}
.yatra-pricing-details li {
padding: 12px 0;
font-size: 15px;
color: #374151;
display: flex;
align-items: center;
gap: 12px;
border-bottom: 1px solid #f3f4f6;
}
.yatra-pricing-details li:last-child {
border-bottom: none;
}
.yatra-pricing-details-icon {
width: 20px;
height: 20px;
color: #10b981;
flex-shrink: 0;
} .yatra-included-excluded {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 32px;
margin-top: 24px;
}
.yatra-included-section,
.yatra-excluded-section {
background: #ffffff;
border-radius: 8px;
padding: 24px;
border: 1px solid #e5e7eb;
}
.yatra-included-section {
border-left: 4px solid #10b981;
}
.yatra-excluded-section {
border-left: 4px solid #ef4444;
}
.yatra-included-section h3,
.yatra-excluded-section h3 {
font-size: 18px;
font-weight: 600;
margin: 0 0 16px 0;
display: flex;
align-items: center;
gap: 8px;
}
.yatra-included-section h3 {
color: #047857;
}
.yatra-excluded-section h3 {
color: #dc2626;
}
.yatra-included-list,
.yatra-excluded-list {
list-style: none;
padding: 0;
margin: 0;
}
.yatra-included-list li,
.yatra-excluded-list li {
padding: 12px 0;
font-size: 15px;
display: flex;
align-items: flex-start;
gap: 10px;
border-bottom: 1px solid #e5e7eb;
line-height: 1.5;
}
.yatra-included-list li:last-child,
.yatra-excluded-list li:last-child {
border-bottom: none;
}
.yatra-included-list li {
color: #065f46;
}
.yatra-excluded-list li {
color: #991b1b;
}
.yatra-item-content {
flex: 1;
}
.yatra-item-title {
font-weight: 500;
margin-bottom: 4px;
}
.yatra-item-desc {
display: block;
margin-top: 6px;
font-size: 13px;
color: #6b7280;
line-height: 1.4;
}
.yatra-included-icon,
.yatra-excluded-icon {
width: 18px;
height: 18px;
flex-shrink: 0;
margin-top: 2px;
}
.yatra-included-icon {
color: #059669;
}
.yatra-excluded-icon {
color: #dc2626;
} .dark .yatra-included-section,
.dark .yatra-excluded-section {
background: #1f2937;
border-color: #374151;
}
.dark .yatra-included-section {
border-left-color: #10b981;
}
.dark .yatra-excluded-section {
border-left-color: #ef4444;
}
.dark .yatra-included-section h3 {
color: #34d399;
}
.dark .yatra-excluded-section h3 {
color: #f87171;
}
.dark .yatra-included-list li,
.dark .yatra-excluded-list li {
border-bottom-color: #374151;
}
.dark .yatra-included-list li {
color: #6ee7b7;
}
.dark .yatra-excluded-list li {
color: #fca5a5;
}
.dark .yatra-item-desc {
color: #9ca3af;
} @media (max-width: 768px) {
.yatra-included-excluded {
grid-template-columns: 1fr;
gap: 20px;
}
.yatra-included-section,
.yatra-excluded-section {
padding: 20px;
}
.yatra-included-section h3,
.yatra-excluded-section h3 {
font-size: 16px;
}
.yatra-included-list li,
.yatra-excluded-list li {
font-size: 14px;
}
} .yatra-trip-gallery {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
gap: 16px;
margin-top: 24px;
}
.yatra-trip-gallery-empty {
grid-column: 1 / -1;
margin: 0;
padding: 1.25rem 1rem;
text-align: center;
color: #6b7280;
font-size: 0.9375rem;
background: #f9fafb;
border-radius: 8px;
border: 1px dashed #e5e7eb;
}
.yatra-gallery-item {
position: relative;
aspect-ratio: 4/3;
overflow: hidden;
border-radius: 8px;
cursor: pointer;
transition: transform 0.2s ease;
background: #f3f4f6;
}
.yatra-gallery-item:hover {
transform: translateY(-2px);
box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}
.yatra-gallery-item img {
width: 100%;
height: 100%;
object-fit: cover;
display: block;
transition: transform 0.5s ease;
}
.yatra-gallery-item:hover img {
transform: scale(1.1);
} .yatra-gallery-modal {
position: fixed;
top: 0;
left: 0;
right: 0;
bottom: 0;
z-index: 10000;
display: none;
align-items: center;
justify-content: center;
}
.yatra-gallery-modal.active {
display: flex;
}
.yatra-gallery-modal-overlay {
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: rgba(0,0,0,0.95);
backdrop-filter: blur(5px);
}
.yatra-gallery-modal-content {
position: relative;
width: 95%;
max-width: 1400px;
height: 90vh;
max-height: 900px;
background: #000;
border-radius: 16px;
overflow: hidden;
display: flex;
flex-direction: column;
z-index: 1;
} .admin-bar .yatra-gallery-modal-content {
margin-top: 32px;
max-height: calc(90vh - 32px);
}
.yatra-gallery-modal-close {
position: absolute;
top: 20px;
right: 20px;
z-index: 100;
width: 44px;
height: 44px;
background: rgba(255,255,255,0.1);
backdrop-filter: blur(10px);
border: 1px solid rgba(255,255,255,0.2);
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
transition: all 0.3s ease;
color: #fff;
margin:0;
padding:0;
}
.yatra-gallery-modal-close:hover {
background: rgba(255,255,255,0.2);
transform: rotate(90deg);
}
.yatra-gallery-modal-prev,
.yatra-gallery-modal-next {
position: absolute;
top: 50%;
transform: translateY(-50%);
z-index: 100;
width: 50px;
height: 50px;
background: rgba(255,255,255,0.1);
backdrop-filter: blur(10px);
border: 1px solid rgba(255,255,255,0.2);
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
transition: all 0.3s ease;
color: #fff;
margin:0;
padding:0;
}
.yatra-gallery-modal-prev {
left: 20px;
}
.yatra-gallery-modal-next {
right: 20px;
}
.yatra-gallery-modal-prev:hover,
.yatra-gallery-modal-next:hover {
background: rgba(255,255,255,0.2);
transform: translateY(-50%) scale(1.1);
}
.yatra-gallery-modal-main {
flex: 1;
display: flex;
align-items: center;
justify-content: center;
position: relative;
background: #000;
overflow: hidden;
}
.yatra-gallery-modal-image {
max-width: 100%;
max-height: 100%;
width: auto;
height: auto;
object-fit: contain;
display: block;
opacity: 0;
transition: opacity 0.3s ease;
}
.yatra-gallery-modal-image.loaded {
opacity: 1;
}
.yatra-gallery-modal-loader {
position: absolute;
color: #fff;
font-size: 16px;
display: none;
}
.yatra-gallery-modal-loader.active {
display: block;
}
.yatra-gallery-modal-info {
padding: 16px 24px;
background: rgba(0,0,0,0.8);
border-top: 1px solid rgba(255,255,255,0.1);
}
.yatra-gallery-modal-counter {
color: #fff;
font-size: 16px;
font-weight: 600;
text-align: center;
}
.yatra-gallery-modal-thumbnails {
padding: 16px;
background: rgba(0,0,0,0.9);
border-top: 1px solid rgba(255,255,255,0.1);
max-height: 120px;
overflow-x: auto;
overflow-y: hidden;
}
.yatra-gallery-thumbnails-container {
display: flex;
gap: 12px;
justify-content: center;
align-items: center;
padding: 0 20px;
}
.yatra-gallery-thumbnail {
width: 80px;
height: 80px;
border-radius: 8px;
overflow: hidden;
cursor: pointer;
opacity: 0.6;
transition: all 0.3s ease;
border: 2px solid transparent;
flex-shrink: 0;
}
.yatra-gallery-thumbnail:hover {
opacity: 1;
transform: scale(1.1);
}
.yatra-gallery-thumbnail.active {
opacity: 1;
border-color: #3b82f6;
}
.yatra-gallery-thumbnail img {
width: 100%;
height: 100%;
object-fit: cover;
display: block;
} .yatra-trip-map {
width: 100%;
height: 450px;
border-radius: 12px;
overflow: hidden;
margin-top: 32px;
background: #e5e7eb;
display: flex;
align-items: center;
justify-content: center;
color: #6b7280;
font-size: 16px;
border: 1px solid #d1d5db;
position: relative;
}
.yatra-map-placeholder {
background: linear-gradient(135deg, #f8fafc, #e2e8f0);
border: 2px dashed #cbd5e1;
}
.yatra-map-placeholder p {
margin: 0;
padding: 20px;
text-align: center;
color: #64748b;
font-weight: 500;
} #yatra-openstreet-map {
border-radius: 12px !important;
overflow: hidden;
box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}
.yatra-custom-marker {
z-index: 1000 !important;
}
.yatra-marker-bounce {
animation: bounce 2s infinite;
}
@keyframes bounce {
0%, 20%, 50%, 80%, 100% {
transform: translateY(0) rotate(-45deg);
}
40% {
transform: translateY(-10px) rotate(-45deg);
}
60% {
transform: translateY(-5px) rotate(-45deg);
}
} @media (prefers-color-scheme: dark) {
.yatra-trip-map {
background: #1e293b;
border-color: #334155;
}
.yatra-map-placeholder {
background: linear-gradient(135deg, #1e293b, #334155);
border-color: #475569;
}
.yatra-map-placeholder p {
color: #94a3b8;
}
} .yatra-trip-faq {
list-style: none;
padding: 0;
margin: 0;
}
.yatra-faq-item {
border-bottom: 1px solid #e5e7eb;
padding: 20px 0;
}
.yatra-faq-item:first-child {
padding-top: 0;
}
.yatra-faq-item:last-child {
border-bottom: none;
padding-bottom: 0;
}
.yatra-faq-question {
font-size: 18px;
font-weight: 600;
color: #111827;
margin: 0 0 12px 0;
cursor: pointer;
display: flex;
align-items: center;
justify-content: space-between;
transition: color 0.2s ease;
}
.yatra-faq-question:hover {
color: #374151;
}
.yatra-faq-toggle {
width: 20px;
height: 20px;
color: #6b7280;
flex-shrink: 0;
transition: transform 0.2s ease;
}
.yatra-faq-item.active .yatra-faq-toggle {
transform: rotate(45deg);
}
.yatra-faq-answer {
font-size: 16px;
line-height: 1.6;
color: #4b5563;
max-height: 0;
overflow: hidden;
transition: max-height 0.2s ease, margin 0.2s ease, padding 0.2s ease;
margin: 0;
padding: 0;
}
.yatra-faq-item.active .yatra-faq-answer {
max-height: 1000px;
margin-top: 12px;
padding-top: 12px;
border-top: 1px solid #f3f4f6;
} .yatra-trip-sidebar {
position: sticky;
top: max(12px, env(safe-area-inset-top, 0px));
height: fit-content;
max-width: 100%;
align-self: flex-start;
transition: top 0.3s ease;
} .admin-bar .yatra-trip-sidebar {
top: 32px; }
@media screen and (max-width: 782px) {
.admin-bar .yatra-trip-sidebar {
top: 46px; }
}
.yatra-booking-card {
background: #fff;
border-radius: 12px;
padding: 24px;
box-shadow: 0 2px 8px rgba(0,0,0,0.1);
border: 1px solid #e5e7eb;
position: relative;
}
.yatra-booking-price {
margin-bottom: 24px;
padding-bottom: 24px;
border-bottom: 1px solid #e5e7eb;
}
.yatra-booking-card .yatra-group-discount-badge-minimal {
margin-bottom: 10px;
background: #f0f9ff;
border-color: rgba(2, 132, 199, 0.22);
}
.yatra-booking-price-from {
margin-bottom: 8px;
}
.yatra-booking-price-from-text {
font-size: 14px;
color: #6b7280;
font-weight: 500;
}
.yatra-booking-price-original {
font-size: 14px;
color: rgba(107, 114, 128, 0.85);
text-decoration: line-through;
font-weight: 500;
text-decoration-thickness: 1px;
text-decoration-color: rgba(107, 114, 128, 0.65);
}
.yatra-booking-price-main {
display: flex;
align-items: baseline;
gap: 10px; flex-wrap: wrap;
white-space: normal;
max-width: 100%;
}
.yatra-booking-price-amount {
font-size: 28px;
font-weight: 700;
color: #ef4444;
line-height: 1.05;
letter-spacing: -0.01em;
}
.yatra-booking-price-label {
font-size: 14px;
color: #6b7280;
font-weight: 500;
line-height: 1.2;
white-space: nowrap;
max-width: 100%;
} @media (max-width: 480px) {
.yatra-booking-price-main {
flex-wrap: wrap;
white-space: normal;
}
} .yatra-booking-discount-badge {
display: inline-block;
padding: 4px 10px;
margin-bottom: 8px;
background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
color: white;
font-size: 12px;
font-weight: 600;
border-radius: 4px;
text-transform: uppercase;
letter-spacing: 0.5px;
} .yatra-contact-pricing {
font-size: 18px !important;
color: #ef4444 !important;
} .yatra-group-discount-badge-minimal {
display: inline-flex;
align-items: center;
gap: 6px;
background: linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 100%);
color: #0369a1;
padding: 4px 8px;
border-radius: 6px;
font-size: 11px;
font-weight: 500;
border: 1px solid #bae6fd;
position: relative;
z-index: 1;
}
.yatra-group-discount-badge-minimal svg {
flex-shrink: 0;
} .yatra-has-tooltip {
cursor: help;
}
.yatra-has-tooltip .yatra-info-icon {
opacity: 0.6;
transition: opacity 0.2s ease;
}
.yatra-has-tooltip:hover .yatra-info-icon {
opacity: 1;
}
.yatra-tooltip {
position: absolute;
bottom: calc(100% + 8px);
left: 50%;
transform: translateX(-50%);
background: #ffffff;
border: 1px solid #e5e7eb;
border-radius: 8px;
box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
padding: 0;
min-width: 220px;
z-index: 999999;
opacity: 0;
visibility: hidden;
transition: opacity 0.2s ease, visibility 0.2s ease;
pointer-events: none;
}
.yatra-has-tooltip:hover .yatra-tooltip {
opacity: 1;
visibility: visible;
pointer-events: auto;
z-index: 999999;
}
.yatra-tooltip::after {
content: '';
position: absolute;
top: 100%;
left: 50%;
transform: translateX(-50%);
border: 6px solid transparent;
border-top-color: #ffffff;
}
.yatra-tooltip-header {
padding: 10px 12px;
border-bottom: 1px solid #e5e7eb;
background: #f9fafb;
border-radius: 8px 8px 0 0;
font-size: 13px;
color: #111827;
}
.yatra-tooltip-content {
padding: 8px;
}
.yatra-discount-tier {
display: flex;
justify-content: space-between;
align-items: center;
padding: 8px 6px;
border-radius: 4px;
transition: background-color 0.15s ease;
}
.yatra-discount-tier:hover {
background: #f3f4f6;
}
.yatra-tier-size {
font-size: 12px;
color: #4b5563;
font-weight: 500;
}
.yatra-tier-discount {
font-size: 12px;
font-weight: 600;
color: #059669;
background: #ecfdf5;
padding: 2px 8px;
border-radius: 4px;
} .yatra-applied-group-discount {
margin-top: 12px;
padding: 10px 12px;
background: #ecfdf5;
border: 1px solid #10b981;
border-radius: 8px;
display: none;
}
.yatra-applied-group-discount.active {
display: block;
}
.yatra-applied-group-discount-header {
display: flex;
align-items: center;
gap: 8px;
margin-bottom: 6px;
}
.yatra-applied-group-discount-icon {
color: #10b981;
}
.yatra-applied-group-discount-title {
font-size: 13px;
font-weight: 600;
color: #047857;
}
.yatra-applied-group-discount-amount {
font-size: 14px;
font-weight: 700;
color: #059669;
margin-left: auto;
}
.yatra-applied-group-discount-desc {
font-size: 12px;
color: #059669;
} .yatra-quantity-price-wrapper {
display: flex;
flex-direction: column;
align-items: flex-start;
gap: 2px;
}
.yatra-pricing-mode-label {
font-size: 10px;
font-weight: 500;
padding: 2px 6px;
border-radius: 4px;
white-space: nowrap;
}
.yatra-pricing-mode-group {
background: #fef3c7;
color: #92400e;
border: 1px solid #f59e0b;
}
.yatra-booking-form {
display: flex;
flex-direction: column;
gap: 16px;
} .yatra-participants-select {
position: relative;
}
.yatra-participants-display {
flex: 1;
padding: 14px 12px 14px 0;
font-size: 15px;
font-weight: 500;
color: #111827;
cursor: pointer;
user-select: none;
height: 100%;
display: flex;
align-items: center;
pointer-events: auto;
position: relative;
z-index: 1;
transition: color 0.2s ease;
}
.yatra-participants-select:hover .yatra-participants-display {
color: #3b82f6;
} .yatra-booking-quantity-selector {
position: absolute;
top: 100%;
left: 0;
right: 0;
margin-top: 8px;
border: 1px solid #e5e7eb;
border-radius: 12px;
padding: 12px;
background: #fff;
box-shadow: 0 10px 25px rgba(0,0,0,0.1), 0 4px 6px rgba(0,0,0,0.05);
z-index: 1000;
display: none;
max-height: 400px;
overflow-y: auto;
overflow-x: hidden;
}
.yatra-participants-select.active .yatra-booking-quantity-selector {
display: block;
animation: slideDown 0.2s ease-out;
}
@keyframes slideDown {
from {
opacity: 0;
transform: translateY(-10px);
}
to {
opacity: 1;
transform: translateY(0);
}
} .yatra-enquiry-participants.active .yatra-booking-quantity-selector {
display: block;
}
.yatra-quantity-row {
display: flex;
align-items: center;
justify-content: space-between;
padding: 16px 12px;
border-radius: 12px;
transition: all 0.2s ease;
gap: 16px;
margin-bottom: 8px;
}
.yatra-quantity-row:hover {
background-color: #f8fafc;
transform: translateX(2px);
}
.yatra-quantity-row:not(:last-child) {
border-bottom: none;
}
.yatra-quantity-label {
display: flex;
flex-direction: column;
gap: 4px;
flex: 1;
min-width: 0;
}
.yatra-quantity-title {
font-size: 15px;
font-weight: 600;
color: #0f172a;
line-height: 1.3;
}
.yatra-quantity-subtitle {
font-size: 12px;
color: #64748b;
line-height: 1.4;
}
.yatra-quantity-price {
display: block;
font-size: 14px;
font-weight: 700;
color: #059669;
margin-top: 2px;
white-space: nowrap;
}
.yatra-booking-price-label-top {
display: block;
font-size: 12px;
color: #6b7280;
text-transform: uppercase;
letter-spacing: 0.5px;
margin-bottom: 2px;
} .yatra-booking-field-group {
margin-bottom: 16px;
}
.yatra-booking-field-label {
display: block;
font-size: 13px;
font-weight: 500;
color: #374151;
margin-bottom: 8px;
}
.yatra-booking-travelers-simple {
display: flex;
align-items: center;
gap: 12px;
padding: 12px 16px;
background: #f9fafb;
border: 1px solid #e5e7eb;
border-radius: 10px;
flex-wrap: wrap;
} .yatra-quantity-controls-inline {
display: flex;
align-items: center;
gap: 2px;
background: #f8fafc;
border: 1.5px solid #e2e8f0;
border-radius: 12px;
padding: 3px;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}
.yatra-quantity-controls-inline:hover {
border-color: #cbd5e1;
box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
background: #ffffff;
}
.yatra-quantity-controls-inline:focus-within {
border-color: #3b82f6;
box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}
.yatra-quantity-controls-inline .yatra-quantity-btn {
width: 32px;
height: 32px;
border-radius: 10px;
border: none;
background: #ffffff;
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
color: #475569;
padding: 0;
flex-shrink: 0;
box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
position: relative;
z-index: 1;
}
.yatra-quantity-controls-inline .yatra-quantity-btn:hover:not(:disabled) {
background: #3b82f6;
color: #ffffff;
transform: translateY(-1px);
box-shadow: 0 4px 8px rgba(59, 130, 246, 0.25);
z-index: 2;
}
.yatra-quantity-controls-inline .yatra-quantity-btn:active:not(:disabled) {
background: #2563eb;
color: #ffffff;
transform: translateY(0);
box-shadow: 0 2px 4px rgba(59, 130, 246, 0.2);
}
.yatra-quantity-controls-inline .yatra-quantity-btn:disabled {
opacity: 0.4;
cursor: not-allowed;
color: #cbd5e1;
background: #f1f5f9;
box-shadow: none;
}
.yatra-quantity-controls-inline .yatra-quantity-btn svg {
width: 16px;
height: 16px;
stroke-width: 2.5;
transition: transform 0.2s ease;
pointer-events: none;
}
.yatra-quantity-controls-inline .yatra-quantity-btn:hover:not(:disabled) svg {
transform: scale(1.1);
}
.yatra-quantity-input-simple {
width: 50px;
text-align: center;
font-size: 15px;
font-weight: 700;
color: #0f172a;
border: none;
background: transparent;
appearance: textfield;
-moz-appearance: textfield;
padding: 0 4px;
border-radius: 8px;
transition: all 0.2s ease;
}
.yatra-quantity-input-simple::-webkit-outer-spin-button,
.yatra-quantity-input-simple::-webkit-inner-spin-button {
-webkit-appearance: none;
margin: 0;
}
.yatra-quantity-input-simple:focus {
outline: none;
background: #ffffff;
box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.1);
}
.yatra-travelers-range,
.yatra-travelers-available {
font-size: 12px;
color: #6b7280;
margin-left: auto;
} .yatra-availability-info {
padding: 8px 12px;
background: #ecfdf5;
border-radius: 8px;
margin-bottom: 16px;
text-align: center;
}
.yatra-availability-count {
font-size: 13px;
font-weight: 500;
color: #059669;
} .yatra-flexible-booking-info {
background: #f3f8ff;
border-left: 3px solid rgba(59, 130, 246, 0.65);
}
.yatra-flexible-booking-info .yatra-availability-count {
color: #1e40af;
display: block;
margin-bottom: 2px;
font-weight: 600;
}
.yatra-availability-note {
display: block;
font-size: 12px;
color: #6b7280;
font-weight: 400;
} .yatra-departure-dates-list {
display: flex;
flex-direction: column;
gap: 8px;
max-height: 280px;
overflow-y: auto;
padding-right: 4px;
}
.yatra-departure-option {
display: flex;
align-items: center;
gap: 12px;
padding: 12px;
border: 2px solid #e5e7eb;
border-radius: 10px;
cursor: pointer;
transition: all 0.2s ease;
background: #fff;
}
.yatra-departure-option:hover {
border-color: #3b82f6;
background: #f8fafc;
}
.yatra-departure-option.selected {
border-color: #3b82f6;
background: #eff6ff;
}
.yatra-departure-option.limited {
border-color: #f59e0b;
}
.yatra-departure-option.limited.selected {
background: #fffbeb;
}
.yatra-departure-option input[type="radio"] {
display: none;
}
.yatra-departure-info {
flex: 1;
}
.yatra-departure-date {
display: flex;
flex-direction: column;
gap: 2px;
}
.yatra-departure-day {
font-size: 11px;
font-weight: 600;
color: #6b7280;
text-transform: uppercase;
}
.yatra-departure-full {
font-size: 14px;
font-weight: 600;
color: #111827;
}
.yatra-return-date {
font-size: 12px;
color: #6b7280;
}
.yatra-departure-meta {
margin-top: 4px;
}
.yatra-departure-seats {
font-size: 11px;
color: #059669;
}
.yatra-departure-seats.limited {
color: #f59e0b;
font-weight: 500;
}
.yatra-departure-price {
text-align: right;
}
.yatra-departure-original-price {
font-size: 12px;
color: #9ca3af;
text-decoration: line-through;
display: block;
}
.yatra-departure-current-price {
font-size: 16px;
font-weight: 700;
color: #059669;
}
.yatra-departure-check {
width: 24px;
height: 24px;
border-radius: 50%;
background: #e5e7eb;
display: flex;
align-items: center;
justify-content: center;
transition: all 0.2s ease;
}
.yatra-departure-check svg {
color: transparent;
transition: color 0.2s ease;
}
.yatra-departure-option.selected .yatra-departure-check {
background: #3b82f6;
}
.yatra-departure-option.selected .yatra-departure-check svg {
color: #fff;
} .yatra-departure-dates-list::-webkit-scrollbar {
width: 4px;
}
.yatra-departure-dates-list::-webkit-scrollbar-track {
background: #f1f5f9;
border-radius: 4px;
}
.yatra-departure-dates-list::-webkit-scrollbar-thumb {
background: #cbd5e1;
border-radius: 4px;
}
.yatra-departure-dates-list::-webkit-scrollbar-thumb:hover {
background: #94a3b8;
} .yatra-quantity-controls {
display: inline-flex;
align-items: center;
gap: 2px;
background: #f8fafc;
padding: 3px;
border-radius: 12px;
border: 1.5px solid #e2e8f0;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}
.yatra-quantity-controls:hover {
border-color: #cbd5e1;
box-shadow: 0 2px 6px rgba(0, 0, 0, 0.08);
background: #ffffff;
}
.yatra-quantity-controls:focus-within {
border-color: #3b82f6;
box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}
.yatra-quantity-btn {
width: 32px;
height: 32px;
border-radius: 10px;
border: none;
background: #ffffff;
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
color: #475569;
padding: 0;
flex-shrink: 0;
box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
position: relative;
z-index: 1;
}
.yatra-quantity-row .yatra-quantity-btn:hover:not(:disabled) {
background: #3b82f6;
color: #ffffff;
transform: translateY(-1px);
box-shadow: 0 4px 8px rgba(59, 130, 246, 0.25);
z-index: 2;
}
.yatra-quantity-btn:active:not(:disabled) {
background: #2563eb;
color: #ffffff;
transform: translateY(0);
box-shadow: 0 2px 4px rgba(59, 130, 246, 0.2);
}
.yatra-quantity-btn:disabled {
opacity: 0.4;
cursor: not-allowed;
color: #cbd5e1;
background: #f1f5f9;
box-shadow: none;
}
.yatra-quantity-btn svg {
width: 16px;
height: 16px;
stroke-width: 2.5;
transition: transform 0.2s ease;
pointer-events: none;
}
.yatra-quantity-btn:hover:not(:disabled) svg {
transform: scale(1.1);
}
.yatra-quantity-row .yatra-quantity-input {
width: 48px;
height: 32px;
text-align: center;
border: none;
background: transparent;
font-size: 15px;
font-weight: 500;
color: #0f172a;
padding: 0 6px;
cursor: default;
min-width: 48px;
border-radius: 8px;
appearance: textfield;
-moz-appearance: textfield;
transition: all 0.2s ease;
line-height: 32px;
}
.yatra-quantity-input::-webkit-outer-spin-button,
.yatra-quantity-input::-webkit-inner-spin-button {
-webkit-appearance: none;
margin: 0;
}
.yatra-quantity-input:focus {
outline: none;
background: #ffffff;
box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.1);
}
.yatra-quantity-note {
margin-top: 12px;
padding-top: 12px;
border-top: 1px solid #e5e7eb;
font-size: 12px;
color: #6b7280;
line-height: 1.4;
}
.yatra-booking-field-select {
position: relative;
display: flex;
align-items: center;
width: 100%;
border: 1px solid rgba(209, 213, 219, 0.9);
border-radius: 8px;
background: #fff;
transition: all 0.3s ease;
min-height: 46px;
height: 46px;
cursor: pointer;
}
.yatra-booking-field-select input[readonly] {
cursor: pointer;
}
.yatra-booking-field-select:focus-within {
border-color: #3b82f6;
box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}
.yatra-booking-field-icon {
padding: 0 12px;
display: flex;
align-items: center;
color: #6b7280;
flex-shrink: 0;
height: 100%;
}
.yatra-booking-field-icon svg {
width: 18px;
height: 18px;
}
.yatra-booking-select {
flex: 1;
padding: 12px 12px 12px 0;
border: none;
background: transparent;
font-size: 15px;
color: #111827;
font-family: inherit;
appearance: none;
cursor: pointer;
height: 100%;
display: flex;
align-items: center;
}
.yatra-booking-select:focus {
outline: none;
}
.yatra-booking-select option {
padding: 8px;
} .yatra-datepicker,
.yatra-booking-field-select input.yatra-datepicker,
input.yatra-datepicker,
.yatra-enquiry-datepicker,
.yatra-enquiry-field .yatra-booking-field-select input {
border: none !important;
outline: none !important;
box-shadow: none !important;
}
.flatpickr-input {
border: none !important;
outline: none !important;
box-shadow: none !important;
} .yatra-enquiry-field .yatra-booking-field-select .flatpickr-input {
border: none !important;
outline: none !important;
box-shadow: none !important;
}
.yatra-select-arrow {
position: absolute;
right: 12px;
width: 20px;
height: 20px;
color: #6b7280;
pointer-events: none;
flex-shrink: 0;
}
.yatra-booking-enquiry-button {
width: 100%;
padding: 14px 24px;
background: transparent;
color: #3b82f6;
border: 2px solid #3b82f6;
border-radius: 8px;
font-size: 15px;
font-weight: 600;
cursor: pointer;
transition: all 0.3s ease;
margin-top: 8px;
display: flex;
align-items: center;
justify-content: center;
gap: 8px;
}
.yatra-booking-enquiry-button svg {
flex-shrink: 0;
}
.yatra-booking-enquiry-button:hover {
background: #3b82f6;
color: #fff;
}
.yatra-booking-button {
width: 100%;
padding: 16px 24px;
background: #3b82f6;
color: #fff;
border: none;
border-radius: 8px;
font-size: 16px;
font-weight: 600;
cursor: pointer;
transition: all 0.3s ease;
margin-top: 8px;
display: flex;
align-items: center;
justify-content: center;
gap: 8px;
}
.yatra-booking-button svg {
flex-shrink: 0;
}
.yatra-booking-button:hover {
background: #2563eb;
transform: translateY(-1px);
box-shadow: 0 4px 12px rgba(59, 130, 246, 0.3);
}
.yatra-booking-button:focus-visible,
.yatra-booking-enquiry-button:focus-visible,
.yatra-booking-field-select:focus-within {
outline: none;
box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.18);
} .yatra-booking-availability-compact {
padding: 8px 12px;
background: #fef3c7;
border: 1px solid #fde68a;
border-radius: 6px;
margin-bottom: 20px;
font-size: 12px;
color: #92400e;
text-align: center;
line-height: 1.4;
}
.yatra-booking-availability-compact strong {
font-weight: 700;
color: #78350f;
} .yatra-booking-trust {
margin-top: 20px;
padding-top: 20px;
border-top: 1px solid #e5e7eb;
display: flex;
align-items: flex-start;
gap: 10px;
}
.yatra-booking-trust-icon {
flex-shrink: 0;
margin-top: 2px;
}
.yatra-booking-trust-icon svg {
width: 18px;
height: 18px;
color: #10b981;
}
.yatra-booking-trust-text {
font-size: 13px;
color: #4b5563;
line-height: 1.5;
}
.yatra-booking-trust-text strong {
color: #111827;
font-weight: 600;
} .yatra-enquiry-modal {
position: fixed;
top: 0;
left: 0;
right: 0;
bottom: 0;
z-index: 99999;
display: none !important;
align-items: center;
justify-content: center;
padding: 20px;
visibility: hidden;
opacity: 0;
transition: opacity 0.3s ease, visibility 0.3s ease;
}
.yatra-enquiry-modal.active {
display: flex !important;
visibility: visible !important;
opacity: 1 !important;
}
.yatra-enquiry-modal-overlay {
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: rgba(0, 0, 0, 0.6);
backdrop-filter: blur(4px);
}
.yatra-enquiry-modal-content {
position: relative;
background: #fff;
border-radius: 16px;
max-width: 700px;
width: 100%;
max-height: 90vh;
overflow-y: auto;
box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
z-index: 1;
}
.yatra-enquiry-modal-close {
position: absolute;
top: 16px;
right: 16px;
width: 40px;
height: 40px;
border: none;
background: #f3f4f6;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
transition: all 0.2s ease;
z-index: 10;
color: #6b7280;
padding:0;
}
.yatra-enquiry-modal-close:hover {
background: #e5e7eb;
color: #111827;
transform: rotate(90deg);
}
.yatra-enquiry-modal-close svg {
width: 20px;
height: 20px;
}
.yatra-enquiry-modal-header {
padding: 32px 32px 24px;
border-bottom: 1px solid #e5e7eb;
}
.yatra-enquiry-modal-title {
font-size: 24px;
font-weight: 700;
color: #111827;
margin: 0 0 8px 0;
}
.yatra-enquiry-modal-subtitle {
font-size: 14px;
color: #6b7280;
margin: 0;
line-height: 1.5;
}
.yatra-enquiry-form {
padding: 24px 32px 32px;
} .yatra-enquiry-message {
margin-bottom: 16px;
padding: 12px 16px;
border-radius: 8px;
font-size: 14px;
line-height: 1.5;
}
.yatra-enquiry-message p {
margin: 0;
}
.yatra-enquiry-message-success {
background-color: #dcfce7;
color: #166534;
border: 1px solid #bbf7d0;
}
.yatra-enquiry-message-error {
background-color: #fef2f2;
color: #dc2626;
border: 1px solid #fecaca;
}
.yatra-enquiry-form-grid {
display: grid;
grid-template-columns: 1fr 1fr 1fr;
gap: 16px;
margin-bottom: 20px;
}
.yatra-enquiry-field {
margin-bottom: 20px;
}
.yatra-enquiry-field-group {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 16px;
margin-bottom: 20px;
} .yatra-enquiry-field .yatra-booking-field-select {
margin-top: 0;
}
.yatra-enquiry-label {
display: block;
font-size: 14px;
font-weight: 600;
color: #374151;
margin-bottom: 8px;
}
.yatra-enquiry-required {
color: #ef4444;
}
.yatra-enquiry-input,
.yatra-enquiry-textarea {
width: 100%;
padding: 12px 16px;
border: 1px solid #d1d5db;
border-radius: 8px;
font-size: 15px;
font-family: inherit;
color: #111827;
background: #fff;
transition: all 0.2s ease;
box-sizing: border-box;
}
.yatra-enquiry-input:focus,
.yatra-enquiry-textarea:focus {
outline: none;
border-color: #3b82f6;
box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}
.yatra-enquiry-textarea {
resize: vertical;
min-height: 80px;
height: 80px;
line-height: 1.6;
} @media (max-width: 640px) {
.yatra-enquiry-form-grid {
grid-template-columns: 1fr;
}
.yatra-enquiry-field-group {
grid-template-columns: 1fr;
}
}
.yatra-enquiry-input::placeholder,
.yatra-enquiry-textarea::placeholder {
color: #9ca3af;
}
.yatra-enquiry-actions {
display: flex;
gap: 12px;
margin-top: 32px;
padding-top: 24px;
border-top: 1px solid #e5e7eb;
}
.yatra-enquiry-cancel {
flex: 1;
padding: 14px 24px;
border: 1px solid #d1d5db;
border-radius: 8px;
background: #fff;
color: #374151;
font-size: 15px;
font-weight: 600;
cursor: pointer;
transition: all 0.2s ease;
display: flex;
align-items: center;
justify-content: center;
gap: 6px;
}
.yatra-enquiry-cancel svg {
flex-shrink: 0;
}
.yatra-enquiry-cancel:hover {
background: #f9fafb;
border-color: #9ca3af;
}
.yatra-enquiry-submit {
flex: 1;
padding: 14px 24px;
border: none;
border-radius: 8px;
background: #3b82f6;
color: #fff;
font-size: 15px;
font-weight: 600;
cursor: pointer;
transition: all 0.2s ease;
display: flex;
align-items: center;
justify-content: center;
gap: 6px;
}
.yatra-enquiry-submit svg {
flex-shrink: 0;
}
.yatra-enquiry-submit:hover {
background: #2563eb;
transform: translateY(-1px);
box-shadow: 0 4px 12px rgba(59, 130, 246, 0.4);
}
.yatra-enquiry-submit:active {
transform: translateY(0);
}
@media (max-width: 640px) {
.yatra-enquiry-modal-content {
max-width: 100%;
border-radius: 12px;
}
.yatra-enquiry-modal-header {
padding: 24px 20px 20px;
}
.yatra-enquiry-form {
padding: 20px;
}
.yatra-enquiry-field-group {
grid-template-columns: 1fr;
}
.yatra-enquiry-actions {
flex-direction: column;
}
}
.yatra-booking-feature-item {
display: flex;
align-items: flex-start;
gap: 12px;
}
.yatra-booking-feature-icon {
flex-shrink: 0;
margin-top: 2px;
}
.yatra-booking-feature-icon svg {
width: 20px;
height: 20px;
color: #10b981;
}
.yatra-booking-feature-content {
flex: 1;
}
.yatra-booking-feature-title {
font-size: 15px;
font-weight: 600;
color: #111827;
margin-bottom: 4px;
}
.yatra-booking-feature-desc {
font-size: 13px;
color: #6b7280;
line-height: 1.5;
}
.yatra-booking-feature-link {
color: #3b82f6;
text-decoration: none;
font-weight: 500;
}
.yatra-booking-feature-link:hover {
text-decoration: underline;
} .yatra-weather-info {
background: #f9fafb;
border-radius: 12px;
padding: 24px;
border: 1px solid #e5e7eb;
}
.yatra-weather-card {
margin-bottom: 24px;
}
.yatra-weather-season {
font-size: 18px;
font-weight: 700;
color: #111827;
margin-bottom: 12px;
}
.yatra-weather-desc {
font-size: 15px;
line-height: 1.7;
color: #4b5563;
margin: 0;
}
.yatra-weather-details {
display: grid;
gap: 16px;
}
.yatra-weather-detail-item {
padding: 16px;
background: #fff;
border-radius: 8px;
border: 1px solid #e5e7eb;
}
.yatra-weather-detail-label {
font-size: 14px;
font-weight: 600;
color: #374151;
margin-bottom: 6px;
}
.yatra-weather-detail-value {
font-size: 14px;
color: #6b7280;
line-height: 1.5;
} .yatra-packing-list {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
gap: 24px;
}
.yatra-packing-category {
background: #f9fafb;
border-radius: 12px;
padding: 24px;
border: 1px solid #e5e7eb;
}
.yatra-packing-category-title {
font-size: 18px;
font-weight: 700;
color: #111827;
margin-bottom: 16px;
padding-bottom: 12px;
border-bottom: 2px solid #3b82f6;
}
.yatra-packing-items {
list-style: none;
padding: 0;
margin: 0;
display: flex;
flex-direction: column;
gap: 10px;
}
.yatra-packing-items li {
font-size: 14px;
color: #4b5563;
line-height: 1.6;
padding-left: 24px;
position: relative;
}
.yatra-packing-items li::before {
content: '✓';
position: absolute;
left: 0;
color: #10b981;
font-weight: 700;
font-size: 16px;
} .yatra-similar-section { padding-top: var(--yatra-section-gap);
padding-bottom: var(--yatra-section-gap);
background: #f8fafc;
margin-top: 0;
border-top: 1px solid var(--yatra-border-color, #e5e7eb);
} .yatra-single-trip .yatra-similar-section > .yatra-similar-section-container {
width: 100%;
max-width: none;
margin-left: 0;
margin-right: 0;
padding-left: 0;
padding-right: 0;
}
.yatra-similar-section-header {
display: flex;
align-items: center;
justify-content: space-between;
margin-bottom: var(--yatra-element-gap);
}
.yatra-similar-section-title {
display: flex;
align-items: center;
gap: var(--yatra-tiny-gap);
font-size: 28px;
font-weight: 700;
color: #111827;
margin: 0;
}
.yatra-similar-section-icon {
width: 32px;
height: 32px;
color: #3b82f6;
} .yatra-carousel-nav {
display: flex;
gap: 8px;
}
.yatra-carousel-btn {
width: 44px;
height: 44px;
display: flex;
align-items: center;
justify-content: center;
background: #fff;
border: 1px solid #e5e7eb;
border-radius: 50%;
cursor: pointer;
color: #374151;
transition: all 0.2s;
}
.yatra-carousel-btn:hover:not(:disabled) {
background: #3b82f6;
border-color: #3b82f6;
color: #fff;
}
.yatra-carousel-btn:disabled {
opacity: 0.5;
cursor: not-allowed;
} .yatra-carousel-wrapper {
overflow: hidden;
position: relative;
}
.yatra-carousel-track {
display: flex;
gap: 24px;
transition: transform 0.4s ease;
}
.yatra-carousel-item {
flex: 0 0 calc(25% - 18px);
min-width: 280px;
}
@media (max-width: 1200px) {
.yatra-carousel-item {
flex: 0 0 calc(33.333% - 16px);
}
}
@media (max-width: 900px) {
.yatra-carousel-item {
flex: 0 0 calc(50% - 12px);
}
}
@media (max-width: 600px) {
.yatra-carousel-item {
flex: 0 0 100%;
}
.yatra-carousel-nav {
display: none;
}
.yatra-carousel-track {
overflow-x: auto;
scroll-snap-type: x mandatory;
-webkit-overflow-scrolling: touch;
scrollbar-width: none;
-ms-overflow-style: none;
}
.yatra-carousel-track::-webkit-scrollbar {
display: none;
}
.yatra-carousel-item {
scroll-snap-align: start;
}
} .yatra-similar-trips-grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
gap: 24px;
}
.yatra-similar-trips-grid .yatra-trip-card {
background: #fff;
border-radius: 12px;
overflow: hidden;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
transition: transform 0.2s, box-shadow 0.2s;
cursor: pointer;
display: flex;
flex-direction: column;
}
.yatra-similar-trips-grid .yatra-trip-card:hover {
transform: translateY(-4px);
box-shadow: 0 8px 25px rgba(0, 0, 0, 0.12);
}
.yatra-similar-trips-grid .yatra-trip-image {
position: relative;
width: 100%;
height: 200px;
overflow: hidden;
background: #e5e7eb;
flex-shrink: 0;
}
.yatra-similar-trips-grid .yatra-trip-image img {
width: 100%;
height: 100%;
object-fit: cover;
transition: transform 0.3s;
}
.yatra-similar-trips-grid .yatra-trip-card:hover .yatra-trip-image img {
transform: scale(1.05);
}
.yatra-similar-trips-grid .yatra-discount-badge {
position: absolute;
top: 12px;
left: 12px;
background: #ef4444;
color: #fff;
padding: 4px 10px;
border-radius: 4px;
font-size: 12px;
font-weight: 600;
z-index: 2;
}
.yatra-similar-trips-grid .yatra-favorite-btn {
position: absolute !important;
top: 12px !important;
right: 12px !important;
width: 36px !important;
height: 36px !important;
background: #ffffff !important;
border: 1px solid rgba(0, 0, 0, 0.1) !important;
border-radius: 50% !important;
cursor: pointer !important;
display: flex !important;
align-items: center !important;
justify-content: center !important;
color: #6b7280 !important;
transition: all 0.2s !important;
z-index: 10 !important;
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15) !important;
padding: 0 !important;
}
.yatra-similar-trips-grid .yatra-favorite-btn:hover {
background: #ffffff !important;
color: #ef4444 !important;
transform: scale(1.1) !important;
}
.yatra-similar-trips-grid .yatra-favorite-btn svg {
width: 18px !important;
height: 18px !important;
}
.yatra-similar-trips-grid .yatra-trip-content {
padding: 20px;
display: flex;
flex-direction: column;
flex: 1;
}
.yatra-similar-trips-grid .yatra-trip-meta {
display: flex;
align-items: center;
gap: 8px;
margin-bottom: 12px;
font-size: 13px;
color: #6b7280;
flex-wrap: wrap;
}
.yatra-similar-trips-grid .yatra-trip-separator {
color: #d1d5db;
}
.yatra-similar-trips-grid .yatra-trip-title {
font-size: 18px;
font-weight: 600;
color: #1f2937;
margin-bottom: 12px;
line-height: 1.4;
}
.yatra-similar-trips-grid .yatra-trip-highlights {
display: flex;
flex-wrap: wrap;
gap: 6px;
margin-top: 0 !important;
margin-bottom: 12px;
}
.yatra-similar-trips-grid .yatra-highlight-badge {
padding: 4px 10px;
background: #eff6ff;
color: #1e40af;
border-radius: 4px;
font-size: 12px;
font-weight: 500;
}
.yatra-similar-trips-grid .yatra-trip-rating {
display: flex;
align-items: center;
gap: 8px;
margin-bottom: 16px;
}
.yatra-similar-trips-grid .yatra-rating-stars {
display: flex;
align-items: center;
gap: 4px;
}
.yatra-similar-trips-grid .yatra-rating-value {
font-size: 13px;
font-weight: 600;
color: #1f2937;
}
.yatra-similar-trips-grid .yatra-reviews-count {
font-size: 12px;
color: #6b7280;
}
.yatra-similar-trips-grid .yatra-trip-footer {
display: flex;
justify-content: space-between;
align-items: center;
margin-top: auto;
padding-top: 16px;
border-top: 1px solid #f3f4f6;
}
.yatra-similar-trips-grid .yatra-trip-price {
display: flex;
flex-direction: column;
}
.yatra-similar-trips-grid .yatra-original-price {
font-size: 12px;
color: #9ca3af;
text-decoration: line-through;
margin-bottom: 2px;
}
.yatra-similar-trips-grid .yatra-current-price {
font-size: 22px;
font-weight: 700;
color: #3b82f6;
line-height: 1;
}
.yatra-similar-trips-grid .yatra-price-note {
font-size: 11px;
color: #9ca3af;
margin-top: 2px;
}
.yatra-similar-trips-grid .yatra-card-view-btn {
display: inline-flex;
align-items: center;
justify-content: center;
padding: 10px 16px;
background: #3b82f6;
color: #fff !important;
border: none;
border-radius: 6px;
font-size: 13px;
font-weight: 600;
cursor: pointer;
transition: all 0.2s;
text-decoration: none !important;
white-space: nowrap;
}
.yatra-similar-trips-grid .yatra-card-view-btn:hover {
background: #2563eb;
transform: translateY(-1px);
box-shadow: 0 4px 12px rgba(59, 130, 246, 0.3);
}
@media (max-width: 1024px) {
.yatra-similar-trips-grid {
grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
gap: 20px;
}
}
@media (max-width: 768px) {
.yatra-similar-trips-grid {
grid-template-columns: 1fr;
}
.yatra-similar-section {
padding-top: var(--yatra-section-gap);
padding-bottom: var(--yatra-section-gap);
margin-top: 0;
}
.yatra-similar-section-title {
font-size: 22px;
}
.yatra-similar-section-header {
flex-direction: column;
align-items: flex-start;
gap: 16px;
margin-bottom: 24px;
}
} .yatra-carousel-item .yatra-trip-card {
background: #fff;
border-radius: 12px;
overflow: hidden;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
transition: transform 0.2s, box-shadow 0.2s;
cursor: pointer;
display: flex;
flex-direction: column;
height: 100%;
}
.yatra-carousel-item .yatra-trip-card:hover {
transform: translateY(-4px);
box-shadow: 0 8px 25px rgba(0, 0, 0, 0.12);
}
.yatra-carousel-item .yatra-trip-image {
position: relative;
width: 100%;
height: 200px;
overflow: hidden;
background: #e5e7eb;
flex-shrink: 0;
}
.yatra-carousel-item .yatra-trip-image img {
width: 100%;
height: 100%;
object-fit: cover;
transition: transform 0.3s;
}
.yatra-carousel-item .yatra-trip-card:hover .yatra-trip-image img {
transform: scale(1.05);
}
.yatra-carousel-item .yatra-discount-badge {
position: absolute;
top: 12px;
left: 12px;
background: #ef4444;
color: #fff;
padding: 4px 10px;
border-radius: 4px;
font-size: 12px;
font-weight: 600;
z-index: 2;
}
.yatra-carousel-item .yatra-favorite-btn {
position: absolute !important;
top: 12px !important;
right: 12px !important;
width: 36px !important;
height: 36px !important;
background: #ffffff !important;
border: 1px solid rgba(0, 0, 0, 0.1) !important;
border-radius: 50% !important;
cursor: pointer !important;
display: flex !important;
align-items: center !important;
justify-content: center !important;
color: #6b7280 !important;
transition: all 0.2s !important;
z-index: 10 !important;
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15) !important;
padding: 0 !important;
}
.yatra-carousel-item .yatra-favorite-btn:hover {
background: #ffffff !important;
color: #ef4444 !important;
transform: scale(1.1) !important;
}
.yatra-carousel-item .yatra-favorite-btn svg {
width: 18px !important;
height: 18px !important;
}
.yatra-carousel-item .yatra-trip-content {
padding: 20px;
display: flex;
flex-direction: column;
flex: 1;
}
.yatra-carousel-item .yatra-trip-meta {
display: flex;
align-items: center;
gap: 8px;
margin-bottom: 12px;
font-size: 13px;
color: #6b7280;
flex-wrap: wrap;
}
.yatra-carousel-item .yatra-trip-separator {
color: #d1d5db;
}
.yatra-carousel-item .yatra-trip-title {
font-size: 18px;
font-weight: 600;
color: #1f2937;
margin-bottom: 12px;
line-height: 1.4;
}
.yatra-carousel-item .yatra-trip-highlights {
display: flex;
flex-wrap: wrap;
gap: 6px;
margin-top: 0 !important;
margin-bottom: 12px;
}
.yatra-carousel-item .yatra-highlight-badge {
padding: 4px 10px;
background: #eff6ff;
color: #1e40af;
border-radius: 4px;
font-size: 12px;
font-weight: 500;
}
.yatra-carousel-item .yatra-trip-location {
color: #6b7280;
}
.yatra-carousel-item .yatra-trip-rating {
display: flex;
align-items: center;
gap: 8px;
margin-bottom: 16px;
}
.yatra-carousel-item .yatra-rating-stars {
display: flex;
align-items: center;
gap: 4px;
}
.yatra-carousel-item .yatra-rating-value {
font-size: 14px;
font-weight: 600;
color: #1f2937;
}
.yatra-carousel-item .yatra-reviews-count {
font-size: 13px;
color: #6b7280;
}
.yatra-carousel-item .yatra-trip-footer {
display: flex;
justify-content: space-between;
align-items: center;
margin-top: auto;
padding-top: 16px;
border-top: 1px solid #f3f4f6;
}
.yatra-carousel-item .yatra-trip-price {
display: flex;
flex-direction: column;
}
.yatra-carousel-item .yatra-original-price {
font-size: 12px;
color: #9ca3af;
text-decoration: line-through;
margin-bottom: 2px;
}
.yatra-carousel-item .yatra-current-price {
font-size: 22px;
font-weight: 700;
color: #3b82f6;
line-height: 1;
}
.yatra-carousel-item .yatra-price-note {
font-size: 11px;
color: #9ca3af;
margin-top: 2px;
}
.yatra-carousel-item .yatra-card-view-btn {
display: inline-flex;
align-items: center;
justify-content: center;
padding: 10px 16px;
background: #3b82f6;
color: #fff !important;
border: none;
border-radius: 6px;
font-size: 13px;
font-weight: 600;
cursor: pointer;
transition: all 0.2s;
text-decoration: none !important;
white-space: nowrap;
}
.yatra-carousel-item .yatra-card-view-btn:hover {
background: #2563eb;
transform: translateY(-1px);
box-shadow: 0 4px 12px rgba(59, 130, 246, 0.3);
} .yatra-reviews-section {
padding-top: var(--yatra-section-gap);
padding-bottom: var(--yatra-section-gap);
background: #fff;
border-top: 1px solid #e5e7eb;
} .yatra-single-trip .yatra-reviews-section > .yatra-reviews-section-container {
width: 100%;
max-width: 100%;
margin-left: 0;
margin-right: 0;
padding-left: 0;
padding-right: 0;
box-sizing: border-box;
}
.yatra-reviews-section .yatra-reviews-header {
margin-bottom: var(--yatra-element-gap);
}
.yatra-reviews-section-title {
display: flex;
align-items: center;
gap: var(--yatra-tiny-gap);
font-size: 28px;
font-weight: 700;
color: #111827;
margin: 0;
}
.yatra-reviews-section-icon {
width: 32px;
height: 32px;
color: #fbbf24;
}
.yatra-reviews-section .yatra-reviews-container {
display: grid;
grid-template-columns: 320px 1fr;
gap: var(--yatra-section-gap);
align-items: start;
}
@media (max-width: 900px) {
.yatra-reviews-section .yatra-reviews-container {
grid-template-columns: 1fr;
gap: var(--yatra-element-gap);
}
} .yatra-rating-distribution {
margin-top: 24px;
}
.yatra-breakdown-star {
font-size: 14px;
color: #d1d5db;
line-height: 1;
}
.yatra-breakdown-star.filled {
color: #fbbf24;
}
.yatra-rating-distribution-title {
font-size: 14px;
font-weight: 600;
color: #374151;
margin: 0 0 16px 0;
}
.yatra-rating-row {
display: flex;
align-items: center;
gap: 12px;
margin-bottom: 8px;
}
.yatra-rating-star-label {
display: flex;
gap: 1px;
width: 80px;
flex-shrink: 0;
}
.yatra-rating-bar {
flex: 1;
height: 8px;
background: #e5e7eb;
border-radius: 4px;
overflow: hidden;
}
.yatra-rating-bar-fill {
height: 100%;
background: var(--yatra-star, #fbbf24);
border-radius: 4px;
transition: width 0.3s ease;
}
.yatra-rating-count {
font-size: 13px;
color: #6b7280;
width: 24px;
text-align: right;
flex-shrink: 0;
} .yatra-reviews-section .yatra-no-reviews-message {
text-align: center;
padding: 48px 24px;
background: #f9fafb;
border-radius: 12px;
border: 1px dashed #d1d5db;
}
.yatra-no-reviews-icon {
width: 48px;
height: 48px;
margin: 0 auto 16px;
color: #9ca3af;
display: flex;
align-items: center;
justify-content: center;
}
.yatra-no-reviews-icon svg {
width: 100%;
height: 100%;
flex-shrink: 0;
}
.yatra-reviews-section .yatra-no-reviews-message p {
color: #6b7280;
font-size: 15px;
margin: 0;
} .yatra-reviews-section .yatra-reviews-items {
display: flex;
flex-direction: column;
gap: var(--yatra-element-gap);
}
.yatra-reviews-section .yatra-review-item {
padding: var(--yatra-element-gap);
background: #f9fafb;
border-radius: 12px;
border: 1px solid #e5e7eb;
}
@media (max-width: 768px) {
.yatra-reviews-section-title {
font-size: 22px;
}
} .yatra-booking-info-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
gap: 24px;
margin-top: 24px;
}
.yatra-booking-info-card {
background: #f9fafb;
border-radius: 12px;
padding: 24px;
border: 1px solid #e5e7eb;
text-align: center;
transition: all 0.3s ease;
}
.yatra-booking-info-card:hover {
background: #fff;
box-shadow: 0 4px 12px rgba(0,0,0,0.08);
transform: translateY(-2px);
}
.yatra-booking-info-icon {
width: 56px;
height: 56px;
margin: 0 auto 16px;
display: flex;
align-items: center;
justify-content: center;
background: #eff6ff;
border-radius: 12px;
color: #3b82f6;
}
.yatra-booking-info-icon svg {
width: 28px;
height: 28px;
}
.yatra-booking-info-title {
font-size: 18px;
font-weight: 700;
color: #111827;
margin-bottom: 8px;
}
.yatra-booking-info-desc {
font-size: 14px;
color: #6b7280;
line-height: 1.6;
margin: 0;
}
.yatra-booking-info-link {
color: #3b82f6;
text-decoration: none;
font-weight: 500;
}
.yatra-booking-info-link:hover {
text-decoration: underline;
} .yatra-trip-testimonials {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
gap: 24px;
margin-top: 32px;
}
.yatra-testimonial-card {
background: #f9fafb;
border-radius: 16px;
padding: 28px;
border-left: 4px solid #3b82f6;
transition: all 0.3s ease;
}
.yatra-testimonial-card:hover {
background: #fff;
box-shadow: 0 4px 20px rgba(0,0,0,0.08);
transform: translateY(-4px);
}
.yatra-testimonial-rating {
color: #fbbf24;
font-size: 18px;
margin-bottom: 16px;
letter-spacing: 2px;
}
.yatra-testimonial-text {
font-size: 15px;
line-height: 1.8;
color: #374151;
margin: 0 0 20px 0;
font-style: italic;
}
.yatra-testimonial-author {
display: flex;
align-items: center;
gap: 16px;
}
.yatra-testimonial-avatar {
width: 52px;
height: 52px;
border-radius: 50%;
background: linear-gradient(135deg, #3b82f6 0%, #1e40af 100%);
display: flex;
align-items: center;
justify-content: center;
color: #fff;
font-weight: 700;
font-size: 20px;
flex-shrink: 0;
}
.yatra-testimonial-info {
flex: 1;
}
.yatra-testimonial-name {
font-size: 16px;
font-weight: 700;
color: #111827;
margin: 0 0 4px 0;
}
.yatra-testimonial-location {
font-size: 14px;
color: #6b7280;
margin: 0;
} .yatra-reviews-header {
margin-bottom: 32px;
}
.yatra-reviews-divider {
height: 2px;
background: #3b82f6;
margin-top: 16px;
width: 100%;
}
.yatra-reviews-container {
display: grid;
grid-template-columns: 320px 1fr;
gap: 48px;
margin-bottom: 40px;
} .yatra-reviews-summary {
position: sticky;
top: 100px;
height: fit-content;
}
.yatra-overall-rating {
text-align: center;
padding-bottom: 32px;
border-bottom: 1px solid #e5e7eb;
margin-bottom: 24px;
}
.yatra-overall-rating-label {
font-size: 12px;
font-weight: 600;
color: #6b7280;
margin: 0 0 16px 0;
text-transform: uppercase;
letter-spacing: 0.5px;
}
.yatra-overall-rating-score {
display: flex;
align-items: baseline;
justify-content: center;
gap: 2px;
margin-bottom: 12px;
}
.yatra-rating-big {
font-size: 56px;
font-weight: 700;
color: #1f2937;
line-height: 1;
}
.yatra-rating-max {
font-size: 24px;
font-weight: 400;
color: #6b7280;
}
.yatra-overall-stars {
display: flex;
justify-content: center;
gap: 4px;
margin-bottom: 8px;
}
.yatra-star-icon {
font-size: 28px;
color: #d1d5db;
}
.yatra-star-icon.filled {
color: var(--yatra-star, #fbbf24);
}
.yatra-star-icon.half {
background: linear-gradient(
90deg,
var(--yatra-star, #fbbf24) 50%,
#d1d5db 50%
);
-webkit-background-clip: text;
-webkit-text-fill-color: transparent;
background-clip: text;
color: transparent;
}
.yatra-reviews-based-on {
font-size: 14px;
color: #6b7280;
margin: 0;
} .yatra-review-categories {
padding: 0;
}
.yatra-review-categories-title {
font-size: 14px;
font-weight: 600;
color: #1f2937;
margin: 0 0 20px 0;
}
.yatra-review-category {
display: flex;
align-items: center;
gap: 12px;
margin-bottom: 16px;
}
.yatra-category-name {
width: 120px;
font-size: 14px;
color: #374151;
flex-shrink: 0;
}
.yatra-category-bar {
flex: 1;
height: 8px;
background: #e5e7eb;
border-radius: 4px;
overflow: hidden;
}
.yatra-category-bar-fill {
height: 100%;
background: #1e3a5f;
border-radius: 4px;
transition: width 0.3s ease;
}
.yatra-category-score {
width: 40px;
font-size: 14px;
color: #6b7280;
text-align: right;
flex-shrink: 0;
} .yatra-reviews-list {
min-width: 0;
}
.yatra-reviews-toolbar {
display: flex;
align-items: center;
gap: 12px;
margin-bottom: 24px;
}
.yatra-reviews-sort {
display: flex;
align-items: center;
gap: 8px;
}
.yatra-sort-label {
font-size: 14px;
color: #6b7280;
}
.yatra-sort-select {
padding: 10px 36px 10px 16px;
border: 1px solid #d1d5db;
border-radius: 8px;
font-size: 14px;
color: #1f2937;
background: #fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 12px center;
cursor: pointer;
appearance: none;
-webkit-appearance: none;
}
.yatra-sort-select:focus {
outline: none;
border-color: #3b82f6;
}
.yatra-filter-btn {
display: flex;
align-items: center;
gap: 6px;
padding: 10px 16px;
border: 1px solid #d1d5db;
border-radius: 8px;
background: #fff;
font-size: 14px;
color: #374151;
cursor: pointer;
transition: all 0.2s;
}
.yatra-filter-btn:hover {
border-color: #9ca3af;
background: #f9fafb;
} .yatra-reviews-items {
display: flex;
flex-direction: column;
gap: 16px;
}
.yatra-review-item {
padding: 20px 24px;
background: #fff;
border: 1px solid #e5e7eb;
border-radius: 12px;
transition: box-shadow 0.2s ease, border-color 0.2s ease;
}
.yatra-review-item:hover {
border-color: #d1d5db;
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.04);
}
.yatra-review-header {
display: flex;
align-items: flex-start;
justify-content: space-between;
margin-bottom: 16px;
}
.yatra-review-header-left {
display: flex;
align-items: center;
gap: 14px;
flex: 1;
}
.yatra-review-avatar {
width: 44px;
height: 44px;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
color: #fff;
font-size: 16px;
font-weight: 600;
flex-shrink: 0;
background: linear-gradient(135deg, #1e3a5f 0%, #2d5a87 100%);
}
.yatra-review-author-info {
flex: 1;
min-width: 0;
}
.yatra-review-author-top {
display: flex;
align-items: center;
gap: 10px;
margin-bottom: 4px;
}
.yatra-review-author-name {
font-size: 15px;
font-weight: 600;
color: #1f2937;
}
.yatra-verified-badge {
display: inline-flex;
align-items: center;
gap: 4px;
padding: 2px 8px;
background: #ecfdf5;
border-radius: 20px;
font-size: 11px;
font-weight: 500;
color: #059669;
}
.yatra-verified-badge .yatra-icon-xs {
width: 12px;
height: 12px;
}
.yatra-review-meta {
display: flex;
align-items: center;
gap: 8px;
font-size: 13px;
color: #6b7280;
}
.yatra-review-author-location {
font-weight: 400;
color: #6b7280;
}
.yatra-review-stars {
display: flex;
align-items: center;
gap: 2px;
}
.yatra-star-sm {
font-size: 14px;
color: #d1d5db;
}
.yatra-star-sm.filled {
color: #fbbf24;
}
.yatra-review-rating-num {
margin-left: 6px;
font-size: 13px;
font-weight: 600;
color: #1f2937;
}
.yatra-review-more-btn {
width: 32px;
height: 32px;
display: flex;
align-items: center;
justify-content: center;
border: none;
background: transparent;
color: #9ca3af;
border-radius: 6px;
cursor: pointer;
transition: all 0.2s;
}
.yatra-review-more-btn:hover {
background: #f3f4f6;
color: #6b7280;
}
.yatra-review-body {
padding-left: 58px;
}
.yatra-review-title {
font-size: 15px;
font-weight: 600;
color: #1f2937;
margin: 0 0 6px 0;
line-height: 1.4;
}
.yatra-review-content {
font-size: 14px;
line-height: 1.7;
color: #4b5563;
margin: 0;
} .yatra-review-author-row {
display: flex;
align-items: flex-start;
gap: 14px;
margin-bottom: 16px;
} .yatra-reviews-load-more {
padding-top: 24px;
}
.yatra-load-more-btn {
width: 100%;
padding: 14px 24px;
border: 1px solid #d1d5db;
border-radius: 8px;
background: #fff;
font-size: 15px;
font-weight: 500;
color: #374151;
cursor: pointer;
transition: all 0.2s;
}
.yatra-load-more-btn:hover {
border-color: #9ca3af;
background: #f9fafb;
}
.yatra-no-reviews-message {
text-align: center;
padding: 40px;
background: #f9fafb;
border-radius: 12px;
color: #6b7280;
} @media (max-width: 968px) {
.yatra-reviews-container {
grid-template-columns: 1fr;
gap: 32px;
}
.yatra-reviews-summary {
position: static;
display: grid;
grid-template-columns: 1fr 1fr;
gap: 24px;
padding: 24px;
background: #f9fafb;
border-radius: 12px;
}
.yatra-overall-rating {
padding-bottom: 0;
border-bottom: none;
margin-bottom: 0;
border-right: 1px solid #e5e7eb;
padding-right: 24px;
}
.yatra-review-categories {
padding-left: 24px;
}
}
@media (max-width: 640px) {
.yatra-reviews-summary {
grid-template-columns: 1fr;
}
.yatra-overall-rating {
border-right: none;
padding-right: 0;
padding-bottom: 24px;
border-bottom: 1px solid #e5e7eb;
margin-bottom: 24px;
}
.yatra-review-categories {
padding-left: 0;
}
.yatra-reviews-toolbar {
flex-wrap: wrap;
}
.yatra-reviews-sort {
width: 100%;
}
.yatra-sort-select {
flex: 1;
}
}
.yatra-review-form-section {
margin-top: 40px;
padding-top: 40px;
padding-bottom: var(--yatra-element-gap);
border-top: 1px solid #e5e7eb;
}
.yatra-review-form-title {
font-size: 20px;
font-weight: 700;
color: #1f2937;
margin: 0 0 24px 0;
}
.yatra-review-login-notice,
.yatra-review-booking-notice,
.yatra-review-already-notice {
padding: 20px 24px;
background: #f3f4f6;
border-radius: 12px;
color: #4b5563;
font-size: 15px;
}
.yatra-review-login-notice a {
color: #3b82f6;
font-weight: 600;
text-decoration: none;
}
.yatra-review-login-notice a:hover {
text-decoration: underline;
}
.yatra-review-form {
display: flex;
flex-direction: column;
gap: 24px;
}
.yatra-form-field {
display: flex;
flex-direction: column;
gap: 8px;
}
.yatra-form-label {
font-size: 14px;
font-weight: 600;
color: #374151;
}
.yatra-required {
color: #ef4444;
}
.yatra-rating-field .yatra-star-rating-input {
display: flex;
flex-direction: row;
justify-content: flex-start;
gap: 4px;
}
.yatra-star-rating-input input {
display: none;
}
.yatra-star-label {
font-size: 32px;
color: #d1d5db;
cursor: pointer;
transition: color 0.2s;
}
.yatra-star-rating-input .yatra-star-label.selected,
.yatra-star-rating-input .yatra-star-label.hover {
color: #fbbf24;
}
.yatra-star-rating-input input:disabled + .yatra-star-label {
cursor: not-allowed;
opacity: 0.5;
} .yatra-star-rating-input .yatra-star-label {
position: relative;
z-index: 1;
user-select: none;
-webkit-user-select: none;
}
.yatra-field-hint {
font-size: 12px;
color: #9ca3af;
margin: 0;
}
.yatra-form-input,
.yatra-form-textarea {
padding: 12px 16px;
border: 1px solid #d1d5db;
border-radius: 8px;
font-size: 15px;
color: #1f2937;
transition: all 0.2s;
}
.yatra-form-input:focus,
.yatra-form-textarea:focus {
outline: none;
border-color: #3b82f6;
box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}
.yatra-form-textarea {
resize: vertical;
min-height: 120px;
}
.yatra-review-submit-btn {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 8px;
padding: 14px 28px;
background: #3b82f6;
color: #fff;
border: none;
border-radius: 8px;
font-size: 15px;
font-weight: 600;
cursor: pointer;
transition: all 0.2s;
width: fit-content;
}
.yatra-review-submit-btn:hover {
background: #2563eb;
transform: translateY(-1px);
box-shadow: 0 4px 12px rgba(59, 130, 246, 0.3);
}
.yatra-review-moderation-notice {
font-size: 13px;
color: #6b7280;
margin: 8px 0 0 0;
font-style: italic;
}
.yatra-review-message {
padding: 16px 20px;
border-radius: 8px;
margin-bottom: 20px;
font-size: 14px;
}
.yatra-review-message p {
margin: 0;
padding: 0;
}
.yatra-review-message-success {
background: #dcfce7;
color: #166534;
border: 1px solid #86efac;
}
.yatra-review-message-error {
background: #fef2f2;
color: #991b1b;
border: 1px solid #fca5a5;
} .yatra-review-edit-notice {
display: flex;
align-items: center;
gap: 10px;
padding: 12px 16px;
background: #eff6ff;
border: 1px solid #bfdbfe;
border-radius: 8px;
margin-bottom: 20px;
color: #1e40af;
font-size: 14px;
}
.yatra-review-edit-notice svg {
flex-shrink: 0;
color: #3b82f6;
}
.yatra-review-edit-notice p {
margin: 0;
}
.yatra-loading-spinner {
display: inline-block;
width: 16px;
height: 16px;
border: 2px solid rgba(255, 255, 255, 0.3);
border-radius: 50%;
border-top-color: #fff;
animation: yatra-spin 0.8s linear infinite;
}
@keyframes yatra-spin {
to {
transform: rotate(360deg);
}
} @media (max-width: 768px) {
.yatra-review-summary {
padding: 24px;
}
.yatra-review-summary-number {
font-size: 36px;
}
.yatra-star-label {
font-size: 28px;
}
.yatra-review-form-section {
margin-top: 32px;
padding-top: 32px;
}
} .yatra-requirements-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
gap: 24px;
margin-top: 32px;
}
.yatra-requirement-card {
background: #f9fafb;
border-radius: 12px;
padding: 24px;
border: 1px solid #e5e7eb;
}
.yatra-requirement-title {
font-size: 18px;
font-weight: 700;
color: #111827;
margin: 0 0 16px 0;
display: flex;
align-items: center;
gap: 10px;
}
.yatra-requirement-icon {
width: 24px;
height: 24px;
color: #3b82f6;
}
.yatra-requirement-content {
font-size: 15px;
line-height: 1.7;
color: #4b5563;
margin: 0;
} .yatra-accommodation-transport {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 32px;
margin-top: 32px;
}
.yatra-accommodation-card,
.yatra-transport-card {
background: #f9fafb;
border-radius: 12px;
padding: 24px;
border: 1px solid #e5e7eb;
}
.yatra-accommodation-title,
.yatra-transport-title {
font-size: 20px;
font-weight: 700;
color: #111827;
margin: 0 0 16px 0;
display: flex;
align-items: center;
gap: 12px;
}
.yatra-accommodation-icon,
.yatra-transport-icon {
width: 24px;
height: 24px;
color: #3b82f6;
}
.yatra-accommodation-details,
.yatra-transport-details {
font-size: 15px;
line-height: 1.8;
color: #374151;
margin: 0;
} @media (max-width: 1024px) {
.yatra-trip-container {
grid-template-columns: 1fr;
gap: var(--yatra-element-gap);
}
.yatra-trip-sidebar {
position: static;
order: -1;
}
.yatra-enquiry-form-grid {
grid-template-columns: 1fr 1fr;
}
.yatra-trip-hero-title {
font-size: 2.75rem;
}
.yatra-included-excluded {
grid-template-columns: 1fr;
}
.yatra-accommodation-transport {
grid-template-columns: 1fr;
}
.yatra-spec-sheet > .yatra-trip-quick-facts {
grid-template-columns: repeat(3, 1fr);
gap: 1px;
padding: 0;
}
.yatra-hero-images {
grid-template-columns: 1fr;
}
.yatra-hero-side-images {
flex-direction: row;
overflow-x: auto;
gap: 12px;
}
.yatra-side-image-item {
min-width: 200px;
flex-shrink: 0;
}
.yatra-trip-hero-title-new {
font-size: 2rem;
}
}
@media (max-width: 768px) {
.yatra-trip-hero {
height: 65vh;
min-height: 550px;
max-height: 650px;
} .yatra-sticky-nav-container {
gap: var(--yatra-tiny-gap);
padding: 0 var(--yatra-container-padding);
scroll-behavior: smooth;
scrollbar-width: none; -ms-overflow-style: none; }
.yatra-sticky-nav-container::-webkit-scrollbar {
display: none; }
.yatra-sticky-nav-item {
font-size: 12px;
padding: 12px 8px;
white-space: nowrap;
flex-shrink: 0;
min-width: fit-content;
}
.yatra-sticky-nav-item svg {
width: 16px;
height: 16px;
}
.yatra-sticky-nav-label {
display: none; } @media (min-width: 480px) {
.yatra-sticky-nav-label {
display: inline;
}
.yatra-sticky-nav-item {
padding: 12px 12px;
}
} .yatra-trip-sidebar {
display: none !important;
position: static !important;
order: unset !important;
}
.yatra-trip-main {
width: 100%;
max-width: none;
}
.yatra-trip-container {
grid-template-columns: 1fr;
}
.yatra-trip-hero-title {
font-size: 2.25rem;
}
.yatra-trip-hero-subtitle {
font-size: 1.125rem;
}
.yatra-spec-sheet > .yatra-trip-quick-facts {
grid-template-columns: repeat(2, 1fr);
gap: 1px;
padding: 0;
}
.yatra-trip-quick-facts .yatra-rating-display {
flex-direction: column;
align-items: flex-start;
gap: 4px;
}
.yatra-trip-hero-new {
padding-top: var(--yatra-hero-mobile-padding-top, 16px);
padding-bottom: var(--yatra-hero-mobile-padding-bottom, 20px);
padding-left: var(--yatra-container-padding);
padding-right: var(--yatra-container-padding);
}
.yatra-trip-hero-title-new {
font-size: 1.75rem;
}
.yatra-hero-meta {
flex-wrap: wrap;
gap: 8px;
}
.yatra-hero-rating {
flex-wrap: wrap;
gap: 8px;
}
.yatra-hero-location,
.yatra-hero-duration {
font-size: 14px;
}
.yatra-hero-breadcrumb {
font-size: 12px;
margin-bottom: 10px;
}
.yatra-hero-breadcrumb-current {
font-weight: 400;
}
.yatra-hero-images {
gap: 12px;
}
.yatra-hero-discount-tag {
top: 12px;
left: 12px;
padding: 8px 14px;
font-size: 12px;
}
.yatra-hero-book-now-btn {
padding: 12px 20px;
font-size: 14px;
}
.yatra-sticky-nav-container {
gap: var(--yatra-element-gap);
padding: 0 var(--yatra-container-padding);
}
.yatra-sticky-nav-item {
font-size: 13px;
padding: 14px 0;
}
.yatra-sticky-nav-price {
font-size: 16px;
}
.yatra-hero-side-images {
flex-direction: row;
overflow-x: auto;
gap: 12px;
-webkit-overflow-scrolling: touch;
}
.yatra-side-image-item {
min-width: 150px;
}
.yatra-hero-tags {
flex-wrap: wrap;
gap: 8px;
padding: 16px 0;
}
.yatra-tag {
font-size: 11px;
padding: 6px 12px;
}
.yatra-carbon-badge {
margin-left: 0;
width: 100%;
margin-top: 8px;
}
.yatra-quick-fact {
gap: 12px;
padding: 12px 14px;
}
.yatra-quick-fact-icon svg {
width: 22px;
height: 22px;
min-width: 22px;
min-height: 22px;
}
.yatra-quick-fact-label {
font-size: 11px;
margin-bottom: 4px;
}
.yatra-quick-fact-value {
font-size: 15px;
}
.yatra-quick-fact-price {
font-size: 15px;
}
.yatra-quick-fact-price-label {
font-size: 11px;
margin-top: 4px;
}
.yatra-hero-gallery-play {
bottom: 20px;
right: 20px;
width: 60px;
height: 60px;
}
.yatra-hero-gallery-play svg {
width: 24px;
height: 24px;
}
.yatra-hero-gallery-play span {
font-size: 9px;
}
.yatra-gallery-modal-content {
width: 100%;
height: 100vh;
max-height: 100vh;
border-radius: 0;
}
.yatra-gallery-modal-prev,
.yatra-gallery-modal-next {
width: 40px;
height: 40px;
}
.yatra-gallery-modal-prev {
left: 10px;
}
.yatra-gallery-modal-next {
right: 10px;
}
.yatra-gallery-modal-close {
top: 10px;
right: 10px;
width: 36px;
height: 36px;
} .admin-bar .yatra-gallery-modal-close {
top: 56px; }
.admin-bar .yatra-gallery-modal-content {
margin-top: 46px;
max-height: calc(100vh - 46px);
}
.yatra-gallery-thumbnail {
width: 60px;
height: 60px;
}
.yatra-trip-section {
padding: 32px 24px;
}
.yatra-trip-section-title {
font-size: 24px;
}
.yatra-trip-gallery {
grid-template-columns: repeat(2, 1fr);
}
.yatra-trip-testimonials {
grid-template-columns: 1fr;
}
.yatra-itinerary-day {
padding-left: 60px;
}
.yatra-itinerary-day-content {
margin-left: 56px;
}
}
@media (max-width: 480px) {
.yatra-trip-hero {
padding-top: 20px;
}
.yatra-trip-hero-title {
font-size: 1.875rem;
}
.yatra-trip-section {
padding: 24px 20px;
}
.yatra-trip-section-title {
font-size: 22px;
}
.yatra-booking-card {
padding: 24px;
}
.yatra-booking-price-amount {
font-size: 42px;
}
.yatra-trip-gallery {
grid-template-columns: 1fr;
}
.yatra-spec-sheet > .yatra-trip-quick-facts {
grid-template-columns: 1fr;
gap: 1px;
padding: 0;
}
} .yatra-badge {
display: inline-flex;
align-items: center;
gap: 6px;
padding: 6px 14px;
border-radius: 20px;
font-size: 12px;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.5px;
}
.yatra-badge-featured {
background: #fef3c7;
color: #92400e;
}
.yatra-badge-popular {
background: #dbeafe;
color: #1e40af;
}
.yatra-badge-new {
background: #d1fae5;
color: #065f46;
}
.yatra-badge-limited {
background: #fee2e2;
color: #991b1b;
}
.yatra-badge-bestseller {
background: #fce7f3;
color: #9f1239;
} .yatra-availability-section {
margin-bottom: 48px;
}
.yatra-availability-header {
margin-bottom: 32px;
}
.yatra-availability-header-top {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 12px;
gap: 24px;
}
.yatra-availability-sort {
flex-shrink: 0;
}
.yatra-availability-sort-select {
padding: 10px 16px;
border: 1px solid #e5e7eb;
border-radius: 8px;
font-size: 14px;
font-weight: 500;
color: #374151;
background: #fff;
cursor: pointer;
transition: all 0.2s ease;
min-width: 200px;
}
.yatra-availability-sort-select:hover {
border-color: #3b82f6;
}
.yatra-availability-sort-select:focus {
outline: none;
border-color: #3b82f6;
box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}
.yatra-availability-subtitle {
font-size: 16px;
color: #6b7280;
margin: 0;
}
.yatra-availability-filters {
display: flex;
gap: 12px;
margin-bottom: 32px;
flex-wrap: wrap;
}
.yatra-availability-filter-btn {
padding: 10px 20px;
border: 1px solid #e5e7eb;
background: #fff;
border-radius: 8px;
font-size: 14px;
font-weight: 500;
color: #374151;
cursor: pointer;
transition: all 0.2s ease;
}
.yatra-availability-filter-btn:hover {
border-color: #3b82f6;
color: #3b82f6;
background: #eff6ff;
}
.yatra-availability-filter-btn.active {
background: #3b82f6;
border-color: #3b82f6;
color: #fff;
} .yatra-availability-list {
display: flex;
flex-direction: column;
gap: 20px;
margin-bottom: 32px;
} .yatra-availability-card {
background: #fff;
border: 1px solid #e5e7eb;
border-radius: 14px;
overflow: visible;
transition: all 0.2s ease;
position: relative;
}
.yatra-availability-card:hover {
border-color: #d1d5db;
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}
.yatra-availability-card.open {
border-color: #bfdbfe;
box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
} .yatra-availability-card.selected {
border-color: #3b82f6;
box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1), 0 10px 30px rgba(15, 23, 42, 0.08);
background: #f0f9ff;
}
.yatra-availability-card.selected .yatra-availability-card-header {
background: #eff6ff;
} .yatra-availability-card-header {
position: relative;
padding: 20px 24px;
cursor: pointer;
user-select: none;
background: #f8fafc;
transition: all 0.2s ease;
border-bottom: 1px solid #e2e8f0;
}
.yatra-availability-card-header:hover {
background: #f1f5f9;
} .yatra-card-date-header {
display: flex;
align-items: center;
gap: 8px;
font-size: 14px;
font-weight: 600;
color: #2563eb;
margin-bottom: 12px;
padding-bottom: 12px;
border-bottom: 1px solid #e5e7eb;
}
.yatra-card-date-header svg {
width: 16px;
height: 16px;
color: #2563eb;
} .yatra-day-trip-grid .yatra-card-header-date {
font-size: 18px;
font-weight: 700;
}
.yatra-card-header-grid {
display: grid;
grid-template-columns: 1fr 1fr auto auto auto;
gap: 20px;
align-items: center;
} .yatra-card-badges-container {
position: absolute;
top: -12px;
right: 20px;
display: flex;
align-items: center;
gap: 8px;
z-index: 10;
}
.yatra-card-header-item {
display: flex;
flex-direction: column;
gap: 6px;
min-width: 0;
}
.yatra-card-header-label {
font-size: 10px;
font-weight: 600;
color: #9ca3af;
text-transform: uppercase;
letter-spacing: 0.5px;
line-height: 1;
}
.yatra-card-header-date {
font-size: 16px;
font-weight: 700;
color: #111827;
line-height: 1.2;
margin-bottom: 2px;
}
.yatra-card-header-location {
font-size: 13px;
color: #6b7280;
line-height: 1.4;
font-weight: 400;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.yatra-card-header-seats {
font-size: 20px;
font-weight: 700;
color: #111827;
line-height: 1;
margin-bottom: 4px;
}
.yatra-card-header-sub {
font-size: 12px;
color: #9ca3af;
line-height: 1.2;
font-weight: 400;
}
.yatra-card-header-price {
position: relative;
display: flex;
flex-direction: column;
align-items: flex-end;
gap: 6px;
flex-shrink: 0;
min-width: 140px;
}
.yatra-card-price-group {
display: flex;
flex-direction: column;
align-items: flex-end;
gap: 2px;
}
.yatra-sale-price {
font-size: 20px;
font-weight: 700;
color: #111827;
line-height: 1;
letter-spacing: -0.5px;
}
.yatra-price-label {
font-size: 12px;
color: #9ca3af;
font-weight: 400;
line-height: 1;
}
.yatra-card-discount-badge {
padding: 6px 12px;
background: #dc2626;
color: #fff;
font-size: 11px;
font-weight: 600;
border-radius: 6px;
text-transform: uppercase;
letter-spacing: 0.5px;
line-height: 1;
white-space: nowrap;
box-shadow: 0 2px 4px rgba(220, 38, 38, 0.3);
}
.yatra-badge-discount {
background: #16a34a;
color: #fff;
}
.yatra-badge-higher {
background: #ef4444;
color: #fff;
}
.yatra-card-price-group {
display: flex;
align-items: baseline;
gap: 6px;
}
.yatra-card-price-original {
font-size: 12px;
color: #9ca3af;
text-decoration: line-through;
line-height: 1.2;
}
.yatra-card-price-sale {
font-size: 18px;
font-weight: 700;
color: #111827;
line-height: 1.2;
}
.yatra-card-header-arrow {
display: flex;
align-items: center;
justify-content: center;
width: 24px;
height: 24px;
color: #9ca3af;
transition: all 0.2s ease;
}
.yatra-card-header-arrow:hover {
color: #6b7280;
}
.yatra-availability-card.open .yatra-card-header-arrow {
transform: rotate(180deg);
color: #2563eb;
} .yatra-availability-card-body {
display: none;
padding: 16px;
background: #fefefe;
border-top: 1px solid #e2e8f0;
overflow: visible;
position: relative;
border-radius:0 0 14px 14px;
}
.yatra-availability-card.open .yatra-availability-card-body {
display: block;
}
.yatra-card-body-content {
display: flex;
flex-direction: column;
gap: 12px;
}
.yatra-card-tour-header {
display: flex;
flex-direction: column;
gap: 4px;
}
.yatra-card-tour-title {
font-size: 18px;
font-weight: 600;
color: #111827;
margin: 0;
line-height: 1.4;
}
.yatra-card-tour-meta {
display: flex;
align-items: center;
gap: 6px;
flex-wrap: wrap;
}
.yatra-card-tour-type {
font-size: 13px;
color: #3b82f6;
font-weight: 500;
line-height: 1.4;
}
.yatra-card-tour-separator {
font-size: 13px;
color: #9ca3af;
line-height: 1.4;
}
.yatra-card-tour-location {
font-size: 13px;
color: #6b7280;
line-height: 1.4;
} .yatra-card-info-grid {
display: flex;
flex-wrap: wrap;
gap: 14px;
padding: 0;
background: transparent;
border-radius: 0;
border: none;
}
.yatra-card-info-item {
display: flex;
gap: 8px;
align-items: center;
padding: 0;
background: transparent;
border: none;
border-radius: 0;
}
.yatra-card-info-icon {
flex-shrink: 0;
width: 18px;
height: 18px;
display: flex;
align-items: center;
justify-content: center;
background: transparent;
border-radius: 0;
color: #2563eb;
}
.yatra-card-info-icon svg {
width: 18px;
height: 18px;
}
.yatra-card-info-content {
flex: 1;
display: flex;
flex-direction: row;
align-items: baseline;
gap: 8px;
}
.yatra-card-info-label {
font-size: 13px;
font-weight: 600;
color: #475569;
text-transform: none;
letter-spacing: 0;
line-height: 1.3;
}
.yatra-card-info-value {
font-size: 13px;
font-weight: 700;
color: #0f172a;
line-height: 1.3;
} .yatra-card-timeline {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 16px;
padding: 10px;
background: #f9fafb;
border-radius: 8px;
border: none;
}
.yatra-timeline-item {
position: relative;
display: flex;
gap: 10px;
align-items: flex-start;
}
.yatra-timeline-dot {
flex-shrink: 0;
width: 10px;
height: 10px;
border-radius: 50%;
border: 2px solid #fff;
margin-top: 20px;
}
.yatra-timeline-dot-start {
background: #10b981;
box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.2);
}
.yatra-timeline-dot-end {
background: #ef4444;
box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.2);
}
.yatra-timeline-content {
flex: 1;
}
.yatra-timeline-label {
font-size: 10px;
font-weight: 600;
color: #6b7280;
text-transform: uppercase;
letter-spacing: 0.4px;
margin-bottom: 3px;
line-height: 1.3;
}
.yatra-timeline-date {
font-size: 14px;
font-weight: 600;
color: #111827;
margin-bottom: 2px;
line-height: 1.3;
}
.yatra-timeline-location {
font-size: 12px;
color: #6b7280;
line-height: 1.4;
}
.yatra-card-traveler-section {
display: flex;
flex-direction: column;
gap: 8px;
}
.yatra-card-action-steps {
display: flex;
align-items: center;
gap: 8px;
padding: 0;
background: transparent;
border: none;
border-radius: 0;
margin-top: 2px;
}
.yatra-card-action-step {
display: inline-flex;
align-items: center;
gap: 8px;
font-size: 13px;
font-weight: 600;
color: #0f172a;
line-height: 1.2;
}
.yatra-card-action-step-num {
width: 20px;
height: 20px;
display: inline-flex;
align-items: center;
justify-content: center;
border-radius: 999px;
background: #2563eb;
color: #fff;
font-size: 11px;
font-weight: 700;
flex-shrink: 0;
}
.yatra-card-action-step-sep {
color: #94a3b8;
font-weight: 700;
}
.yatra-card-action-help {
font-size: 12px;
color: #64748b;
line-height: 1.4;
margin-top: 0;
}
.yatra-card-traveler-label {
font-size: 12px;
font-weight: 600;
color: #374151;
line-height: 1.4;
}
.yatra-card-traveler-section .yatra-booking-field-select {
width: 100%;
border-color: #e5e7eb;
border-radius: 12px;
min-height: 52px;
height: 52px;
}
.yatra-card-traveler-section .yatra-booking-field-select:focus-within {
border-color: #93c5fd;
box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.12);
}
.yatra-card-traveler-section .yatra-booking-field-icon {
color: #2563eb;
} .yatra-availability-card .yatra-availability-participants {
width: 100%;
}
.yatra-availability-card .yatra-availability-participants .yatra-booking-field-select {
border-radius: 12px;
border-color: #e5e7eb;
background: #fff;
min-height: 52px;
height: 52px;
}
.yatra-availability-card .yatra-availability-participants .yatra-booking-field-icon {
padding: 0 14px;
color: #2563eb;
}
.yatra-availability-card .yatra-availability-participants-display {
padding: 0 42px 0 0;
font-size: 14px;
font-weight: 600;
color: #0f172a;
}
.yatra-availability-card .yatra-select-arrow {
right: 14px;
width: 18px;
height: 18px;
color: #64748b;
}
.yatra-availability-card .yatra-availability-quantity-selector {
left: 0;
right: 0;
margin-top: 10px;
border-radius: 14px;
border-color: #e5e7eb;
padding: 12px;
}
.yatra-availability-card .yatra-quantity-row {
padding: 10px 8px;
border-radius: 10px;
}
.yatra-availability-card .yatra-quantity-row:not(:last-child) {
border-bottom: 1px solid #f1f5f9;
margin-bottom: 2px;
padding-bottom: 10px;
} .yatra-availability-travelers-simple {
display: flex;
align-items: center;
gap: 12px;
padding: 10px 14px;
background: #f9fafb;
border: 1px solid #e5e7eb;
border-radius: 8px;
}
.yatra-availability-travelers-simple .yatra-booking-field-icon {
flex-shrink: 0;
}
.yatra-availability-travelers-simple .yatra-quantity-input-simple {
width: 45px;
font-size: 14px;
font-weight: 600;
color: #111827;
background: transparent;
border: none;
}
.yatra-availability-travelers-simple .yatra-quantity-btn {
width: 28px;
height: 28px;
display: flex;
align-items: center;
justify-content: center;
background: #fff;
border: 1px solid #d1d5db;
border-radius: 6px;
cursor: pointer;
transition: all 0.15s ease;
}
.yatra-availability-travelers-simple .yatra-quantity-btn:hover:not(:disabled) {
background: #f3f4f6;
border-color: #2563eb;
}
.yatra-availability-travelers-simple .yatra-quantity-btn:disabled {
opacity: 0.5;
cursor: not-allowed;
}
.yatra-availability-travelers-simple .yatra-quantity-btn svg {
width: 14px;
height: 14px;
color: #374151;
}
.yatra-availability-travelers-simple .yatra-travelers-label {
font-size: 13px;
color: #6b7280;
margin-left: 4px;
} .yatra-card-booking-row {
display: flex;
gap: 10px;
align-items: stretch;
margin-top: 16px;
padding-top: 16px;
border-top: 1px solid #eef2f7;
}
.yatra-card-total-box {
flex: 1;
padding: 8px 12px;
background: #f8fafc;
border: 1px solid #eef2f7;
border-radius: 12px;
display: flex;
flex-direction: row;
align-items: center;
gap: 6px;
}
.yatra-card-total-label {
font-size: 12px;
font-weight: 600;
color: #6b7280;
text-transform: uppercase;
letter-spacing: 0.5px;
white-space: nowrap;
}
.yatra-card-total-note {
font-size: 12px;
color: #6b7280;
white-space: nowrap;
}
.yatra-card-total-amount {
font-size: 16px;
font-weight: 700;
color: #3b82f6;
line-height: 1;
white-space: nowrap;
margin-left: auto;
}
.yatra-card-book-btn {
flex: 1;
padding: 12px 16px;
background: #3b82f6;
color: #fff;
border: none;
border-radius: 12px;
font-size: 13px;
font-weight: 600;
cursor: pointer;
transition: all 0.2s ease;
white-space: nowrap;
display: inline-flex;
align-items: center;
justify-content: center;
gap: 10px;
text-align: left;
text-decoration: none;
}
.yatra-card-book-btn svg {
width: 18px;
height: 18px;
flex-shrink: 0;
}
.yatra-card-book-btn-text {
display: flex;
flex-direction: column;
align-items: flex-start;
line-height: 1.1;
}
.yatra-card-book-btn-title {
font-size: 14px;
font-weight: 700;
color: #fff;
}
.yatra-card-book-btn-subtitle {
font-size: 11px;
font-weight: 500;
color: rgba(255,255,255,0.9);
}
.yatra-card-book-btn:hover:not(:disabled),
a.yatra-card-book-btn:hover {
background: #2563eb;
transform: translateY(-1px);
box-shadow: 0 4px 12px rgba(59, 130, 246, 0.3);
color: #fff;
text-decoration: none;
}
.yatra-card-book-btn:disabled {
background: #9ca3af;
cursor: not-allowed;
opacity: 0.7;
} .yatra-availability-participants {
position: relative;
width: 100%;
cursor: pointer;
}
.yatra-availability-participants-display {
flex: 1;
padding: 14px 12px 14px 0;
font-size: 15px;
font-weight: 500;
color: #111827;
cursor: pointer;
user-select: none;
height: 100%;
display: flex;
align-items: center;
transition: color 0.2s ease;
}
.yatra-availability-participants:hover .yatra-availability-participants-display {
color: #3b82f6;
}
.yatra-availability-quantity-selector {
position: absolute;
top: 100%;
left: -12px;
right: -12px;
margin-top: 8px;
border: 1px solid #e5e7eb;
border-radius: 12px;
padding: 12px;
background: #fff;
box-shadow: 0 10px 25px rgba(0,0,0,0.1), 0 4px 6px rgba(0,0,0,0.05);
z-index: 1000;
display: none;
max-height: 350px;
overflow-y: auto;
}
.yatra-availability-participants.active .yatra-availability-quantity-selector {
display: block;
animation: slideDown 0.2s ease-out;
} @media (max-width: 1024px) {
.yatra-card-header-grid {
grid-template-columns: 1fr 1fr;
gap: 16px;
}
.yatra-card-header-price {
grid-column: 1 / -1;
align-items: flex-start;
}
.yatra-card-header-arrow {
grid-column: 2;
grid-row: 1;
justify-self: end;
}
.yatra-card-body-content {
gap: 16px;
}
}
@media (max-width: 768px) {
.yatra-availability-card-header {
padding: 14px 16px;
}
.yatra-card-header-grid {
grid-template-columns: 1fr;
gap: 10px;
}
.yatra-card-header-arrow {
position: absolute;
top: 14px;
right: 16px;
}
.yatra-availability-card-body {
padding: 14px;
}
.yatra-card-body-content {
gap: 16px;
}
.yatra-card-body-left {
gap: 10px;
}
.yatra-card-info-grid {
grid-template-columns: 1fr;
gap: 10px;
padding: 10px;
}
.yatra-card-booking-row {
flex-direction: column;
margin-top: 12px;
padding-top: 12px;
}
.yatra-card-book-btn {
width: 100%;
}
}
.yatra-availability-toggle {
border: none;
background: transparent;
width: 100%;
border-radius:12px;
} .yatra-availability-load-more {
display: flex;
flex-direction: column;
gap: 2px;
min-width: 120px;
flex: 1 1 0;
}
.yatra-summary-label {
font-size: 12px;
color: #6b7280;
text-transform: uppercase;
letter-spacing: 0.5px;
}
.yatra-summary-value {
font-size: 16px;
font-weight: 700;
color: #0f172a;
}
.yatra-summary-sub {
font-size: 13px;
color: #6b7280;
}
.yatra-summary-price {
margin-left: auto;
text-align: right;
flex: 0 0 auto;
display: flex;
flex-direction: column;
align-items: flex-end;
gap: 2px;
min-width: 250px;
}
.yatra-summary-price div {
display: flex;
align-items: baseline;
justify-content: flex-end;
gap: 8px;
}
.yatra-summary-original {
font-size: 13px;
color: #9ca3af;
text-decoration: line-through;
}
.yatra-summary-sale {
font-size: 20px;
font-weight: 700;
color: #111827;
}
.yatra-summary-arrow {
width: 14px;
height: 14px;
border-right: 2px solid #374151;
border-bottom: 2px solid #374151;
transform: rotate(45deg);
transition: transform 0.2s ease;
}
.yatra-availability-item.open .yatra-summary-arrow {
transform: rotate(-135deg);
}
.yatra-availability-details {
display: none;
border-top: 1px solid #e5e7eb;
padding: 0 24px 24px;
background: #f9fafb;
}
.yatra-availability-item.open .yatra-availability-details {
display: block;
}
.yatra-availability-details-content {
display: flex;
flex-direction: column;
gap: 20px;
padding-top: 20px;
}
.yatra-details-heading {
display: flex;
flex-direction: column;
gap: 4px;
}
.yatra-details-title {
font-size: 18px;
font-weight: 700;
color: #0f172a;
margin: 0;
}
.yatra-details-subtitle {
font-size: 14px;
color: #3b82f6;
font-weight: 600;
margin: 0;
}
.yatra-details-timeline {
border-left: 2px dashed #d1d5db;
padding-left: 18px;
margin-left: 10px;
display: flex;
flex-direction: column;
gap: 16px;
}
.yatra-timeline-row {
display: flex;
gap: 12px;
align-items: flex-start;
}
.yatra-timeline-dot {
width: 14px;
height: 14px;
border-radius: 50%;
margin-left: -25px;
margin-top: 20px;
}
.yatra-timeline-dot.success {
background: #10b981;
box-shadow: 0 0 0 4px rgba(16, 185, 129, 0.2);
}
.yatra-timeline-dot.danger {
background: #ef4444;
box-shadow: 0 0 0 4px rgba(239, 68, 68, 0.2);
}
.yatra-timeline-label {
font-size: 12px;
color: #6b7280;
text-transform: uppercase;
letter-spacing: 0.4px;
}
.yatra-timeline-meta {
display: block;
font-size: 13px;
color: #6b7280;
}
.yatra-details-right {
border-left: 1px solid #e5e7eb;
padding-left: 24px;
display: flex;
flex-direction: column;
gap: 16px;
}
.yatra-details-price-group {
display: flex;
flex-direction: column;
gap: 6px;
}
.yatra-details-price-label {
font-size: 12px;
color: #6b7280;
text-transform: uppercase;
letter-spacing: 0.4px;
}
.yatra-details-price {
display: flex;
align-items: baseline;
gap: 8px;
}
.yatra-details-price-note {
font-size: 12px;
color: #6b7280;
}
.yatra-availability-traveler-picker {
display: flex;
flex-direction: column;
gap: 8px;
}
.yatra-availability-traveler-picker .yatra-booking-field-select {
width: 100%;
}
.yatra-availability-total-row {
display: flex;
align-items: center;
gap: 16px;
width: 100%;
}
.yatra-availability-total-price {
display: flex;
flex-direction: column;
background: #f8fafc;
border: 1px solid #e5e7eb;
border-radius: 10px;
padding: 10px 14px;
flex: 1 1 50%;
}
.yatra-availability-total-label {
font-size: 13px;
font-weight: 600;
color: #374151;
text-transform: uppercase;
letter-spacing: 0.4px;
}
.yatra-availability-total-note {
font-size: 12px;
color: #6b7280;
margin-top: 2px;
}
.yatra-availability-total-amount {
font-size: 20px;
font-weight: 700;
color: #0f172a;
}
.yatra-availability-book-btn {
padding: 14px 18px;
border-radius: 12px;
border: none;
background: #3b82f6;
color: #fff;
font-size: 15px;
font-weight: 600;
cursor: pointer;
transition: background 0.2s ease;
flex: 1 1 50%;
}
.yatra-availability-book-btn:hover {
background: #2563eb;
}
.yatra-availability-book-btn:disabled {
background: #9ca3af;
cursor: not-allowed;
}
@media (max-width: 640px) {
.yatra-availability-total-row {
flex-direction: column;
}
.yatra-availability-book-btn {
width: 100%;
}
}
.yatra-availability-book-btn:disabled {
background: #9ca3af;
cursor: not-allowed;
}
.yatra-availability-details-content {
flex-direction: column;
}
@media (min-width: 900px) {
.yatra-availability-summary {
flex-wrap: nowrap;
}
.yatra-availability-details-content {
flex-direction: row;
gap: 32px;
}
.yatra-details-left {
flex: 1 1 55%;
}
.yatra-details-right {
flex: 1 1 45%;
}
}
.yatra-availability-date-section {
display: flex;
flex-direction: column;
gap: 12px;
}
.yatra-availability-main-date {
display: flex;
align-items: baseline;
gap: 8px;
}
.yatra-availability-day {
font-size: 13px;
font-weight: 600;
color: #6b7280;
text-transform: uppercase;
letter-spacing: 0.5px;
}
.yatra-availability-date {
font-size: 24px;
font-weight: 700;
color: #111827;
line-height: 1;
}
.yatra-availability-year {
font-size: 16px;
font-weight: 500;
color: #6b7280;
}
.yatra-availability-date-range {
display: flex;
align-items: center;
gap: 12px;
font-size: 13px;
}
.yatra-availability-date-item {
display: flex;
align-items: center;
gap: 6px;
}
.yatra-availability-date-label {
font-weight: 500;
color: #6b7280;
font-size: 12px;
}
.yatra-availability-date-value {
font-weight: 600;
color: #111827;
font-size: 13px;
}
.yatra-availability-separator {
color: #9ca3af;
font-size: 14px;
font-weight: 500;
}
.yatra-availability-location-section {
display: flex;
align-items: center;
gap: 12px;
font-size: 13px;
padding: 12px;
background: #f9fafb;
border-radius: 8px;
}
.yatra-availability-location-item {
display: flex;
align-items: center;
gap: 6px;
flex: 1;
}
.yatra-availability-location-item svg {
color: #6b7280;
flex-shrink: 0;
}
.yatra-availability-location-value {
font-weight: 600;
color: #111827;
font-size: 13px;
}
.yatra-availability-meta {
display: flex;
align-items: center;
gap: 20px;
font-size: 13px;
color: #6b7280;
}
.yatra-availability-duration {
display: flex;
align-items: center;
gap: 6px;
}
.yatra-availability-duration-icon {
width: 14px;
height: 14px;
flex-shrink: 0;
color: #6b7280;
}
.yatra-availability-seats-info {
display: flex;
align-items: center;
gap: 6px;
}
.yatra-availability-seats-info svg {
color: #6b7280;
flex-shrink: 0;
}
.yatra-availability-status-badge {
display: inline-block;
padding: 6px 12px;
border-radius: 6px;
font-size: 12px;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.5px;
width: fit-content;
}
.yatra-availability-status-available {
background: #d1fae5;
color: #065f46;
}
.yatra-availability-status-limited {
background: #fef3c7;
color: #92400e;
}
.yatra-availability-status-waitlist {
background: #fee2e2;
color: #991b1b;
}
.yatra-availability-status-sold-out {
background: #fee2e2;
color: #991b1b;
}
.yatra-availability-status-blocked {
background: #1f2937;
color: #f9fafb;
}
.yatra-availability-status-closed {
background: #f3f4f6;
color: #6b7280;
border: 1px solid #d1d5db;
}
.yatra-availability-status-cancelled {
background: #9ca3af;
color: #ffffff;
} .yatra-badge-status {
display: inline-flex;
align-items: center;
padding: 6px 12px;
font-size: 11px;
font-weight: 600;
border-radius: 6px;
text-transform: uppercase;
letter-spacing: 0.5px;
line-height: 1;
white-space: nowrap;
box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
} .yatra-badge-status.yatra-badge-available {
background: #10b981;
color: #fff;
}
.yatra-badge-status.yatra-badge-limited {
background: #f59e0b;
color: #fff;
}
.yatra-badge-status.yatra-badge-sold-out {
background: #dc2626;
color: #fff;
}
.yatra-badge-status.yatra-badge-blocked {
background: #1f2937;
color: #fff;
}
.yatra-badge-status.yatra-badge-closed {
background: #6b7280;
color: #fff;
}
.yatra-badge-status.yatra-badge-cancelled {
background: #9ca3af;
color: #fff;
} .yatra-availability-card.yatra-card-status-available {
border-left: 4px solid #10b981;
}
.yatra-availability-card.yatra-card-status-available:hover {
border-left-color: #059669;
box-shadow: 0 4px 12px rgba(16, 185, 129, 0.15);
}
.yatra-availability-card.yatra-card-status-limited {
border-left: 4px solid #f59e0b;
}
.yatra-availability-card.yatra-card-status-limited:hover {
border-left-color: #d97706;
box-shadow: 0 4px 12px rgba(245, 158, 11, 0.15);
}
.yatra-availability-card.yatra-card-status-sold-out {
border-left: 4px solid #ef4444;
opacity: 0.85;
}
.yatra-availability-card.yatra-card-status-sold-out:hover {
border-left-color: #dc2626;
box-shadow: 0 4px 12px rgba(239, 68, 68, 0.15);
}
.yatra-availability-card.yatra-card-status-blocked {
border-left: 4px solid #1f2937;
opacity: 0.7;
}
.yatra-availability-card.yatra-card-status-blocked:hover {
border-left-color: #111827;
box-shadow: 0 4px 12px rgba(31, 41, 55, 0.15);
}
.yatra-availability-card.yatra-card-status-closed {
border-left: 4px solid #6b7280;
opacity: 0.8;
}
.yatra-availability-card.yatra-card-status-closed:hover {
border-left-color: #4b5563;
box-shadow: 0 4px 12px rgba(107, 114, 128, 0.15);
}
.yatra-availability-card.yatra-card-status-cancelled {
border-left: 4px solid #9ca3af;
opacity: 0.75;
}
.yatra-availability-card.yatra-card-status-cancelled:hover {
border-left-color: #6b7280;
box-shadow: 0 4px 12px rgba(156, 163, 175, 0.15);
} .yatra-availability-right {
display: flex;
flex-direction: column;
gap: 20px;
padding-left: 24px;
border-left: 1px solid #e5e7eb;
}
.yatra-availability-pricing-section {
display: flex;
flex-direction: column;
align-items: flex-end;
gap: 8px;
}
.yatra-availability-discount-badge {
display: inline-block;
padding: 4px 10px;
background: #dc2626;
color: #fff;
font-size: 11px;
font-weight: 700;
border-radius: 4px;
text-transform: uppercase;
letter-spacing: 0.5px;
}
.yatra-availability-pricing {
display: flex;
flex-direction: column;
align-items: flex-end;
gap: 4px;
}
.yatra-availability-price-original {
font-size: 14px;
color: #9ca3af;
text-decoration: line-through;
}
.yatra-availability-price-main {
display: flex;
align-items: baseline;
gap: 6px;
}
.yatra-availability-price-sale {
font-size: 32px;
font-weight: 700;
color: #111827;
line-height: 1;
}
.yatra-availability-price-label {
font-size: 13px;
color: #6b7280;
font-weight: 500;
} .yatra-availability-travelers {
display: flex;
flex-direction: column;
gap: 12px;
}
.yatra-availability-traveler-label {
font-size: 13px;
font-weight: 600;
color: #374151;
margin-bottom: 4px;
} .yatra-availability-total-price {
display: flex;
align-items: center;
justify-content: space-between;
padding: 12px;
background: #fff;
border: 2px solid #3b82f6;
border-radius: 8px;
margin-top: 4px;
}
.yatra-availability-total-label {
font-size: 15px;
font-weight: 600;
color: #374151;
}
.yatra-availability-total-amount {
font-size: 20px;
font-weight: 700;
color: #3b82f6;
}
.yatra-availability-book-btn {
padding: 14px 24px;
background: #3b82f6;
color: #fff;
border: none;
border-radius: 8px;
font-size: 15px;
font-weight: 600;
cursor: pointer;
transition: all 0.2s ease;
width: 100%;
text-align: center;
}
.yatra-availability-book-btn:hover:not(:disabled) {
background: #2563eb;
transform: translateY(-1px);
box-shadow: 0 4px 12px rgba(59, 130, 246, 0.3);
}
.yatra-availability-book-btn:disabled {
background: #9ca3af;
cursor: not-allowed;
opacity: 0.7;
} @media (max-width: 1024px) {
.yatra-availability-item-main {
grid-template-columns: 1fr;
gap: 24px;
}
.yatra-availability-right {
padding-left: 0;
border-left: none;
border-top: 1px solid #e5e7eb;
padding-top: 24px;
}
}
.yatra-availability-load-more {
text-align: center;
margin-top: 32px;
margin-bottom: 24px;
display: flex;
flex-direction: column;
align-items: center;
gap: 12px;
}
.yatra-availability-load-more-btn {
display: inline-flex;
align-items: center;
justify-content: center;
gap: 8px;
padding: 14px 32px;
background: #10b981;
color: #fff;
border: 2px solid #10b981;
border-radius: 8px;
font-size: 15px;
font-weight: 600;
cursor: pointer;
transition: all 0.3s ease;
}
.yatra-availability-load-more-btn:hover:not(:disabled) {
background: #059669;
border-color: #059669;
}
.yatra-availability-load-more-btn:disabled {
opacity: 0.7;
cursor: not-allowed;
}
.yatra-availability-load-more-btn svg {
width: 18px;
height: 18px;
}
.yatra-availability-count-info {
font-size: 13px;
color: #6b7280;
} .yatra-spinner {
animation: yatra-spin 1s linear infinite;
}
@keyframes yatra-spin {
from {
transform: rotate(0deg);
}
to {
transform: rotate(360deg);
}
} @media (max-width: 1024px) {
.yatra-availability-header-top {
flex-direction: column;
align-items: flex-start;
}
.yatra-availability-sort-select {
width: 100%;
}
.yatra-availability-item-main {
grid-template-columns: 1fr;
gap: 24px;
}
.yatra-availability-pricing-info {
align-items: flex-start;
}
.yatra-availability-book-btn {
max-width: 100%;
}
}
@media (max-width: 768px) {
.yatra-availability-filters {
overflow-x: auto;
flex-wrap: nowrap;
padding-bottom: 8px;
-webkit-overflow-scrolling: touch;
}
.yatra-availability-filter-btn {
white-space: nowrap;
flex-shrink: 0;
}
.yatra-availability-item {
padding: 20px;
}
.yatra-availability-date {
font-size: 20px;
}
.yatra-availability-price-sale {
font-size: 24px;
}
} .yatra-price-section {
margin: 16px 0;
border-top: 1px solid #e5e7eb;
padding-top: 12px;
}
.yatra-price-section-title {
display: flex;
align-items: center;
gap: 8px;
font-weight: 600;
color: #374151;
margin-bottom: 8px;
font-size: 14px;
}
.dark .yatra-price-section-title {
color: #d1d5db;
} .yatra-price-itinerary {
display: flex;
justify-content: space-between;
align-items: center;
padding: 6px 0;
font-size: 13px;
color: #6b7280;
}
.yatra-price-itinerary span:first-child {
font-weight: 500;
color: #374151;
}
.yatra-price-itinerary span:last-child {
font-weight: 600;
color: #059669;
}
.dark .yatra-price-itinerary {
color: #9ca3af;
}
.dark .yatra-price-itinerary span:first-child {
color: #d1d5db;
}
.dark .yatra-price-itinerary span:last-child {
color: #10b981;
} .yatra-availability-empty-actions {
display: flex;
gap: 12px;
margin-top: 20px;
flex-wrap: wrap;
}
.yatra-availability-empty-actions .yatra-btn {
min-width: 140px;
}
.yatra-availability-empty .yatra-icon-xl {
color: #10b981;
margin-bottom: 16px;
}
.dark .yatra-availability-empty .yatra-icon-xl {
color: #34d399;
} .flatpickr-calendar {
box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
border-radius: 8px;
}
.flatpickr-day.selected {
background: #3b82f6;
border-color: #3b82f6;
}
.flatpickr-day:hover {
background: #dbeafe;
border-color: #93c5fd;
}
.flatpickr-day.today {
border-color: #3b82f6;
}
.flatpickr-day.disabled {
color: #d1d5db;
} .dark .flatpickr-calendar {
background: #1f2937;
border-color: #374151;
}
.dark .flatpickr-months {
background: #1f2937;
}
.dark .flatpickr-current-month .flatpickr-monthDropdown-months,
.dark .flatpickr-current-month input.cur-year {
color: #f9fafb;
}
.dark .flatpickr-weekday {
color: #9ca3af;
}
.dark .flatpickr-day {
color: #f9fafb;
}
.dark .flatpickr-day:hover {
background: #374151;
border-color: #4b5563;
}
.dark .flatpickr-day.disabled {
color: #4b5563;
} .yatra-availability-empty-info {
display: flex;
flex-direction: column;
gap: 16px;
margin: 24px 0;
padding: 20px;
background: #f9fafb;
border-radius: 8px;
border: 1px solid #e5e7eb;
}
.dark .yatra-availability-empty-info {
background: #1f2937;
border-color: #374151;
}
.yatra-availability-empty-info-item {
display: flex;
align-items: center;
gap: 12px;
}
.yatra-availability-empty-info-icon {
width: 40px;
height: 40px;
display: flex;
align-items: center;
justify-content: center;
background: #10b981;
color: white;
border-radius: 8px;
flex-shrink: 0;
}
.yatra-availability-empty-info-text {
display: flex;
flex-direction: column;
gap: 2px;
}
.yatra-availability-empty-info-label {
font-size: 12px;
color: #6b7280;
font-weight: 500;
}
.yatra-availability-empty-info-value {
font-size: 16px;
color: #111827;
font-weight: 600;
}
.dark .yatra-availability-empty-info-label {
color: #9ca3af;
}
.dark .yatra-availability-empty-info-value {
color: #f9fafb;
} .yatra-trip-attributes {
--yatra-attr-divider: #d6d3d1;
}
.yatra-trip-attributes .yatra-section-header {
margin-bottom: 14px;
padding-bottom: 12px;
border-bottom: 1px solid var(--yatra-attr-divider);
}
.yatra-trip-attributes .yatra-section-title {
font-size: 1.125rem;
font-weight: 600;
letter-spacing: -0.02em;
color: #1c1917;
margin: 0 0 6px 0;
line-height: 1.25;
}
.yatra-trip-attributes .yatra-section-description {
font-size: 13px;
line-height: 1.5;
color: #78716c;
margin: 0;
max-width: 42em;
} .yatra-attributes-grid {
margin-top: 0;
}
.yatra-attributes-filter-wrapper .yatra-attributes-grid {
display: grid;
} .yatra-attributes-grid > .yatra-attribute-item {
display: flex;
align-items: flex-start;
gap: 12px;
padding: 14px 16px;
background: #fff;
border: none;
border-radius: 0;
transition: background-color 0.15s ease;
min-width: 0;
min-height: 100%;
box-sizing: border-box;
align-self: stretch;
}
.yatra-attributes-grid > .yatra-attribute-item:hover {
background: #fafaf9;
}
.yatra-attributes-grid .yatra-attribute-icon {
width: auto;
height: auto;
min-width: 28px;
min-height: 28px;
display: flex;
align-items: center;
justify-content: center;
background: transparent;
color: #57534e;
border-radius: 0;
flex-shrink: 0;
overflow: visible;
}
.yatra-attributes-grid .yatra-attribute-icon svg {
display: block;
width: 22px;
height: 22px;
min-width: 22px;
min-height: 22px;
flex-shrink: 0;
overflow: visible;
opacity: 0.92;
}
.yatra-attributes-grid .yatra-attribute-icon svg[fill="none"] {
stroke: currentColor;
}
.yatra-attributes-grid .yatra-attribute-icon svg[fill="currentColor"] {
stroke: none;
opacity: 1;
}
.yatra-attribute-icon-img {
width: 26px;
height: 26px;
max-width: 100%;
max-height: 100%;
object-fit: contain;
border-radius: 4px;
}
.yatra-attributes-grid .yatra-attribute-content {
flex: 1 1 auto;
min-width: 0;
display: flex;
flex-direction: column;
justify-content: flex-start;
min-height: 0;
}
.yatra-attributes-grid .yatra-attribute-content .yatra-attribute-name {
font-size: 13px;
font-weight: 600;
color: #292524;
margin-bottom: 3px;
line-height: 1.35;
}
.yatra-attributes-grid .yatra-attribute-value {
font-size: 13px;
color: #57534e;
margin-bottom: 0;
word-wrap: break-word;
line-height: 1.45;
}
.yatra-attributes-grid .yatra-attribute-value a {
color: var(--yatra-primary-color, #3b82f6);
text-decoration: none;
}
.yatra-attributes-grid .yatra-attribute-value a:hover {
text-decoration: underline;
}
.yatra-color-swatch {
display: inline-block;
width: 16px;
height: 16px;
border-radius: 3px;
border: 1px solid var(--yatra-border-color, #e5e7eb);
vertical-align: middle;
margin-right: 6px;
}
.yatra-attributes-grid .yatra-attribute-description {
margin-top: 6px;
font-size: 11px;
color: #a8a29e;
font-style: italic;
line-height: 1.35;
} .yatra-booking-info {
margin: 20px 0;
padding: 16px;
background: var(--yatra-bg-card, #ffffff);
border: 1px solid var(--yatra-border-color, #e5e7eb);
border-radius: 8px;
}
.yatra-booking-info h5 {
font-size: 14px;
font-weight: 600;
color: var(--yatra-text-primary, #1a1a1a);
margin: 0 0 12px 0;
padding-bottom: 8px;
border-bottom: 1px solid var(--yatra-border-color, #e5e7eb);
}
.yatra-booking-info-list {
display: flex;
flex-direction: column;
gap: 8px;
}
.yatra-booking-info-item {
display: flex;
justify-content: space-between;
align-items: center;
padding: 6px 0;
border-bottom: 1px solid var(--yatra-border-light, #f3f4f6);
}
.yatra-booking-info-item:last-child {
border-bottom: none;
}
.yatra-booking-info-name {
font-size: 12px;
font-weight: 500;
color: var(--yatra-text-secondary, #6b7280);
flex: 1;
min-width: 0;
margin-right: 8px;
}
.yatra-booking-info-value {
font-size: 12px;
font-weight: 600;
color: var(--yatra-text-primary, #1a1a1a);
text-align: right;
flex-shrink: 0;
} .dark .yatra-booking-info {
background: var(--yatra-bg-card-dark, #1f2937);
border-color: var(--yatra-border-color-dark, #374151);
}
.dark .yatra-booking-info h5 {
color: var(--yatra-text-primary-dark, #f9fafb);
border-bottom-color: var(--yatra-border-color-dark, #374151);
}
.dark .yatra-booking-info-item {
border-bottom-color: var(--yatra-border-light-dark, #374151);
}
.dark .yatra-booking-info-name {
color: var(--yatra-text-secondary-dark, #9ca3af);
}
.dark .yatra-booking-info-value {
color: var(--yatra-text-primary-dark, #f9fafb);
} .yatra-cancellation-policy-content p {
font-size: 13px;
line-height: 1.5;
color: var(--yatra-text-secondary, #6b7280);
margin: 0 0 8px 0;
}
.yatra-cancellation-policy-content p:last-child {
margin-bottom: 0;
}
.yatra-policy-more {
font-size: 12px;
font-style: italic;
color: var(--yatra-text-muted, #9ca3af);
margin-top: 8px;
} .dark .yatra-cancellation-policy-content p {
color: var(--yatra-text-secondary-dark, #9ca3af);
}
.dark .yatra-policy-more {
color: var(--yatra-text-muted-dark, #6b7280);
} .yatra-important-info-grid {
display: flex;
flex-direction: column;
gap: 20px;
margin-top: 32px;
}
.yatra-important-info-card {
display: flex;
align-items: flex-start;
gap: 20px;
background: var(--yatra-bg-card, #ffffff);
border: 1px solid var(--yatra-border-color, #e5e7eb);
border-radius: 12px;
padding: 24px;
transition: all 0.2s ease;
}
.yatra-important-info-card:hover {
transform: translateY(-2px);
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}
.yatra-important-info-icon {
width: 48px;
height: 48px;
display: flex;
align-items: center;
justify-content: center;
background: var(--yatra-primary-light, #eff6ff);
color: var(--yatra-primary-color, #3b82f6);
border-radius: 12px;
font-size: 20px;
flex-shrink: 0;
}
.yatra-important-info-content-wrapper {
flex: 1;
}
.yatra-important-info-title {
font-size: 16px;
font-weight: 600;
color: var(--yatra-text-primary, #1a1a1a);
margin: 0 0 16px 0;
display: flex;
align-items: center;
gap: 0;
}
.yatra-important-info-title .yatra-icon-inline {
display: none;
}
.yatra-important-info-content {
font-size: 14px;
line-height: 1.6;
color: var(--yatra-text-secondary, #6b7280);
margin: 0;
}
.yatra-important-info-content p {
margin: 0 0 8px 0;
}
.yatra-important-info-content p:last-child {
margin-bottom: 0;
} .yatra-info-detail-row {
display: flex;
align-items: flex-start;
justify-content: space-between;
padding: 6px 0;
}
.yatra-info-label {
font-size: 13px;
font-weight: 500;
color: #6b7280;
display: flex;
align-items: center;
gap: 6px;
}
.yatra-info-value {
font-size: 14px;
font-weight: 600;
color: #1a1a1a;
text-align: right;
} .yatra-info-badge {
display: inline-flex;
align-items: center;
gap: 6px;
padding: 6px 12px;
border-radius: 6px;
font-size: 13px;
font-weight: 500;
margin-bottom: 12px;
}
.yatra-badge-included {
background: #d1fae5;
color: #065f46;
} .yatra-info-description {
margin-top: 12px;
} .yatra-icon-tiny {
width: 14px;
height: 14px;
} .yatra-icon-physical {
background: #fef3c7;
color: #d97706;
}
.yatra-icon-visa {
background: #dbeafe;
color: #2563eb;
}
.yatra-icon-health {
background: #fce7f3;
color: #db2777;
}
.yatra-icon-policy {
background: #fee2e2;
color: #dc2626;
}
.yatra-icon-age {
background: #e0e7ff;
color: #6366f1;
}
.yatra-icon-accommodation {
background: #d1fae5;
color: #059669;
}
.yatra-icon-transport {
background: #ddd6fe;
color: #7c3aed;
} .yatra-section-description {
font-size: 15px;
line-height: 1.6;
color: #6b7280;
margin: 12px 0 0 0;
} @media (max-width: 768px) {
.yatra-important-info-grid {
gap: 16px;
}
.yatra-important-info-card {
padding: 20px;
gap: 16px;
}
.yatra-important-info-icon {
width: 40px;
height: 40px;
font-size: 18px;
}
.yatra-important-info-title {
font-size: 15px;
}
.yatra-info-detail-row {
flex-direction: column;
gap: 4px;
}
.yatra-info-value {
text-align: left;
}
.yatra-important-info-content {
font-size: 13px;
}
}
@media (max-width: 480px) {
.yatra-important-info-card {
flex-direction: column;
text-align: center;
gap: 12px;
}
.yatra-important-info-icon {
margin: 0 auto;
}
} .yatra-booking-attributes {
margin: 20px 0;
padding: 16px;
background: var(--yatra-bg-card, #ffffff);
border: 1px solid var(--yatra-border-color, #e5e7eb);
border-radius: 8px;
}
.yatra-booking-attributes h5 {
font-size: 14px;
font-weight: 600;
color: var(--yatra-text-primary, #1a1a1a);
margin: 0 0 12px 0;
padding-bottom: 8px;
border-bottom: 1px solid var(--yatra-border-color, #e5e7eb);
}
.yatra-booking-attributes-list {
display: flex;
flex-direction: column;
gap: 8px;
}
.yatra-booking-attribute-item {
display: flex;
justify-content: space-between;
align-items: center;
padding: 6px 0;
border-bottom: 1px solid var(--yatra-border-light, #f3f4f6);
}
.yatra-booking-attribute-item:last-child {
border-bottom: none;
}
.yatra-booking-attribute-name {
font-size: 12px;
font-weight: 500;
color: var(--yatra-text-secondary, #6b7280);
flex: 1;
min-width: 0;
margin-right: 8px;
}
.yatra-booking-attribute-value {
font-size: 12px;
font-weight: 600;
color: var(--yatra-text-primary, #1a1a1a);
text-align: right;
flex-shrink: 0;
}
.yatra-booking-color-swatch {
display: inline-block;
width: 12px;
height: 12px;
border-radius: 2px;
border: 1px solid var(--yatra-border-color, #e5e7eb);
vertical-align: middle;
} .dark .yatra-booking-attributes {
background: var(--yatra-bg-card-dark, #1f2937);
border-color: var(--yatra-border-color-dark, #374151);
}
.dark .yatra-booking-attributes h5 {
color: var(--yatra-text-primary-dark, #f9fafb);
border-bottom-color: var(--yatra-border-color-dark, #374151);
}
.dark .yatra-booking-attribute-item {
border-bottom-color: var(--yatra-border-light-dark, #374151);
}
.dark .yatra-booking-attribute-name {
color: var(--yatra-text-secondary-dark, #9ca3af);
}
.dark .yatra-booking-attribute-value {
color: var(--yatra-text-primary-dark, #f9fafb);
}  .yatra-input-group {
display: flex;
flex-direction: column;
gap: 12px;
width: 100%;
}
.yatra-input-group input.yatra-filter-input {
width: 100%;
} .yatra-filter-icon[width="18"] {
width: 18px !important;
height: 18px !important;
object-fit: contain !important;
} .yatra-attribute-item {
margin-bottom: 20px;
padding-bottom: 20px;
border-bottom: 1px solid #f0f0f2;
}
.yatra-attribute-item:last-child {
margin-bottom: 0;
padding-bottom: 0;
border-bottom: none;
}
.yatra-attribute-label {
display: flex;
align-items: center;
gap: 10px;
margin-bottom: 12px;
}
.yatra-attribute-icon {
width: 18px;
height: 18px;
flex-shrink: 0;
object-fit: contain;
display: flex;
align-items: center;
justify-content: center;
}
.yatra-attribute-icon img {
width: 18px !important;
height: 18px !important;
object-fit: contain !important;
}
.yatra-attribute-icon svg {
width: 18px;
height: 18px;
color: #6b7280;
}
.yatra-attribute-name {
font-size: 14px;
font-weight: 600;
color: #374151;
line-height: 1.5;
}
.yatra-attribute-content {
width: 100%;
display: block;
}
.yatra-attribute-content input.yatra-filter-input {
width: 100% !important;
max-width: 100% !important;
box-sizing: border-box;
}
.yatra-attribute-content .yatra-checkbox-group {
width: 100%;
}
.yatra-attribute-content .yatra-input-group {
width: 100%;
}
.yatra-attribute-content .yatra-input-group input {
width: 100% !important;
max-width: 100% !important;
box-sizing: border-box;
} .dark .yatra-attribute-item {
border-bottom-color: #374151;
}
.dark .yatra-attribute-icon svg {
color: #9ca3af;
}
.dark .yatra-attribute-name {
color: #e5e7eb;
} @media (max-width: 768px) {
.yatra-attr-filter {
margin: 20px 0;
border-radius: 12px;
}
.yatra-attr-filter__header {
padding: 20px 20px;
flex-direction: column;
align-items: flex-start;
gap: 14px;
}
.yatra-attr-filter__title {
font-size: 16px;
}
.yatra-attr-filter__reset {
width: 100%;
justify-content: center;
}
.yatra-attr-group {
padding: 20px 20px;
}
.yatra-attr-icon {
width: 36px;
height: 36px;
}
.yatra-attr-icon img {
width: 18px;
height: 18px;
}
.yatra-attr-icon svg {
width: 18px;
height: 18px;
}
.yatra-attr-range {
flex-direction: column;
align-items: stretch;
gap: 12px;
}
.yatra-attr-range__sep {
display: none;
}
} .dark .yatra-attr-filter {
background: #1e293b;
border-color: #334155;
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2), 0 1px 2px rgba(0, 0, 0, 0.3);
}
.dark .yatra-attr-filter:hover {
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.25), 0 2px 4px rgba(0, 0, 0, 0.35);
}
.dark .yatra-attr-filter__header {
background: #0f172a;
border-bottom-color: #334155;
}
.dark .yatra-attr-filter__title {
color: #f1f5f9;
}
.dark .yatra-attr-filter__reset {
background: #1e293b;
border-color: #475569;
color: #cbd5e1;
}
.dark .yatra-attr-filter__reset:hover {
background: #334155;
border-color: #64748b;
color: #f1f5f9;
}
.dark .yatra-attr-group {
border-bottom-color: #334155;
}
.dark .yatra-attr-group:hover {
background: #1a2332;
}
.dark .yatra-attr-group__label {
border-bottom-color: #334155;
}
.dark .yatra-attr-icon {
background: linear-gradient(135deg, #1e3a8a 0%, #1e40af 100%);
border-color: #3b82f6;
box-shadow: 0 1px 2px rgba(59, 130, 246, 0.15);
}
.dark .yatra-attr-icon svg {
color: #60a5fa;
}
.dark .yatra-attr-name {
color: #f1f5f9;
}
.dark .yatra-attr-checkbox:hover {
background: #1a2332;
}
.dark .yatra-attr-checkbox__box {
border-color: #475569;
background: #334155;
box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}
.dark .yatra-attr-checkbox input[type="checkbox"]:checked + .yatra-attr-checkbox__box {
background: #3b82f6;
border-color: #3b82f6;
box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.15);
}
.dark .yatra-attr-checkbox:hover .yatra-attr-checkbox__box {
border-color: #64748b;
background: #475569;
}
.dark .yatra-attr-checkbox input[type="checkbox"]:checked:hover + .yatra-attr-checkbox__box {
background: #2563eb;
border-color: #2563eb;
}
.dark .yatra-attr-checkbox__label {
color: #e2e8f0;
}
.dark .yatra-attr-range__sep {
color: #64748b;
}
.dark .yatra-attr-input {
background: #334155;
border-color: #475569;
color: #f1f5f9;
box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}
.dark .yatra-attr-input:hover {
border-color: #64748b;
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.25);
}
.dark .yatra-attr-input:focus {
border-color: #3b82f6;
background: #334155;
box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.15), 0 1px 2px rgba(0, 0, 0, 0.2);
}
.dark .yatra-attr-input::placeholder {
color: #64748b;
} .yatra-attribute-input-wrap input {
border: none;
background: transparent;
font-size: 15px;
font-weight: 600;
color: var(--yatra-text-primary, #0f172a);
padding: 0;
outline: none;
}
.yatra-attribute-input-wrap input::placeholder {
color: rgba(15, 23, 42, 0.35);
}
.yatra-attribute-input-separator {
font-size: 22px;
color: rgba(15, 23, 42, 0.2);
font-weight: 200;
} @media (max-width: 960px) {
.yatra-attributes-panel__head {
flex-direction: column;
align-items: flex-start;
}
}
@media (max-width: 640px) {
.yatra-attributes-panel__body {
grid-template-columns: 1fr;
padding: 24px;
}
.yatra-attributes-panel__head {
padding: 24px;
}
.yatra-attribute-input-row {
flex-direction: column;
}
.yatra-attribute-input-separator {
display: none;
}
} .dark .yatra-attributes-panel {
background: #0b1120;
border-color: rgba(148, 163, 184, 0.12);
box-shadow: 0 25px 60px rgba(0, 0, 0, 0.35);
}
.dark .yatra-attributes-panel__head {
background: linear-gradient(120deg, #020617 0%, #0f172a 60%, #1e3a8a 100%);
}
.dark .yatra-attribute-tile {
background: rgba(15, 23, 42, 0.75);
}
.dark .yatra-attribute-tile:hover {
background: rgba(15, 23, 42, 0.95);
}
.dark .yatra-attribute-tile__name {
color: #e2e8f0;
}
.dark .yatra-attribute-tile__type {
color: rgba(148, 163, 184, 0.8);
}
.dark .yatra-attribute-pill {
background: rgba(15, 23, 42, 0.45);
color: #cbd5e5;
border-color: rgba(148, 163, 184, 0.2);
}
.dark .yatra-attribute-pill input:checked ~ span {
color: #60a5fa;
}
.dark .yatra-attribute-input-row {
background: rgba(15, 23, 42, 0.45);
border-color: rgba(148, 163, 184, 0.2);
}
.dark .yatra-attribute-input-wrap label {
color: rgba(148, 163, 184, 0.7);
}
.dark .yatra-attribute-input-wrap input {
color: #f1f5f9;
}
.dark .yatra-attribute-input-wrap input::placeholder {
color: rgba(148, 163, 184, 0.4);
}
.dark .yatra-attribute-input-separator {
color: rgba(148, 163, 184, 0.2);
} .yatra-attribute-range-inputs {
display: flex;
align-items: center;
gap: 12px;
background: #f8fafc;
border: 1px solid #e2e8f0;
border-radius: 10px;
padding: 16px;
}
.yatra-attribute-input-group {
flex: 1;
min-width: 0;
}
.yatra-attribute-input-label {
display: block;
font-size: 12px;
font-weight: 600;
color: #718096;
margin-bottom: 6px;
text-transform: uppercase;
letter-spacing: 0.5px;
}
.yatra-attribute-input {
width: 100%;
padding: 10px 14px;
background: #ffffff;
border: 2px solid #e2e8f0;
border-radius: 8px;
font-size: 14px;
font-weight: 500;
color: #2d3748;
transition: all 0.2s ease;
}
.yatra-attribute-input:focus {
outline: none;
border-color: #667eea;
box-shadow: 0 0 0 3px rgba(102, 126, 234, 0.1);
}
.yatra-attribute-range-separator {
font-size: 16px;
font-weight: 600;
color: #a0aec0;
margin-top: 20px;
} @media (max-width: 768px) {
.yatra-attributes-filter-header {
flex-direction: column;
gap: 12px;
text-align: center;
padding: 16px;
}
.yatra-attributes-filter-title {
justify-content: center;
}
.yatra-attributes-filter-wrapper .yatra-attributes-grid {
grid-template-columns: 1fr;
gap: 16px;
}
.yatra-attribute-card-header {
padding: 16px;
gap: 12px;
}
.yatra-attribute-icon-wrapper {
width: 40px;
height: 40px;
}
.yatra-attribute-icon-img {
width: 24px;
height: 24px;
}
.yatra-attribute-icon-svg {
width: 20px;
height: 20px;
}
.yatra-attribute-title {
font-size: 14px;
}
.yatra-attribute-card-body {
padding: 16px;
}
.yatra-attribute-range-inputs {
flex-direction: column;
gap: 12px;
}
.yatra-attribute-range-separator {
display: none;
}
}
@media (max-width: 480px) {
.yatra-attributes-filter-wrapper {
margin: 16px 0;
}
.yatra-attributes-filter-header {
padding: 12px;
}
.yatra-attributes-filter-title h3 {
font-size: 16px;
}
.yatra-attributes-clear-btn {
padding: 6px 12px;
font-size: 13px;
}
.yatra-attribute-card-header {
padding: 12px;
}
.yatra-attribute-card-body {
padding: 12px;
}
.yatra-attribute-option {
padding: 10px 12px;
gap: 10px;
}
.yatra-attribute-option-label {
font-size: 13px;
}
.yatra-attribute-input {
padding: 8px 12px;
font-size: 13px;
}
} .dark .yatra-attribute-item {
background: var(--yatra-bg-secondary-dark, #1f2937);
border-color: var(--yatra-border-color-dark, #374151);
}
.dark .yatra-attribute-item:hover {
background: var(--yatra-bg-card-dark, #1f2937);
border-color: var(--yatra-primary-color-dark, #60a5fa);
box-shadow: 0 2px 8px rgba(96, 165, 250, 0.15);
}
.dark .yatra-attribute-header {
border-bottom-color: var(--yatra-border-color-dark, #374151);
}
.dark .yatra-attribute-svg-icon {
color: var(--yatra-primary-color-dark, #60a5fa);
}
.dark .yatra-attribute-name {
color: var(--yatra-text-primary-dark, #f9fafb);
}
.dark .yatra-attribute-options .yatra-checkbox-label {
background: var(--yatra-bg-card-dark, #1f2937);
border-color: var(--yatra-border-color-dark, #374151);
}
.dark .yatra-attribute-options .yatra-checkbox-label:hover {
background: var(--yatra-primary-light-dark, #1e3a8a);
border-color: var(--yatra-primary-color-dark, #60a5fa);
box-shadow: 0 1px 4px rgba(96, 165, 250, 0.25);
}
.dark .yatra-attribute-options .yatra-checkbox-label span {
color: var(--yatra-text-primary-dark, #f9fafb);
}
.dark .yatra-attribute-options .yatra-checkbox-label .yatra-filter-count {
background: var(--yatra-bg-secondary-dark, #374151);
color: var(--yatra-text-muted-dark, #9ca3af);
}
.dark .yatra-attribute-options .yatra-price-inputs {
background: var(--yatra-bg-card-dark, #1f2937);
border-color: var(--yatra-border-color-dark, #374151);
}
.dark .yatra-attribute-options .yatra-price-input-label {
color: var(--yatra-text-muted-dark, #9ca3af);
}
.dark .yatra-attribute-options .yatra-price-input {
background: var(--yatra-bg-card-dark, #1f2937);
border-color: var(--yatra-border-color-dark, #374151);
color: var(--yatra-text-primary-dark, #f9fafb);
}
.dark .yatra-attribute-options .yatra-price-input:focus {
border-color: var(--yatra-primary-color-dark, #60a5fa);
box-shadow: 0 0 0 3px rgba(96, 165, 250, 0.15);
} .dark .yatra-attributes-filter-header {
background: linear-gradient(135deg, #4c1d95 0%, #5b21b6 100%);
border-color: #374151;
}
.dark .yatra-attributes-filter-icon {
background: rgba(255, 255, 255, 0.1);
color: #e9d5ff;
}
.dark .yatra-attributes-filter-title h3 {
color: #f3f4f6;
}
.dark .yatra-attributes-clear-btn {
background: rgba(255, 255, 255, 0.1);
border-color: rgba(255, 255, 255, 0.2);
color: #f3f4f6;
}
.dark .yatra-attributes-clear-btn:hover {
background: rgba(255, 255, 255, 0.2);
}
.dark .yatra-attribute-card {
background: #1f2937;
border-color: #374151;
box-shadow: 0 2px 12px rgba(0, 0, 0, 0.3);
}
.dark .yatra-attribute-card:hover {
border-color: #8b5cf6;
box-shadow: 0 8px 25px rgba(139, 92, 246, 0.2);
}
.dark .yatra-attribute-card-header {
background: linear-gradient(135deg, #1e1b4b 0%, #312e81 100%);
border-bottom-color: #374151;
}
.dark .yatra-attribute-icon-wrapper {
background: #374151;
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}
.dark .yatra-attribute-icon-svg {
color: #a78bfa;
}
.dark .yatra-attribute-title {
color: #f3f4f6;
}
.dark .yatra-attribute-type {
color: #9ca3af;
}
.dark .yatra-attribute-option {
background: #374151;
border-color: #4b5563;
}
.dark .yatra-attribute-option:hover {
background: #4b5563;
border-color: #6b7280;
}
.dark .yatra-attribute-option-indicator {
background: #1f2937;
border-color: #6b7280;
}
.dark .yatra-attribute-option input[type="checkbox"]:checked + .yatra-attribute-option-indicator {
background: #8b5cf6;
border-color: #8b5cf6;
}
.dark .yatra-attribute-option-label {
color: #e5e7eb;
}
.dark .yatra-attribute-range-inputs {
background: #374151;
border-color: #4b5563;
}
.dark .yatra-attribute-input-label {
color: #9ca3af;
}
.dark .yatra-attribute-input {
background: #1f2937;
border-color: #4b5563;
color: #f3f4f6;
}
.dark .yatra-attribute-input:focus {
border-color: #8b5cf6;
box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.15);
}
.dark .yatra-attribute-range-separator {
color: #6b7280;
}   .yatra-empty-itinerary {
text-align: center;
padding: 60px 20px;
background: #f8fafc;
border-radius: 12px;
border: 1px solid #e2e8f0;
}
.yatra-empty-state-icon {
margin-bottom: 20px;
color: #6b7280;
}
.yatra-empty-state-title {
font-size: 1.5rem;
font-weight: 600;
color: #374151;
margin-bottom: 12px;
}
.yatra-empty-state-description {
color: #6b7280;
max-width: 500px;
margin: 0 auto;
line-height: 1.6;
} .yatra-entry-gallery {
margin-top: 20px;
}
.yatra-gallery-title {
display: flex;
align-items: center;
gap: 8px;
font-size: 0.875rem;
font-weight: 600;
color: #374151;
margin-bottom: 12px;
}
.yatra-gallery-grid {
display: grid;
grid-template-columns: repeat(6, 1fr);
gap: 8px;
width: 100%;
}
.yatra-gallery-item-link {
display: block;
text-decoration: none;
}
.yatra-gallery-item {
position: relative;
aspect-ratio: 1;
border-radius: 8px;
overflow: hidden;
cursor: pointer;
transition: opacity 0.2s ease;
background: #f3f4f6;
}
.yatra-gallery-item:hover {
opacity: 0.8;
}
.yatra-media-card {
position: relative;
width: 100%;
height: 100%;
border-radius: 8px;
overflow: hidden;
}
.yatra-media-card img {
width: 100%;
height: 100%;
object-fit: cover;
display: block;
} .yatra-entry-gallery .yatra-media-overlay {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
width: 16px;
height: 16px;
background: rgba(0, 0, 0, 0.4);
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
pointer-events: auto;
cursor: pointer;
transition: all 0.2s ease;
}
.yatra-entry-gallery .yatra-media-overlay:hover {
background: rgba(0, 0, 0, 0.5);
transform: translate(-50%, -50%) scale(1.1);
} .yatra-entry-gallery .yatra-youtube-play-button svg {
width: 24px !important;
height: 24px !important;
}
.yatra-entry-gallery .yatra-youtube-play-button svg circle {
fill: rgba(255, 0, 0, 0.9) !important;
stroke: white !important;
stroke-width: 1px !important;
}
.yatra-entry-gallery .yatra-youtube-play-button svg path {
fill: white !important;
} .yatra-entry-video {
display: none;
} @media (max-width: 768px) {
.yatra-gallery-grid {
grid-template-columns: repeat(4, 1fr);
gap: 6px;
width: 100%;
}
.yatra-entry-gallery .yatra-media-overlay {
width: 12px;
height: 12px;
}
.yatra-entry-gallery .yatra-youtube-play-button svg {
width: 18px !important;
height: 18px !important;
}
.yatra-entry-gallery .yatra-youtube-play-button svg circle {
fill: rgba(255, 0, 0, 0.9) !important;
stroke: white !important;
stroke-width: 0.5px !important;
}
.yatra-entry-gallery .yatra-youtube-play-button svg path {
fill: white !important;
}
}
@media (max-width: 480px) {
.yatra-gallery-grid {
grid-template-columns: repeat(3, 1fr);
gap: 4px;
width: 100%;
}
.yatra-entry-gallery .yatra-media-overlay {
width: 10px;
height: 10px;
}
.yatra-entry-gallery .yatra-youtube-play-button svg {
width: 14px !important;
height: 14px !important;
}
.yatra-entry-gallery .yatra-youtube-play-button svg circle {
fill: rgba(255, 0, 0, 0.9) !important;
stroke: white !important;
stroke-width: 0.5px !important;
}
.yatra-entry-gallery .yatra-youtube-play-button svg path {
fill: white !important;
}
} @media (max-width: 768px) {
.yatra-gallery-grid {
grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
gap: 8px;
}
.yatra-play-overlay {
width: 40px;
height: 40px;
}
} .yatra-trip-details-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
gap: 24px;
margin-top: 24px;
}
.yatra-detail-item {
display: flex;
align-items: flex-start;
padding: 16px;
background: #f9fafb;
border-radius: 8px;
border: 1px solid #e5e7eb;
transition: all 0.2s ease;
}
.yatra-detail-item:hover {
background: #f3f4f6;
border-color: #d1d5db;
transform: translateY(-2px);
}
.yatra-detail-label {
display: flex;
align-items: center;
gap: 8px;
font-weight: 600;
color: #374151;
font-size: 0.875rem;
margin-bottom: 4px;
flex-shrink: 0;
min-width: 140px;
}
.yatra-detail-icon {
width: 16px;
height: 16px;
color: #6b7280;
}
.yatra-detail-value {
color: #111827;
font-size: 0.95rem;
line-height: 1.5;
flex: 1;
}
.yatra-no-details {
text-align: center;
padding: 48px 24px;
background: #f9fafb;
border-radius: 8px;
border: 1px solid #e5e7eb;
margin-top: 24px;
}
.yatra-no-details p {
color: #6b7280;
font-size: 1rem;
margin: 0;
} @media (max-width: 768px) {
.yatra-trip-details-grid {
grid-template-columns: 1fr;
gap: 16px;
margin-top: 16px;
}
.yatra-detail-item {
padding: 12px;
flex-direction: column;
align-items: flex-start;
}
.yatra-detail-label {
min-width: auto;
margin-bottom: 8px;
}
.yatra-detail-value {
font-size: 0.9rem;
}
}
@media (max-width: 480px) {
.yatra-trip-details-grid {
gap: 12px;
}
.yatra-detail-item {
padding: 10px;
}
.yatra-no-details {
padding: 32px 16px;
}
} .yatra-sticky-nav-icon {
width: 18px;
height: 18px;
color: #6b7280;
transition: color 0.2s ease;
}
.yatra-sticky-nav-item:hover .yatra-sticky-nav-icon {
color: #3b82f6;
}
.yatra-sticky-nav-item.active .yatra-sticky-nav-icon {
color: #3b82f6;
} .yatra-hero-season {
display: flex;
align-items: center;
gap: 6px;
color: #6b7280;
font-size: 15px;
font-weight: 500;
} .faq-toggle-btn {
display: flex;
align-items: center;
gap: 8px;
padding: 8px 16px;
background: #ffffff;
border: 1px solid #e5e7eb;
border-radius: 6px;
color: #374151;
font-size: 14px;
font-weight: 500;
cursor: pointer;
transition: all 0.2s ease;
}
.faq-toggle-btn:hover {
background: #f9fafb;
border-color: #d1d5db;
color: #111827;
}
.faq-toggle-btn .toggle-icon {
width: 16px;
height: 16px;
color: #6b7280;
}
.faq-toggle-btn .toggle-text {
font-size: 14px;
font-weight: 500;
}  .yatra-similar-trip-card {
background: #ffffff;
border-radius: 12px;
overflow: hidden;
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
transition: all 0.3s ease;
height: 100%;
display: flex;
flex-direction: column;
}
.yatra-similar-trip-card:hover {
transform: translateY(-4px);
box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
} .yatra-similar-trip-image {
position: relative;
width: 100%;
height: 200px;
overflow: hidden;
}
.yatra-similar-trip-image img {
width: 100%;
height: 100%;
object-fit: cover;
transition: transform 0.3s ease;
}
.yatra-similar-trip-card:hover .yatra-similar-trip-image img {
transform: scale(1.05);
}
.yatra-similar-image-link {
display: block;
width: 100%;
height: 100%;
text-decoration: none;
} .yatra-similar-discount-badge {
position: absolute;
top: 12px;
left: 12px;
background: #ef4444;
color: white;
padding: 6px 12px;
border-radius: 20px;
font-size: 12px;
font-weight: 600;
text-transform: uppercase;
letter-spacing: 0.5px;
z-index: 5;
box-shadow: 0 2px 8px rgba(239, 68, 68, 0.3);
} .yatra-similar-favorite-btn {
position: absolute;
top: 12px;
right: 12px;
background: rgba(255, 255, 255, 0.9);
border: none;
width: 36px;
height: 36px;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
transition: all 0.3s ease;
z-index: 5;
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}
.yatra-similar-favorite-btn:hover {
background: #ffffff;
transform: scale(1.1);
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}
.yatra-similar-favorite-btn svg {
color: #6b7280;
transition: color 0.3s ease;
}
.yatra-similar-favorite-btn:hover svg {
color: #ef4444;
} .yatra-similar-difficulty-overlay {
position: absolute;
bottom: 12px;
right: 12px;
background: rgba(0, 0, 0, 0.7);
color: white;
padding: 6px 10px;
border-radius: 6px;
font-size: 12px;
font-weight: 500;
display: flex;
align-items: center;
gap: 4px;
z-index: 5;
backdrop-filter: blur(4px);
}
.similar-difficulty-icon {
width: 14px;
height: 14px;
flex-shrink: 0;
} .yatra-similar-trip-content {
padding: 20px;
flex: 1;
display: flex;
flex-direction: column;
} .yatra-similar-destinations {
display: flex;
align-items: center;
gap: 6px;
margin-bottom: 12px;
font-size: 14px;
color: #6b7280;
}
.similar-location-icon {
width: 14px;
height: 14px;
flex-shrink: 0;
color: #9ca3af;
}
.similar-destination-link {
color: #6b7280;
text-decoration: none;
transition: color 0.3s ease;
}
.similar-destination-link:hover {
color: #3b82f6;
} .yatra-similar-trip-title {
margin: 0 0 16px 0;
font-size: 18px;
font-weight: 600;
line-height: 1.4;
color: #111827;
}
.yatra-similar-title-link {
color: #111827;
text-decoration: none;
transition: color 0.3s ease;
}
.yatra-similar-title-link:hover {
color: #3b82f6;
} .yatra-similar-trip-stats {
display: flex;
gap: 16px;
margin-bottom: 16px;
flex-wrap: wrap;
}
.yatra-similar-stat {
display: flex;
align-items: center;
gap: 6px;
font-size: 13px;
color: #6b7280;
}
.similar-stat-icon {
width: 14px;
height: 14px;
flex-shrink: 0;
color: #9ca3af;
} .yatra-similar-categories {
display: flex;
gap: 8px;
margin-bottom: 20px;
flex-wrap: wrap;
}
.yatra-similar-category-tag {
background: #f3f4f6;
color: #374151;
padding: 4px 10px;
border-radius: 12px;
font-size: 12px;
font-weight: 500;
text-decoration: none;
transition: all 0.3s ease;
}
.yatra-similar-category-tag:hover {
background: #e5e7eb;
color: #111827;
} .yatra-similar-trip-footer {
margin-top: auto;
display: flex;
align-items: center;
justify-content: space-between;
gap: 12px;
} .yatra-similar-price {
display: flex;
flex-direction: row;
align-items: center;
min-width: 0;
flex: 1;
}
.yatra-similar-trip-price {
display: flex;
flex-wrap: wrap;
align-items: baseline;
column-gap: 6px;
row-gap: 2px;
line-height: 1.25;
color: #111827;
}
.yatra-similar-price-label {
font-size: 11px;
font-weight: 600;
color: #6b7280;
letter-spacing: 0.02em;
flex-shrink: 0;
}
.yatra-similar-price-amount {
font-size: 15px;
font-weight: 700;
color: #111827;
}
.yatra-similar-price-contact {
font-size: 13px;
font-weight: 500;
color: #6b7280;
}
.yatra-similar-original-price {
font-size: 11px;
font-weight: 500;
color: #9ca3af;
text-decoration: line-through;
margin-left: 0;
} .yatra-similar-view-btn {
background: #3b82f6;
color: white;
border: none;
padding: 10px 18px;
border-radius: 6px;
font-size: 14px;
font-weight: 600;
text-decoration: none;
transition: all 0.3s ease;
white-space: nowrap;
flex-shrink: 0;
}
.yatra-similar-view-btn:hover {
background: #2563eb;
transform: translateY(-1px);
box-shadow: 0 4px 12px rgba(59, 130, 246, 0.3);
} @media (max-width: 768px) {
.yatra-similar-trip-card {
margin-bottom: 16px;
}
.yatra-similar-trip-image {
height: 160px;
}
.yatra-similar-trip-content {
padding: 16px;
}
.yatra-similar-trip-title {
font-size: 16px;
}
.yatra-similar-trip-stats {
gap: 12px;
}
.yatra-similar-trip-footer {
flex-direction: column;
align-items: flex-start;
gap: 12px;
}
.yatra-similar-price {
width: 100%;
}
.yatra-similar-view-btn {
width: 100%;
text-align: center;
}
}
@media (max-width: 480px) {
.yatra-similar-trip-image {
height: 140px;
}
.yatra-similar-trip-content {
padding: 12px;
}
.yatra-similar-trip-title {
font-size: 15px;
margin-bottom: 12px;
}
.yatra-similar-trip-stats {
gap: 8px;
font-size: 12px;
}
.yatra-similar-categories {
margin-bottom: 16px;
}
}  .yatra-downloads-container {
margin-top: 24px;
}
.yatra-downloads-list {
display: flex;
flex-direction: column;
gap: 16px;
margin-top: 20px;
} .yatra-download-item {
display: flex;
align-items: center;
gap: 16px;
background: #ffffff;
border: 1px solid #e5e7eb;
border-radius: 12px;
padding: 20px;
transition: all 0.3s ease;
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}
.yatra-download-item:hover {
transform: translateY(-1px);
box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
border-color: #d1d5db;
} .yatra-download-icon {
display: flex;
align-items: center;
justify-content: center;
width: 60px;
height: 60px;
min-width: 60px;
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
border-radius: 12px;
color: white;
flex-shrink: 0;
}
.yatra-download-file-icon {
width: 28px;
height: 28px;
color: white;
} .yatra-download-content {
flex: 1;
min-width: 0;
}
.yatra-download-title {
margin: 0 0 8px 0;
font-size: 16px;
font-weight: 600;
line-height: 1.4;
color: #111827;
}
.yatra-download-description {
margin: 0 0 12px 0;
font-size: 14px;
line-height: 1.5;
color: #6b7280;
} .yatra-download-meta {
display: flex;
align-items: center;
gap: 12px;
flex-wrap: wrap;
font-size: 12px;
color: #9ca3af;
}
.yatra-download-file-size,
.yatra-download-file-type {
background: #f3f4f6;
padding: 3px 8px;
border-radius: 4px;
font-weight: 500;
} .yatra-download-action {
flex-shrink: 0;
margin-left: auto;
}
.yatra-download-btn {
display: flex;
align-items: center;
gap: 8px;
background: #3b82f6;
color: white;
border: none;
padding: 10px 20px;
border-radius: 8px;
font-size: 14px;
font-weight: 600;
cursor: pointer;
text-decoration: none;
transition: all 0.3s ease;
white-space: nowrap;
}
.yatra-download-btn:hover {
background: #2563eb;
transform: translateY(-1px);
box-shadow: 0 4px 12px rgba(59, 130, 246, 0.3);
color: white;
}
.yatra-download-btn-icon {
width: 16px;
height: 16px;
flex-shrink: 0;
}
.yatra-download-btn-disabled {
background: #9ca3af;
color: #6b7280;
cursor: not-allowed;
opacity: 0.7;
}
.yatra-download-btn-disabled:hover {
background: #9ca3af;
transform: none;
box-shadow: none;
color: #6b7280;
} @media (max-width: 768px) {
.yatra-downloads-list {
gap: 12px;
}
.yatra-download-item {
flex-direction: column;
align-items: flex-start;
gap: 12px;
padding: 16px;
}
.yatra-download-icon {
width: 50px;
height: 50px;
min-width: 50px;
}
.yatra-download-file-icon {
width: 24px;
height: 24px;
}
.yatra-download-action {
margin-left: 0;
width: 100%;
}
.yatra-download-btn {
width: 100%;
justify-content: center;
}
}
@media (max-width: 480px) {
.yatra-download-item {
padding: 12px;
}
.yatra-download-title {
font-size: 15px;
}
.yatra-download-description {
font-size: 13px;
}
.yatra-download-meta {
font-size: 11px;
gap: 8px;
}
}   #what-makes-special .yatra-trip-special-container {
max-width: 800px;
margin: 0 auto;
}
#what-makes-special .yatra-trip-special-content {
background: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);
border-radius: 16px;
padding: clamp(var(--yatra-container-padding), 5vw, 2.5rem);
box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
position: relative;
overflow: hidden;
}
#what-makes-special .yatra-trip-special-content::before {
content: '';
position: absolute;
top: -50%;
right: -50%;
width: 200%;
height: 200%;
background: radial-gradient(circle, rgba(251, 191, 36, 0.1) 0%, transparent 70%);
animation: yatra-special-float 6s ease-in-out infinite;
}
@keyframes yatra-special-float {
0%, 100% { transform: translateY(0) rotate(0deg); }
50% { transform: translateY(-20px) rotate(180deg); }
}
#what-makes-special .yatra-special-features {
position: relative;
z-index: 1;
}
#what-makes-special .yatra-special-feature-item {
display: flex;
align-items: flex-start;
gap: var(--yatra-small-gap);
margin-bottom: var(--yatra-element-gap);
padding: var(--yatra-small-gap);
background: rgba(255, 255, 255, 0.7);
border-radius: 12px;
transition: transform 0.3s ease, box-shadow 0.3s ease, background 0.3s ease;
}
#what-makes-special .yatra-special-feature-item:hover {
background: rgba(255, 255, 255, 0.9);
transform: translateY(-2px);
box-shadow: 0 8px 25px -5px rgba(251, 191, 36, 0.2);
}
#what-makes-special .yatra-special-feature-item:last-child {
margin-bottom: 0;
}
#what-makes-special .yatra-special-feature-icon {
flex-shrink: 0;
width: 24px;
height: 24px;
color: #f59e0b;
margin-top: 2px;
}
#what-makes-special .yatra-special-feature-text {
font-size: 1rem;
line-height: 1.6;
color: #78350f;
font-weight: 500;
}
#what-makes-special .yatra-special-badge {
display: inline-flex;
align-items: center;
gap: var(--yatra-mini-gap);
margin-top: var(--yatra-element-gap);
padding: var(--yatra-tiny-gap) var(--yatra-element-gap);
background: #f59e0b;
color: #fff;
border-radius: 25px;
font-weight: 600;
font-size: 0.875rem;
box-shadow: 0 4px 6px -1px rgba(245, 158, 11, 0.3);
}
#what-makes-special .yatra-badge-icon {
width: 16px;
height: 16px;
}
#what-makes-special .yatra-special-features .yatra-no-content {
color: #92400e;
font-style: italic;
text-align: center;
padding: 2rem;
background: rgba(255, 255, 255, 0.5);
border-radius: 12px;
}
@media (prefers-color-scheme: dark) {
#what-makes-special .yatra-trip-special-content {
background: linear-gradient(135deg, #451a03 0%, #78350f 100%);
}
#what-makes-special .yatra-special-feature-item {
background: rgba(30, 41, 59, 0.7);
}
#what-makes-special .yatra-special-feature-item:hover {
background: rgba(30, 41, 59, 0.9);
}
#what-makes-special .yatra-special-feature-text {
color: #fbbf24;
}
#what-makes-special .yatra-special-badge {
background: #f59e0b;
color: #451a03;
}
#what-makes-special .yatra-special-features .yatra-no-content {
color: #fbbf24;
background: rgba(30, 41, 59, 0.5);
}
}
@media (max-width: 768px) {
#what-makes-special .yatra-special-feature-item {
padding: var(--yatra-tiny-gap);
gap: var(--yatra-tiny-gap);
}
#what-makes-special .yatra-special-feature-icon {
width: 20px;
height: 20px;
}
#what-makes-special .yatra-special-feature-text {
font-size: 0.9rem;
}
} #trip-story .yatra-trip-story-container {
max-width: 800px;
margin: 0 auto;
}
#trip-story .yatra-trip-story-content {
background: linear-gradient(135deg, #f8fafc 0%, #f1f5f9 100%);
border-radius: 16px;
padding: clamp(var(--yatra-container-padding), 5vw, 2.5rem);
box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
position: relative;
overflow: hidden;
}
#trip-story .yatra-trip-story-content::before {
content: '"';
position: absolute;
top: -20px;
left: var(--yatra-element-gap);
font-size: 120px;
color: #e2e8f0;
font-family: Georgia, serif;
z-index: 0;
}
#trip-story .yatra-trip-story-text {
position: relative;
z-index: 1;
font-size: 1.125rem;
line-height: 1.8;
color: #475569;
}
#trip-story .yatra-trip-story-text p {
margin-bottom: 1.5rem;
}
#trip-story .yatra-trip-story-text p:last-child {
margin-bottom: 0;
}
#trip-story .yatra-trip-story-text h1,
#trip-story .yatra-trip-story-text h2,
#trip-story .yatra-trip-story-text h3 {
color: #1e293b;
margin-top: 2rem;
margin-bottom: 1rem;
}
#trip-story .yatra-trip-story-text h1 { font-size: 1.875rem; }
#trip-story .yatra-trip-story-text h2 { font-size: 1.5rem; }
#trip-story .yatra-trip-story-text h3 { font-size: 1.25rem; }
#trip-story .yatra-trip-story-text ul,
#trip-story .yatra-trip-story-text ol {
margin: 1.5rem 0;
padding-left: 2rem;
}
#trip-story .yatra-trip-story-text li {
margin-bottom: 0.5rem;
color: #475569;
}
#trip-story .yatra-trip-story-text blockquote {
border-left: 4px solid #3b82f6;
padding-left: 1.5rem;
margin: 1.5rem 0;
font-style: italic;
color: #64748b;
}
#trip-story .yatra-trip-story-text strong {
color: #1e293b;
font-weight: 600;
}
#trip-story .yatra-trip-story-text em {
color: #64748b;
font-style: italic;
}
#trip-story .yatra-trip-story-meta {
margin-top: var(--yatra-element-gap);
text-align: center;
}
#trip-story .yatra-story-highlight {
display: inline-flex;
align-items: center;
gap: var(--yatra-mini-gap);
padding: var(--yatra-mini-gap) var(--yatra-small-gap);
background: #fef3c7;
border-radius: 20px;
color: #92400e;
font-size: 0.875rem;
font-weight: 500;
}
#trip-story .yatra-story-icon {
width: 16px;
height: 16px;
}
#trip-story .yatra-trip-story-text > .yatra-no-content {
color: #94a3b8;
font-style: italic;
text-align: center;
padding: 2rem;
}
@media (prefers-color-scheme: dark) {
#trip-story .yatra-trip-story-content {
background: linear-gradient(135deg, #1e293b 0%, #334155 100%);
}
#trip-story .yatra-trip-story-content::before {
color: #475569;
}
#trip-story .yatra-trip-story-text {
color: #cbd5e1;
}
#trip-story .yatra-trip-story-text h1,
#trip-story .yatra-trip-story-text h2,
#trip-story .yatra-trip-story-text h3 {
color: #f8fafc;
}
#trip-story .yatra-trip-story-text li {
color: #cbd5e1;
}
#trip-story .yatra-trip-story-text blockquote {
color: #94a3b8;
border-left-color: #60a5fa;
}
#trip-story .yatra-trip-story-text strong {
color: #f8fafc;
}
#trip-story .yatra-trip-story-text em {
color: #94a3b8;
}
#trip-story .yatra-story-highlight {
background: #451a03;
color: #fbbf24;
}
#trip-story .yatra-trip-story-text > .yatra-no-content {
color: #64748b;
}
}
@media (max-width: 768px) {
#trip-story .yatra-trip-story-text {
font-size: 1rem;
}
#trip-story .yatra-trip-story-content::before {
font-size: 80px;
top: -10px;
left: var(--yatra-tiny-gap);
}
} .yatra-testimonials-content {
margin-top: var(--yatra-section-gap);
}
.yatra-testimonial-avatar {
width: 52px;
height: 52px;
border-radius: 50%;
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
color: #fff;
display: flex;
align-items: center;
justify-content: center;
font-weight: 600;
font-size: 18px;
flex-shrink: 0;
}
.yatra-testimonials-empty {
text-align: center;
padding: clamp(3rem, 10vw, 5rem) var(--yatra-container-padding);
background: #f8fafc;
border-radius: 16px;
border: 2px dashed #e2e8f0;
}
.yatra-testimonials-empty-icon {
margin-bottom: var(--yatra-element-gap);
}
.yatra-testimonials-empty-svg {
width: 80px;
height: 80px;
color: #cbd5e1;
margin: 0 auto;
}
.yatra-testimonials-empty-title {
font-size: 1.5rem;
font-weight: 600;
color: #1e293b;
margin-bottom: var(--yatra-tiny-gap);
}
.yatra-testimonials-empty-text {
color: #64748b;
margin-bottom: var(--yatra-section-gap);
max-width: 400px;
margin-left: auto;
margin-right: auto;
}
.yatra-testimonials-empty-cta {
display: inline-flex;
align-items: center;
gap: var(--yatra-mini-gap);
background: #3b82f6;
color: #fff;
text-decoration: none;
padding: var(--yatra-tiny-gap) var(--yatra-element-gap);
border-radius: 8px;
font-weight: 500;
transition: background-color 0.3s ease;
}
.yatra-testimonials-empty-cta:hover {
background: #2563eb;
color: #fff;
}
@media (prefers-color-scheme: dark) {
.yatra-testimonials-empty {
background: #1e293b;
border-color: #334155;
}
.yatra-testimonials-empty-title {
color: #f8fafc;
}
.yatra-testimonials-empty-text {
color: #cbd5e1;
}
}
@media (max-width: 768px) {
.yatra-testimonials-empty {
padding: clamp(2.5rem, 8vw, 3.75rem) var(--yatra-container-padding);
}
} #faq .faq-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: var(--yatra-element-gap);
flex-wrap: wrap;
gap: var(--yatra-small-gap);
}
#faq .faq-controls {
display: flex;
gap: var(--yatra-mini-gap);
}
#faq .faq-toggle-btn,
#faq .faq-btn {
display: inline-flex;
align-items: center;
gap: 6px;
padding: 6px var(--yatra-tiny-gap);
background: #fff;
border: 1px solid #e5e7eb;
border-radius: 6px;
font-size: 13px;
color: #6b7280;
cursor: pointer;
transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}
#faq .faq-toggle-btn:hover,
#faq .faq-btn:hover {
background: #f9fafb;
border-color: #d1d5db;
color: #374151;
}
#faq .faq-toggle-btn svg,
#faq .faq-btn svg {
flex-shrink: 0;
}
#faq .faq-btn-arrow {
color: #9ca3af;
transition: transform 0.3s ease;
}
#faq .faq-container {
max-width: 800px;
margin: 0 auto;
border: 1px solid #e5e7eb;
border-radius: 8px;
overflow: hidden;
}
#faq .faq-item {
border-bottom: 1px solid #e5e7eb;
}
#faq .faq-item:last-child {
border-bottom: none;
}
#faq .faq-question {
width: 100%;
background: none;
border: none;
padding: var(--yatra-small-gap) var(--yatra-element-gap);
text-align: left;
font-size: 15px;
font-weight: 500;
color: #374151;
cursor: pointer;
display: flex;
justify-content: space-between;
align-items: center;
transition: background-color 0.2s ease;
}
#faq .faq-question:hover {
background: #f9fafb;
}
#faq .faq-item.active .faq-question {
background: #f9fafb;
font-weight: 600;
}
#faq .faq-arrow {
color: #9ca3af;
transition: transform 0.3s ease;
flex-shrink: 0;
margin-left: var(--yatra-tiny-gap);
}
#faq .faq-item.active .faq-arrow {
color: #6b7280;
transform: rotate(180deg);
}
#faq .faq-toggle-btn .collapse-icon {
display: none;
}
#faq .faq-toggle-btn.is-all-expanded .expand-icon {
display: none;
}
#faq .faq-toggle-btn.is-all-expanded .collapse-icon {
display: block;
}
#faq .faq-answer {
max-height: 0;
overflow: hidden;
transition: max-height 0.35s ease;
background: #f9fafb;
padding: 0 var(--yatra-element-gap);
color: #6b7280;
line-height: 1.5;
font-size: 14px;
}
#faq .faq-item.active .faq-answer {
max-height: min(4000px, 200vh);
padding: 0 var(--yatra-element-gap) var(--yatra-small-gap) var(--yatra-element-gap);
}
#faq .faq-answer p {
margin: 0 0 var(--yatra-mini-gap) 0;
}
#faq .faq-answer p:last-child {
margin-bottom: 0;
}
#faq .faq-answer ul,
#faq .faq-answer ol {
margin: var(--yatra-mini-gap) 0;
padding-left: var(--yatra-small-gap);
}
#faq .faq-answer li {
margin-bottom: var(--yatra-micro-gap);
}
@media (max-width: 768px) {
#faq .faq-header {
flex-direction: column;
align-items: flex-start;
gap: var(--yatra-tiny-gap);
}
#faq .faq-controls {
width: 100%;
justify-content: flex-start;
}
#faq .faq-question {
padding: 14px var(--yatra-small-gap);
font-size: 14px;
}
#faq .faq-answer {
font-size: 13px;
}
#faq .faq-item.active .faq-answer {
padding: 0 var(--yatra-small-gap) 14px var(--yatra-small-gap);
}
}.yatra-activity-image {
position: relative;
width: 100%;
aspect-ratio: 4 / 3;
overflow: hidden;
}
.yatra-activity-image img {
width: 100%;
height: 100%;
display: block;
object-fit: cover;
}
.yatra-activity-icon-wrapper,
.yatra-activity-placeholder {
width: 100%;
height: 100%;
display: flex;
align-items: center;
justify-content: center;
}
.yatra-activity-icon-wrapper {
background: linear-gradient(135deg, #f3f4f6 0%, #e5e7eb 100%);
color: #4b5563;
}
.yatra-activity-icon {
width: 100%;
height: 100%;
object-fit: contain;
}
.yatra-activity-placeholder {
background-color: #f3f4f6;
}
.yatra-activity-placeholder-text {
font-weight: 600;
font-size: 1.25rem;
letter-spacing: 0.08em;
} .yatra-activity-listing .yatra-view-toggle .yatra-view-btn svg {
display: block;
}  .yatra-activity-grid .yatra-activity-card {
display: flex;
flex-direction: column;
} .yatra-activity-grid.list-view {
display: flex;
flex-direction: column;
gap: 1.25rem;
}
.yatra-activity-grid.list-view .yatra-activity-card {
flex-direction: row;
}
.yatra-activity-grid.list-view .yatra-activity-image {
flex: 0 0 260px;
}
.yatra-activity-grid.list-view .yatra-activity-content {
flex: 1 1 auto;
} .yatra-listing-pagination .yatra-pagination-btn.disabled {
opacity: 0.5;
cursor: default;
pointer-events: none;
}.yatra-destination-image {
position: relative;
width: 100%;
aspect-ratio: 4 / 3;
overflow: hidden;
}
.yatra-destination-image img {
width: 100%;
height: 100%;
display: block;
object-fit: cover;
}
.yatra-destination-icon-wrapper,
.yatra-destination-placeholder {
width: 100%;
height: 100%;
display: flex;
align-items: center;
justify-content: center;
}
.yatra-destination-icon-wrapper {
background-color: #f3f4f6;
color: #4b5563;
}
.yatra-destination-icon {
width: 100%;
height: 100%;
object-fit: contain;
}
.yatra-destination-placeholder {
background-color: #f3f4f6;
}
.yatra-destination-placeholder-text {
font-weight: 600;
font-size: 1.25rem;
letter-spacing: 0.08em;
} .yatra-destination-listing .yatra-view-toggle .yatra-view-btn svg {
display: block;
}  .yatra-destination-grid .yatra-destination-card {
display: flex;
flex-direction: column;
} .yatra-destination-grid.list-view {
display: flex;
flex-direction: column;
gap: 1.25rem;
}
.yatra-destination-grid.list-view .yatra-destination-card {
flex-direction: row;
}
.yatra-destination-grid.list-view .yatra-destination-image {
flex: 0 0 260px;
}
.yatra-destination-grid.list-view .yatra-destination-content {
flex: 1 1 auto;
} .yatra-listing-pagination .yatra-pagination-btn.disabled {
opacity: 0.5;
cursor: default;
pointer-events: none;
}.yatra-card-tour-meta {
display: flex;
align-items: center;
flex-wrap: wrap;
gap: 8px;
margin-top: 4px;
}
.yatra-card-tour-capacity {
display: inline-flex;
align-items: center;
font-size: 13px;
color: #4a5568;
background-color: #f7fafc;
padding: 2px 8px;
border-radius: 4px;
font-weight: 500;
}
.yatra-available-spots {
font-weight: 600;
color: #2d3748;
} .yatra-availability-card.limited .yatra-card-tour-capacity {
background-color: #fff5f5;
color: #c53030;
}
.yatra-availability-card.limited .yatra-available-spots {
color: #9b2c2c;
} .yatra-availability-card.full .yatra-card-tour-capacity {
background-color: #f8f9fa;
color: #718096;
text-decoration: line-through;
} @media (max-width: 768px) {
.yatra-card-tour-meta {
flex-direction: column;
align-items: flex-start;
gap: 4px;
}
.yatra-card-tour-separator {
display: none;
}
}.yatra-video-player-modal {
position: fixed !important;
top: 0 !important;
left: 0 !important;
right: 0 !important;
bottom: 0 !important;
z-index: 99999 !important;
align-items: center !important;
justify-content: center !important;
animation: yatraVideoFadeIn 0.3s ease;
}
.yatra-video-player-modal[style*="display: flex"] {
display: flex !important;
}
@keyframes yatraVideoFadeIn {
from {
opacity: 0;
}
to {
opacity: 1;
}
}
.yatra-video-player-overlay {
position: absolute !important;
top: 0 !important;
left: 0 !important;
right: 0 !important;
bottom: 0 !important;
background: rgba(0, 0, 0, 0.95) !important;
cursor: pointer !important;
z-index: 1 !important;
}
.yatra-video-player-content {
position: relative !important;
width: 90% !important;
max-width: 1200px !important;
height: 80vh !important;
max-height: 675px !important; z-index: 2 !important;
}
.yatra-video-player-close {
position: absolute !important;
top: 16px !important;
right: 16px !important;
background: rgba(255, 255, 255, 0.2) !important;
border: 2px solid rgba(255, 255, 255, 0.4) !important;
color: white !important;
width: 44px !important;
height: 44px !important;
border-radius: 50% !important;
cursor: pointer !important;
display: flex !important;
align-items: center !important;
justify-content: center !important;
transition: all 0.3s ease;
z-index: 100 !important;
padding:0;
}
.yatra-video-player-close:hover {
background: rgba(255, 255, 255, 0.2);
border-color: rgba(255, 255, 255, 0.5);
transform: rotate(90deg) scale(1.1);
}
.yatra-video-player-close svg {
width: 24px;
height: 24px;
}
.yatra-video-player-wrapper {
width: 100% !important;
height: 100% !important;
min-height: 400px !important;
background: #000 !important;
border-radius: 12px;
overflow: hidden;
box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
position: relative !important;
display: block !important;
}
.yatra-video-player-wrapper iframe {
width: 100% !important;
height: 100% !important;
border: none !important;
display: block !important;
} @media (max-width: 1024px) {
.yatra-video-player-content {
width: 95%;
}
}
@media (max-width: 768px) {
.yatra-video-player-content {
width: 95%;
max-width: none;
}
.yatra-video-player-close {
top: -45px;
width: 40px;
height: 40px;
}
.yatra-video-player-close svg {
width: 20px;
height: 20px;
}
}
@media (max-width: 480px) {
.yatra-video-player-content {
width: 100%;
}
.yatra-video-player-wrapper {
border-radius: 0;
}
.yatra-video-player-close {
top: 10px;
right: 10px;
background: rgba(0, 0, 0, 0.7);
}
} .yatra-video-player-wrapper.loading::before {
content: '';
position: absolute;
top: 50%;
left: 50%;
width: 50px;
height: 50px;
margin: -25px 0 0 -25px;
border: 3px solid rgba(255, 255, 255, 0.3);
border-top-color: #fff;
border-radius: 50%;
animation: yatraVideoSpin 0.8s linear infinite;
}
@keyframes yatraVideoSpin {
to {
transform: rotate(360deg);
}
}.yatra-tour-viewer-modal {
position: fixed !important;
top: 0 !important;
left: 0 !important;
right: 0 !important;
bottom: 0 !important;
z-index: 99999 !important;
align-items: center !important;
justify-content: center !important;
animation: yatraTourFadeIn 0.3s ease;
}
.yatra-tour-viewer-modal[style*="display: flex"] {
display: flex !important;
}
@keyframes yatraTourFadeIn {
from {
opacity: 0;
}
to {
opacity: 1;
}
}
.yatra-tour-viewer-overlay {
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: rgba(0, 0, 0, 0.95);
cursor: pointer;
}
.yatra-tour-viewer-content {
position: relative !important;
width: 95% !important;
max-width: 1400px !important;
height: 90vh !important;
z-index: 2 !important;
}
.yatra-tour-viewer-close {
position: absolute !important;
top: 16px !important;
right: 70px !important;
background: rgba(16, 185, 129, 0.3) !important;
border: 2px solid rgba(16, 185, 129, 0.6) !important;
color: white !important;
width: 44px !important;
height: 44px !important;
border-radius: 50% !important;
cursor: pointer !important;
display: flex !important;
align-items: center !important;
justify-content: center !important;
transition: all 0.3s ease;
z-index: 100 !important;
padding:0;
}
.yatra-tour-viewer-close:hover {
background: rgba(16, 185, 129, 0.3);
border-color: rgba(16, 185, 129, 0.7);
transform: rotate(90deg) scale(1.1);
}
.yatra-tour-viewer-close svg {
width: 24px;
height: 24px;
}
.yatra-tour-viewer-header {
display: flex;
align-items: center;
justify-content: space-between;
padding: 16px 20px;
background: rgba(0, 0, 0, 0.8);
border-radius: 12px 12px 0 0;
backdrop-filter: blur(10px);
}
.yatra-tour-viewer-title {
margin: 0;
font-size: 18px;
font-weight: 600;
color: white;
}
.yatra-tour-viewer-controls {
display: flex;
gap: 8px;
}
.yatra-tour-viewer-fullscreen {
background: rgba(255, 255, 255, 0.1);
border: 1px solid rgba(255, 255, 255, 0.2);
color: white;
width: 36px;
height: 36px;
border-radius: 6px;
cursor: pointer;
display: flex;
align-items: center;
justify-content: center;
transition: all 0.3s ease;
padding:0;
}
.yatra-tour-viewer-fullscreen:hover {
background: rgba(255, 255, 255, 0.2);
border-color: rgba(255, 255, 255, 0.3);
}
.yatra-tour-viewer-wrapper {
width: 100%;
height: calc(100% - 68px);
background: #000;
border-radius: 0 0 12px 12px;
overflow: hidden;
box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
}
.yatra-tour-viewer-wrapper iframe {
width: 100%;
height: 100%;
border: none;
} .yatra-tour-viewer-wrapper:fullscreen {
border-radius: 0;
}
.yatra-tour-viewer-wrapper:-webkit-full-screen {
border-radius: 0;
}
.yatra-tour-viewer-wrapper:-moz-full-screen {
border-radius: 0;
} @media (max-width: 1024px) {
.yatra-tour-viewer-content {
width: 98%;
height: 85vh;
}
}
@media (max-width: 768px) {
.yatra-tour-viewer-content {
width: 100%;
height: 100vh;
}
.yatra-tour-viewer-close {
top: 10px;
right: 10px;
width: 40px;
height: 40px;
background: rgba(0, 0, 0, 0.7);
border-color: rgba(255, 255, 255, 0.3);
}
.yatra-tour-viewer-close svg {
width: 20px;
height: 20px;
}
.yatra-tour-viewer-header {
padding: 12px 16px;
border-radius: 0;
}
.yatra-tour-viewer-title {
font-size: 16px;
}
.yatra-tour-viewer-wrapper {
border-radius: 0;
height: calc(100% - 56px);
}
}
@media (max-width: 480px) {
.yatra-tour-viewer-title {
font-size: 14px;
}
.yatra-tour-viewer-fullscreen {
width: 32px;
height: 32px;
}
} .yatra-tour-viewer-wrapper.loading::before {
content: '';
position: absolute;
top: 50%;
left: 50%;
width: 60px;
height: 60px;
margin: -30px 0 0 -30px;
border: 4px solid rgba(16, 185, 129, 0.3);
border-top-color: #10b981;
border-radius: 50%;
animation: yatraTourSpin 0.8s linear infinite;
z-index: 1;
}
@keyframes yatraTourSpin {
to {
transform: rotate(360deg);
}
}body .yatra-trip-search-shortcode {
--yatra-ts-accent: #2563eb;
--yatra-ts-accent-hover: #1d4ed8;
--yatra-ts-surface: #ffffff;
--yatra-ts-text: #0f172a;
--yatra-ts-muted: #64748b;
--yatra-ts-border: #e2e8f0;
--yatra-ts-radius: 14px;
--yatra-ts-row: 52px;
--yatra-ts-z-dropdown: 10050;
display: block;
width: 100%;
max-width: 100%;
position: relative;
z-index: 1000;
isolation: isolate;
font-family: system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
line-height: 1.4;
color: var(--yatra-ts-text);
-webkit-font-smoothing: antialiased;
}
body .yatra-trip-search-shortcode *,
body .yatra-trip-search-shortcode *::before,
body .yatra-trip-search-shortcode *::after {
box-sizing: border-box !important;
}
body .yatra-trip-search-shortcode button,
body .yatra-trip-search-shortcode input,
body .yatra-trip-search-shortcode select {
font-family: inherit !important;
font-size: inherit;
line-height: inherit;
} body .yatra-trip-search-shortcode .yatra-horizontal-search {
padding:0;
margin: 0 !important;
position: relative;
z-index: 1;
}
body .yatra-trip-listing-search-wrap .yatra-trip-search-shortcode .yatra-horizontal-search {
padding-top: 0 !important;
padding-bottom: 28px !important;
background: transparent !important;
}
body .yatra-trip-search-shortcode .yatra-horizontal-search-container {
width: 100% !important;
max-width: var(--yatra-container-max-width, 1200px) !important;
margin-left: auto !important;
margin-right: auto !important;
padding-left: var(--yatra-container-padding, 20px) !important;
padding-right: var(--yatra-container-padding, 20px) !important;
position: relative;
z-index: 2;
} body .yatra-trip-search-shortcode .yatra-search-bar {
display: flex !important;
flex-direction: row;
align-items: stretch !important;
flex-wrap: nowrap;
gap: 0 !important;
width: 100% !important;
margin: 0 !important;
padding: 5px 6px 5px 8px !important;
background: var(--yatra-ts-surface) !important;
border: 1px solid var(--yatra-ts-border) !important;
border-radius: var(--yatra-ts-radius) !important;
box-shadow:
0 1px 2px rgba(15, 23, 42, 0.04),
0 8px 24px rgba(15, 23, 42, 0.06) !important;
transition: box-shadow 0.2s ease, border-color 0.2s ease;
}
body .yatra-trip-search-shortcode .yatra-search-bar:hover {
border-color: #cbd5e1 !important;
box-shadow:
0 1px 2px rgba(15, 23, 42, 0.05),
0 12px 32px rgba(15, 23, 42, 0.08) !important;
}
body .yatra-trip-search-shortcode .yatra-search-divider {
width: 1px !important;
flex-shrink: 0 !important;
align-self: center !important;
height: 28px !important;
margin: 0 2px !important;
padding: 0 !important;
border: none !important;
background: rgba(148, 163, 184, 0.45) !important;
} body .yatra-trip-search-shortcode .yatra-search-keyword-segment {
display: flex !important;
flex: 2.5;
align-items: stretch !important;
min-width: 260px;
max-width: 480px;
margin: 0 !important;
padding: 0 !important;
}
body .yatra-trip-search-shortcode .yatra-search-keyword-inner {
display: flex !important;
flex-direction: row;
align-items: center !important;
gap: 10px !important;
width: 100% !important;
min-height: var(--yatra-ts-row) !important;
padding: 8px 12px !important;
margin: 0 !important;
border: 1px solid transparent !important;
border-radius: calc(var(--yatra-ts-radius) - 6px) !important;
background: transparent !important;
box-shadow: none !important;
transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}
body .yatra-trip-search-shortcode .yatra-search-keyword-inner:hover {
background: #f8fafc !important;
}
body .yatra-trip-search-shortcode .yatra-search-keyword-inner:focus-within {
background: #fafafa !important;
border-color: rgba(37, 99, 235, 0.28) !important;
box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1) !important;
outline: none !important;
}
body .yatra-trip-search-shortcode .yatra-search-keyword-leading {
display: flex !important;
flex-shrink: 0 !important;
align-items: center !important;
justify-content: center !important;
width: 20px !important;
height: 20px !important;
margin: 0 !important;
padding: 0 !important;
border: none !important;
background: transparent !important;
color: #64748b !important;
}
body .yatra-trip-search-shortcode .yatra-search-keyword-leading svg {
display: block !important;
width: 20px !important;
height: 20px !important;
max-width: none !important;
fill: none !important;
stroke: currentColor !important;
vertical-align: middle !important;
}
body .yatra-trip-search-shortcode .yatra-search-keyword-inner:focus-within .yatra-search-keyword-leading {
color: var(--yatra-ts-accent) !important;
}
body .yatra-trip-search-shortcode .yatra-search-keyword-stack {
display: flex !important;
flex-direction: column !important;
align-items: flex-start !important;
justify-content: center !important;
gap: 4px !important;
flex: 1 1 auto !important;
min-width: 0 !important;
margin: 0 !important;
padding: 0 !important;
}
body .yatra-trip-search-shortcode .yatra-search-keyword-stack .yatra-dropdown-label {
margin: 0 !important;
padding: 0 !important;
}
body .yatra-trip-search-shortcode .yatra-search-keyword-input {
display: block !important;
width: 100% !important;
min-width: 0 !important;
margin: 0 !important;
padding: 0 !important;
border: none !important;
border-radius: 0 !important;
background: transparent !important;
background-color: transparent !important;
box-shadow: none !important;
font-size: 15px !important;
font-weight: 600 !important;
line-height: 1.3 !important;
color: var(--yatra-ts-text) !important;
-webkit-appearance: none !important;
appearance: none !important;
}
body .yatra-trip-search-shortcode .yatra-search-keyword-input::placeholder {
color: #94a3b8 !important;
font-weight: 500 !important;
opacity: 1 !important;
}
body .yatra-trip-search-shortcode .yatra-search-keyword-input:focus {
outline: none !important;
box-shadow: none !important;
}
body .yatra-trip-search-shortcode .yatra-search-keyword-input::-webkit-search-decoration,
body .yatra-trip-search-shortcode .yatra-search-keyword-input::-webkit-search-cancel-button {
-webkit-appearance: none !important;
appearance: none !important;
} body .yatra-trip-search-shortcode .yatra-search-dropdown {
position: relative !important;
flex: 1 1 auto !important;
min-width: 180px !important;
margin: 0 !important;
padding: 0 !important;
isolation: isolate;
}
body .yatra-trip-search-shortcode .yatra-dropdown-trigger {
display: flex !important;
flex-direction: row !important;
align-items: center !important;
gap: 10px !important;
width: 100% !important;
min-height: var(--yatra-ts-row) !important;
margin: 0 !important;
padding: 8px 12px !important;
border: 1px solid transparent !important;
border-radius: calc(var(--yatra-ts-radius) - 6px) !important;
background: transparent !important;
box-shadow: none !important;
cursor: pointer !important;
text-align: left !important;
overflow: visible !important;
transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}
body .yatra-trip-search-shortcode .yatra-dropdown-trigger:hover {
background: #f8fafc !important;
}
body .yatra-trip-search-shortcode .yatra-dropdown-trigger:active {
background: #f1f5f9 !important;
}
body .yatra-trip-search-shortcode .yatra-dropdown-trigger:focus {
outline: none !important;
border-color: rgba(37, 99, 235, 0.3) !important;
box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1) !important;
}
body .yatra-trip-search-shortcode .yatra-dropdown-trigger svg:first-of-type {
flex-shrink: 0 !important;
display: block !important;
width: 20px !important;
height: 20px !important;
min-width: 20px !important;
min-height: 20px !important;
margin: 0 !important;
padding: 0 !important;
color: #64748b !important;
fill: none !important;
stroke: currentColor !important;
}
body .yatra-trip-search-shortcode .yatra-dropdown-trigger:hover svg:first-of-type {
color: #475569 !important;
}
body .yatra-trip-search-shortcode .yatra-dropdown-content {
display: flex !important;
flex-direction: column !important;
align-items: flex-start !important;
gap: 4px !important;
flex: 1 1 auto !important;
min-width: 0 !important;
margin: 0 !important;
padding: 0 !important;
}
body .yatra-trip-search-shortcode .yatra-dropdown-label {
display: block !important;
margin: 0 !important;
padding: 0 !important;
font-size: 10px !important;
font-weight: 600 !important;
line-height: 1.2 !important;
letter-spacing: 0.06em !important;
text-transform: uppercase !important;
color: var(--yatra-ts-muted) !important;
}
body .yatra-trip-search-shortcode .yatra-dropdown-value {
display: block !important;
margin: 0 !important;
padding: 0 !important;
font-size: 15px !important;
font-weight: 600 !important;
line-height: 1.3 !important;
color: #111827 !important;
max-width: 100%;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
body .yatra-trip-search-shortcode .yatra-dropdown-arrow {
flex-shrink: 0 !important;
display: block !important;
width: 16px !important;
height: 16px !important;
min-width: 16px !important;
min-height: 16px !important;
margin: 0 0 0 auto !important;
padding: 0 !important;
color: #9ca3af !important;
fill: none !important;
stroke: currentColor !important;
transition: transform 0.15s ease;
}
body .yatra-trip-search-shortcode .yatra-search-dropdown.open .yatra-dropdown-arrow {
transform: rotate(180deg);
} body .yatra-trip-search-shortcode .yatra-dropdown-search-wrap {
flex-shrink: 0 !important;
margin: 0 !important;
padding: 0 !important;
}
body .yatra-trip-search-shortcode .yatra-dropdown-filter-input {
width: 100% !important;
margin: 0 !important;
padding: 8px 10px !important;
font-size: 13px !important;
font-weight: 500 !important;
line-height: 1.35 !important;
color: #111827 !important;
border: 1px solid #e2e8f0 !important;
border-radius: 6px !important;
background: #f8fafc !important;
box-shadow: none !important;
-webkit-appearance: none !important;
appearance: none !important;
}
body .yatra-trip-search-shortcode .yatra-dropdown-filter-input::placeholder {
color: #9ca3af !important;
opacity: 1 !important;
}
body .yatra-trip-search-shortcode .yatra-dropdown-filter-input:focus {
outline: none !important;
border-color: #3b82f6 !important;
background: #ffffff !important;
box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.12) !important;
}
body .yatra-trip-search-shortcode .yatra-dropdown-options {
flex: 1 1 auto !important;
min-height: 0 !important;
max-height: 280px !important;
overflow-y: auto !important;
overflow-x: hidden !important;
margin: 0 !important;
padding: 2px 0 !important;
list-style: none !important;
}
body .yatra-trip-search-shortcode .yatra-dropdown-option--hidden {
display: none !important;
}
body .yatra-trip-search-shortcode .yatra-dropdown-menu {
position: absolute !important;
top: calc(100% + 4px) !important;
left: 0 !important;
right: auto !important;
min-width: 260px !important;
margin: 0 !important;
padding: 6px !important;
background: #ffffff !important;
border: 1px solid #e2e8f0 !important;
border-radius: 10px !important;
box-shadow:
0 10px 40px rgba(15, 23, 42, 0.1),
0 4px 12px rgba(15, 23, 42, 0.06) !important;
z-index: var(--yatra-ts-z-dropdown) !important;
opacity: 0;
visibility: hidden;
transform: translateY(-8px) scale(0.95);
transition: opacity 0.2s ease, visibility 0.2s ease, transform 0.2s cubic-bezier(0.4, 0, 0.2, 1);
display: none !important;
}
body .yatra-trip-search-shortcode .yatra-search-dropdown.open .yatra-dropdown-menu,
body .yatra-trip-search-shortcode .yatra-dropdown-menu.show {
display: block !important;
opacity: 1 !important;
visibility: visible !important;
transform: translateY(0) scale(1) !important;
}
body .yatra-trip-search-shortcode .yatra-search-dropdown.open .yatra-dropdown-menu.yatra-dropdown-menu--filterable,
body .yatra-trip-search-shortcode .yatra-dropdown-menu.yatra-dropdown-menu--filterable.show {
display: flex !important;
flex-direction: column !important;
gap: 6px !important;
padding: 8px !important;
max-height: min(380px, 70vh) !important;
}
body .yatra-trip-search-shortcode .yatra-dropdown-option {
margin: 0 !important;
padding: 8px 10px !important;
font-size: 13px !important;
font-weight: 500 !important;
line-height: 1.35 !important;
color: #374151 !important;
border-radius: 6px !important;
cursor: pointer !important;
display: flex !important;
align-items: center !important;
position: relative !important;
background: transparent !important;
border: none !important;
text-align: left !important;
width: 100% !important;
box-shadow: none !important;
}
body .yatra-trip-search-shortcode .yatra-dropdown-option:hover {
background: #f1f5f9 !important;
color: #0f172a !important;
}
body .yatra-trip-search-shortcode .yatra-dropdown-option.selected {
background: #eff6ff !important;
color: #1d4ed8 !important;
font-weight: 600 !important;
padding-right: 26px !important;
}
body .yatra-trip-search-shortcode .yatra-dropdown-option.selected::before {
content: '' !important;
position: absolute !important;
right: 8px !important;
top: 50% !important;
transform: translateY(-50%) !important;
width: 16px !important;
height: 16px !important;
background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%233b82f6' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E");
background-repeat: no-repeat !important;
background-position: center !important;
background-size: 16px 16px !important;
} body .yatra-trip-search-shortcode .yatra-duration-menu {
min-width: 260px !important;
padding: 8px !important;
}
body .yatra-trip-search-shortcode .yatra-duration-slider-wrapper {
display: flex !important;
flex-direction: column !important;
gap: 10px !important;
}
body .yatra-trip-search-shortcode .yatra-duration-header {
text-align: center !important;
margin: 0 !important;
}
body .yatra-trip-search-shortcode .yatra-duration-title {
font-size: 13px !important;
font-weight: 600 !important;
color: #1f2937 !important;
margin: 0 0 2px !important;
}
body .yatra-trip-search-shortcode .yatra-duration-subtitle {
font-size: 11px !important;
font-weight: 500 !important;
color: #6b7280 !important;
line-height: 1.3 !important;
margin: 0 !important;
}
body .yatra-trip-search-shortcode .yatra-duration-badges {
display: flex !important;
justify-content: space-between !important;
align-items: center !important;
padding: 8px 10px !important;
background: #f8fafc !important;
border: 1px solid #e2e8f0 !important;
border-radius: 6px !important;
}
body .yatra-trip-search-shortcode .yatra-duration-badge {
font-size: 11px !important;
font-weight: 600 !important;
color: #1f2937 !important;
padding: 4px 8px !important;
background: #ffffff !important;
border: 1px solid #3b82f6 !important;
border-radius: 4px !important;
} body .yatra-trip-search-shortcode .yatra-dual-range-slider {
position: relative !important;
height: 36px !important;
box-sizing: border-box !important;
width: calc(100% - 20px) !important;
max-width: calc(100% - 20px) !important;
margin: 6px auto 10px !important;
padding: 0 !important;
}
body .yatra-trip-search-shortcode .yatra-slider-track {
position: absolute !important;
width: calc(100% - 16px) !important;
height: 6px !important;
left: 8px !important;
top: 50% !important;
transform: translateY(-50%) !important;
background: #e5e7eb !important;
border-radius: 3px !important;
box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1) !important;
box-sizing: border-box !important;
}
body .yatra-trip-search-shortcode .yatra-slider-range {
position: absolute !important;
height: 6px !important;
top: 50% !important;
transform: translateY(-50%) !important;
background: linear-gradient(90deg, #3b82f6 0%, #2563eb 100%) !important;
border-radius: 3px !important;
box-shadow: 0 2px 6px rgba(59, 130, 246, 0.3) !important;
}
body .yatra-trip-search-shortcode .yatra-dual-range-slider input[type='range'] {
position: absolute !important;
width: 100% !important;
height: 6px !important;
top: 37% !important;
margin: 0 !important;
padding: 0 !important;
background: transparent !important;
-webkit-appearance: none !important;
appearance: none !important;
pointer-events: none;
}
body .yatra-trip-search-shortcode .yatra-dual-range-slider input[type='range']::-webkit-slider-thumb {
-webkit-appearance: none !important;
appearance: none !important;
width: 20px !important;
height: 20px !important;
border-radius: 50% !important;
background: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%) !important;
border: 3px solid #3b82f6 !important;
cursor: pointer !important;
pointer-events: all !important;
z-index: 3 !important;
box-shadow: 0 3px 8px rgba(59, 130, 246, 0.3), 0 1px 3px rgba(0, 0, 0, 0.1) !important;
}
body .yatra-trip-search-shortcode .yatra-dual-range-slider input[type='range']::-moz-range-thumb {
width: 20px !important;
height: 20px !important;
border-radius: 50% !important;
background: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%) !important;
border: 3px solid #3b82f6 !important;
cursor: pointer !important;
pointer-events: all !important;
z-index: 3 !important;
box-shadow: 0 3px 8px rgba(59, 130, 246, 0.3), 0 1px 3px rgba(0, 0, 0, 0.1) !important;
} body .yatra-trip-search-shortcode .yatra-search-button-container {
display: flex !important;
flex-shrink: 0 !important;
align-items: stretch !important;
margin: 0 0 0 4px !important;
padding: 4px 4px 4px 10px !important;
border: none !important;
border-left: 1px solid rgba(148, 163, 184, 0.35) !important;
background: transparent !important;
}
body .yatra-trip-search-shortcode .yatra-search-main-btn {
-webkit-appearance: none !important;
appearance: none !important;
display: inline-flex !important;
align-items: center !important;
justify-content: center !important;
min-width: 120px !important;
min-height: var(--yatra-ts-row) !important;
margin: 0 !important;
padding: 0 22px !important;
border: none !important;
border-radius: 10px !important;
background: var(--yatra-ts-accent) !important;
background-color: var(--yatra-ts-accent) !important;
color: #ffffff !important;
font-size: 15px !important;
font-weight: 600 !important;
letter-spacing: 0.01em !important;
text-transform: none !important;
text-decoration: none !important;
cursor: pointer !important;
box-shadow:
0 1px 2px rgba(15, 23, 42, 0.06),
0 4px 14px rgba(37, 99, 235, 0.28) !important;
transition: background 0.18s ease, box-shadow 0.18s ease, transform 0.15s ease !important;
}
body .yatra-trip-search-shortcode .yatra-search-main-btn:hover {
background: var(--yatra-ts-accent-hover) !important;
background-color: var(--yatra-ts-accent-hover) !important;
color: #ffffff !important;
box-shadow:
0 2px 6px rgba(15, 23, 42, 0.08),
0 8px 22px rgba(37, 99, 235, 0.35) !important;
}
body .yatra-trip-search-shortcode .yatra-search-main-btn:active {
transform: scale(0.99);
}
body .yatra-trip-search-shortcode .yatra-search-main-btn:focus {
outline: none !important;
box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.35) !important;
} @media (max-width: 1024px) {
body .yatra-trip-search-shortcode .yatra-search-bar {
flex-wrap: wrap !important;
gap: 8px !important;
}
body .yatra-trip-search-shortcode .yatra-search-dropdown {
min-width: calc(50% - 20px) !important;
flex: 1 1 calc(50% - 20px) !important;
}
body .yatra-trip-search-shortcode .yatra-search-divider {
display: none !important;
}
}
@media (max-width: 768px) {
body .yatra-trip-search-shortcode .yatra-search-bar {
flex-direction: column !important;
align-items: stretch !important;
gap: 4px !important;
padding: 12px !important;
}
body .yatra-trip-search-shortcode .yatra-search-keyword-segment {
max-width: none !important;
width: 100% !important;
min-width: 0 !important;
}
body .yatra-trip-search-shortcode .yatra-search-dropdown {
width: 100% !important;
min-width: 100% !important;
flex: 1 1 auto !important;
}
body .yatra-trip-search-shortcode .yatra-search-divider {
display: block !important;
width: 100% !important;
height: 1px !important;
margin: 6px 0 !important;
}
body .yatra-trip-search-shortcode .yatra-search-button-container {
width: 100% !important;
margin-left: 0 !important;
padding: 10px 0 4px !important;
border-left: none !important;
border-top: 1px solid rgba(148, 163, 184, 0.35) !important;
}
body .yatra-trip-search-shortcode .yatra-search-main-btn {
width: 100% !important;
min-height: 48px !important;
margin-top: 0 !important;
}
body .yatra-trip-search-shortcode .yatra-dropdown-menu {
left: 0 !important;
right: 0 !important;
min-width: 100% !important;
}
body .yatra-trip-search-shortcode .yatra-duration-menu {
min-width: 100% !important;
}
}.cmplz-video.cmplz-iframe-styles{background-color:transparent}.cmplz-video.cmplz-hidden{visibility:hidden !important}.cmplz-blocked-content-notice{display:none}.cmplz-placeholder-parent{height:inherit}.cmplz-optin .cmplz-blocked-content-container .cmplz-blocked-content-notice,.cmplz-optin .cmplz-wp-video .cmplz-blocked-content-notice,.cmplz-optout .cmplz-blocked-content-container .cmplz-blocked-content-notice,.cmplz-optout .cmplz-wp-video .cmplz-blocked-content-notice{display:block}.cmplz-blocked-content-container,.cmplz-wp-video{animation-name:cmplz-fadein;animation-duration:600ms;background:#FFF;border:0;border-radius:3px;box-shadow:0 0 1px 0 rgba(0,0,0,0.5),0 1px 10px 0 rgba(0,0,0,0.15);display:flex;justify-content:center;align-items:center;background-repeat:no-repeat !important;background-size:cover !important;height:inherit;position:relative}.cmplz-blocked-content-container.gmw-map-cover,.cmplz-wp-video.gmw-map-cover{max-height:100%;position:absolute}.cmplz-blocked-content-container.cmplz-video-placeholder,.cmplz-wp-video.cmplz-video-placeholder{padding-bottom:initial}.cmplz-blocked-content-container iframe,.cmplz-wp-video iframe{visibility:hidden;max-height:100%;border:0 !important}.cmplz-blocked-content-container .cmplz-custom-accept-btn,.cmplz-wp-video .cmplz-custom-accept-btn{white-space:normal;text-transform:initial;cursor:pointer;position:absolute !important;width:100%;top:50%;left:50%;transform:translate(-50%,-50%);max-width:200px;font-size:14px;padding:10px;background-color:rgba(0,0,0,0.5);color:#fff;text-align:center;z-index:98;line-height:23px}.cmplz-blocked-content-container .cmplz-custom-accept-btn:focus,.cmplz-wp-video .cmplz-custom-accept-btn:focus{border:1px dotted #cecece}.cmplz-blocked-content-container .cmplz-blocked-content-notice,.cmplz-wp-video .cmplz-blocked-content-notice{white-space:normal;text-transform:initial;position:absolute !important;width:100%;top:50%;left:50%;transform:translate(-50%,-50%);max-width:300px;font-size:14px;padding:10px;background-color:rgba(0,0,0,0.5);color:#fff;text-align:center;z-index:98;line-height:23px}.cmplz-blocked-content-container .cmplz-blocked-content-notice .cmplz-links,.cmplz-wp-video .cmplz-blocked-content-notice .cmplz-links{display:block;margin-bottom:10px}.cmplz-blocked-content-container .cmplz-blocked-content-notice .cmplz-links a,.cmplz-wp-video .cmplz-blocked-content-notice .cmplz-links a{color:#fff}.cmplz-blocked-content-container .cmplz-blocked-content-notice .cmplz-blocked-content-notice-body,.cmplz-wp-video .cmplz-blocked-content-notice .cmplz-blocked-content-notice-body{display:block}.cmplz-blocked-content-container div div{display:none}.cmplz-wp-video .cmplz-placeholder-element{width:100%;height:inherit}@keyframes cmplz-fadein{from{opacity:0}to{opacity:1}}body#colibri .style-101 {
padding-left: 0;
padding-right: 0;
} body#colibri .wp-block-latest-comments .wp-block-latest-comments__comment-meta {
font-weight: unset;
} body#colibri .widget-shortcode .widget_search .wp-block-search .wp-block-search__inside-wrapper .wp-block-search__input {
background-color: #F5F6F7;
border-radius: 0;
}
body#colibri .style-168 .widget.widget_search input[type="submit"],
body#colibri .style-168 .widget.widget_search button[type="submit"] {
background-color: #f7f7f7;
border-radius: 0;
}
body#colibri .h-widget-area .widget-shortcode .widget_search {
border-radius: 0;
} body#colibri .style-101 .comment-content p {
color: #525252;
font-size: 14px;
} html.silverstorm-theme .style-101 {
padding-left: 0;
padding-right: 0;
} html.silverstorm-theme .wp-block-latest-comments .wp-block-latest-comments__comment-meta {
font-weight: unset;
} html.silverstorm-theme .widget-shortcode .widget_search .wp-block-search .wp-block-search__inside-wrapper .wp-block-search__input {
background-color: #F5F6F7;
border-radius: 0;
}
html.silverstorm-theme .style-168 .widget.widget_search input[type="submit"],
html.silverstorm-theme .style-168 .widget.widget_search button[type="submit"] {
background-color: #f7f7f7;
border-radius: 0;
}
html.silverstorm-theme .h-widget-area .widget-shortcode .widget_search {
border-radius: 0;
} html.silverstorm-theme .style-101 .comment-content p {
color: #525252;
font-size: 14px;
}