.elementor-198 .elementor-element.elementor-element-59a90e8{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--flex-wrap:wrap;}.elementor-widget-text-editor{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );color:var( --e-global-color-text );}.elementor-widget-text-editor.elementor-drop-cap-view-stacked .elementor-drop-cap{background-color:var( --e-global-color-primary );}.elementor-widget-text-editor.elementor-drop-cap-view-framed .elementor-drop-cap, .elementor-widget-text-editor.elementor-drop-cap-view-default .elementor-drop-cap{color:var( --e-global-color-primary );border-color:var( --e-global-color-primary );}.elementor-198 .elementor-element.elementor-element-3246554{font-family:"Roboto", Sans-serif;font-size:1px;font-weight:400;color:var( --e-global-color-primary );width:var( --container-widget-width, 99.732% );max-width:99.732%;--container-widget-width:99.732%;--container-widget-flex-grow:0;}.elementor-198 .elementor-element.elementor-element-3246554 p{margin-block-end:0px;}.elementor-198 .elementor-element.elementor-element-3246554.elementor-element{--flex-grow:0;--flex-shrink:0;}.elementor-198 .elementor-element.elementor-element-9840f97{width:var( --container-widget-width, 100.431% );max-width:100.431%;--container-widget-width:100.431%;--container-widget-flex-grow:0;}.elementor-198 .elementor-element.elementor-element-9840f97.elementor-element{--flex-grow:0;--flex-shrink:0;}.elementor-widget-image .widget-image-caption{color:var( --e-global-color-text );font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );}.elementor-198 .elementor-element.elementor-element-3477adc{padding:29px 29px 14px 29px;}.elementor-198 .elementor-element.elementor-element-2f30e74{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-198 .elementor-element.elementor-element-cc2e5d9{color:#004773;margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;}/* Start custom CSS for text-editor, class: .elementor-element-3477adc *//* ==== Oceans Location Header — quick patch for your current structure ==== */
/* IDs from your snippet:
   Parent container: .elementor-element-59a90e8
   3 blue columns:   .elementor-element-73d2436, .elementor-element-2af7380, .elementor-element-37dda8d
   Image widget:     .elementor-element-f535251
*/

/* Layout + width */
.elementor-element-59a90e8{
  max-width:1240px; margin:0 auto; padding:28px 20px 0;
  gap:0 !important;                 /* remove spacing between columns */
  flex-wrap:wrap;                   /* let image break to next row */
}

/* Make the 3 blocks sit in one row, image below */
.elementor-element-73d2436,
.elementor-element-2af7380,
.elementor-element-37dda8d{ flex:0 0 33.333%; }
.elementor-element-f535251{ flex:0 0 100%; }

/* Blue bar styling (each block shares the same background) */
.elementor-element-73d2436,
.elementor-element-2af7380,
.elementor-element-37dda8d{
  background:#004773;               /* Deep Blue */
  color:#fff; text-align:center;
  padding:22px clamp(16px,3vw,28px);
  position:relative;
}

/* Rounded ends + shadow to read as one bar */
.elementor-element-73d2436{ border-radius:14px 0 0 14px; }
.elementor-element-37dda8d{ border-radius:0 14px 14px 0; }
.elementor-element-73d2436,
.elementor-element-2af7380,
.elementor-element-37dda8d{ box-shadow:0 16px 42px rgba(0,0,0,.18); }

/* Gold dividers */
.elementor-element-73d2436,
.elementor-element-2af7380{ border-right:1px solid rgba(217,200,146,.45); }

/* Typography inside (keeps your inline white but normalizes sizes) */
.elementor-element-59a90e8 h3,
.elementor-element-59a90e8 h4{ margin:0; line-height:1.25; }

/* Mobile stacking + horizontal dividers */
@media (max-width:899px){
  .elementor-element-73d2436,
  .elementor-element-2af7380,
  .elementor-element-37dda8d{
    flex:0 0 100%; border-radius:0 !important;
  }
  .elementor-element-73d2436,
  .elementor-element-2af7380{ border-right:none; border-bottom:1px solid rgba(217,200,146,.45); }
  .elementor-element-73d2436{ border-top-left-radius:14px; border-top-right-radius:14px; }
  .elementor-element-37dda8d{ border-bottom-left-radius:14px; border-bottom-right-radius:14px; }
}

/* Photo card under the bar */
.elementor-element-f535251{ 
  margin-top:18px; 
  border:1px solid #E6EDF3; 
  border-radius:14px; 
  overflow:hidden; 
  background:#D1ECFD; 
  position:relative;
  box-shadow:0 20px 48px rgba(0,0,0,.14);
}
/* thin gold rule */
.elementor-element-f535251:before{
  content:""; display:block; height:4px; background:#D9C892; width:100%;
}
.elementor-element-f535251 img{
  display:block; width:100%; height:clamp(220px,40vw,420px); object-fit:cover; object-position:center;
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-59a90e8 *//* ===== OCE: Location box ===== */
.oce-locbox{
  background:#004773; color:#fff; border-radius:14px;
  box-shadow:0 14px 36px rgba(0,0,0,.15);
  display:grid; gap:0; grid-template-columns:1fr; overflow:hidden; margin:0;
}
@media (min-width:900px){
  .oce-locbox{ grid-template-columns:1.05fr 1.9fr 1fr; }
}

/* Items (links) */
.oce-locbox .item{
  display:flex; align-items:center; gap:12px;
  padding:18px 22px; text-decoration:none; color:inherit; position:relative;
}
.oce-locbox .item:hover{ background:rgba(255,255,255,.06); }
.oce-locbox .item:focus-visible{ outline:3px solid #D9C892; outline-offset:-3px; }

/* Dividers */
@media (min-width:900px){
  .oce-locbox .item:not(:last-child){ border-right:1px solid rgba(217,200,146,.45); }
}
@media (max-width:899px){
  .oce-locbox .item:not(:last-child){ border-bottom:1px solid rgba(217,200,146,.45); }
}

/* Icon pill + Font Awesome */
.oce-locbox .icon-pill{
  width:40px; height:40px; border-radius:999px;
  background:rgba(0,102,164,.22);
  border:1px solid rgba(255,255,255,.18);
  display:grid; place-items:center; flex:0 0 auto;
}
.oce-locbox i{ color:#fff; font-size:18px; line-height:1; }

/* Text */
.oce-locbox .text strong{ font-weight:700; color:#fff; }
.oce-locbox .sub{ display:block; opacity:.95; }

/* Optional thin top rule above next section */
/*
.oce-locbox + *::before{ content:""; display:block; height:4px; background:#D9C892; }
*//* End custom CSS */
/* Start custom CSS for text-editor, class: .elementor-element-cc2e5d9 *//* ===== Oceans Behavioral Hospital — universal location styles ===== */
.obh-location { 
  --radius: 16px;
  --pad: clamp(16px,3vw,28px);
  --gap: clamp(14px,2vw,22px);
  --ring: 0 12px 36px rgba(0,0,0,.08);
  --muted: #f6f8fb;
  --accent: #0e3e6e;      /* brand accent */
  --accent-ink: #fff;     /* text on accent */
  --hero-bg: none;        /* per-page: url('…/image.webp') */
  color: inherit;
}

/* Typographic safety: prevent ugly word breaks from themes */
.obh-location h1,
.obh-location h2,
.obh-location h3{
  word-break: keep-all;
  overflow-wrap: normal;
  hyphens: none;
}

/* Layout helpers */
.obh-location .wrap{ max-width:1800px; margin:0 auto; padding:0 var(--pad); }
.obh-location .grid{ display:grid; gap:var(--gap); }

/* ---------- HERO ---------- */
.obh-location .hero{
  color:#0c2239;
  background:
    linear-gradient(180deg, rgba(255,255,255,.85), rgba(255,255,255,.96)),
    var(--hero-bg);
  background-size: cover; background-position: center;
  border:1px solid rgba(0,0,0,.06);
  border-radius: var(--radius);
  box-shadow: var(--ring);
  padding: clamp(22px,5vw,48px) 0;
}
.obh-location h1{ margin:.1em 0 .4em; line-height:1.1; font-size:clamp(28px,4.8vw,44px); }
.obh-location .lead{ font-size:clamp(16px,2.2vw,20px); margin:0; max-width:70ch; }
.obh-location .badges{ display:flex; flex-wrap:wrap; gap:10px; margin:18px 0 0; padding:0; list-style:none; }
.obh-location .badges li{
  border:1px solid rgba(0,0,0,.08); border-radius:999px; padding:.5em .9em; background:#fff; 
  box-shadow:0 6px 16px rgba(0,0,0,.05); font-size:14px; white-space:nowrap;
}

/* ---------- INFO STRIP (iconized) ---------- */
.obh-location .infostrip{ background: var(--muted); padding: clamp(18px,3vw,26px) 0; margin-top: clamp(18px,4vw,28px); }
.obh-location .strip-grid{ display:grid; gap: var(--gap); grid-template-columns: repeat(auto-fit,minmax(260px,1fr)); }
.obh-location .strip-item{
  display:flex; gap:12px; align-items:flex-start;
  background:#fff; border:1px solid rgba(0,0,0,.06); border-radius:14px; padding:16px 18px; 
  box-shadow:0 10px 24px rgba(0,0,0,.06);
}
.obh-location .strip-title{ display:block; font-weight:600; margin:0 0 .35em; }
.obh-location .strip-item .icon{
  width:38px; height:38px; border-radius:10px; display:grid; place-items:center;
  background: var(--accent); color: var(--accent-ink);
  box-shadow:0 8px 18px rgba(14,62,110,.25); flex:0 0 auto;
}

/* ---------- SECTIONS ---------- */
.obh-location .section{ margin-top: clamp(26px,6vw,56px); }
.obh-location .section.muted{ background: var(--muted); padding: clamp(18px,3.5vw,28px) 0; border-radius: 16px; }
.obh-location .section > .wrap > h2{
  font-size:clamp(22px,3vw,28px); margin:0 0 .6em; line-height:1.2; position:relative; display:inline-block; padding-bottom:.25em;
  color: var(--accent);
}
.obh-location .section > .wrap > h2:after{
  content:""; position:absolute; left:0; right:0; bottom:0; height:3px;
  background: linear-gradient(90deg, currentColor 0%, transparent 70%); opacity:.3;
}
.obh-location .eyebrow{ margin:-.25em 0 1.2em; color:rgba(0,0,0,.65); font-size:clamp(15px,2vw,18px); }

/* ---------- CARDS (Programs) ---------- */
.obh-location .grid.cards{ grid-template-columns: repeat(auto-fit, minmax(260px,1fr)); }
.obh-location .card{
  background:#fff; border:1px solid rgba(0,0,0,.06); border-radius:14px; padding:18px;
  box-shadow: var(--ring); transition: transform .18s ease, box-shadow .18s ease;
}
.obh-location .card:hover{ transform: translateY(-2px); box-shadow:0 18px 42px rgba(0,0,0,.10); }
.obh-location .card h3{
  margin:.1em 0 .25em; font-size:clamp(16px,2.2vw,20px); line-height:1.25;
  word-break: keep-all; overflow-wrap: normal; hyphens: none;
}
.obh-location .card .meta{ margin:0 0 .5em; font-size:13px; opacity:.7; }

/* ---------- FEATURES (Expectations) ---------- */
.obh-location .grid.features{ grid-template-columns: repeat(auto-fit, minmax(260px,1fr)); }
.obh-location .features .feature{
  display:flex; align-items:flex-start; gap:.6em; background:#fff; border:1px solid rgba(0,0,0,.06);
  padding:14px 16px; border-radius:12px; box-shadow:0 6px 16px rgba(0,0,0,.05);
}
.obh-location .tick{
  display:inline-grid; place-items:center; width:22px; height:22px; border-radius:999px;
  border:1px solid rgba(0,0,0,.15); font-size:13px; line-height:1;
  background: radial-gradient(circle at 30% 30%, #fff, rgba(0,0,0,.02));
}

/* ---------- PILL LIST (Conditions) ---------- */
.obh-location .pill-list{ list-style:none; padding:0; margin:0; display:flex; flex-wrap:wrap; gap:10px; }
.obh-location .pill-list li{
  background:#fff; border:1px solid rgba(0,0,0,.08); border-radius:999px; padding:.45em .85em;
  box-shadow:0 6px 16px rgba(0,0,0,.05); font-size:14px;
}

/* ---------- CTA ---------- */
.obh-location .cta{ margin-top: clamp(28px,6vw,60px); }
.obh-location .cta .cta-box{
  position:relative; padding:clamp(18px,3vw,28px); border-radius:18px;
  background: linear-gradient(180deg, #ffffff, rgba(240,247,255,.85));
  border:1px solid rgba(0,0,0,.06); box-shadow:0 20px 50px rgba(0,0,0,.10);
}
.obh-location .cta .cta-box:before{
  content:""; position:absolute; inset:-1px; border-radius:18px;
  background: linear-gradient(90deg, currentColor, transparent 60%); opacity:.10; z-index:0;
}
.obh-location .cta .cta-box > *{ position:relative; z-index:1; }
.obh-location .cta h2{ margin:0 0 .25em; }

/* Buttons */
.obh-location .cta-actions{ display:flex; flex-wrap:wrap; gap:10px; margin-top:12px; }
.obh-location .btn{ display:inline-block; padding:.7em 1.05em; border-radius:999px; text-decoration:none; font-weight:700; border:1px solid currentColor; }
.obh-location .btn.primary{ background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }
.obh-location .btn.primary:hover{ filter: brightness(.95); }
.obh-location .btn.ghost{ background:#fff; color: var(--accent); border-color: var(--accent); }
.obh-location .btn.ghost:hover{ background: rgba(14,62,110,.06); }

/* ---------- CARE PATHWAY ---------- */
.obh-location .pathway{ display:grid; gap:14px; margin-top: 16px; }
@media (min-width:720px){ .obh-location .pathway{ grid-template-columns: repeat(4,1fr); } }
.obh-location .step{
  position:relative; padding:16px; border-radius:14px; background:#fff; border:1px solid rgba(0,0,0,.06);
  box-shadow:0 10px 26px rgba(0,0,0,.08);
}
.obh-location .step .badge{
  display:inline-block; font-size:12px; font-weight:700; letter-spacing:.02em;
  background: var(--accent); color: var(--accent-ink); border-radius:999px; padding:.25em .6em; margin-bottom:.4em;
}
.obh-location .step:after{
  content:""; position:absolute; top:50%; right:-10px; transform:translateY(-50%);
  width:20px; height:2px; background: linear-gradient(90deg, var(--accent), transparent);
}
.obh-location .step:last-child:after{ display:none; }

/* ---------- TESTIMONIAL + MAP ---------- */
.obh-location .two-col{ display:grid; gap:var(--gap); }
@media (min-width:900px){ .obh-location .two-col{ grid-template-columns: 1.2fr .8fr; } }
.obh-location blockquote{
  margin:0; padding:18px; border-left:4px solid var(--accent); background:#fff; border-radius:10px;
  box-shadow:0 8px 24px rgba(0,0,0,.06);
}
.obh-location .map-card{
  background:#fff; border:1px solid rgba(0,0,0,.06); border-radius:14px; box-shadow:0 12px 28px rgba(0,0,0,.08);
  overflow:hidden;
}
.obh-location .map-card .map-embed{ aspect-ratio: 16/10; width:100%; border:0; }
.obh-location .map-card .meta{ padding:12px 14px; font-size:14px; }

/* ---------- Sticky Mobile Action Bar ---------- */
@media (max-width:820px){
  .obh-location{ padding-bottom: 80px; } /* prevent overlap with bar */
  .obh-location .actionbar{
    position: fixed; left: 0; right: 0; bottom: 0;
    display:flex; gap:8px; padding:10px env(safe-area-inset-right) calc(10px + env(safe-area-inset-bottom)) env(safe-area-inset-left);
    background: rgba(255,255,255,.92); backdrop-filter: blur(8px);
    border-top: 1px solid rgba(0,0,0,.08); z-index: 999;
  }
  .obh-location .actionbar a{
    flex:1 1 0; display:flex; align-items:center; justify-content:center; gap:.5em;
    padding:.8em; border-radius:999px; text-decoration:none; font-weight:700;
    border:1px solid rgba(0,0,0,.12); background:#fff; box-shadow:0 6px 16px rgba(0,0,0,.06);
    color:inherit;
  }
  .obh-location .actionbar a.primary{ background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }
}

/* ---------- Accessibility: focus states & reduced motion ---------- */
.obh-location a:focus-visible,
.obh-location .btn:focus-visible,
.obh-location .strip-item .icon:focus-visible{
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
@media (prefers-reduced-motion: reduce){
  .obh-location *{ transition: none !important; animation: none !important; }
}/* End custom CSS */