/**
 * Petion-Ville.com — Mobile-First Responsive Patch
 * File: /wp-content/themes/divi-child/assets/css/pv-mobile.css
 * Scope: .pv-site body class only — safe for Divi Child
 * Breakpoints:
 *   mobile  : < 640px
 *   tablet  : 640px – 1024px
 *   desktop : 1025px – 1365px
 *   wide    : >= 1366px
 */

/* ============================================================
   0. CSS VARIABLES — Petion-Ville Design Tokens
   ============================================================ */
.pv-site {
  --pv-primary:       #C8102E;   /* Rouge Haïtien */
  --pv-gold:          #D4A843;   /* Or Caraïbes   */
  --pv-navy:          #0D1B2A;
  --pv-surface:       #FAFAF8;
  --pv-text:          #1A1A1A;
  --pv-text-muted:    #5A5A5A;
  --pv-border:        #E2DDD5;
  --pv-radius-sm:     6px;
  --pv-radius-md:     10px;
  --pv-radius-lg:     16px;
  --pv-shadow-card:   0 2px 12px rgba(0,0,0,0.08), 0 1px 3px rgba(0,0,0,0.05);
  --pv-shadow-hover:  0 6px 24px rgba(0,0,0,0.13), 0 2px 6px rgba(0,0,0,0.07);
  --pv-transition:    0.22s cubic-bezier(0.4, 0, 0.2, 1);
  --pv-touch-target:  44px;
  --pv-gap-sm:        8px;
  --pv-gap-md:        16px;
  --pv-gap-lg:        24px;
}

/* ============================================================
   1. GLOBAL RESETS — No horizontal overflow
   ============================================================ */
.pv-site *,
.pv-site *::before,
.pv-site *::after {
  box-sizing: border-box;
}

.pv-site html,
.pv-site body {
  overflow-x: hidden;
  -webkit-text-size-adjust: 100%;
}

.pv-site img,
.pv-site video,
.pv-site iframe {
  max-width: 100%;
  height: auto;
  display: block;
}

/* Divi overflow guard */
.pv-site .et_pb_section,
.pv-site .et_pb_row,
.pv-site .et_pb_column,
.pv-site .et_pb_module {
  max-width: 100%;
  overflow-x: hidden;
}

/* ============================================================
   2. TYPOGRAPHY — Mobile base scale
   ============================================================ */
.pv-site {
  font-size: 16px;
  line-height: 1.55;
  color: var(--pv-text);
  -webkit-font-smoothing: antialiased;
}

.pv-site h1 { font-size: clamp(1.6rem,  5vw, 3rem);   line-height: 1.2; }
.pv-site h2 { font-size: clamp(1.3rem,  4vw, 2.2rem);  line-height: 1.25; }
.pv-site h3 { font-size: clamp(1.1rem,  3vw, 1.6rem);  line-height: 1.3; }
.pv-site h4 { font-size: clamp(1rem,  2.5vw, 1.3rem);  line-height: 1.35; }
.pv-site p  { font-size: clamp(0.9rem, 2.2vw, 1rem);   line-height: 1.6; }

/* ============================================================
   3. HERO — Mobile readability
   ============================================================ */
.pv-site .pv-hero,
.pv-site .et_pb_fullwidth_header {
  position: relative;
  min-height: 52vw;
  display: flex;
  align-items: center;
}

.pv-site .pv-hero::after,
.pv-site .et_pb_fullwidth_header::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    160deg,
    rgba(13,27,42,0.68) 0%,
    rgba(13,27,42,0.30) 60%,
    transparent 100%
  );
  pointer-events: none;
  z-index: 1;
}

.pv-site .pv-hero__content,
.pv-site .et_pb_fullwidth_header .et_pb_fullwidth_header_container {
  position: relative;
  z-index: 2;
  padding: var(--pv-gap-lg) var(--pv-gap-md);
  max-width: 720px;
}

.pv-site .pv-hero__title,
.pv-site .et_pb_fullwidth_header .et_pb_fullwidth_header_title {
  color: #fff;
  text-shadow: 0 2px 12px rgba(0,0,0,0.45);
  font-size: clamp(1.5rem, 6vw, 3.2rem);
  font-weight: 800;
  letter-spacing: -0.01em;
  margin-bottom: 0.4em;
}

