/*
 * SBC Standalone CSS Pack v1.0
 * Complete design system to replace TownHub theme styling when disabled.
 * ──────────────────────────────────────────────────────────────────────
 */

:root {
  --sbc-primary:#4DB7FE;
  --sbc-primary-dark:#3da5e8;
  --sbc-accent:#5ecfb1;
  --sbc-accent-dark:#4db89d;
  --sbc-title:#334e6f;
  --sbc-text:#566985;
  --sbc-muted:#7d93b2;
  --sbc-border:#e5e7f2;
  --sbc-border-light:#f0f0f0;
  --sbc-bg:#f5f6fa;
  --sbc-bg-soft:#f8fafc;
  --sbc-warn:#f59e0b;
  --sbc-error:#e8734a;
  --sbc-purple:#8b5cf6;
  --sbc-radius:12px;
  --sbc-radius-sm:8px;
  --sbc-radius-lg:16px;
  --sbc-shadow:0 4px 20px rgba(0,0,0,.06);
  --sbc-shadow-lg:0 10px 40px rgba(0,0,0,.1);
  --sbc-transition:all .2s ease;
}

/* ═══ BASE & RESET ═══ */
.sbc-standalone *,
.sbc-standalone *::before,
.sbc-standalone *::after{box-sizing:border-box}

.sbc-standalone{
  color:var(--sbc-text);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen,sans-serif;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

.sbc-standalone h1,.sbc-standalone h2,.sbc-standalone h3,.sbc-standalone h4,.sbc-standalone h5{
  color:var(--sbc-title);
  font-weight:800;
  line-height:1.3;
  margin-top:0;
}

.sbc-standalone p{margin:0 0 14px}
.sbc-standalone a{color:var(--sbc-primary);text-decoration:none;transition:color .15s}
.sbc-standalone a:hover{color:var(--sbc-primary-dark)}
.sbc-standalone img{max-width:100%;height:auto;display:block}

/* ═══ LAYOUT ═══ */
.sbc-container{max-width:1280px;margin:0 auto;padding:0 20px}
.sbc-container-sm{max-width:720px;margin:0 auto;padding:0 20px}
.sbc-container-md{max-width:960px;margin:0 auto;padding:0 20px}

.sbc-page{padding:30px 0;min-height:50vh}

.sbc-grid{display:grid;gap:20px}
.sbc-grid-2{grid-template-columns:repeat(2,1fr)}
.sbc-grid-3{grid-template-columns:repeat(3,1fr)}
.sbc-grid-4{grid-template-columns:repeat(4,1fr)}
.sbc-grid-auto{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}

/* ═══ CARDS ═══ */
.sbc-card{
  background:#fff;
  border:1px solid var(--sbc-border);
  border-radius:var(--sbc-radius);
  padding:20px;
  transition:var(--sbc-transition);
}

.sbc-card.hover:hover{
  transform:translateY(-3px);
  box-shadow:var(--sbc-shadow);
  border-color:var(--sbc-primary);
}

.sbc-card-img{
  margin:-20px -20px 16px;
  aspect-ratio:16/10;
  background:var(--sbc-bg);
  background-size:cover;
  background-position:center;
  border-radius:var(--sbc-radius) var(--sbc-radius) 0 0;
}

/* ═══ BUTTONS ═══ */
.sbc-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:11px 22px;
  background:var(--sbc-primary);
  color:#fff;
  border:0;
  border-radius:var(--sbc-radius-sm);
  font-weight:700;
  font-size:14px;
  cursor:pointer;
  text-decoration:none;
  transition:var(--sbc-transition);
}

