/**
 * RakuShopBD — Global mobile & tablet responsive fixes
 */

html {
  -webkit-text-size-adjust: 100%;
}

body {
  overflow-x: clip;
}

img,
video,
svg {
  max-width: 100%;
  height: auto;
}

/* Safe-area helpers (iPhone notch / home indicator) */
:root {
  --safe-top: env(safe-area-inset-top, 0px);
  --safe-right: env(safe-area-inset-right, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --safe-left: env(safe-area-inset-left, 0px);
}

/* ——— Touch targets ——— */
@media (max-width: 768px) {
  button,
  .btn-primary,
  .btn-outline,
  .btn-outline-white,
  .add-cart-btn,
  .preorder-btn,
  .header-icon-btn,
  .navbar-hamburger,
  a.header-icon-btn {
    min-height: 44px;
  }

  input,
  select,
  textarea {
    font-size: 16px; /* prevents iOS zoom on focus */
  }
}

/* ——— Compact announcement on mobile ——— */
@media (max-width: 768px) {
  .announcement {
    display: flex;
    padding: 6px 12px;
    padding-left: max(12px, var(--safe-left));
    padding-right: max(12px, var(--safe-right));
    font-size: 11px;
    line-height: 1.35;
    gap: 6px;
  }

  .announcement i:last-child {
    display: none;
  }

  .announcement span {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    min-width: 0;
  }
}

/* ——— Navbar ——— */
@media (max-width: 768px) {
  .navbar {
    padding-top: var(--safe-top);
  }

  .navbar-inner {
    padding-left: 0;
    padding-right: 0;
  }

  .navbar-row--primary {
    padding-left: max(16px, var(--safe-left));
    padding-right: max(16px, var(--safe-right));
  }

  .navbar-row--secondary {
    display: none;
  }

  .mobile-cat-menu-panel {
    padding-bottom: var(--safe-bottom);
  }

  .mobile-cat-menu-header,
  .mobile-cat-menu-list,
  .mobile-cat-menu-extra {
    padding-left: max(16px, var(--safe-left));
    padding-right: max(16px, var(--safe-right));
  }

  .search-suggest {
    left: 0;
    right: 0;
    width: 100%;
    max-width: none;
    border-radius: 0 0 12px 12px;
  }
}

@media (max-width: 380px) {
  #nav-wishlist-btn {
    display: none !important;
  }

  .nav-actions--header {
    gap: 2px;
  }

  .navbar-top {
    gap: 6px;
  }
}

/* ——— Layout ——— */
@media (max-width: 768px) {
  .main {
    padding: 14px max(12px, var(--safe-left)) 14px max(12px, var(--safe-right));
  }

  .section-header {
    flex-wrap: wrap;
    gap: 8px;
  }

  .section-title {
    font-size: 16px;
  }

  /* Hero */
  .hero-main {
    flex-direction: column;
    align-items: stretch;
    padding: 32px 20px;
    min-height: 280px;
  }

  .hero-main--has-bg-photo {
    padding: 0;
    min-height: 0;
  }

  .hero-title {
    font-size: 26px;
  }

  .hero-sub {
    font-size: 14px;
    margin-bottom: 18px;
  }

  .hero-btns {
    flex-wrap: wrap;
    width: 100%;
  }

  .hero-btns .btn-primary,
  .hero-btns .btn-outline-white {
    flex: 1;
    min-width: 140px;
    justify-content: center;
  }

  .hero-side {
    flex-direction: column;
  }

  .hero-card {
    width: 100%;
  }

  /* Home horizontal scroll */
  .home-scroll-wrap {
    margin-left: calc(-1 * max(12px, var(--safe-left)) + 12px);
    margin-right: calc(-1 * max(12px, var(--safe-right)) + 12px);
  }

  .home-scroll-track {
    padding-left: max(4px, var(--safe-left));
    padding-right: max(4px, var(--safe-right));
    scroll-padding-left: max(4px, var(--safe-left));
  }

  /* Stats */
  .stat-card {
    padding: 12px 14px;
  }

  .stat-num {
    font-size: 17px;
  }

  /* Category row — full bleed handled in main.css */

  /* Product cards */
  .product-card {
    min-width: 0;
  }

  .product-card .product-name {
    font-size: 13px;
    line-height: 1.35;
  }

  .product-card .product-price {
    font-size: 15px;
  }

  /* Trust bar — one bold slide at a time on mobile */
  .trust-bar-wrap {
    width: 100%;
    margin: 0 max(0px, var(--safe-left)) 20px max(0px, var(--safe-right));
    overflow: hidden;
  }

  .trust-bar {
    display: flex !important;
    grid-template-columns: none !important;
    width: 100%;
    gap: 0;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }

  .trust-bar::-webkit-scrollbar {
    display: none;
  }

  .trust-item {
    flex: 0 0 auto;
    width: 100%;
    min-width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    scroll-snap-align: start;
    scroll-snap-stop: always;
    justify-content: center;
    text-align: center;
    padding: 18px 20px;
    gap: 12px;
    border-right: none !important;
    border-top: none !important;
  }

  .trust-icon {
    font-size: 30px;
    flex-shrink: 0;
  }

  .trust-title {
    font-size: 15px;
    font-weight: 800;
    line-height: 1.3;
    color: var(--text);
  }

  .trust-sub {
    font-size: 12px;
    font-weight: 600;
    line-height: 1.4;
    color: var(--text-muted);
    margin-top: 4px;
  }

  /* Footer */
  .footer-inner {
    padding: 0 max(12px, var(--safe-left)) 0 max(12px, var(--safe-right));
  }

  .footer-payment {
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
  }
}