.pv-site .pv-hero__subtitle,
.pv-site .et_pb_fullwidth_header .et_pb_fullwidth_header_subhead {
  color: rgba(255,255,255,0.88);
  font-size: clamp(0.9rem, 2.8vw, 1.15rem);
  text-shadow: 0 1px 6px rgba(0,0,0,0.4);
  max-width: 540px;
}

/* ============================================================
   4. TOUCH-FRIENDLY BUTTONS
   ============================================================ */
.pv-site .et_pb_button,
.pv-site .pv-btn,
.pv-site button,
.pv-site [type="submit"],
.pv-site [type="button"],
.pv-site .button,
.pv-site .wp-block-button__link {
  min-height: var(--pv-touch-target);
  min-width: var(--pv-touch-target);
  padding: 11px 22px;
  border-radius: var(--pv-radius-sm);
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  line-height: 1.3;
  cursor: pointer;
  transition: background var(--pv-transition),
              transform var(--pv-transition),
              box-shadow var(--pv-transition);
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.pv-site .et_pb_button:active,
.pv-site .pv-btn:active,
.pv-site button:active {
  transform: scale(0.97);
}

/* Primary CTA */
.pv-site .pv-btn--primary,
.pv-site .et_pb_button.pv-btn--primary {
  background: var(--pv-primary);
  color: #fff;
  border: none;
  box-shadow: 0 2px 8px rgba(200,16,46,0.30);
}

.pv-site .pv-btn--primary:hover {
  background: #a50d26;
  box-shadow: 0 4px 16px rgba(200,16,46,0.40);
}

/* Gold accent */
.pv-site .pv-btn--gold,
.pv-site .et_pb_button.pv-btn--gold {
  background: var(--pv-gold);
  color: var(--pv-navy);
  border: none;
}

/* ============================================================
   5. SEARCH AREA — Mobile usable
   ============================================================ */
.pv-site .pv-search,
.pv-site .pv-hero__search,
.pv-site .searchform {
  display: flex;
  flex-wrap: wrap;
  gap: var(--pv-gap-sm);
  width: 100%;
  max-width: 640px;
}

.pv-site .pv-search input[type="text"],
.pv-site .pv-search input[type="search"],
.pv-site .searchform input[type="search"] {
  flex: 1 1 200px;
  min-height: var(--pv-touch-target);
  padding: 10px 16px;
  font-size: 1rem;
  border: 1.5px solid var(--pv-border);
  border-radius: var(--pv-radius-sm);
  background: #fff;
  color: var(--pv-text);
  outline: none;
  transition: border-color var(--pv-transition), box-shadow var(--pv-transition);
}

.pv-site .pv-search input:focus,
.pv-site .searchform input:focus {
  border-color: var(--pv-primary);
  box-shadow: 0 0 0 3px rgba(200,16,46,0.12);
}

.pv-site .pv-search__submit,
.pv-site .searchform [type="submit"] {
  flex: 0 0 auto;
  background: var(--pv-primary);
  color: #fff;
  border: none;
  border-radius: var(--pv-radius-sm);
  min-height: var(--pv-touch-target);
  padding: 10px 20px;
  font-size: 0.95rem;
  font-weight: 700;
}

/* ============================================================
   6. CATEGORY CARDS — Responsive grid
   ============================================================ */
.pv-site .pv-categories {
  display: grid;
  gap: var(--pv-gap-md);
  grid-template-columns: repeat(2, 1fr); /* mobile: 2 col */
}

.pv-site .pv-category-card {
  position: relative;
  border-radius: var(--pv-radius-md);
  overflow: hidden;
  aspect-ratio: 4/3;
  background: var(--pv-navy);
  box-shadow: var(--pv-shadow-card);
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: transform var(--pv-transition), box-shadow var(--pv-transition);
}

.pv-site .pv-category-card:active {
  transform: scale(0.98);
}

.pv-site .pv-category-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}

.pv-site .pv-category-card:hover img {
  transform: scale(1.04);
}

