/* ──────────────────────────────────────────────────────────────────────
 * EcoNomad — responsive overrides.
 *
 * Loaded LAST in the cascade (after ec-shared, ec-pages, ec-v2). Holds
 * every media-query in one file so rollback is one wp_dequeue_style().
 *
 * Bootstrap-5 breakpoints (desktop-first cascade):
 *   xxl  ≥1400  — design baseline (no media query, original styles)
 *   xl   ≤1399  — small desktops / large laptops
 *   lg   ≤1199  — laptops / landscape tablets
 *   md   ≤991   — portrait tablets / large mobiles  (mobile-nav appears)
 *   sm   ≤767   — mobiles
 *   xs   ≤575   — small mobiles
 * ────────────────────────────────────────────────────────────────────── */


/* ═════════════════════════════════════════════════════════════════════
   ≥1600px — wide-monitor extra breathing room (Sprint 9)
   ───────────────────────────────────────────────────────────────────── */
@media (min-width:1600px){
  :root{
    --gutter:clamp(96px, 6vw, 160px);
  }
}

/* Update --header-h for body sizing on smaller screens */
@media (max-width:991.98px){
  :root{ --header-h:68px; }
}


/* ═════════════════════════════════════════════════════════════════════
   xl  ≤1399.98px
   ───────────────────────────────────────────────────────────────────── */
@media (max-width:1399.98px){

  /* SPRINT-4 home */
  .hero h1{font-size:88px}
  .sec{padding:var(--sec-y) var(--gutter)}
  .hero .inner{padding:48px var(--gutter) 80px}
  .hero .meta-bar{right:var(--gutter);bottom:48px}
  .hero .scroll-ind{left:var(--gutter);bottom:48px}
  .hero .slider-pag{left:var(--gutter)}

  /* anchor: SPRINT-5 single-tour */

  /* anchor: SPRINT-6 page-artisans / location / poi */

  /* anchor: SPRINT-7 contacts / partners / footer */

}


/* ═════════════════════════════════════════════════════════════════════
   lg  ≤1199.98px
   ───────────────────────────────────────────────────────────────────── */
@media (max-width:1199.98px){

  /* SPRINT-4 home */
  .hero{height:auto;min-height:680px}
  .hero h1{font-size:72px}
  .experiences-row{grid-template-columns:repeat(3,1fr)}
  .exp-item{border-bottom:1px solid var(--ec-border)}
  .exp-item:nth-child(3n){border-right:0}
  .exp-item:nth-last-child(-n+3){border-bottom:0}
  .map-preview{grid-template-columns:240px 1fr}
  .mp-info{grid-column:1/-1;border-top:1px solid var(--ec-border)}
  .mp-canvas{height:480px}
  .preview-row-6,.partner-grid-6{grid-template-columns:repeat(3,1fr)}
  .artisan-strip{grid-template-columns:repeat(4,1fr)}
  .cta-block{grid-template-columns:1fr;padding:64px 56px;gap:40px}

  /* SPRINT-5 single-tour */
  .tour-hero{height:auto;min-height:520px}
  .tour-hero .inner{padding:48px var(--gutter) 64px}
  .tour-hero h1{font-size:64px}
  .tour-hero .actions{top:64px;right:var(--gutter)}
  .tour-gallery{padding:6px var(--gutter) 0;grid-template-columns:repeat(3,1fr)}
  .tour-layout{grid-template-columns:1fr 340px;gap:40px;padding:64px var(--gutter)}
  .highlights{grid-template-columns:repeat(3,1fr)}
  .filter-bar{padding:24px var(--gutter)}
  .tours-archive{padding:36px var(--gutter) 80px;grid-template-columns:repeat(2,1fr)}

  /* SPRINT-6 page-artisans */
  .artisans-page{grid-template-columns:300px 1fr;height:auto;min-height:520px}
  .ap-sidebar{padding:24px 18px}

  /* SPRINT-6 location / poi */
  .poi-grid-4{grid-template-columns:repeat(3,1fr)}
  .place-body{grid-template-columns:1fr 320px;gap:48px}
  .place-body .gallery-grid{grid-template-rows:160px 160px}

  /* anchor: SPRINT-7 contacts / partners / footer */

}


/* ═════════════════════════════════════════════════════════════════════
   md  ≤991.98px  — mobile navigation appears
   ───────────────────────────────────────────────────────────────────── */
