/* ==========================================================================
   Clinic & Store Locator Widget v3.1 — Frontend CSS
   By Damanlabs  |  10 layouts  |  Full mobile-first responsive
   ========================================================================== */

/* ── Reset ── */
.clw-wrapper,.clw-wrapper *{box-sizing:border-box;}
.clw-wrapper{width:100%;font-family:inherit;}

/* ════════════════════════════════════════════════════════════════════════════
   BUTTONS
   ════════════════════════════════════════════════════════════════════════════ */
.clw-buttons{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px;justify-content:center;align-items:center;}
.clw-btn{
  display:inline-flex;align-items:center;justify-content:center;
  cursor:pointer;border:2px solid transparent;
  font-family:inherit;font-size:14px;font-weight:700;line-height:1.4;
  padding:11px 22px;border-radius:8px;background:#1D9E75;color:#fff;
  transition:background .2s,color .2s,border-color .2s,transform .12s,opacity .2s;
  outline:none;white-space:nowrap;-webkit-appearance:none;touch-action:manipulation;
  -webkit-tap-highlight-color:transparent;
}
.clw-btn:hover{opacity:.86;transform:scale(.985);}
.clw-btn.clw-active{background:#0F6E56;border-color:#0F6E56;}
.clw-btn:focus-visible{box-shadow:0 0 0 3px rgba(29,158,117,.35);}

/* Tablet */
@media(max-width:1024px){
  .clw-btn{font-size:13px;padding:9px 18px;}
}
/* Mobile */
@media(max-width:767px){
  .clw-buttons{gap:7px;margin-bottom:14px;}
  .clw-btn{font-size:13px;padding:9px 14px;}
}

/* ════════════════════════════════════════════════════════════════════════════
   MAP
   ════════════════════════════════════════════════════════════════════════════ */
.clw-map-panel{width:100%;overflow:hidden;border-radius:10px;}
.clw-map-frame{display:none;width:100%;height:420px;position:relative;overflow:hidden;}
.clw-map-frame.clw-map-active{display:block;}
.clw-map-iframe{display:block;width:100%;height:100%;border:0;background:#f0f0ee;}
@media(max-width:1024px){.clw-map-frame{height:340px;}.clw-map-iframe{height:340px;}}
@media(max-width:767px) {.clw-map-frame{height:260px;}.clw-map-iframe{height:260px;}}

/* ── Placeholder ── */
.clw-placeholder{width:100%;height:100%;min-height:160px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:#f7f7f5;color:#aaa;font-size:13px;text-align:center;padding:24px;}
.clw-placeholder--error{background:#fff8f3;color:#c05a20;}
.clw-placeholder p{margin:0;max-width:260px;line-height:1.5;}

/* ════════════════════════════════════════════════════════════════════════════
   INFO CARD
   ════════════════════════════════════════════════════════════════════════════ */
.clw-info-card{background:#fff;border-top:1px solid #e5e5e5;padding:22px 26px;}
.clw-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 28px;}
.clw-info-cell{display:flex;flex-direction:column;gap:4px;}
.clw-info-cell--full{grid-column:1/-1;}
.clw-info-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#888780;}
.clw-info-value{font-size:14px;font-weight:500;color:#2c2c2a;text-decoration:none;word-break:break-word;line-height:1.45;}
a.clw-info-value:hover{text-decoration:underline;color:#1D9E75;}

/* Tablet info */
@media(max-width:1024px){
  .clw-info-card{padding:18px 20px;}
  .clw-info-grid{gap:12px 20px;}
}
/* Mobile info — single column */
@media(max-width:767px){
  .clw-info-card{padding:14px;}
  .clw-info-grid{grid-template-columns:1fr;gap:10px;}
}

/* ── Status badge ── */
.clw-status{display:inline-block;font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;line-height:1.5;}
.clw-status-open{background:#EAF3DE;color:#3B6D11;}
.clw-status-closed{background:#FCEBEB;color:#A32D2D;}
.clw-status-appointment{background:#FAEEDA;color:#854F0B;}

/* ── Directions button ── */
.clw-dir-wrap{margin-top:16px;padding-top:14px;border-top:1px solid #e5e5e5;display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.clw-dir-btn{display:inline-flex;align-items:center;gap:7px;padding:10px 20px;background:#1D9E75;color:#fff;border:none;border-radius:7px;font-size:13px;font-weight:700;font-family:inherit;text-decoration:none;cursor:pointer;transition:background .2s,transform .12s;white-space:nowrap;touch-action:manipulation;-webkit-tap-highlight-color:transparent;}
.clw-dir-btn:hover{background:#0F6E56;transform:scale(.98);color:#fff;}
/* Full-width on mobile */
@media(max-width:767px){
  .clw-dir-wrap{flex-direction:column;align-items:stretch;}
  .clw-dir-btn{width:100%;justify-content:center;padding:12px 16px;font-size:14px;}
}

/* ── Credit ── */
.clw-credit{margin-top:8px;font-size:10px;color:#ccc;text-align:right;}
.clw-credit a{color:#1D9E75;text-decoration:none;font-weight:600;}
.clw-credit a:hover{text-decoration:underline;}

/* ════════════════════════════════════════════════════════════════════════════
   LAYOUT 2 — SPLIT SCREEN
   ════════════════════════════════════════════════════════════════════════════ */
.clw-layout-split .clw-split-wrap{display:grid;grid-template-columns:1fr 1fr;overflow:hidden;border-radius:10px;border:1px solid #e5e5e5;}
.clw-layout-split .clw-map-col{height:420px;overflow:hidden;}
.clw-layout-split .clw-map-col .clw-map-panel{height:100%;border-radius:0;}
.clw-layout-split .clw-map-col .clw-map-frame{height:100%;}
.clw-layout-split .clw-info-col{display:flex;flex-direction:column;overflow-y:auto;background:#fff;}
.clw-layout-split .clw-info-col .clw-buttons{padding:18px 18px 0;margin-bottom:0;justify-content:flex-start;}
.clw-layout-split .clw-info-col .clw-info-card{flex:1;border-top:1px solid #e5e5e5;}
/* Tablet: narrow sidebar */
@media(max-width:1024px){
  .clw-layout-split .clw-split-wrap{grid-template-columns:1fr 300px;}
  .clw-layout-split .clw-map-col{height:340px;}
}
/* Mobile: stack */
@media(max-width:767px){
  .clw-layout-split .clw-split-wrap{grid-template-columns:1fr;}
  .clw-layout-split .clw-map-col{height:260px;}
  .clw-layout-split .clw-info-col .clw-buttons{justify-content:center;}
}

/* ════════════════════════════════════════════════════════════════════════════
   LAYOUT 3 — OVERLAP CARD
   ════════════════════════════════════════════════════════════════════════════ */
.clw-layout-overlap .clw-overlap-wrap{position:relative;}
.clw-layout-overlap .clw-map-area{height:420px;overflow:hidden;border-radius:12px;}
.clw-layout-overlap .clw-map-area .clw-map-panel{height:100%;border-radius:0;}
.clw-layout-overlap .clw-map-area .clw-map-frame{height:100%;}
.clw-layout-overlap .clw-overlap-card{position:relative;margin:-70px auto 0;max-width:500px;background:#fff;border-radius:14px;box-shadow:0 10px 36px rgba(0,0,0,.14);z-index:2;}
.clw-layout-overlap .clw-overlap-card .clw-info-card{border-top:none;border-radius:14px;}
@media(max-width:1024px){.clw-layout-overlap .clw-map-area{height:340px;}.clw-layout-overlap .clw-overlap-card{margin:-50px auto 0;max-width:90%;}}
@media(max-width:767px){.clw-layout-overlap .clw-map-area{height:220px;}.clw-layout-overlap .clw-overlap-card{margin:-30px 12px 0;}}

/* ════════════════════════════════════════════════════════════════════════════
   LAYOUT 4 — SIDEBAR
   ════════════════════════════════════════════════════════════════════════════ */
.clw-layout-sidebar .clw-sidebar-wrap{display:grid;grid-template-columns:290px 1fr;overflow:hidden;border-radius:10px;border:1px solid #e5e5e5;}
.clw-layout-sidebar .clw-sidebar-col{display:flex;flex-direction:column;background:#f9f9f7;border-right:1px solid #e5e5e5;overflow-y:auto;}
.clw-layout-sidebar .clw-sidebar-col .clw-buttons{flex-direction:column;padding:14px;gap:7px;margin-bottom:0;}
.clw-layout-sidebar .clw-sidebar-col .clw-btn{width:100%;text-align:left;justify-content:flex-start;font-size:13px;padding:9px 14px;}
.clw-layout-sidebar .clw-sidebar-col .clw-info-card{flex:1;border-top:1px solid #e5e5e5;}
.clw-layout-sidebar .clw-map-col{overflow:hidden;}
.clw-layout-sidebar .clw-map-col .clw-map-panel{height:100%;min-height:420px;border-radius:0;}
.clw-layout-sidebar .clw-map-col .clw-map-frame{height:100%;min-height:420px;}
/* Tablet: smaller sidebar */
@media(max-width:1024px){
  .clw-layout-sidebar .clw-sidebar-wrap{grid-template-columns:240px 1fr;}
  .clw-layout-sidebar .clw-map-col .clw-map-panel,.clw-layout-sidebar .clw-map-col .clw-map-frame{min-height:340px;}
}
/* Mobile: stack */
@media(max-width:767px){
  .clw-layout-sidebar .clw-sidebar-wrap{grid-template-columns:1fr;}
  .clw-layout-sidebar .clw-sidebar-col .clw-buttons{flex-direction:row;flex-wrap:wrap;padding:12px;}
  .clw-layout-sidebar .clw-sidebar-col .clw-btn{width:auto;}
  .clw-layout-sidebar .clw-map-col .clw-map-panel,.clw-layout-sidebar .clw-map-col .clw-map-frame{min-height:260px;}
}

/* ════════════════════════════════════════════════════════════════════════════
   LAYOUT 5 — DRAWER
   ════════════════════════════════════════════════════════════════════════════ */
.clw-layout-drawer .clw-map-area{position:relative;overflow:hidden;border-radius:12px;}
.clw-layout-drawer .clw-map-area .clw-map-panel,.clw-layout-drawer .clw-map-area .clw-map-frame{height:100%;border-radius:0;}
.clw-layout-drawer .clw-drawer-panel{position:absolute;bottom:0;left:0;right:0;background:#fff;border-radius:16px 16px 0 0;box-shadow:0 -4px 24px rgba(0,0,0,.13);transform:translateY(calc(100% - 48px));transition:transform .35s cubic-bezier(.4,0,.2,1);z-index:3;max-height:80%;}
.clw-layout-drawer .clw-drawer-panel.clw-drawer-open{transform:translateY(0);}
.clw-layout-drawer .clw-drawer-handle{height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;user-select:none;touch-action:manipulation;}
.clw-layout-drawer .clw-drawer-handle span{display:block;width:40px;height:4px;background:#ddd;border-radius:4px;transition:background .2s;}
.clw-layout-drawer .clw-drawer-handle:hover span,.clw-layout-drawer .clw-drawer-panel.clw-drawer-open .clw-drawer-handle span{background:#aaa;}
.clw-layout-drawer .clw-info-card{border-top:none;max-height:calc(80vh - 48px);overflow-y:auto;}
@media(max-width:767px){
  .clw-layout-drawer .clw-drawer-panel{max-height:70%;}
}

/* ════════════════════════════════════════════════════════════════════════════
   LAYOUT 6 — FULLSCREEN HERO
   ════════════════════════════════════════════════════════════════════════════ */
.clw-layout-fullscreen .clw-map-area{position:relative;overflow:hidden;border-radius:12px;}
.clw-layout-fullscreen .clw-map-area .clw-map-panel,.clw-layout-fullscreen .clw-map-area .clw-map-frame{height:100%;border-radius:0;}
.clw-layout-fullscreen .clw-fs-badge{position:absolute;top:16px;left:16px;width:260px;max-height:calc(100% - 32px);overflow-y:auto;background:#fff;border-radius:12px;box-shadow:0 4px 20px rgba(0,0,0,.18);z-index:3;}
.clw-layout-fullscreen .clw-fs-badge .clw-info-card{border-top:none;padding:14px 16px;border-radius:12px;}
.clw-layout-fullscreen .clw-buttons{margin-bottom:14px;}
@media(max-width:1024px){
  .clw-layout-fullscreen .clw-fs-badge{width:220px;}
}
@media(max-width:767px){
  .clw-layout-fullscreen .clw-fs-badge{
    width:calc(100% - 20px);top:auto;bottom:10px;left:10px;
    max-height:45%;overflow-y:auto;
  }
}

/* ════════════════════════════════════════════════════════════════════════════
   LAYOUT 7 — PILL NAV
   ════════════════════════════════════════════════════════════════════════════ */
.clw-layout-pillnav .clw-pillnav-wrap{}
.clw-layout-pillnav .clw-map-area{overflow:hidden;border-radius:12px 12px 0 0;}
.clw-layout-pillnav .clw-map-area .clw-map-panel,.clw-layout-pillnav .clw-map-area .clw-map-frame{border-radius:0;height:100%;}
.clw-layout-pillnav .clw-buttons{margin:0;padding:10px 12px;justify-content:center;background:#f9f9f7;border-left:1px solid #e5e5e5;border-right:1px solid #e5e5e5;}
.clw-layout-pillnav .clw-buttons--pills .clw-btn{border-radius:50px;padding:8px 18px;font-size:13px;}
.clw-layout-pillnav .clw-info-card{border-radius:0 0 12px 12px;border:1px solid #e5e5e5;border-top:none;}
@media(max-width:767px){
  .clw-layout-pillnav .clw-buttons{overflow-x:auto;flex-wrap:nowrap;justify-content:flex-start;padding:10px;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;}
  .clw-layout-pillnav .clw-buttons--pills .clw-btn{flex-shrink:0;scroll-snap-align:start;}
}

/* ════════════════════════════════════════════════════════════════════════════
   LAYOUT 8 — GRID CARDS
   ════════════════════════════════════════════════════════════════════════════ */
.clw-layout-gridcards .clw-loc-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:16px;}
.clw-loc-card{background:#fff;border:2px solid #e5e5e5;border-radius:12px;padding:16px;cursor:pointer;transition:border-color .2s,box-shadow .2s,transform .15s;display:flex;flex-direction:column;gap:7px;touch-action:manipulation;}
.clw-loc-card:hover,.clw-loc-card:focus{border-color:#1D9E75;box-shadow:0 4px 16px rgba(29,158,117,.12);transform:translateY(-2px);outline:none;}
.clw-loc-card.clw-active{border-color:#1D9E75;box-shadow:0 4px 20px rgba(29,158,117,.18);}
.clw-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;}
.clw-card-name{font-size:14px;font-weight:700;color:#2c2c2a;line-height:1.3;}
.clw-card-addr,.clw-card-hours{font-size:12px;color:#888;line-height:1.4;}
.clw-card-dir{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;color:#1D9E75;text-decoration:none;margin-top:4px;}
.clw-card-dir:hover{text-decoration:underline;}
@media(max-width:1024px){.clw-layout-gridcards .clw-loc-cards{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));}}
@media(max-width:767px) {.clw-layout-gridcards .clw-loc-cards{grid-template-columns:1fr 1fr;gap:8px;}}
@media(max-width:440px) {.clw-layout-gridcards .clw-loc-cards{grid-template-columns:1fr;}}

/* ════════════════════════════════════════════════════════════════════════════
   LAYOUT 9 — TABBED PANEL
   ════════════════════════════════════════════════════════════════════════════ */
.clw-layout-tabbed .clw-tabbed-wrap{border:1px solid #e5e5e5;border-radius:12px;overflow:hidden;}
.clw-tab-strip{display:flex;flex-wrap:nowrap;background:#f5f5f3;border-bottom:1px solid #e5e5e5;overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;}
.clw-tab-btn{flex-shrink:0;background:transparent;border:none;border-right:1px solid #e5e5e5;padding:12px 16px;font-size:13px;font-weight:600;color:#888;cursor:pointer;font-family:inherit;transition:background .2s,color .2s;white-space:nowrap;scroll-snap-align:start;touch-action:manipulation;-webkit-tap-highlight-color:transparent;}
.clw-tab-btn:last-child{border-right:none;}
.clw-tab-btn:hover{background:#eee;color:#2c2c2a;}
.clw-tab-btn.clw-active{background:#fff;color:#1D9E75;border-bottom:2px solid #1D9E75;margin-bottom:-1px;}
.clw-tab-panel{display:none;}
.clw-tab-panel.clw-map-active{display:block;}
.clw-tab-panel .clw-map-iframe{height:320px;}
.clw-tab-panel .clw-placeholder{height:320px;}
.clw-tab-panel .clw-info-card{border-top:1px solid #e5e5e5;}
@media(max-width:1024px){.clw-tab-panel .clw-map-iframe,.clw-tab-panel .clw-placeholder{height:260px;}}
@media(max-width:767px) {.clw-tab-panel .clw-map-iframe,.clw-tab-panel .clw-placeholder{height:220px;}.clw-tab-btn{padding:10px 12px;font-size:12px;}}

/* ════════════════════════════════════════════════════════════════════════════
   LAYOUT 10 — MINIMAL FLOATING
   ════════════════════════════════════════════════════════════════════════════ */
.clw-layout-floating .clw-map-area{position:relative;overflow:hidden;border-radius:12px;}
.clw-layout-floating .clw-map-area .clw-map-panel,.clw-layout-floating .clw-map-area .clw-map-frame{height:100%;border-radius:0;}
.clw-float-card{position:absolute;top:14px;right:14px;width:220px;background:#fff;border-radius:12px;box-shadow:0 4px 22px rgba(0,0,0,.18);padding:14px 16px;z-index:3;display:flex;flex-direction:column;gap:7px;}
.clw-float-dots{display:flex;gap:7px;align-items:center;}
.clw-float-dot{width:12px!important;height:12px!important;border-radius:50%!important;padding:0!important;background:#ddd!important;border:2px solid #ddd!important;min-width:0;flex-shrink:0;transition:background .2s,border-color .2s;}
.clw-float-dot.clw-active{background:#1D9E75!important;border-color:#1D9E75!important;}
.clw-float-name{font-size:14px;font-weight:700;color:#2c2c2a;line-height:1.3;}
.clw-float-addr{font-size:11px;color:#888;line-height:1.4;}
.clw-float-row{display:flex;align-items:center;justify-content:space-between;gap:6px;flex-wrap:wrap;}
.clw-float-dir{padding:5px 10px!important;font-size:11px!important;border-radius:6px!important;}
.clw-float-phone{font-size:12px;}
@media(max-width:1024px){.clw-float-card{width:200px;}}
@media(max-width:767px){
  .clw-float-card{
    width:calc(100% - 20px);top:auto;bottom:10px;
    right:10px;left:10px;flex-direction:row;flex-wrap:wrap;padding:10px 12px;gap:6px;
    border-radius:10px;
  }
  .clw-float-name{font-size:13px;flex:1 0 60%;}
  .clw-float-addr{font-size:11px;flex:1 0 100%;}
}