.pv-site .pv-category-card__label {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 28px 10px 10px;
  background: linear-gradient(transparent, rgba(13,27,42,0.82));
  color: #fff;
  font-size: 0.82rem;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

/* ============================================================
   7. LISTING CARDS — Compact premium 2-col mobile grid
   ============================================================ */
.pv-site .pv-listings-grid {
  display: grid;
  gap: var(--pv-gap-sm);
  grid-template-columns: repeat(2, 1fr); /* mobile: 2 compact col */
}

.pv-site .pv-listing-card {
  background: #fff;
  border-radius: var(--pv-radius-md);
  overflow: hidden;
  box-shadow: var(--pv-shadow-card);
  display: flex;
  flex-direction: column;
  transition: box-shadow var(--pv-transition), transform var(--pv-transition);
  -webkit-tap-highlight-color: transparent;
}

.pv-site .pv-listing-card:hover {
  box-shadow: var(--pv-shadow-hover);
  transform: translateY(-2px);
}

.pv-site .pv-listing-card__thumb {
  position: relative;
  aspect-ratio: 16/10;
  overflow: hidden;
  background: var(--pv-border);
  flex-shrink: 0;
}

.pv-site .pv-listing-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.35s ease;
}

.pv-site .pv-listing-card:hover .pv-listing-card__thumb img {
  transform: scale(1.05);
}

.pv-site .pv-listing-card__badge {
  position: absolute;
  top: 6px;
  left: 6px;
  background: var(--pv-primary);
  color: #fff;
  font-size: 0.64rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 3px 7px;
  border-radius: 4px;
  line-height: 1.3;
}

.pv-site .pv-listing-card__body {
  padding: 9px 10px 10px;
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: 4px;
}

.pv-site .pv-listing-card__title {
  font-size: 0.8rem;
  font-weight: 700;
  line-height: 1.3;
  color: var(--pv-text);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin: 0;
}

.pv-site .pv-listing-card__price {
  font-size: 0.82rem;
  font-weight: 800;
  color: var(--pv-primary);
  margin: 0;
}

.pv-site .pv-listing-card__meta {
  font-size: 0.7rem;
  color: var(--pv-text-muted);
  display: flex;
  gap: 5px;
  align-items: center;
  flex-wrap: wrap;
}

.pv-site .pv-listing-card__cta {
  margin-top: auto;
  display: block;
  text-align: center;
  background: var(--pv-navy);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
  padding: 7px 8px;
  border-radius: var(--pv-radius-sm);
  text-decoration: none;
  letter-spacing: 0.02em;
  transition: background var(--pv-transition);
  min-height: 32px;
  line-height: 18px;
}

.pv-site .pv-listing-card__cta:hover {
  background: var(--pv-primary);
  color: #fff;
}

/* ============================================================
   8. HAITIAN IMAGERY BLOCKS — Elegant across breakpoints
   ============================================================ */
.pv-site .pv-haitian-feature,
.pv-site .pv-haitian-banner {
  position: relative;
  overflow: hidden;
  border-radius: var(--pv-radius-lg);
}

.pv-site .pv-haitian-feature img,
.pv-site .pv-haitian-banner img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
}

.pv-site .pv-haitian-feature__caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 40px 20px 18px;
  background: linear-gradient(transparent, rgba(13,27,42,0.78));
  color: #fff;
}

.pv-site .pv-haitian-feature__caption h3 {
  font-size: clamp(1rem, 3.5vw, 1.6rem);
  font-weight: 800;
  margin: 0 0 4px;
  text-shadow: 0 1px 8px rgba(0,0,0,0.5);
}

.pv-site .pv-haitian-feature__caption p {
  font-size: 0.85rem;
  margin: 0;
  opacity: 0.88;
}

/* ============================================================
   9. SPACING — Balanced, not compressed
   ============================================================ */
.pv-site .et_pb_section {
  padding-top: clamp(28px, 5vw, 64px);
  padding-bottom: clamp(28px, 5vw, 64px);
}

.pv-site .et_pb_row {
  padding-left: clamp(12px, 4vw, 24px);
  padding-right: clamp(12px, 4vw, 24px);
  max-width: 1400px;
  margin-left: auto;
  margin-right: auto;
}

/* ============================================================
   10. FOOTER BLOCKS — Clean mobile
   ============================================================ */
.pv-site #main-footer,
.pv-site .et_pb_section.footer-section {
  padding-left: var(--pv-gap-md);
  padding-right: var(--pv-gap-md);
}

