/* FILE: assets/css/mobile.css */

/* =========================
   TABLET
========================= */

@media (max-width: 1200px) {
  .layout {
    grid-template-columns: 260px 1fr 260px;
    gap: 14px;
    padding: 14px;
  }

  .alerts {
    grid-template-columns: 1fr;
    grid-auto-rows: auto;
  }

  .header-left h1 {
    font-size: 30px;
  }

  #clockTime {
    font-size: 24px;
  }

  .clock {
    min-width: 160px;
  }
}

/* =========================
   SMALL TABLET / LARGE PHONE
========================= */

@media (max-width: 980px) {
  .layout {
    display: flex;
    flex-direction: column;
  }

  .main-board {
    order: 1;
    padding: 14px;
  }

  .left-panel {
    order: 2;
  }

  .right-panel {
    order: 3;
  }

  .side-panel {
    display: flex;
    flex-direction: column;
    gap: 14px;
  }

  .section-title {
    justify-content: center;
  }

  .review-ticker-wrap {
    width: 100%;
    max-width: none;
    order: 3;
  }
}

/* =========================
   MOBILE ORDER FIX
========================= */

@media (max-width: 700px) {
  .layout {
    display: flex !important;
    flex-direction: column !important;
  }

  .layout > [data-include] {
    display: contents !important;
  }

  .left-panel,
  .right-panel {
    display: contents !important;
  }

  .main-board {
    order: 1 !important;
  }

  .mobile-order-chat,
  .chat-open-box {
    order: 2 !important;
  }

  .mobile-order-incident-map,
  .incident-map-open-box {
    order: 3 !important;
  }

  .mobile-order-lifeboat,
  .lifeboat-launch-box {
    order: 4 !important;
  }

  .mobile-order-weather,
  .weather-box {
    order: 5 !important;
  }

  .mobile-order-reviews,
  .reviews-box {
    order: 6 !important;
  }

  .mobile-order-support,
  .support-box {
    order: 7 !important;
  }

  .mobile-order-community-links,
  .community-links-box {
    order: 8 !important;
  }

  .mobile-order-useful-links,
  .useful-links {
    order: 9 !important;
  }

  .rnli-latest-box {
    order: 98 !important;
  }

  .mobile-order-advert,
  .advert-box {
    order: 99 !important;
  }
}

/* =========================
   MOBILE
========================= */