@media (max-width: 600px) {
  .product-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
  }
}

/* Product cards — stack price + button on narrow/mobile grids */
@media (max-width: 768px) {
  .product-card .prod-foot {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }

  .product-card .prod-foot > div:first-child {
    width: 100%;
    min-width: 0;
  }

  .product-card .prod-price {
    font-size: 14px;
    line-height: 1.25;
    word-break: break-word;
  }

  .product-card .prod-old {
    display: block;
    margin-left: 0;
    margin-top: 2px;
    font-size: 10px;
  }

  .product-card .discount-pct {
    display: block;
    font-size: 10px;
    margin-top: 2px;
    margin-left: 0;
  }

  .product-card .add-cart-btn,
  .product-card .preorder-btn {
    width: 100%;
    min-height: 34px;
    padding: 7px 10px;
    font-size: 11px;
    gap: 4px;
    border-radius: 8px;
    justify-content: center;
    box-sizing: border-box;
  }

  .product-card .add-cart-btn .ti,
  .product-card .preorder-btn .ti {
    font-size: 14px;
  }

  .product-grid .prod-info {
    padding: 10px 10px 12px;
  }

  .product-grid .prod-img {
    height: 140px;
  }
}

@media (max-width: 480px) {
  .main {
    padding: 12px max(10px, var(--safe-left)) 12px max(10px, var(--safe-right));
  }

  .stats-grid {
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }

  .promo-card {
    min-height: auto;
    padding: 20px 16px;
  }
}

@media (max-width: 360px) {
  .hero-title {
    font-size: 22px;
  }

  .product-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }
}