.pv-site .et_pb_widget,
.pv-site .footer-widget {
  margin-bottom: var(--pv-gap-lg);
}

.pv-site .et_pb_widget a,
.pv-site .footer-widget a {
  min-height: var(--pv-touch-target);
  display: inline-flex;
  align-items: center;
  color: inherit;
  text-decoration: none;
  padding: 3px 0;
}

/* ============================================================
   11. TABLET — 640px+
   ============================================================ */
@media (min-width: 640px) {
  .pv-site .pv-categories {
    grid-template-columns: repeat(3, 1fr);
  }

  .pv-site .pv-listings-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--pv-gap-md);
  }

  .pv-site .pv-listing-card__title {
    font-size: 0.88rem;
  }

  .pv-site .pv-listing-card__body {
    padding: 11px 12px 12px;
  }

  .pv-site .pv-listing-card__cta {
    font-size: 0.78rem;
    padding: 8px 10px;
  }

  .pv-site .pv-hero__content,
  .pv-site .et_pb_fullwidth_header .et_pb_fullwidth_header_container {
    padding: 40px 28px;
  }
}

/* ============================================================
   12. LARGE TABLET — 768px+
   ============================================================ */
@media (min-width: 768px) {
  .pv-site .pv-categories {
    grid-template-columns: repeat(3, 1fr);
  }

  .pv-site .pv-listings-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .pv-site .pv-hero {
    min-height: 44vw;
  }
}

/* ============================================================
   13. DESKTOP — 1025px+
   ============================================================ */
@media (min-width: 1025px) {
  .pv-site .pv-categories {
    grid-template-columns: repeat(4, 1fr);
  }

  .pv-site .pv-listings-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: var(--pv-gap-md);
  }

  .pv-site .pv-listing-card__title {
    font-size: 0.9rem;
  }

  .pv-site .pv-listing-card__body {
    padding: 12px 14px 14px;
    gap: 6px;
  }

  .pv-site .pv-hero {
    min-height: 520px;
  }

  .pv-site .pv-hero__content,
  .pv-site .et_pb_fullwidth_header .et_pb_fullwidth_header_container {
    padding: 60px 48px;
  }
}

/* ============================================================
   14. WIDE DESKTOP — 1366px+
   ============================================================ */
@media (min-width: 1366px) {
  .pv-site .pv-listings-grid {
    grid-template-columns: repeat(4, 1fr);
  }

  .pv-site .pv-listing-card__title {
    font-size: 0.95rem;
  }

  .pv-site .pv-listing-card__badge {
    font-size: 0.68rem;
    padding: 3px 8px;
  }

  .pv-site .et_pb_row {
    max-width: 1500px;
  }
}

/* ============================================================
   15. DIVI COLUMN OVERRIDE — Multi-column on mobile
   ============================================================ */

/* Force 2 equal columns for listing Divi rows on mobile */
.pv-site .pv-divi-listings-row.et_pb_row {
  display: grid;
  gap: var(--pv-gap-sm);
  grid-template-columns: repeat(2, 1fr);
}

@media (min-width: 640px) {
  .pv-site .pv-divi-listings-row.et_pb_row {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--pv-gap-md);
  }
}

@media (min-width: 768px) {
  .pv-site .pv-divi-listings-row.et_pb_row {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (min-width: 1025px) {
  .pv-site .pv-divi-listings-row.et_pb_row {
    grid-template-columns: repeat(4, 1fr);
  }
}

.pv-site .pv-divi-listings-row.et_pb_row > .et_pb_column {
  width: 100% !important;
  margin: 0 !important;
}

/* ============================================================
   16. UTILITY — Visibility & spacing helpers
   ============================================================ */
.pv-site .pv-hide-mobile  { display: none !important; }
.pv-site .pv-show-mobile  { display: block !important; }

@media (min-width: 640px) {
  .pv-site .pv-hide-mobile  { display: block !important; }
  .pv-site .pv-show-mobile  { display: none !important; }
}

.pv-site .pv-spacer-sm { height: var(--pv-gap-sm); }
.pv-site .pv-spacer-md { height: var(--pv-gap-md); }
.pv-site .pv-spacer-lg { height: var(--pv-gap-lg); }
