/* Custon scrollbar */
/* .aurora ::-webkit-scrollbar {
    -webkit-appearance: none;
    width: 8px;
}
  
.aurora ::-webkit-scrollbar-thumb {
    border-radius: 4px;
    background-color: rgba(80, 73, 72, 0.9);
    box-shadow: 0 0 1px rgba(0, 0, 0, 0.5);
}

.device-android ::-webkit-scrollbar, .device-ios ::-webkit-scrollbar {
    -webkit-appearance: none;
    width: 5px;
}
.device-android ::-webkit-scrollbar-thumb, .device-ios ::-webkit-scrollbar-thumb {
    border-radius: 4px;
    background-color: #0b2941;
    box-shadow: 0 0 1px rgba(0, 0, 0, 0.5);
} */

/* ===== Scrollbar CSS ===== */
  /* Firefox */
  * {
    scrollbar-width: thin;
    scrollbar-color: #0b2941 #fff;
  }

  /* Chrome, Edge, and Safari */
  *::-webkit-scrollbar {
    -webkit-appearance: none;
    width: 5px;
  }

  *::-webkit-scrollbar-track {
    background: #fff;
  }

  *::-webkit-scrollbar-thumb {
    background-color: #0b2941;
    border-radius: 4px;
    border: 4px solid #ffffff;
    box-shadow: 0 0 1px rgba(0, 0, 0, 0.5);
  }

html {
    overscroll-behavior: none;
    -moz-user-select: none;
    -webkit-user-select: none;
    user-select: none;
}
body {
    overscroll-behavior-y: contain;
}
.md body.refreshing header, .ios body.refreshing header {
    filter: blur(1px);
    touch-action: none;
}

:root {
    --f7-theme-color: #0b2941;
    --f7-theme-color-rgb: 7, 37, 63;
    --f7-navbar-height: 80px;
    --f7-badge-size: 36px;
    --f7-badge-font-size: 16px;
    --f7-bars-bg-color: var(--f7-theme-color) !important;
    --f7-bars-bg-color-rgb: var(--f7-theme-color-rgb);
    --f7-bars-translucent-opacity: 0.9;
    --f7-bars-text-color: #fff;
    --f7-bars-link-color: #fff;
    --f7-navbar-subtitle-text-color: rgba(255,255,255,0.85);
    --f7-bars-border-color: transparent;
    --f7-tabbar-link-active-color: #fff;
    --f7-tabbar-link-inactive-color: rgba(255,255,255,0.54);
    --f7-sheet-border-color: transparent;
    --f7-tabbar-link-active-border-color: #fff;
    --f7-page-bg-color: #efeff4;
}

.navbar .subnavbar {
    top: 99% !important;
}

 
.ios-translucent-bars .navbar-bg {
    background-color: rgb(10 40 64);
}

  .md {
    --f7-block-title-text-color: rgba(0,0,0,0.9);
    --f7-label-text-color: rgba(0,0,0,0.9);
  }

  .appbar,
  .navbar,
  .toolbar,
  .subnavbar,
  .calendar-header,
  .calendar-footer {
    --f7-touch-ripple-color: var(--f7-touch-ripple-white);
    --f7-link-highlight-color: var(--f7-link-highlight-white);
    --f7-link-touch-ripple-color: var(--f7-touch-ripple-white);
    --f7-button-text-color: #fff;
    --f7-button-pressed-bg-color: rgba(255,255,255,0.1);
  }
  .navbar-large-transparent,
  .navbar-large.navbar-transparent {
    --f7-navbar-large-title-text-color: #000;
    --r: 216;
    --g: 179;
    --b: 177;
    --progress: var(--f7-navbar-large-collapse-progress);
    --f7-bars-link-color: rgb(
      calc(var(--r) + (255 - var(--r)) * var(--progress)),
      calc(var(--g) + (255 - var(--g)) * var(--progress)),
      calc(var(--b) + (255 - var(--b)) * var(--progress))
    );
  }
.dark .navbar-large-transparent,
.dark .navbar-large.navbar-transparent {
    --f7-navbar-large-title-text-color: #fff;
}

.full-size-available {
    width: -webkit-fill-available !important;
}

.full-size {
    width: 100%;
}
.text_align_just {
    text-align: justify !important;
}

.text_align_center {
    text-align: center !important;
}

