/* COSYNEST MOBILE PASS 3 - MOBILE ONLY */
@media (max-width: 768px) {
  html, body { font-size: 15px; }
  body { padding-bottom: 74px !important; }

  /* Header / nav */
  .site-nav { margin-bottom: -68px !important; }
  .nav-shell, .nav-inner {
    padding-top: 0.38rem !important;
    padding-bottom: 0.38rem !important;
  }
  .nav-logo-wrap img,
  .w-10.h-10.rounded-xl {
    width: 36px !important;
    height: 36px !important;
  }
  .nav-brand-text {
    font-size: 0.82rem !important;
    line-height: 1.05 !important;
  }
  .lang-btn {
    padding: 0.3rem 0.48rem !important;
    font-size: 0.76rem !important;
    min-width: 2rem !important;
  }
  .flex.items-center.gap-1\.5.text-white.font-medium.rounded-full {
    padding: 0.24rem !important;
    gap: 0.28rem !important;
  }

  /* Hero */
  header {
    padding-top: 0.6rem !important;
    padding-bottom: 0.6rem !important;
  }
  header .w-full.bg-brand-blue.shadow-lg.relative.overflow-hidden picture,
  header .w-full.bg-brand-blue.shadow-lg.relative.overflow-hidden img {
    display: block !important;
  }
  header .w-full.bg-brand-blue.shadow-lg.relative.overflow-hidden img {
    width: 100% !important;
    height: 50vh !important;
    max-height: 430px !important;
    object-fit: cover !important;
    object-position: center center !important;
  }
  header .max-w-4xl.mx-auto.px-4.text-center.mt-12 {
    margin-top: 0.95rem !important;
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }
  header h1,
  .hero-title,
  .text-5xl,
  .md\:text-6xl,
  .md\:text-5xl {
    font-size: 1.6rem !important;
    line-height: 1.08 !important;
    letter-spacing: -0.03em !important;
    margin-bottom: 0.45rem !important;
  }
  header p,
  .hero-subtitle,
  .text-lg,
  .md\:text-xl {
    font-size: 0.88rem !important;
    line-height: 1.36 !important;
  }
  header .mb-10 {
    margin-bottom: 0.8rem !important;
  }
  header .flex.flex-col.sm\:flex-row {
    gap: 0.5rem !important;
  }
  header .hero-cta-main,
  header .hero-cta-call,
  header .hero-cta-secondary,
  .hero-cta-main,
  .hero-cta-call,
  .hero-cta-secondary {
    min-height: 40px !important;
    padding: 0.68rem 0.75rem !important;
    font-size: 0.86rem !important;
    border-radius: 12px !important;
  }

  /* Intro / trust section */
  #static-management-note,
  .why-book-section,
  .rounded-\[32px\],
  .rounded-\[28px\] {
    border-radius: 20px !important;
  }
  #static-management-note .p-8,
  #static-management-note .p-10,
  #static-management-note .p-12 {
    padding: 1rem !important;
  }
  #static-management-note h2,
  #static-management-note .text-4xl,
  #static-management-note .text-5xl {
    font-size: 1rem !important;
    line-height: 1.22 !important;
  }
  #static-management-note p,
  #static-management-note .text-lg,
  #static-management-note .text-base {
    font-size: 0.86rem !important;
    line-height: 1.4 !important;
  }
  #static-management-note .grid {
    gap: 8px !important;
    margin-top: 10px !important;
  }
  #static-management-note .grid > div {
    flex: 0 0 78% !important;
    padding: 0.82rem !important;
    border-radius: 16px !important;
  }
  #static-management-note .grid > div h3,
  #static-management-note .grid > div .text-xl {
    font-size: 0.92rem !important;
    line-height: 1.2 !important;
  }
  #static-management-note .grid > div p {
    font-size: 0.8rem !important;
    line-height: 1.38 !important;
  }

  /* Title blocks + spacing */
  #properties-section,
  .properties-section {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
  }
  #properties-section .mb-16,
  #properties-section .mb-20,
  #properties-section .mb-12 {
    margin-bottom: 0.7rem !important;
  }
  .section-title,
  #properties-section h2,
  h2.text-5xl,
  h2.text-4xl,
  .text-4xl.font-bold,
  .text-5xl.font-bold {
    font-size: 1.72rem !important;
    line-height: 1.05 !important;
    margin-bottom: 0.25rem !important;
  }

  /* Filters */
  #guest-filter-wrap {
    gap: 6px !important;
    padding-bottom: 0 !important;
  }
  #guest-filter-wrap > span {
    font-size: 0.78rem !important;
    line-height: 1.15 !important;
  }
  #guest-filter-wrap button,
  #guest-filter-wrap .rounded-full,
  #guest-filter-wrap > div > * {
    min-height: 36px !important;
    min-width: 36px !important;
    padding: 0.48rem 0.78rem !important;
    font-size: 0.82rem !important;
  }

  /* Property cards */
  #properties-section .grid,
  .property-grid,
  .grid.md\:grid-cols-2,
  .grid.lg\:grid-cols-3 {
    gap: 12px !important;
  }
  #properties-section .bg-white.rounded-\[24px\],
  #properties-section .bg-white.rounded-2xl,
  .property-card,
  .group.bg-white {
    border-radius: 18px !important;
  }
  #properties-section .h-64,
  .property-card img,
  .group.bg-white img {
    height: 182px !important;
  }
  #properties-section .p-6,
  .property-card .p-6,
  .group.bg-white .p-6 {
    padding: 13px !important;
  }
  #properties-section h3,
  #properties-section .text-2xl,
  .property-card h3,
  .property-card .text-xl {
    font-size: 0.96rem !important;
    line-height: 1.24 !important;
    margin-bottom: 0.16rem !important;
  }
  #properties-section .text-xl.font-bold.text-brand-blue,
  .property-card .price,
  .property-card .font-bold.text-brand-blue {
    font-size: 0.96rem !important;
  }
  #properties-section .text-sm,
  #properties-section .text-base,
  .property-card p,
  .property-card span {
    font-size: 0.81rem !important;
    line-height: 1.36 !important;
  }
  .property-card p:last-of-type,
  #properties-section .text-gray-600:last-of-type {
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
  }
  .property-details-btn,
  .inline-flex.rounded-full,
  .inline-flex.rounded-\[18px\] {
    min-height: 38px !important;
    font-size: 0.84rem !important;
    padding: 0.64rem 0.8rem !important;
  }

  /* Apartment pages */
  .pt-24.pb-20.px-4.max-w-6xl.mx-auto {
    padding-top: 4.6rem !important;
    padding-bottom: 0.85rem !important;
  }
  h1.text-3xl.md\:text-5xl {
    font-size: 1.48rem !important;
    line-height: 1.12 !important;
    margin-bottom: 0.38rem !important;
  }
  .share-like-bar {
    gap: 0.42rem !important;
    margin: 0.4rem 0 0.6rem !important;
  }
  .share-btn, .like-btn {
    padding: 0.52rem 0.76rem !important;
    font-size: 0.8rem !important;
  }
  .flex.items-center.gap-4.text-gray-600.mb-8.font-medium {
    gap: 0.32rem !important;
    margin-bottom: 0.65rem !important;
    font-size: 0.75rem !important;
  }
  .detail-image-grid {
    gap: 8px !important;
    margin-bottom: 0.85rem !important;
  }
  .detail-image-grid > img,
  .detail-image-grid > div {
    height: 210px !important;
    border-radius: 13px !important;
    flex: 0 0 84% !important;
  }
  .grid.md\:grid-cols-3.gap-12.max-w-7xl.mx-auto.px-4 {
    gap: 0.9rem !important;
  }
  .border-b.border-gray-200.pb-8.mb-8 {
    padding-bottom: 0.8rem !important;
    margin-bottom: 0.8rem !important;
  }
  h2.text-2xl.font-bold.text-brand-blue,
  h3.text-2xl.font-bold.text-brand-blue {
    font-size: 1.03rem !important;
  }
  .mb-10.text-gray-700.leading-relaxed.text-lg {
    margin-bottom: 0.8rem !important;
    font-size: 0.89rem !important;
    line-height: 1.5 !important;
  }
  .mb-10.text-gray-700.leading-relaxed.text-lg p {
    margin-bottom: 0.6rem !important;
  }

  /* Reviews */
  [data-guest-feedback] {
    padding-top: 0.8rem !important;
    margin-top: 0.8rem !important;
  }
  [data-guest-feedback] .grid.md\:grid-cols-2.gap-4 {
    gap: 9px !important;
  }
  [data-guest-feedback] .rounded-2xl {
    border-radius: 15px !important;
    padding: 11px !important;
  }
  [data-guest-feedback] .font-bold.text-brand-blue {
    font-size: 0.86rem !important;
  }
  [data-guest-feedback] .text-xs,
  [data-guest-feedback] .text-sm {
    font-size: 0.72rem !important;
  }
  [data-guest-feedback] p.text-gray-700.leading-relaxed {
    font-size: 0.81rem !important;
    line-height: 1.42 !important;
  }

  /* Booking card */
  .rounded-\[30px\].border.border-slate-200.bg-white.p-5.md\:p-6 {
    border-radius: 18px !important;
    padding: 11px !important;
  }
  .border.border-slate-200.rounded-\[24px\].mb-4.overflow-hidden.bg-white.shadow-sm {
    border-radius: 15px !important;
    margin-bottom: 0.68rem !important;
  }
  .text-3xl.font-bold.text-brand-blue[data-price-hook="booking-top-price"] {
    font-size: 1.22rem !important;
  }
  .booking-date-input {
    font-size: 0.86rem !important;
    padding: 0.48rem 0.05rem !important;
    min-height: 32px !important;
  }
  label.text-\[10px\].font-semibold.uppercase {
    font-size: 8px !important;
    letter-spacing: 0.1em !important;
  }
  #booking-summary-placeholder .text-sm,
  #booking-summary-placeholder .text-base,
  #booking-summary-placeholder .text-xs {
    font-size: 0.78rem !important;
  }
  #summary-message {
    line-height: 1.34 !important;
    margin-top: 0.38rem !important;
  }
  .booking-card-actions.mt-6 {
    margin-top: 0.68rem !important;
  }
  .booking-card-actions .rounded-\[24px\] {
    border-radius: 15px !important;
    padding: 9px !important;
  }
  .booking-card-actions .rounded-\[18px\] {
    border-radius: 12px !important;
  }
  input[id^="guest-name-"] {
    font-size: 0.86rem !important;
    min-height: 38px !important;
  }
  .booking-card-actions a.inline-flex {
    min-height: 40px !important;
    font-size: 0.84rem !important;
    padding-top: 0.68rem !important;
    padding-bottom: 0.68rem !important;
  }

  /* Sticky booking bar */
  .mobile-booking-bar {
    padding: 7px 12px !important;
    min-height: 58px !important;
  }
  .mobile-booking-bar .price-text {
    font-size: 0.9rem !important;
    line-height: 1.02 !important;
  }
  .mobile-booking-bar .price-sub {
    font-size: 0.65rem !important;
  }
  .mobile-booking-bar .book-btn {
    padding: 8px 15px !important;
    font-size: 0.8rem !important;
    border-radius: 11px !important;
  }
}