@media (max-width: 700px) {
  body {
    font-size: 14px;
  }

  .topbar {
    position: relative !important;
    display: block !important;
    height: 205px !important;
    min-height: 205px !important;
    padding: 0 !important;
    overflow: hidden !important;
    background-size: cover !important;
    background-position: center top !important;
  }

  .header-left h1,
  .header-left p {
    display: none !important;
  }

  .header-logo {
    position: absolute !important;
    top: 58px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    z-index: 3 !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .header-logo img {
    width: 105px !important;
    height: 105px !important;
    object-fit: contain !important;
  }

  .brand-rating-row {
    position: absolute !important;
    left: 8px !important;
    bottom: 8px !important;
    width: 46% !important;
    z-index: 4 !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    justify-content: flex-start !important;
    align-items: center !important;
  }

  .brand-rating-row .stars,
  .stars {
    font-size: 24px !important;
    line-height: 1 !important;
    white-space: nowrap !important;
  }

  .header-right {
    position: absolute !important;
    right: 8px !important;
    bottom: 8px !important;
    width: 46% !important;
    z-index: 4 !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    justify-content: flex-end !important;
    align-items: center !important;
  }

  .clock {
    width: 100% !important;
    max-width: 150px !important;
    min-width: 0 !important;
    padding: 4px 6px !important;
    text-align: center !important;
  }

  #clockTime {
    font-size: 23px !important;
    line-height: 1 !important;
  }

  .clock small,
  #clockDate {
    font-size: 9px !important;
    line-height: 1.05 !important;
  }

  .layout {
    width: 100% !important;
    max-width: 100% !important;
    padding: 10px !important;
    gap: 12px !important;
    box-sizing: border-box !important;
    align-items: stretch !important;
  }

  .page-scale {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  .main-board,
  .notice,
  .weather-box,
  .incident-map-open-box,
  .reviews-box,
  .chat-open-box,
  .lifeboat-launch-box,
  .rnli-latest-box,
  .community-links-box,
  .useful-links,
  .support-box,
  .advert-box {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  .side-panel {
    grid-template-columns: 1fr;
  }

  .section-title h2 {
    font-size: 20px;
    letter-spacing: 2px;
  }

  .board-login-btn {
    min-width: 105px;
    font-size: 12px;
  }

/* =========================
   ALERT PREVIEW IMAGE
========================= */

.alert-body {
  display: flex !important;
  flex-direction: column !important;
}

.alert-main {
  width: 100% !important;
  height: auto !important;
  display: block !important;
}

.alert-preview {
  width: 100% !important;
  height: 90px !important;
  margin-top: 4px !important;
}

.alert-image {
  width: 100% !important;
  height: 100% !important;
}

  /* =========================
     MOBILE ALERT CARD FIX
  ========================= */

  .alerts {
    display: flex !important;
    flex-direction: column !important;
    gap: 7px !important;
    grid-auto-rows: unset !important;
    align-items: stretch !important;
    overflow: visible !important;
  }

  .alert-card {
    grid-template-columns: 72px 1fr !important;
    height: auto !important;
    min-height: 132px !important;
    grid-row: auto !important;
    overflow: hidden !important;
    border-left-width: 5px !important;
    border-radius: 9px !important;
  }


  .alert-left {
    padding: 4px 3px !important;
    gap: 4px !important;
  }

  .alert-body {
    height: auto !important;
    padding: 6px 7px !important;
  }

  .alert-head {
    flex-direction: row !important;
    align-items: flex-start !important;
    gap: 5px !important;
  }

  .alert-head h3 {
    font-size: 12px !important;
    line-height: 1.15 !important;
  }

  .priority {
    padding: 2px 5px !important;
    font-size: 8px !important;
    line-height: 1.1 !important;
    letter-spacing: .25px !important;
  }

  .location,
  .ngr,
  .details {
    margin-top: 3px !important;
    font-size: 10px !important;
    line-height: 1.2 !important;
  }

  .meta {
    margin-top: 4px !important;
    padding-top: 4px !important;
    gap: 5px !important;
    font-size: 8px !important;
    line-height: 1.15 !important;
  }

  .cat-icon {
    font-size: 18px !important;
    line-height: 1 !important;
  }

  .service-logo {
    width: 24px !important;
    height: 24px !important;
  }

  .cat-name {
    font-size: 8px !important;
    line-height: 1.1 !important;
    letter-spacing: .2px !important;
  }

  .alert-image {
    margin-top: 5px !important;
    max-height: 120px !important;
    border-radius: 7px !important;
  }

  /* =========================
     MOBILE REVIEWS FIX
  ========================= */

  .reviews-box {
    overflow: hidden !important;
  }

  #reviewsList {
    max-height: 300px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
  }

  .review-card,
  .review-item {
    width: 100% !important;
    padding: 4px 4px !important;
    box-sizing: border-box !important;
    text-align: left !important;
    position: relative !important;
  }

  .review-card p.review-text,
  .review-item p.review-text,
  .review-text {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
    text-align: left !important;
  }

  .review-text.is-collapsed {
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
  }

  .review-text.is-expanded {
    display: block !important;
    overflow: visible !important;
    white-space: normal !important;
  }

  .review-expand-btn {
    width: auto !important;
    margin: 4px 0 0 0 !important;
    padding: 2px 7px !important;
    font-size: 10px !important;
    line-height: 1.2 !important;
  }

  .review-stars {
    color: #ffcc00 !important;
  }

  /* =========================
     MOBILE POPUPS
  ========================= */

  .chat-popup,
  .incident-map-popup,
  .member-account-popup {
    padding: 10px !important;
  }

  .chat-popup-panel,
  .incident-map-panel,
  .member-account-panel {
    width: 100% !important;
    height: calc(100vh - 20px) !important;
    max-height: none !important;
    border-radius: 14px !important;
  }

  .member-account-panel {
    overflow-y: auto !important;
  }

  .member-account-header {
    min-height: 28px !important;
    padding: 5px 44px 9px !important;
    margin-bottom: 14px !important;
  }

  .member-account-header strong {
    font-size: 12px !important;
    line-height: 1.2 !important;
    letter-spacing: .25px !important;
  }

  .member-account-content {
    padding: 14px !important;
  }

  .member-profile-row {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
    justify-items: center !important;
  }

  .member-profile-image-wrap {
    width: min(100%, 290px) !important;
  }

  .member-profile-image-preview {
    width: 138px !important;
    height: 138px !important;
    margin-bottom: 10px !important;
  }

  .member-avatar-large {
    width: 118px !important;
    height: 118px !important;
  }

  .member-avatar-grid {
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 7px !important;
  }

  .member-avatar-option {
    border-radius: 10px !important;
    padding: 3px !important;
  }

  .member-details-wrap {
    width: 100% !important;
  }

  .member-detail-line,
  .member-role-line {
    grid-template-columns: 1fr !important;
    gap: 6px !important;
    padding: 8px 0 !important;
  }

  .member-detail-line label {
    font-size: 12px !important;
  }

  .member-detail-line input {
    font-size: 13px !important;
    padding: 9px 10px !important;
  }

  .member-change-btn {
    width: 100% !important;
  }

  .member-role-display {
    width: 100% !important;
    box-sizing: border-box !important;
    justify-content: center !important;
    text-align: center !important;
  }

  .member-account-warning {
    margin-top: 14px !important;
    font-size: 11px !important;
  }

  .chat-messages {
    max-height: 45vh;
  }

  .chat-message {
    grid-template-columns: 52px 1fr !important;
    gap: 9px !important;
    padding: 9px !important;
  }

  .chat-avatar-wrap {
    width: 52px !important;
    height: 52px !important;
    border-radius: 11px !important;
  }

  .chat-message strong,
  .chat-nickname {
    font-size: 12px !important;
  }

  .chat-message p {
    font-size: 13px !important;
  }

  .weather-main {
    grid-template-columns: 70px 1fr;
  }

  .weather-main-icon {
    width: 58px;
    height: 58px;
  }

  .weather-temp {
    font-size: 28px;
  }

  .advert-head {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .advert-logo {
    margin: 0 auto;
  }

  .grid,
  .grid-3 {
    grid-template-columns: 1fr;
  }

  .admin-wrap {
    padding: 14px;
  }

  /* =========================
     ADMIN MOBILE ORDER FIX
  ========================= */

  .admin-wrap .grid {
    display: flex !important;
    flex-direction: column !important;
    gap: 18px !important;
  }

  .admin-wrap .admin-column {
    display: contents !important;
  }

  .admin-order-create-alert {
    order: 1 !important;
  }

  .admin-order-active-alerts {
    order: 2 !important;
  }

  .admin-order-chat-moderation {
    order: 3 !important;
  }

  .admin-order-reviews-moderation {
    order: 4 !important;
  }

  .admin-order-owner-users {
    order: 5 !important;
  }

  .admin-order-owner-categories {
    order: 6 !important;
  }
}

/* =========================
   VERY SMALL PHONES
========================= */

@media (max-width: 430px) {
  .topbar {
    height: 195px !important;
    min-height: 195px !important;
  }

  .header-logo {
    top: 54px !important;
  }

  .header-logo img {
    width: 95px !important;
    height: 95px !important;
  }

  .brand-rating-row {
    left: 6px !important;
    bottom: 7px !important;
    width: 47% !important;
  }

  .brand-rating-row .stars,
  .stars {
    font-size: 21px !important;
  }

  .header-right {
    right: 6px !important;
    bottom: 7px !important;
    width: 47% !important;
  }

  .clock {
    max-width: 140px !important;
    padding: 4px 5px !important;
  }

  #clockTime {
    font-size: 21px !important;
  }

  .clock small,
  #clockDate {
    font-size: 8px !important;
  }

  .section-title {
    gap: 8px;
  }

  .section-title h2 {
    font-size: 18px;
  }

  .alerts {
    gap: 6px !important;
  }

  .alert-card {
    grid-template-columns: 58px 1fr !important;
    height: auto !important;
    min-height: 118px !important;
    grid-row: auto !important;
    overflow: hidden !important;
    border-left-width: 4px !important;
    border-radius: 8px !important;
  }

  .alert-card:has(.details.is-expanded) {
    height: auto !important;
    min-height: 118px !important;
    grid-row: auto !important;
    overflow: visible !important;
  }

  .alert-card:has(.details.is-expanded) .alert-body {
    overflow: visible !important;
  }

  .alert-left {
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    gap: 3px !important;
    padding: 3px 2px !important;
  }

  .alert-body {
    padding: 5px 6px !important;
    height: auto !important;
  }

  .alert-head {
    flex-direction: row !important;
    align-items: flex-start !important;
    gap: 4px !important;
  }

  .alert-head h3 {
    font-size: 11px !important;
    line-height: 1.12 !important;
  }

  .priority {
    padding: 2px 4px !important;
    font-size: 7px !important;
    line-height: 1.1 !important;
  }

  .location,
  .ngr,
  .details {
    margin-top: 2px !important;
    font-size: 9px !important;
    line-height: 1.18 !important;
  }

  .details.is-collapsed {
    -webkit-line-clamp: 2 !important;
    max-height: 22px !important;
  }

  .details.is-expanded {
    max-height: none !important;
    overflow: visible !important;
    overflow-y: visible !important;
  }

  .alert-expand-btn {
    margin-top: 3px !important;
    padding: 2px 5px !important;
    font-size: 7px !important;
  }

  .meta {
    margin-top: 3px !important;
    padding-top: 3px !important;
    gap: 4px !important;
    font-size: 7px !important;
    line-height: 1.1 !important;
  }

  .cat-icon {
    font-size: 15px !important;
  }

  .service-logo {
    width: 20px !important;
    height: 20px !important;
  }

  .cat-name {
    font-size: 7px !important;
    line-height: 1.05 !important;
    letter-spacing: .15px !important;
  }

  .alert-image {
    margin-top: 4px !important;
    max-height: 100px !important;
    border-radius: 6px !important;
  }

  .review-head,
  .review-meta {
    gap: 5px !important;
  }

  .review-stars {
    font-size: 11px !important;
  }

  .review-card p.review-text,
  .review-item p.review-text,
  .review-text {
    font-size: 12px !important;
    line-height: 1.22 !important;
  }

  .chat-send-wrap {
    grid-template-columns: 1fr;
  }

  .chat-message {
    grid-template-columns: 48px 1fr !important;
    gap: 8px !important;
    padding: 8px !important;
  }

  .chat-avatar-wrap {
    width: 48px !important;
    height: 48px !important;
    border-radius: 10px !important;
  }

  .member-account-header strong {
    font-size: 11px !important;
    letter-spacing: .15px !important;
  }

  .member-profile-image-preview {
    width: 128px !important;
    height: 128px !important;
  }

  .member-avatar-large {
    width: 110px !important;
    height: 110px !important;
  }

  .member-avatar-grid {
    gap: 6px !important;
  }

  .board-login-btn {
    width: 100%;
  }
}