.no-background {
    background-color: transparent !important;
}

.padding-10px {
    padding: 10px;
}

.padding-top-bottom-10px {
    padding: 10px 0px 10px 0px;
}

.padding-left-right-5px {
    padding: 0px 5px 0px 5px;
}

.padding-left-right-10px {
    padding: 0px 10px 0px 10px;
}
.margin-left-right-2px {
    margin: 0px 2px 0px 2px;
}
.margin-left-right-5px {
    margin: 0px 5px 0px 5px;
}
.margin-top-bottom-15px {
    margin: 015px 0 15px 0;
}
.no-margin-top-bottom {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}
.no-margin {
    margin: 0 !important;
}

.no-padding {
    padding: 0 !important;
}

.no-overflow {
    overflow: hidden !important;
}

.map { 
    height: 100%; 
}
.logo {
    height: 60px;
    width: 60px;
}

.badge-mini {
    height: 20px !important;
    font-size: 10px !important;
    min-width: 20px !important;
}

.timeline-item-date {
    width: 120px !important;
}
.color-lightslategray {
    color: lightslategray;
}

.timeline-trajeto-linha {
    text-align: center !important;
    font-size: 12pt !important;
    color: white !important;
    font-weight: 700 !important;
    width: 25px !important;
    height: 25px !important;
}

.resume_time {
    position: relative;
    text-align: right;
    font-size: .9em;
    font-weight: bold;
    padding: .5em 0.4em;
    line-height: 6px;
    white-space: nowrap;
    color: #333;
}

.journey_time {
    font-size: 18px;
    line-height: 22px;
}

.card-header-pic .card-header {
    height: 55vw;
    background-size: cover;
    background-position: center;
    color: #fff;
}

.card-header-pic .card-content-padding .date {
    color: #000;
}

.porto-img {
    background-image:url(/static/img/porto.jpg) !important;
    background-repeat: no-repeat !important;
}

.menu-item-media {
    padding-top: 25px !important;
}

.price {
    padding-right: 10px;
    font-weight: 800;
}

.price-table {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0 8px;
    margin-top: 10px;
}
.price-table th,
.price-table td {
    padding: 10px 12px;
    text-align: center;
    border-radius: 8px;
}
.price-table thead th {
    background: #e1ecf9;
    font-weight: 600;
    color: #2162a9;
    border-bottom: none;
}
.price-table tbody tr {
    background: #f9fbff;
    box-shadow: 0 2px 6px rgb(0 0 0 / 0.05);
    transition: background-color 0.2s;
}
.price-table tbody tr:hover {
    background: #e0f0ff;
}
.discount-list {
    margin-top: 14px;
    padding-left: 20px;
    color: #444;
    font-weight: 600;
}
.discount-list li {
    margin-bottom: 6px;
    font-size: 0.95rem;
    position: relative;
    padding-left: 22px;
}
.discount-list li::before {
    content: "\f058"; /* FontAwesome check icon */
    font-family: "Font Awesome 6 Free";
    font-weight: 900;
    position: absolute;
    left: 0;
    color: #28a745;
    font-size: 0.9rem;
    top: 2px;
}
.toast .toast-text {
    text-align: justify;
}

.block-title {
  min-height: 20px;
  margin-top: 1rem !important;
  margin-bottom: 1rem !important;
  overflow: hidden !important;
}

ul {
  list-style-position: inside !important;
  margin-top: 0 !important;
  padding-inline-start: 1rem;
  transition: opacity 0.2s ease-in-out;
}

.stamp {
    font-size: 2rem;
    font-weight: 700;
    display: inline-block;
    padding: 0.25rem 1rem;
    text-transform: uppercase;
    font-family: 'Roboto';
    -webkit-mask-image: url('/static/img/grunge.webp');
    -webkit-mask-size: 236px 151px;
    mix-blend-mode: multiply;
    position: absolute !important;
    margin: 0 auto !important;
}

.is-approved {
    color: #0A9928;
    border: 0.5rem solid #0A9928;
    -webkit-mask-position: 13rem 6rem;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(-5deg);
    border-radius: 0;
} 

.strikethrough-price {
  color: #888;
  text-decoration: line-through;
  text-decoration-color: red;
  margin-right: 0.5em;
  transition: color 0.3s ease;
}