/* ——— Product page ——— */
@media (max-width: 768px) {
  #page-product .pv-breadcrumb {
    padding-left: max(12px, var(--safe-left));
    padding-right: max(12px, var(--safe-right));
  }

  #page-product .pv-wrap,
  #page-product .pv-tabs-wrap,
  #page-product .related-section {
    padding-left: max(12px, var(--safe-left));
    padding-right: max(12px, var(--safe-right));
  }

  #page-product .main-product-img {
    height: min(56vw, 280px);
    min-height: 220px;
  }

  #page-product .main-product-img i {
    font-size: 90px;
  }

  #page-product .pv-title {
    font-size: 18px;
    line-height: 1.35;
  }

  #page-product .pv-specs-inline {
    margin: 0 0 12px;
  }

  #page-product .pv-specs-inline .spec-table {
    font-size: 12px;
  }

  #page-product .pv-specs-inline .spec-table th,
  #page-product .pv-specs-inline .spec-table td {
    display: block;
    width: 100%;
    box-sizing: border-box;
  }

  #page-product .pv-specs-inline .spec-table tr {
    display: block;
    border-bottom: 1px solid var(--border);
  }

  #page-product .pv-specs-inline .spec-table tr:last-child {
    border-bottom: none;
  }

  #page-product .pv-specs-inline .spec-table th {
    border-right: none;
    padding-bottom: 4px;
  }

  #page-product .pv-specs-inline .spec-table td {
    padding-top: 0;
    padding-bottom: 10px;
  }

  #page-product .pv-price {
    font-size: 22px;
  }

  #page-product .pv-price-row {
    padding: 6px 12px;
    margin-bottom: 10px;
  }

  #page-product .pv-action-row {
    flex-wrap: wrap;
    gap: 10px;
  }

  #page-product .btn-add-cart,
  #page-product .btn-buy,
  #page-product .btn-preorder {
    flex: 1 1 calc(50% - 5px);
    min-width: 0;
  }

  #page-product .btn-wish-lg {
    width: 100%;
    height: 46px;
  }

  #page-product .pv-meta-label {
    min-width: 72px;
  }

  #page-product .spec-table th,
  #page-product .spec-table td {
    display: block;
    width: 100%;
    box-sizing: border-box;
  }

  #page-product .spec-table tr {
    display: block;
    border-bottom: 1px solid var(--border);
  }

  #page-product .spec-table tr:last-child {
    border-bottom: none;
  }

  #page-product .spec-table th {
    border-right: none;
    padding-bottom: 4px;
  }

  #page-product .spec-table td {
    padding-top: 0;
    padding-bottom: 12px;
  }

  #page-product .product-desc-rich {
    line-height: 1.65;
    color: var(--text);
    word-break: break-word;
  }

  #page-product .product-desc-rich p {
    margin: 0 0 0.75em;
  }

  #page-product .product-desc-rich p:last-child {
    margin-bottom: 0;
  }

  #page-product .pv-qty-row {
    flex-wrap: wrap;
    gap: 10px;
  }
}

@media (max-width: 420px) {
  #page-product .btn-add-cart,
  #page-product .btn-buy,
  #page-product .btn-preorder {
    flex: 1 1 100%;
  }

  #page-product .thumb-row {
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: 4px;
    -webkit-overflow-scrolling: touch;
  }

  #page-product .thumb-img {
    flex-shrink: 0;
  }
}

/* ——— Checkout page ——— */
@media (max-width: 768px) {
  #page-checkout .checkout-wrap {
    padding: 16px max(12px, var(--safe-left)) 32px max(12px, var(--safe-right));
  }

  #page-checkout .checkout-steps {
    padding: 0 12px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  #page-checkout .step-label {
    font-size: 10px;
  }

  #page-checkout .step-circle {
    width: 28px;
    height: 28px;
    font-size: 12px;
  }

  #page-checkout .checkout-summary-box {
    position: static;
  }

  #page-checkout .section-card {
    padding: 16px;
  }
}

@media (max-width: 420px) {
  #page-checkout .step-label {
    display: none;
  }

  #page-checkout .card-row {
    grid-template-columns: 1fr;
  }
}

/* ——— Success page ——— */
@media (max-width: 480px) {
  #page-success .success-actions {
    flex-direction: column;
    width: 100%;
  }

  #page-success .btn-track,
  #page-success .btn-home-again {
    width: 100%;
    justify-content: center;
  }
}

/* ——— Category page ——— */
@media (max-width: 768px) {
  .cat-page-wrap {
    padding: 12px max(12px, var(--safe-left)) 40px max(12px, var(--safe-right));
  }

  .cat-toolbar {
    flex-wrap: wrap;
    gap: 10px;
  }

  .cat-toolbar select,
  .cat-toolbar .cat-sort {
    flex: 1 1 100%;
    min-width: 0;
  }
}

/* ——— Cart page ——— */
@media (max-width: 640px) {
  .cart-page-wrap {
    padding: 16px max(12px, var(--safe-left)) calc(48px + var(--safe-bottom)) max(12px, var(--safe-right));
  }

  .cart-page-title {
    font-size: 20px;
  }

  .c-item {
    flex-wrap: wrap;
    padding: 14px;
    gap: 12px;
  }

  .c-item-thumb {
    width: 80px;
    height: 80px;
  }

  .c-item-right {
    width: 100%;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }

  .cart-summary-box {
    position: static;
  }

  .cart-summary-box .c-checkout-btn {
    width: 100%;
    justify-content: center;
  }
}