.sbc-btn:hover{background:var(--sbc-primary-dark);color:#fff;transform:translateY(-1px)}
.sbc-btn-outline{background:transparent;color:var(--sbc-text);border:1px solid var(--sbc-border)}
.sbc-btn-outline:hover{background:var(--sbc-bg-soft);color:var(--sbc-primary)}
.sbc-btn-accent{background:var(--sbc-accent)}
.sbc-btn-accent:hover{background:var(--sbc-accent-dark)}
.sbc-btn-sm{padding:7px 14px;font-size:12px}
.sbc-btn-lg{padding:14px 28px;font-size:15px}

/* ═══ BADGES ═══ */
.sbc-badge{
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:3px 10px;
  background:var(--sbc-bg);
  color:var(--sbc-text);
  border-radius:20px;
  font-size:11px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.5px;
}

.sbc-badge-primary{background:var(--sbc-primary);color:#fff}
.sbc-badge-accent{background:var(--sbc-accent);color:#fff}
.sbc-badge-warn{background:var(--sbc-warn);color:#fff}
.sbc-badge-error{background:var(--sbc-error);color:#fff}
.sbc-badge-purple{background:var(--sbc-purple);color:#fff}

/* ═══ FORMS ═══ */
.sbc-form label{
  display:block;
  font-weight:600;
  color:var(--sbc-title);
  font-size:12px;
  margin-bottom:5px;
}

.sbc-form input[type=text],
.sbc-form input[type=email],
.sbc-form input[type=tel],
.sbc-form input[type=url],
.sbc-form input[type=number],
.sbc-form input[type=search],
.sbc-form input[type=password],
.sbc-form input[type=date],
.sbc-form input[type=time],
.sbc-form input[type=datetime-local],
.sbc-form textarea,
.sbc-form select{
  width:100%;
  padding:10px 12px;
  border:1px solid var(--sbc-border);
  border-radius:var(--sbc-radius-sm);
  font-size:14px;
  background:#fff;
  color:var(--sbc-text);
  font-family:inherit;
  transition:border-color .15s,box-shadow .15s;
}

.sbc-form input:focus,
.sbc-form textarea:focus,
.sbc-form select:focus{
  outline:none;
  border-color:var(--sbc-primary);
  box-shadow:0 0 0 3px rgba(77,183,254,.15);
}

.sbc-form textarea{resize:vertical;min-height:100px}
.sbc-form .sbc-field{margin-bottom:14px}
.sbc-form .sbc-field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* ═══ LISTING CARDS (for archive/grid views) ═══ */
.sbc-listing-card{
  background:#fff;
  border:1px solid var(--sbc-border);
  border-radius:var(--sbc-radius);
  overflow:hidden;
  transition:var(--sbc-transition);
}

.sbc-listing-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--sbc-shadow);
  border-color:var(--sbc-primary);
}

.sbc-listing-card-img{
  aspect-ratio:16/10;
  background-size:cover;
  background-position:center;
  background-color:var(--sbc-bg);
  position:relative;
}

.sbc-listing-card-badges{
  position:absolute;
  top:12px;
  left:12px;
  display:flex;
  gap:6px;
  flex-wrap:wrap;
}

.sbc-listing-card-fav{
  position:absolute;
  top:12px;
  right:12px;
  width:36px;
  height:36px;
  background:rgba(255,255,255,.92);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  color:var(--sbc-muted);
  border:0;
  transition:var(--sbc-transition);
}

.sbc-listing-card-fav:hover,.sbc-listing-card-fav.active{color:var(--sbc-error);background:#fff}

.sbc-listing-card-body{padding:16px}
.sbc-listing-card-title{font-size:16px;margin:0 0 4px;color:var(--sbc-title)}
.sbc-listing-card-meta{font-size:12px;color:var(--sbc-muted);margin-bottom:10px}
.sbc-listing-card-footer{display:flex;justify-content:space-between;align-items:center;font-size:13px}
.sbc-listing-card-rating{color:var(--sbc-warn);font-weight:700}
.sbc-listing-card-price{color:var(--sbc-title);font-weight:700}

/* ═══ ALERTS / NOTICES ═══ */
.sbc-alert{padding:12px 16px;border-radius:var(--sbc-radius-sm);font-size:13px;margin-bottom:14px;border:1px solid}
.sbc-alert-info{background:#eff6ff;color:#1e40af;border-color:#bfdbfe}
.sbc-alert-success{background:#dcfce7;color:#15803d;border-color:#86efac}
.sbc-alert-warn{background:#fef3c7;color:#92400e;border-color:#fcd34d}
.sbc-alert-error{background:#fee2e2;color:#991b1b;border-color:#fca5a5}

/* ═══ SECTIONS ═══ */
.sbc-section{background:#fff;border:1px solid var(--sbc-border);border-radius:var(--sbc-radius);margin-bottom:20px;overflow:hidden}
.sbc-section-header{padding:16px 22px;border-bottom:1px solid var(--sbc-border-light)}
.sbc-section-header h3{margin:0;font-size:17px;color:var(--sbc-title)}
.sbc-section-body{padding:22px}

/* ═══ PAGINATION ═══ */
.sbc-pagination{display:flex;justify-content:center;gap:6px;margin:30px 0}
.sbc-pagination a,.sbc-pagination span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:36px;
  height:36px;
  padding:0 10px;
  background:#fff;
  border:1px solid var(--sbc-border);
  border-radius:var(--sbc-radius-sm);
  color:var(--sbc-text);
  font-weight:600;
  font-size:13px;
  text-decoration:none;
}
.sbc-pagination a:hover{background:var(--sbc-bg-soft);border-color:var(--sbc-primary);color:var(--sbc-primary)}
.sbc-pagination .current{background:var(--sbc-primary);color:#fff;border-color:var(--sbc-primary)}

/* ═══ UTILITIES ═══ */
.sbc-text-center{text-align:center}
.sbc-text-muted{color:var(--sbc-muted)}
.sbc-text-primary{color:var(--sbc-primary)}
.sbc-text-accent{color:var(--sbc-accent)}
.sbc-text-error{color:var(--sbc-error)}
.sbc-text-warn{color:var(--sbc-warn)}

.sbc-mb-0{margin-bottom:0}
.sbc-mb-1{margin-bottom:8px}
.sbc-mb-2{margin-bottom:16px}
.sbc-mb-3{margin-bottom:24px}
.sbc-mb-4{margin-bottom:32px}

.sbc-mt-0{margin-top:0}
.sbc-mt-1{margin-top:8px}
.sbc-mt-2{margin-top:16px}
.sbc-mt-3{margin-top:24px}
.sbc-mt-4{margin-top:32px}

.sbc-flex{display:flex}
.sbc-flex-center{display:flex;align-items:center;justify-content:center}
.sbc-flex-between{display:flex;align-items:center;justify-content:space-between}
.sbc-gap-2{gap:8px}
.sbc-gap-3{gap:12px}
.sbc-gap-4{gap:16px}

/* ═══ RESPONSIVE BREAKPOINTS ═══ */
@media(max-width:1024px){
  .sbc-grid-4{grid-template-columns:repeat(3,1fr)}
}

@media(max-width:768px){
  .sbc-grid-3,.sbc-grid-4{grid-template-columns:repeat(2,1fr)}
  .sbc-grid-2{grid-template-columns:1fr}
  .sbc-form .sbc-field-row{grid-template-columns:1fr}
  .sbc-container{padding:0 14px}
}

@media(max-width:520px){
  .sbc-grid-3,.sbc-grid-4,.sbc-grid-auto{grid-template-columns:1fr}
}

/* ═══ ANIMATIONS ═══ */
@keyframes sbcFadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes sbcPulse{0%,100%{opacity:1}50%{opacity:.5}}

.sbc-fade-in{animation:sbcFadeIn .3s ease-out}
.sbc-pulse{animation:sbcPulse 1.5s infinite}

/* ═══════════════════════════════════════════════════════════════
   MOBILE OPTIMIZATION LAYER (v3 — 60% traffic priority)
   Standardized breakpoints:
   - ≥1200px : desktop
   - 900-1199 : tablet landscape
   - 600-899 : tablet portrait  
   - <600 : mobile
   ═══════════════════════════════════════════════════════════════ */

/* ─── Fluid typography (clamp for auto-scale) ─── */
:root{
  --sbc-fs-body:clamp(14px, 1.6vw, 16px);
  --sbc-fs-h1:clamp(22px, 4.5vw, 40px);
  --sbc-fs-h2:clamp(18px, 3vw, 28px);
  --sbc-fs-h3:clamp(16px, 2.2vw, 20px);
  --sbc-fs-small:clamp(11px, 1.3vw, 13px);
  --sbc-touch-min:44px; /* WCAG minimum tap target */
  --sbc-safe-bottom:env(safe-area-inset-bottom,0px);
}

/* ─── iOS zoom prevention: all inputs >= 16px ─── */
@media(max-width:899px){
  .sbc-standalone input[type="text"],
  .sbc-standalone input[type="email"],
  .sbc-standalone input[type="tel"],
  .sbc-standalone input[type="url"],
  .sbc-standalone input[type="password"],
  .sbc-standalone input[type="number"],
  .sbc-standalone input[type="search"],
  .sbc-standalone input[type="date"],
  .sbc-standalone textarea,
  .sbc-standalone select{
    font-size:16px!important;
  }
}

/* ─── Tablet (≤899px) ─── */
@media(max-width:899px){
  /* Grids collapse */
  .sbc-single-grid{grid-template-columns:1fr!important;gap:20px!important}
  .sbc-nearby-grid{grid-template-columns:repeat(2,1fr)!important}
  .sbc-container{padding:0 16px!important}
  
  /* Hero smaller */
  .sbc-single-hero{height:auto!important;min-height:320px!important;padding:24px 0 20px}
  .sbc-single-hero h1{font-size:clamp(22px,6vw,32px)!important;line-height:1.2!important}
  
  /* Cards padding reduced */
  .sbc-card,[class*="sbc-card"]{padding:16px!important;border-radius:12px!important}
  
  /* Section 2-col → 1-col */
  .sbc-section-2col{grid-template-columns:1fr!important}
  
  /* Tables overflow */
  .sbc-t,.sbc-section table{display:block;overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch}
  
  /* Section grids (Entrance&Reservations, Services, etc) */
  .sbc-section-body [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important;gap:8px!important}
}

/* ─── Mobile (≤599px) ─── */
@media(max-width:599px){
  /* Nearby 1 column */
  .sbc-nearby-grid{grid-template-columns:1fr!important}
  
  /* Hero compact */
  .sbc-single-hero{min-height:260px!important}
  .sbc-single-hero h1{font-size:26px!important}
  
  /* Gallery single col */
  .sbc-gal-grid{grid-template-columns:1fr!important;height:auto!important;gap:8px!important}
  .sbc-gal-grid > div:first-child{height:240px!important}
  .sbc-gal-grid > div:last-child{grid-template-rows:repeat(3,88px)!important}
  
  /* Touch-friendly buttons */
  .sbc-cta,.sbc-btn,.button,button[class*="sbc-"],a[class*="sbc-cta"]{
    min-height:var(--sbc-touch-min);
    padding:12px 20px!important;
    font-size:14px!important;
  }
  
  /* Footer stack */
  .sbc-footer-widgets{grid-template-columns:1fr!important;gap:24px!important}
  .sbc-footer-inner{padding:20px 16px!important}
  
  /* Page padding reduced */
  main.sbc-main,.sbc-standalone .sbc-page{padding:20px 0!important}
  
  /* Widget titles smaller */
  .sbc-widget-title{font-size:13px!important;padding:12px 14px!important}
  .sbc-widget-body{padding:12px 14px!important}
  
  /* Reviews form stack */
  .sbc-standalone form [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}
  
  /* Category badges wrap */
  .sbc-single-hero [style*="display:flex;gap:8px"]{gap:6px!important;flex-wrap:wrap}
  
  /* Tag pills smaller */
  .sbc-tag-pill{font-size:11px!important;padding:3px 8px!important}
}

/* ─── Small mobile (≤375px — iPhone SE, etc.) ─── */
@media(max-width:375px){
  .sbc-container{padding:0 12px!important}
  .sbc-card,[class*="sbc-card"]{padding:14px!important}
  .sbc-single-hero h1{font-size:22px!important}
  .sbc-widget{margin-bottom:12px!important}
}

/* ─── STICKY MOBILE CTA BAR (listings only) ─── */
.sbc-mobile-cta-bar{display:none}
@media(max-width:899px){
  .sbc-single-listing .sbc-mobile-cta-bar{
    display:flex;
    position:fixed;
    bottom:0;left:0;right:0;
    background:#fff;
    padding:10px 12px;
    padding-bottom:calc(10px + var(--sbc-safe-bottom));
    box-shadow:0 -4px 20px rgba(0,0,0,.12);
    z-index:9998;
    gap:8px;
    border-top:1px solid #e5e7f2;
  }
  .sbc-mobile-cta-bar a,.sbc-mobile-cta-bar button{
    flex:1;
    min-height:48px;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:6px;
    border-radius:10px;
    text-decoration:none;
    font-weight:600;
    font-size:13px;
    transition:transform .15s;
  }
  .sbc-mobile-cta-bar a:active,.sbc-mobile-cta-bar button:active{transform:scale(.97)}
  .sbc-mobile-cta-bar .sbc-m-call{background:#5ecfb1;color:#fff}
  .sbc-mobile-cta-bar .sbc-m-wa{background:#25D366;color:#fff}
  .sbc-mobile-cta-bar .sbc-m-web{background:#4DB7FE;color:#fff}
  .sbc-mobile-cta-bar .sbc-m-fav{background:#f5f6fa;color:#334e6f;border:1px solid #e5e7f2;flex:0 0 48px;padding:0}
  
  /* Push content up to not be hidden by bar */
  body.sbc-single-listing{padding-bottom:80px!important}
}

/* ─── Admin-bar safe spacing ─── */
@media(max-width:782px){
  body.admin-bar.sbc-single-listing .sbc-mobile-cta-bar{bottom:0}
}

/* ─── Hide on desktop ─── */
@media(min-width:900px){
  .sbc-mobile-only{display:none!important}
}
@media(max-width:899px){
  .sbc-desktop-only{display:none!important}
}

/* ─── Smooth tap feedback ─── */
@media(hover:none){
  .sbc-standalone a:active,.sbc-standalone button:active{opacity:.7;transition:opacity .05s}
}

/* ─── Prevent horizontal scroll ─── */
html,body{overflow-x:hidden;max-width:100%}
.sbc-standalone img,.sbc-standalone iframe{max-width:100%;height:auto}

/* ═══════════════════════════════════════════════════════════════
   SINGLE BEACH LISTING — MOBILE PRIORITY OPTIMIZATION
   Specifically targets /listing/* pages for the 60% mobile traffic
   ═══════════════════════════════════════════════════════════════ */

/* ─── HERO: fluid height + typography ─── */
.sbc-single-listing .sbc-single-hero{
  height:auto!important;
  min-height:clamp(260px, 40vw, 440px);
  display:flex;
  align-items:flex-end;
  padding:20px 0 24px;
}
.sbc-single-listing .sbc-single-hero h1{
  font-size:clamp(22px, 6vw, 40px)!important;
  line-height:1.15!important;
  margin:0 0 8px!important;
  word-break:break-word;
  hyphens:auto;
}
.sbc-single-listing .sbc-single-hero .sbc-container{padding:16px!important}

/* Category pills — wrap & compact on mobile */
.sbc-single-listing .sbc-single-hero a[style*="border-radius:20px"]{
  font-size:clamp(10px, 1.4vw, 12px)!important;
  padding:4px 10px!important;
}

/* Location row (Greece, Israel, Rhodos) */
.sbc-single-listing .sbc-single-hero [style*="font-size:14px"]{
  font-size:clamp(12px, 1.6vw, 14px)!important;
  gap:8px!important;
}

/* ─── MAIN CONTENT CONTAINER ─── */
.sbc-single-listing > .sbc-standalone > .sbc-container{padding:20px 16px!important}
@media(min-width:900px){
  .sbc-single-listing > .sbc-standalone > .sbc-container{padding:40px 20px!important}
}

/* ─── GALLERY: adaptive premium layout ─── */
@media(max-width:899px){
  .sbc-single-gallery{padding:10px!important;margin-bottom:16px!important;border-radius:12px!important}
  .sbc-single-gallery .sbc-gal-grid{
    grid-template-columns:1fr!important;
    height:auto!important;
    gap:8px!important;
  }
  .sbc-single-gallery .sbc-gal-grid > a:first-child{
    height:clamp(200px, 50vw, 320px)!important;
  }
  .sbc-single-gallery .sbc-gal-grid > div{
    grid-template-columns:repeat(3,1fr)!important;
    grid-template-rows:80px!important;
    gap:6px!important;
  }
  .sbc-single-gallery .sbc-gal-grid > div > a:nth-child(n+4){display:none}
  .sbc-single-gallery .sbc-gal-grid > div > a:nth-child(3){position:relative}
  /* "+N more" overlay repositioned */
  .sbc-gal-view-all{
    top:8px!important;right:8px!important;
    font-size:11px!important;padding:5px 10px!important;
    opacity:1!important;
  }
}

/* Photo count badge more visible on mobile */
@media(max-width:599px){
  .sbc-single-gallery .sbc-gal-grid > a:first-child > div{
    font-size:11px!important;padding:5px 10px!important;
  }
}

/* ─── ABOUT SECTION ─── */
@media(max-width:899px){
  .sbc-single-listing main > section{padding:18px!important;margin-bottom:16px!important;border-radius:12px!important}
  .sbc-single-listing main h2{font-size:clamp(18px, 3vw, 22px)!important;margin-top:0!important}
  .sbc-single-listing main p{font-size:clamp(14px, 1.7vw, 15px)!important;line-height:1.65!important}
}

/* ─── SBC SECTIONS (Beach Info, Pricing, etc.) ─── */
@media(max-width:899px){
  .sbc-section{border-radius:10px!important;overflow:hidden}
  .sbc-section-header h3{font-size:clamp(14px, 2vw, 16px)!important;padding:10px 14px!important}
  .sbc-section-header{padding:0!important}
  .sbc-section-body{padding:14px!important}
  .sbc-section-2col{grid-template-columns:1fr!important;gap:10px!important}
  
  /* Table → cards on mobile */
  .sbc-t{
    display:block!important;
    width:100%!important;
    border-collapse:collapse!important;
  }
  .sbc-t thead{display:none}
  .sbc-t tbody,.sbc-t tr{display:block;width:100%}
  .sbc-t tr{
    margin-bottom:8px;
    background:#f8fafc;
    border-radius:8px;
    padding:10px 12px;
    border:1px solid #e5e7f2;
  }
  .sbc-t td{
    display:flex;
    justify-content:space-between;
    align-items:center;
    padding:4px 0!important;
    border:0!important;
    font-size:13px;
  }
  .sbc-t .sbc-l{
    font-weight:600;
    color:#7d93b2;
    font-size:11px;
    text-transform:uppercase;
    letter-spacing:.3px;
  }
  .sbc-t .sbc-v{font-weight:600;color:#334e6f}
  
  /* Facts grid → stack / 2-col */
  .sbc-section-body [style*="grid-template-columns:1fr 1fr"]{
    grid-template-columns:1fr 1fr!important;
    gap:8px!important;
  }
  .sbc-section-body [style*="background:#f8fafc"][style*="border-radius:8px"]{
    padding:8px 10px!important;
  }
  .sbc-section-body [style*="font-size:11px"][style*="uppercase"]{font-size:10px!important}
  .sbc-section-body [style*="font-size:14px"][style*="font-weight:500"]{font-size:13px!important}
  
  /* CTAs stack on small mobile */
  .sbc-ctas{display:flex;flex-direction:column;gap:8px}
  .sbc-cta{width:100%;text-align:center;padding:12px 20px!important;font-size:14px!important}
}

@media(max-width:599px){
  .sbc-section-body [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}
}

/* ─── VISITOR REVIEWS ─── */
@media(max-width:899px){
  .sbc-standalone #sbc-rev-form-9463,
  .sbc-standalone form[id^="sbc-rev-form"]{padding:16px!important}
  .sbc-standalone form[id^="sbc-rev-form"] [style*="grid-template-columns:1fr 1fr"]{
    grid-template-columns:1fr!important;
  }
  /* Star rating bigger on mobile for easier tap */
  .sbc-rev-stars{font-size:32px!important}
  .sbc-rev-stars span{padding:0 4px;min-width:36px}
}

/* ─── NEARBY BEACH CLUBS — horizontal scroll on mobile ─── */
@media(max-width:899px){
  .sbc-nearby-grid{
    display:flex!important;
    overflow-x:auto;
    gap:12px!important;
    padding:4px 4px 12px;
    margin:0 -16px;
    padding-left:16px;
    padding-right:16px;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  .sbc-nearby-grid::-webkit-scrollbar{display:none}
  .sbc-nearby-grid > a{
    flex:0 0 260px;
    scroll-snap-align:start;
  }
}
@media(max-width:599px){
  .sbc-nearby-grid > a{flex:0 0 240px}
}

/* ─── SIDEBAR WIDGETS on mobile ─── */
@media(max-width:899px){
  /* Sidebar becomes full-width below main */
  .sbc-standalone > .sbc-container > div > aside{margin-top:0}
  
  /* Widget compact */
  .sbc-widget{border-radius:12px!important;margin-bottom:14px!important}
  .sbc-widget-title{padding:12px 16px!important;font-size:13px!important}
  .sbc-widget-body{padding:12px 16px!important}
  
  /* Contact list tighter */
  .sbc-contact-list li{font-size:13px!important;padding:10px 0!important}
  
  /* Weather widget compact */
  .sbc-widget-weather [style*="font-size:42px"]{font-size:34px!important}
  .sbc-widget-weather [style*="font-size:32px"]{font-size:26px!important}
  
  /* Sunrise widget compact */
  .sbc-widget-sunrise [style*="font-size:18px"]{font-size:16px!important}
  
  /* Socials row - fill width */
  .sbc-socials-row{flex-wrap:wrap;justify-content:space-between}
  .sbc-socials-row a{
    min-width:44px;min-height:44px;
    width:auto!important;height:44px!important;
    flex:1 1 auto;
    max-width:52px;
  }
}

/* ─── CONTACT FORM mobile ─── */
@media(max-width:899px){
  .sbc-contact-box{padding:16px!important;border-radius:12px!important;margin:16px 0!important}
  .sbc-contact-box h3{font-size:15px!important}
  .sbc-contact-box input,.sbc-contact-box textarea{padding:12px!important}
  .sbc-msg-form button[type="submit"]{
    width:100%;margin-top:8px;
    padding:14px 24px!important;
    font-size:14px!important;
  }
  .sbc-msg-form [style*="display:flex"][style*="space-between"]{flex-direction:column;gap:8px;align-items:stretch!important}
}

/* ─── CLAIM WIDGET mobile ─── */
@media(max-width:899px){
  .sbc-widget-claim{padding:16px!important}
  .sbc-widget-claim [style*="font-size:14px"]{font-size:13px!important}
  .sbc-widget-claim a{padding:10px 20px!important;font-size:11px!important;width:auto;display:inline-block}
}

/* ─── MAP widget mobile ─── */
@media(max-width:899px){
  .sbc-widget-location iframe,
  .sbc-widget iframe{height:200px!important;border-radius:8px}
  #sbc-single-map{height:200px!important}
}

/* ─── LEGAL DISCLAIMER tighter on mobile ─── */
@media(max-width:599px){
  .sbc-gallery-disclaimer [style*="padding:8px"]{padding:10px 12px!important;font-size:10px!important;line-height:1.5!important}
}

/* ─── IMAGES/IFRAMES always fluid ─── */
.sbc-single-listing img,
.sbc-single-listing iframe,
.sbc-single-listing video{
  max-width:100%;
  height:auto;
}

/* ─── Body spacing with sticky CTA bar ─── */
@media(max-width:899px){
  body.sbc-single-listing{padding-bottom:calc(76px + env(safe-area-inset-bottom,0px))!important}
}

/* ─── Scroll to top arrow on mobile listing ─── */
.sbc-scroll-top{
  display:none;
  position:fixed;
  bottom:calc(84px + env(safe-area-inset-bottom,0px));
  right:14px;
  width:44px;height:44px;
  border-radius:50%;
  background:rgba(255,255,255,.95);
  color:#334e6f;
  border:1px solid #e5e7f2;
  box-shadow:0 4px 12px rgba(0,0,0,.1);
  z-index:9997;
  font-size:16px;
  cursor:pointer;
  align-items:center;
  justify-content:center;
  transition:opacity .2s,transform .2s;
}
.sbc-scroll-top.show{display:flex}
.sbc-scroll-top:active{transform:scale(.9)}
@media(min-width:900px){.sbc-scroll-top{display:none!important}}

/* ═══════════════════════════════════════════════════════════════
   PERFORMANCE BOOSTERS — modern browsers
   ═══════════════════════════════════════════════════════════════ */

/* Defer rendering of below-fold sections (huge mobile perf gain) */
@supports (content-visibility: auto){
  .sbc-single-listing main > section:not(.sbc-single-gallery){
    content-visibility:auto;
    contain-intrinsic-size:auto 400px;
  }
  .sbc-nearby-wrap,
  .sbc-widget-weather,
  .sbc-widget-sunrise,
  .sbc-widget-instagram,
  .sbc-widget-location{
    content-visibility:auto;
    contain-intrinsic-size:auto 300px;
  }
}

/* Reduced motion: disable animations */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:.01ms!important;
    scroll-behavior:auto!important;
  }
}

/* Dark mode aware mobile CTA bar */
@media (prefers-color-scheme: dark){
  .sbc-mobile-cta-bar{background:#1f2937;border-top:1px solid #374151}
  .sbc-mobile-cta-bar .sbc-m-fav{background:#374151;color:#f3f4f6;border-color:#4b5563}
  .sbc-scroll-top{background:rgba(31,41,55,.95);color:#f3f4f6;border-color:#374151}
}

/* ─── Final mobile safety net ─── */
@media(max-width:899px){
  /* Ensure no element creates horizontal scroll */
  .sbc-single-listing *{max-width:100%!important;box-sizing:border-box}
  .sbc-single-listing pre,.sbc-single-listing code{overflow-x:auto}
  /* Sticky elements never overflow */
  .sbc-mobile-cta-bar,.sbc-scroll-top{max-width:100vw}
}

/* ─── Touch drag feedback for nearby carousel ─── */
@media(max-width:899px){
  .sbc-nearby-grid{
    cursor:grab;
    -webkit-user-drag:auto;
    scroll-padding-left:16px;
  }
  .sbc-nearby-grid:active{cursor:grabbing}
}