@media (max-width:991.98px){

  /* ── SPRINT-3 mobile nav (header skinny + bottom-bar + drawer) ─── */

  /* Header — hide desktop nav and search/book actions, keep only logo */
  .doc-header .doc-nav,
  .doc-header .doc-actions{display:none}
  .doc-header-in{justify-content:space-between;padding:14px var(--gutter);gap:14px}
  .doc-topbar{display:none}              /* topbar hidden on mobile */

  /* Header burger */
  .mnav-burger{display:inline-flex;align-items:center;justify-content:center;
    width:var(--touch);height:var(--touch);border:0;background:transparent;
    color:var(--ec-primary-dark);cursor:pointer;font-size:24px;border-radius:var(--r-2)}
  .mnav-burger:hover{background:var(--ec-bg-alt)}

  /* Bottom navigation bar */
  body{padding-bottom:var(--mnav-h)}
  .mnav-bottom{display:grid;grid-template-columns:repeat(5,1fr);
    position:fixed;bottom:0;left:0;right:0;height:var(--mnav-h);
    background:#fff;border-top:1px solid var(--ec-border);
    box-shadow:0 -2px 12px rgba(31,54,45,.06);z-index:60;
    padding:6px 4px env(safe-area-inset-bottom);box-sizing:content-box}
  .mnav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:2px;border:0;background:transparent;cursor:pointer;
    color:var(--ec-text-muted);text-decoration:none;font:inherit;padding:0}
  .mnav-item i{font-size:20px;line-height:1}
  .mnav-item span{font-size:10px;letter-spacing:.04em;text-transform:uppercase;font-family:var(--ec-font-mono)}
  .mnav-item.is-active,.mnav-item:hover{color:var(--ec-primary-dark)}
  .mnav-item.is-active i{color:var(--ec-clay)}

  /* Full-screen drawer overlay (JS removes [hidden] on first open) */
  .mnav-drawer,.mnav-drawer[hidden]{display:flex;flex-direction:column;
    position:fixed;inset:0;z-index:70;background:var(--ec-bg);
    transform:translateX(100%);transition:transform .22s ease-out;
    overflow-y:auto;padding-bottom:env(safe-area-inset-bottom);
    pointer-events:none;visibility:hidden}
  body.mnav-open{overflow:hidden}
  body.mnav-open .mnav-drawer{transform:translateX(0);pointer-events:auto;visibility:visible}

  .mnav-drawer-head{display:flex;align-items:center;justify-content:space-between;
    padding:14px var(--gutter);border-bottom:1px solid var(--ec-border);background:#fff}
  .mnav-drawer-title{font-family:var(--ec-font-display);font-size:18px;font-weight:700;color:var(--ec-primary-dark)}
  .mnav-drawer-close{width:var(--touch);height:var(--touch);border:0;background:transparent;
    color:var(--ec-text);cursor:pointer;font-size:20px;border-radius:var(--r-2)}
  .mnav-drawer-close:hover{background:var(--ec-bg-alt)}

  .mnav-drawer-nav{display:flex;flex-direction:column;padding:8px 0;flex:1}
  .mnav-drawer-nav a{display:flex;align-items:center;padding:14px var(--gutter);
    font-size:18px;color:var(--ec-text);text-decoration:none;font-family:var(--ec-font-display);
    border-bottom:1px solid var(--ec-border);min-height:var(--touch)}
  .mnav-drawer-nav a:hover,.mnav-drawer-nav a.active{background:var(--ec-bg-alt);color:var(--ec-primary-dark)}

  .mnav-drawer-cta{padding:18px var(--gutter);border-top:1px solid var(--ec-border);
    display:flex;flex-direction:column;gap:10px;background:#fff}
  .mnav-drawer-cta .btn{width:100%;justify-content:center}
  .mnav-drawer-tel{display:flex;align-items:center;justify-content:center;gap:10px;
    color:var(--ec-clay);font-family:var(--ec-font-mono);font-size:14px;text-decoration:none;padding:8px}

  /* Float WA button — push above mobile-bar */
  .wa-fab{bottom:calc(var(--mnav-h) + 16px)}

  /* SPRINT-8 filter — mobile bottom-sheet pattern */
  .filter-toggle{display:inline-flex !important;
    position:sticky;top:var(--header-h);left:0;right:0;
    margin:0 var(--gutter);transform:translateY(0);
    z-index:24;background:#fff;border:1px solid var(--ec-border-strong);
    width:calc(100% - var(--gutter)*2);justify-content:center}
  .filter-bar{position:fixed;left:0;right:0;bottom:0;top:auto;
    height:80vh;max-height:80vh;overflow-y:auto;
    border-radius:16px 16px 0 0;border-top:0;
    transform:translateY(100%);transition:transform .25s ease-out;
    z-index:65;padding:24px var(--gutter) calc(var(--mnav-h) + 24px);
    background:var(--ec-bg);box-shadow:0 -4px 24px rgba(0,0,0,.15);
    pointer-events:none;visibility:hidden}
  body.is-filter-open{overflow:hidden}
  body.is-filter-open .filter-bar{transform:translateY(0);pointer-events:auto;visibility:visible}
  .filter-bar .row{flex-direction:column;align-items:flex-start;gap:14px}
  .filter-group{flex-direction:column;align-items:flex-start;gap:8px;width:100%}
  .filter-bar-close{display:inline-flex;position:absolute;top:14px;right:14px;
    width:var(--touch);height:var(--touch);border:0;background:transparent;
    color:var(--ec-text);cursor:pointer;font-size:18px;border-radius:50%;
    align-items:center;justify-content:center;z-index:2}
  .filter-bar-close:hover{background:var(--ec-bg-alt)}
  /* Backdrop overlay (uses pseudo on body via :before substitute) */
  body.is-filter-open::after{content:"";position:fixed;inset:0;
    background:rgba(26,31,28,.5);z-index:60;backdrop-filter:blur(2px)}

  /* Reduced motion */
  @media (prefers-reduced-motion:reduce){
    .mnav-drawer,.filter-bar{transition:none}
  }

  /* SPRINT-4 home */
  .hero{min-height:560px}
  .hero h1{font-size:var(--h1)}
  .hero .meta-bar,.hero .scroll-ind,.hero .slider-pag{display:none}
  .hero .sub{font-size:18px}
  .about-split{grid-template-columns:1fr;gap:48px}
  .about-split .photo-stack{height:auto;aspect-ratio:4/3;min-height:360px}
  .about-split .copy h2{font-size:36px}
  .tours-grid,.reviews-grid,.blog-grid{grid-template-columns:repeat(2,1fr)}
  .usp-row{grid-template-columns:repeat(2,1fr);gap:24px}
  .map-preview{grid-template-columns:1fr}
  .mp-filters{border-right:0;border-bottom:1px solid var(--ec-border)}
  .mp-canvas{height:420px}
  .sec-head{flex-direction:column;align-items:flex-start;gap:16px;margin-bottom:32px}
  .sec-head h2{font-size:42px}
  .sec-head .right{align-items:flex-start}

  /* SPRINT-5 single-tour — stack sidebar, simplify hero */
  .tour-hero{min-height:440px}
  .tour-hero h1{font-size:44px;margin-bottom:14px}
  .tour-hero .sub{font-size:18px}
  .tour-hero .stat-strip{gap:24px;font-size:11px;flex-wrap:wrap;margin-top:24px}
  .tour-hero .stat-strip span b{font-size:24px}
  .tour-hero .actions{top:auto;bottom:24px}
  .tour-gallery{grid-template-columns:repeat(2,1fr)}
  .tour-layout{grid-template-columns:1fr;gap:40px;padding:48px var(--gutter)}
  .tour-layout > aside{position:static;max-height:none;overflow:visible}
  .tour-content > section + section{margin-top:48px}
  .tour-content h2{font-size:32px}
  .day-row{grid-template-columns:1fr;gap:8px;padding:24px 0}
  .day-row .day-mark{flex-direction:row;align-items:baseline;gap:14px}
  .day-row .day-mark .day-no{font-size:32px}
  .day-row .day-gallery{grid-template-columns:repeat(3,1fr)}
  .highlights{grid-template-columns:repeat(2,1fr)}
  .guide-card-grid{grid-template-columns:120px 1fr;gap:18px;padding:18px}
  .tours-archive{padding:28px var(--gutter) 64px}
  .filter-bar .row{flex-direction:column;align-items:stretch}

  /* SPRINT-6 page-artisans — vertical stack */
  .artisans-page{grid-template-columns:1fr;height:auto;min-height:0}
  .ap-sidebar{position:static;border-right:0;border-bottom:1px solid var(--ec-border);
    max-height:none;padding:20px var(--gutter)}
  .ap-mapwrap{height:60vh;min-height:420px;position:relative}
  .ap-detail{width:100%;height:80vh;top:auto;bottom:0;left:0;right:0;
    border-left:0;border-top:1px solid var(--ec-border);
    border-radius:16px 16px 0 0;
    transform:translateY(100%)}
  body.ap-detail-open .ap-detail{transform:translateY(0)}
  .ap-mapwrap .legend{flex-wrap:wrap;font-size:11px;padding:10px 14px;gap:10px;left:12px;bottom:12px}

  /* SPRINT-6 location / poi */
  .poi-grid-4,.tour-grid-3,.artisan-grid-3{grid-template-columns:repeat(2,1fr)}
  .place-body{grid-template-columns:1fr;gap:40px}
  .place-body .gallery-grid{grid-template-columns:repeat(2,1fr);grid-template-rows:140px 140px}
  .guide-hero-grid{grid-template-columns:1fr;text-align:center;gap:20px;max-width:520px}
  .guide-hero-grid .photo{max-width:200px;margin:0 auto}

  /* SPRINT-7 contacts / partners / footer / forms */
  .contacts-grid{grid-template-columns:1fr}
  .partners-grid{grid-template-columns:repeat(2,1fr)}
  .partners-2col{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:0}
  .footer-brand{padding-bottom:32px;border-bottom:1px solid rgba(255,255,255,.1)}
  .footer-col{border-bottom:1px solid rgba(255,255,255,.1)}
  .footer-col[open]{padding-bottom:18px}
  .footer-col summary{cursor:pointer;pointer-events:auto;
    padding:18px 0;display:flex;align-items:center;justify-content:space-between;
    min-height:var(--touch)}
  .footer-col summary h6{margin:0}
  .footer-col summary::after{content:"+";font-size:22px;color:var(--ec-accent);font-weight:300;line-height:1}
  .footer-col[open] summary::after{content:"−"}
  .footer-col[open] ul{margin-top:6px}

  /* Inputs — anti-zoom on iOS, ensure ≥16px font */
  .input,input,select,textarea{font-size:max(16px,1rem)}

  /* Touch targets */
  .btn,button.btn,.faq-row{min-height:var(--touch)}
  .faq-row{padding:18px 0}

  /* Topbar — collapse second column */
  .doc-topbar-in{flex-direction:column;align-items:flex-start;gap:4px;padding:8px var(--gutter);font-size:13px}

}


/* ═════════════════════════════════════════════════════════════════════
   sm  ≤767.98px  — mobile portrait
   ───────────────────────────────────────────────────────────────────── */
@media (max-width:767.98px){

  /* SPRINT-4 home */
  .hero h1{font-size:48px}
  .hero .sub{font-size:16px;margin-bottom:24px}
  .hero .cta-row{flex-direction:column;align-items:stretch}
  .hero .cta-row .btn{width:100%;justify-content:center}
  .experiences-row{grid-template-columns:repeat(2,1fr)}
  .exp-item{padding:24px 18px;border-right:1px solid var(--ec-border)}
  .exp-item:nth-child(2n){border-right:0}
  .exp-item:nth-last-child(-n+2){border-bottom:0}
  .tours-grid,.reviews-grid,.blog-grid{grid-template-columns:1fr}
  .usp-row{grid-template-columns:1fr}
  .preview-row-6,.partner-grid-6{grid-template-columns:repeat(2,1fr)}
  .artisan-strip{grid-template-columns:repeat(2,1fr)}
  .cta-block{padding:48px 28px}
  .cta-block h2{font-size:36px}
  .cta-block p{font-size:18px}
  .about-split .copy h2{font-size:30px}

  /* SPRINT-5 single-tour */
  .tour-hero{min-height:380px}
  .tour-hero h1{font-size:36px}
  .tour-hero .sub{font-size:16px}
  .tour-hero .stat-strip{gap:20px}
  .tour-hero .stat-strip span b{font-size:20px}
  .tour-gallery{grid-template-columns:1fr}
  .highlights{grid-template-columns:1fr}
  .tours-archive{grid-template-columns:1fr}

  /* SPRINT-6 page-artisans / location / poi */
  .ap-mapwrap{height:55vh;min-height:380px}
  .ap-detail{height:85vh}
  .poi-grid-4,.tour-grid-3,.artisan-grid-3,.partner-grid-6,.artisan-strip{grid-template-columns:1fr}
  .artisan-gallery{grid-template-columns:repeat(2,1fr)}
  .card-grid-2{grid-template-columns:1fr}
  .place-body .gallery-grid{grid-template-columns:1fr;grid-template-rows:none;grid-auto-rows:200px}
  .place-body .gallery-grid > div{grid-column:auto !important;grid-row:auto !important}

  /* SPRINT-7 contacts / partners / footer */
  .partners-grid{grid-template-columns:1fr}
  .footer-grid{padding:0 var(--gutter)}
  .doc-header-in{padding:12px var(--gutter)}
  .brand-logo{max-height:36px;width:auto}

}


/* ═════════════════════════════════════════════════════════════════════
   xs  ≤575.98px  — small mobiles
   ───────────────────────────────────────────────────────────────────── */
@media (max-width:575.98px){

  /* SPRINT-5 single-tour */
  .tour-hero{min-height:340px}
  .tour-hero h1{font-size:30px}
  .tour-hero .stat-strip{gap:14px}
  .day-row .day-gallery{grid-template-columns:repeat(2,1fr)}
  .guide-card-grid{grid-template-columns:1fr;text-align:center;padding:20px;gap:14px}
  .form-2col{grid-template-columns:1fr}

  /* Sprint 10: shrink hero/page-hero on small phones to fit 568h viewport */
  .hero{min-height:480px}
  .page-hero{padding:48px var(--gutter) 36px}

  /* anchor: SPRINT-7 forms / footer */

}