@media (max-width: 400px) {
  .c-item {
    flex-direction: column;
    align-items: stretch;
  }

  .c-item-thumb {
    width: 100%;
    height: auto;
    aspect-ratio: 1;
    min-height: 160px;
    max-height: 220px;
  }

  .c-item-right {
    flex-direction: row;
  }
}

/* ——— Wishlist ——— */
@media (max-width: 520px) {
  .wl-wrap {
    padding: 16px max(12px, var(--safe-left)) calc(48px + var(--safe-bottom)) max(12px, var(--safe-right));
  }

  .wl-grid {
    grid-template-columns: 1fr;
  }

  .wl-title {
    font-size: 20px;
  }
}

/* ——— Account page ——— */
@media (max-width: 768px) {
  #page-account .acc-wrap {
    padding: 16px max(12px, var(--safe-left)) calc(48px + var(--safe-bottom)) max(12px, var(--safe-right));
  }

  #page-account .acc-auth-shell {
    margin: 0;
    border-radius: 16px;
  }

  #page-account .acc-order-card {
    overflow: hidden;
  }

  #page-account .acc-order-foot {
    flex-wrap: wrap;
    gap: 10px;
  }
}

@media (max-width: 480px) {
  #page-account .acc-auth-brand,
  #page-account .acc-auth-panel {
    padding: 24px 18px;
  }
}

/* ——— Appointment page ——— */
@media (max-width: 768px) {
  .appt-wrap {
    padding: 16px max(12px, var(--safe-left)) calc(48px + var(--safe-bottom)) max(12px, var(--safe-right));
  }

  .appt-head {
    padding: 16px;
  }

  .appt-body {
    padding: 16px;
  }
}

/* ——— Checkout modal ——— */
@media (max-width: 768px) {
  .checkout-modal-overlay {
    display: flex;
    flex-direction: column;
    padding: 0;
    overflow: hidden;
  }

  .checkout-modal-box {
    width: 100%;
    max-width: 100%;
    height: 100dvh;
    max-height: 100dvh;
    margin: 0;
    border-radius: 0;
    overflow: hidden;
    box-shadow: none;
  }

  .checkout-modal-head {
    padding: 14px 16px;
    padding-top: max(14px, calc(10px + var(--safe-top)));
  }

  .checkout-modal-body {
    flex: 1;
    min-height: 0;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    touch-action: pan-y;
    padding: 14px 16px calc(24px + var(--safe-bottom));
  }

  .checkout-modal-body .card-row {
    grid-template-columns: 1fr;
  }

  body.checkout-modal-open .face-analyzer-fab {
    visibility: hidden;
    pointer-events: none;
  }
}

/* ——— Track page ——— */
@media (max-width: 768px) {
  .track-wrap {
    padding: 16px max(12px, var(--safe-left)) 40px max(12px, var(--safe-right));
  }

  .track-grid {
    grid-template-columns: 1fr;
  }

  .trk-form {
    flex-direction: column;
    align-items: stretch;
  }

  .trk-input-wrap {
    min-width: 0;
    width: 100%;
  }

  .trk-btn {
    width: 100%;
    justify-content: center;
  }
}

/* ——— Reviews ——— */
@media (max-width: 640px) {
  .reviews-write-card {
    padding: 16px;
  }

  .home-customer-reviews {
    padding-left: max(0px, var(--safe-left));
    padding-right: max(0px, var(--safe-right));
  }

  .home-messenger-reviews {
    padding-left: max(0px, var(--safe-left));
    padding-right: max(0px, var(--safe-right));
  }
}

/* ——— Face analyzer FAB ——— */
@media (max-width: 768px) {
  .face-analyzer-fab {
    left: max(10px, var(--safe-left));
    bottom: max(14px, calc(10px + var(--safe-bottom)));
    transform: scale(0.92);
    transform-origin: left bottom;
  }

  .face-analyzer-fab:hover {
    transform: scale(0.94);
  }

  .face-analyzer-fab-bubble {
    max-width: min(168px, calc(100vw - 100px));
  }
}

@media (max-width: 480px) {
  .face-analyzer-fab {
    transform: scale(0.85);
  }

  .face-analyzer-fab-bubble {
    min-width: 0;
    max-width: 150px;
    padding: 8px 12px;
  }

  .face-analyzer-fab-popup {
    font-size: 12px;
  }

  .face-analyzer-fab-avatar {
    width: 58px;
    height: 58px;
  }
}

/* ——— Search suggest dropdown ——— */
@media (max-width: 480px) {
  .search-suggest {
    max-height: min(60vh, 320px);
    overflow-y: auto;
  }

  .search-suggest-item {
    padding: 10px 12px;
  }
}

/* ——— Modals (track overlay etc.) ——— */
@media (max-width: 768px) {
  .trk-overlay {
    padding: max(12px, var(--safe-top)) max(12px, var(--safe-right)) max(12px, var(--safe-bottom)) max(12px, var(--safe-left));
    align-items: flex-end;
  }

  .trk-modal {
    max-height: min(90vh, calc(100dvh - var(--safe-top) - var(--safe-bottom) - 24px));
    border-radius: 18px 18px 0 0;
  }
}

/* Category row — single line scroll (styles in main.css) */

/* ——— Home product rows: 2 cards visible on mobile ——— */
@media (max-width: 768px) {
  .home-scroll-track .product-card {
    flex: 0 0 auto;
    flex-shrink: 0;
    box-sizing: border-box;
  }

  .home-scroll-track {
    gap: 12px;
  }

  .home-scroll-track .prod-name {
    font-size: 12px;
    line-height: 1.35;
  }

  .home-scroll-track .prod-img {
    height: 140px;
  }

  .home-scroll-track .prod-info {
    padding: 10px 10px 12px;
  }

  .home-scroll-track .prod-category {
    font-size: 9px;
    margin-bottom: 3px;
  }

  .home-scroll-track .prod-rating {
    margin-bottom: 6px;
  }

  .home-scroll-track .prod-foot {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }

  .home-scroll-track .prod-foot > div:first-child {
    width: 100%;
  }

  .home-scroll-track .prod-price {
    font-size: 14px;
    line-height: 1.2;
  }

  .home-scroll-track .prod-old {
    display: block;
    margin-left: 0;
    margin-top: 2px;
    font-size: 10px;
  }

  .home-scroll-track .discount-pct {
    display: block;
    font-size: 10px;
    margin-top: 2px;
  }

  .home-scroll-track .add-cart-btn {
    width: 100%;
    min-height: 34px;
    padding: 7px 8px;
    font-size: 10px;
    gap: 4px;
    border-radius: 8px;
    white-space: nowrap;
  }

  .home-scroll-track .preorder-btn {
    width: 100%;
    min-height: 34px;
    padding: 7px 8px;
    font-size: 10px;
    gap: 4px;
    border-radius: 8px;
    white-space: nowrap;
  }

  .home-scroll-track .add-cart-btn .ti {
    font-size: 14px;
  }

  .home-scroll-track .preorder-btn .ti {
    font-size: 14px;
  }

  .today-deals-scroll-track .today-deals-card-foot {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }

  .today-deals-scroll-track .today-deals-card-foot > div:first-child {
    width: 100%;
    min-width: 0;
  }

  .today-deals-scroll-track .prod-price,
  .today-deals-scroll-track .today-deals-card-price {
    font-size: 14px;
    line-height: 1.2;
  }

  .today-deals-scroll-track .prod-old,
  .today-deals-scroll-track .today-deals-card-old {
    display: block;
    margin-left: 0;
    margin-top: 2px;
    font-size: 10px;
  }

  .today-deals-scroll-track .add-cart-btn,
  .today-deals-scroll-track .preorder-btn {
    width: 100%;
    min-height: 34px;
    padding: 7px 8px;
    font-size: 10px;
    gap: 4px;
    border-radius: 8px;
    white-space: nowrap;
    flex-shrink: 0;
  }

  .today-deals-scroll-track .add-cart-btn .ti,
  .today-deals-scroll-track .preorder-btn .ti {
    font-size: 14px;
  }

  /* Customer reviews — 2 cards visible */
  .home-reviews-track .home-review-card {
    flex: 0 0 calc((100vw - 48px) / 2) !important;
    min-width: calc((100vw - 48px) / 2) !important;
    max-width: calc((100vw - 48px) / 2) !important;
    width: calc((100vw - 48px) / 2) !important;
    flex-shrink: 0 !important;
    box-sizing: border-box;
  }
}
