/* ============================================================
   JID Rebuild — Core (tokens, chrome, shared UI)
   Complete Physio · brand teal #1db1db / slate #545f68
   ============================================================ */
:root{
  --teal:#1db1db; --teal-deep:#1591b5; --teal-ink:#0e6f8c;
  --slate:#545f68; --ink:#172029; --body:#4b565f;
  --bg:#f6fafb; --card:#fff; --line:#e7eef1;
  --pill:rgba(29,177,219,.10); --pill-line:rgba(29,177,219,.28);
  --shadow:0 1px 2px rgba(23,32,41,.04);
  --shadow-lift:0 18px 40px -16px rgba(21,108,134,.28), 0 4px 12px rgba(23,32,41,.05);
  --r:18px; --r-sm:12px; --maxw:1320px; --head-h:104px;
  --header-bg:#15242d;
  --font-display:'Montserrat',system-ui,sans-serif;
  --font-body:'Open Sans',system-ui,sans-serif;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body.jid-page{
  margin:0; background:var(--bg); color:var(--body);
  font-family:var(--font-body); font-size:16px; line-height:1.6;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
body.jid-page::before{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(900px 520px at 88% -8%, rgba(29,177,219,.10), transparent 60%),
    radial-gradient(700px 480px at -6% 4%, rgba(84,95,104,.06), transparent 55%);
}
/* Low-specificity reset (:where = 0 specificity) so explicit logo/media rules always win */
body.jid-page :where(img){max-width:100%; height:auto; display:block}
a{color:inherit; text-decoration:none}
.jid-wrap{max-width:var(--maxw); margin:0 auto; padding:0 28px}
.jid-main{position:relative; z-index:1}

/* ---------- Buttons ---------- */
.jid-btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:var(--font-display); font-weight:700; font-size:.92rem; line-height:1;
  padding:13px 24px; border-radius:999px; border:1.5px solid transparent;
  cursor:pointer; transition:all .22s ease; white-space:nowrap;
}
.jid-btn--primary{background:var(--teal); color:#fff}
.jid-btn--primary:hover{background:var(--teal-deep); box-shadow:0 8px 20px -8px rgba(29,177,219,.6)}
.jid-btn--ghost{background:transparent; color:var(--ink); border-color:var(--line)}
.jid-btn--ghost:hover{border-color:var(--teal); color:var(--teal-ink)}
.jid-btn--light{background:#fff; color:var(--teal-ink)}
.jid-btn--light:hover{transform:translateY(-2px); box-shadow:0 12px 26px -12px rgba(0,0,0,.35)}
.jid-btn--block{width:100%}

/* ---------- Header (dark, matches site nav) ---------- */
.jid-header{
  position:sticky; top:0; z-index:1000; background:var(--header-bg);
  box-shadow:0 1px 0 rgba(255,255,255,.06), 0 6px 24px -12px rgba(0,0,0,.5);
}
.jid-header__inner{
  max-width:var(--maxw); margin:0 auto; padding:0 30px; height:var(--head-h);
  display:flex; align-items:center; gap:24px;
}
.jid-header__logo{display:flex; align-items:center; flex-shrink:0}
.jid-header__logo img{height:72px; width:auto; max-height:72px}
.jid-nav{flex:1; display:flex; justify-content:center; min-width:0}
.jid-nav__menu{list-style:none; margin:0; padding:0; display:flex; align-items:center; gap:0; flex-wrap:nowrap}
.jid-nav__menu li{position:relative}
/* Hide any Avada-injected custom menu items (e.g. the inline search form) */
.jid-nav__menu .fusion-custom-menu-item,
.jid-nav__menu .fusion-main-menu-search,
.jid-nav__menu .fusion-main-menu-cart{display:none !important}
.jid-nav__menu>li>a{
  position:relative; display:block; font-family:var(--font-display); font-weight:600; font-size:.72rem;
  letter-spacing:.035em; text-transform:uppercase; color:rgba(255,255,255,.82);
  padding:11px 11px; transition:color .18s ease; white-space:nowrap;
}
.jid-nav__menu>li>a::after{
  content:""; position:absolute; left:11px; right:11px; bottom:7px; height:2px;
  background:var(--teal); border-radius:2px; transform:scaleX(0); transform-origin:center;
  transition:transform .24s cubic-bezier(.2,.7,.2,1);
}
.jid-nav__menu>li>a:hover{color:#fff}
.jid-nav__menu>li>a:hover::after,
.jid-nav__menu>li.current-menu-item>a::after,
.jid-nav__menu>li.current_page_item>a::after,
.jid-nav__menu>li.current-menu-parent>a::after{transform:scaleX(1)}
.jid-nav__menu>li.current-menu-item>a,
.jid-nav__menu>li.current_page_item>a,
.jid-nav__menu>li.current-menu-parent>a{color:#fff}
.jid-nav__menu .sub-menu{
  position:absolute; top:calc(100% + 8px); left:0; min-width:240px;
  background:#fff; border:1px solid var(--line); border-radius:var(--r-sm);
  box-shadow:var(--shadow-lift); padding:8px; list-style:none; margin:0;
  opacity:0; visibility:hidden; transform:translateY(8px); transition:all .2s ease; z-index:50;
}
.jid-nav__menu li:hover>.sub-menu{opacity:1; visibility:visible; transform:translateY(0)}
.jid-nav__menu .sub-menu a{
  display:block; font-family:var(--font-body); font-size:.88rem; color:var(--body);
  text-transform:none; letter-spacing:0; padding:9px 12px; border-radius:8px; transition:all .15s ease;
}
.jid-nav__menu .sub-menu a:hover{background:var(--pill); color:var(--teal-ink)}
.jid-header__actions{display:flex; align-items:center; gap:18px; flex-shrink:0; padding-left:26px; margin-left:8px; border-left:1px solid rgba(255,255,255,.14)}
.jid-header__tel{
  display:inline-flex; align-items:center; gap:7px; font-family:var(--font-display);
  font-weight:700; font-size:.88rem; color:rgba(255,255,255,.9); transition:color .18s ease; white-space:nowrap;
}
.jid-header__tel:hover{color:var(--teal)}
.jid-header__tel svg{color:var(--teal)}
.jid-burger{display:none; flex-direction:column; gap:5px; width:44px; height:44px;
  align-items:center; justify-content:center; background:transparent; border:1px solid rgba(255,255,255,.28);
  border-radius:10px; cursor:pointer}
.jid-burger span{width:20px; height:2px; background:#fff; border-radius:2px; transition:.2s}

/* ---------- Mobile drawer ---------- */
.jid-drawer-backdrop{position:fixed; inset:0; background:rgba(23,32,41,.45); z-index:1001; opacity:0; transition:opacity .25s ease}
.jid-drawer-backdrop.is-open{opacity:1}
.jid-drawer{
  position:fixed; top:0; right:0; height:100dvh; width:min(360px,86vw); background:#fff;
  z-index:1002; transform:translateX(100%); transition:transform .3s cubic-bezier(.2,.7,.2,1);
  display:flex; flex-direction:column; box-shadow:-20px 0 50px -20px rgba(0,0,0,.3);
}
.jid-drawer.is-open{transform:translateX(0)}
/* Dark bar so the white "Complete" wordmark in the logo stays visible (logo is built for dark bg) */
.jid-drawer__head{display:flex; align-items:center; justify-content:space-between; padding:16px 22px; background:var(--header-bg)}
.jid-drawer__head img{height:40px; width:auto}
.jid-drawer__close{background:none; border:none; font-size:2rem; line-height:1; color:rgba(255,255,255,.85); cursor:pointer; transition:color .15s ease}
.jid-drawer__close:hover{color:#fff}
.jid-drawer__nav{flex:1; overflow-y:auto; padding:14px 18px}
.jid-drawer__nav .jid-nav__menu{flex-direction:column; align-items:stretch; gap:2px}
/* In the white drawer the header's white link colour is invisible — force dark, left-aligned, no header-underline */
.jid-drawer__nav .jid-nav__menu>li>a{font-size:1rem; font-weight:700; letter-spacing:0; text-transform:none; color:var(--ink); padding:13px 10px; border-radius:8px}
.jid-drawer__nav .jid-nav__menu>li>a::after{display:none}
.jid-drawer__nav .jid-nav__menu>li>a:hover{color:var(--teal-ink); background:var(--pill)}
.jid-drawer__nav .jid-nav__menu>li.current-menu-item>a,
.jid-drawer__nav .jid-nav__menu>li.current_page_item>a{color:var(--teal-ink)}
/* Accordion: parent submenus collapsed by default, toggled by the caret */
.jid-drawer__nav .menu-item-has-children{position:relative}
.jid-drawer__nav .menu-item-has-children>a{padding-right:54px}
.jid-drawer__nav .sub-menu{position:static; opacity:1; visibility:visible; transform:none; box-shadow:none; border:none; min-width:0;
  max-height:0; overflow:hidden; padding:0 0 0 12px; transition:max-height .35s ease}
.jid-drawer__nav li.is-open>.sub-menu{max-height:1600px; padding-bottom:6px}
.jid-drawer__nav .sub-menu a{color:var(--slate)}
.jid-drawer-caret{position:absolute; top:4px; right:2px; width:46px; height:46px; display:flex; align-items:center; justify-content:center;
  background:none; border:none; cursor:pointer; color:var(--slate); border-radius:8px; transition:background .15s ease, color .15s ease}
.jid-drawer-caret:hover{color:var(--teal-ink); background:var(--pill)}
.jid-drawer-caret svg{transition:transform .28s cubic-bezier(.2,.7,.2,1)}
.jid-drawer__nav li.is-open>.jid-drawer-caret{color:var(--teal-ink)}
.jid-drawer__nav li.is-open>.jid-drawer-caret svg{transform:rotate(180deg)}
.jid-drawer__actions{padding:18px 22px; border-top:1px solid var(--line); display:flex; flex-direction:column; gap:10px}

/* ---------- Masthead ---------- */
.jid-masthead{padding:64px 0 28px; max-width:760px; margin-left:auto; margin-right:auto; text-align:center}
.jid-kicker{display:inline-flex; align-items:center; gap:10px; font-family:var(--font-display);
  font-weight:700; font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; color:var(--teal-ink); margin-bottom:18px}
.jid-kicker::before{content:""; width:30px; height:2px; background:var(--teal); border-radius:2px}
.jid-masthead h1{font-family:var(--font-display); font-weight:800; color:var(--ink);
  font-size:clamp(2.4rem,5vw,3.6rem); line-height:1.04; letter-spacing:-.02em; margin:0 0 18px}
.jid-masthead h1 em{font-style:normal; color:var(--teal)}
.jid-masthead p{font-size:1.18rem; color:var(--slate); margin:0 auto; max-width:600px}

/* ---------- Toolbar ---------- */
.jid-toolbar{display:flex; align-items:center; justify-content:center; gap:24px; flex-wrap:wrap; padding:24px 0 8px; margin-bottom:40px; border-top:1px solid var(--line)}
.jid-chips{display:flex; gap:10px; flex-wrap:wrap; flex:1; min-width:0}
.jid-chip{font-family:var(--font-display); font-weight:600; font-size:.82rem; padding:9px 16px; border-radius:999px;
  border:1px solid var(--line); background:#fff; color:var(--slate); white-space:nowrap; transition:all .2s ease}
.jid-chip:hover{border-color:var(--pill-line); color:var(--teal-ink)}
.jid-chip.is-active{background:var(--ink); color:#fff; border-color:var(--ink)}
.jid-search{position:relative; flex:0 1 520px}
.jid-search input{width:100%; font-family:var(--font-body); font-size:.95rem; color:var(--ink);
  padding:13px 16px 13px 44px; border-radius:999px; border:1px solid var(--line); background:#fff; outline:none; transition:all .2s ease; box-shadow:var(--shadow)}
.jid-search input::placeholder{color:#9aa6ad}
.jid-search input:focus{border-color:var(--teal); box-shadow:0 0 0 4px rgba(29,177,219,.13)}
.jid-search svg{position:absolute; left:15px; top:50%; transform:translateY(-50%); color:#9aa6ad}

/* ---------- Read link ---------- */
.jid-readlink{display:inline-flex; align-items:center; gap:8px; font-family:var(--font-display); font-weight:700; font-size:.84rem; color:var(--teal-ink)}
.jid-readlink svg{transition:transform .25s ease}
.jid-readlink--lg{font-size:.92rem}

/* ---------- Pagination ---------- */
.jid-pagination{padding:48px 0 92px}
.jid-pagination ul{list-style:none; display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin:0; padding:0}
.jid-pagination a, .jid-pagination span{
  display:inline-flex; align-items:center; justify-content:center; min-width:44px; height:44px; padding:0 14px;
  font-family:var(--font-display); font-weight:600; font-size:.9rem; border-radius:10px;
  border:1px solid var(--line); background:#fff; color:var(--ink); transition:all .18s ease}
.jid-pagination a:hover{border-color:var(--teal); color:var(--teal-ink)}
.jid-pagination .current{background:var(--ink); color:#fff; border-color:var(--ink)}
.jid-pagination .dots{border:none; background:transparent}

/* ---------- Footer CTA ---------- */
.jid-footcta{position:relative; z-index:1; margin-top:40px;
  background:linear-gradient(120deg,var(--teal-deep),var(--teal)); color:#fff}
.jid-footcta__inner{max-width:var(--maxw); margin:0 auto; padding:54px 28px;
  display:flex; align-items:center; justify-content:space-between; gap:30px; flex-wrap:wrap}
.jid-footcta h2{font-family:var(--font-display); font-weight:800; font-size:clamp(1.5rem,3vw,2.1rem); margin:0 0 8px; letter-spacing:-.01em}
.jid-footcta p{margin:0; font-size:1.05rem; opacity:.92; max-width:560px}

/* ---------- Footer ---------- */
.jid-footer{position:relative; z-index:1; background:var(--ink); color:#aeb9c1}
.jid-footer__inner{max-width:var(--maxw); margin:0 auto; padding:60px 28px 40px;
  display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px}
.jid-footer__brand img{height:42px; width:auto; filter:brightness(0) invert(1); margin-bottom:18px}
.jid-footer__brand p{font-size:.92rem; line-height:1.7; margin:0 0 16px; max-width:320px}
.jid-footer__tel{font-family:var(--font-display); font-weight:700; font-size:1.2rem; color:#fff}
.jid-footer__col h3{font-family:var(--font-display); font-weight:700; font-size:.8rem; letter-spacing:.14em; text-transform:uppercase; color:#fff; margin:0 0 18px}
.jid-footer__col ul{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:11px}
.jid-footer__col li{font-size:.92rem}
.jid-footer__col li span{color:var(--teal); font-weight:600; margin-left:4px}
.jid-footer__col a{transition:color .18s ease}
.jid-footer__col a:hover{color:#fff}
.jid-footer__bar{border-top:1px solid rgba(255,255,255,.1); padding:22px 28px;
  max-width:var(--maxw); margin:0 auto; display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; font-size:.82rem}
.jid-footer__credit{color:#7e8a93}

/* ---------- Animation ---------- */
@keyframes jid-rise{from{opacity:0; transform:translateY(22px)}to{opacity:1; transform:none}}
.jid-anim{opacity:0; animation:jid-rise .7s cubic-bezier(.2,.7,.2,1) forwards}

/* ---------- Responsive ---------- */
@media(max-width:1024px){
  .jid-nav{display:none}
  .jid-burger{display:flex}
  .jid-header__tel{display:none}
  /* nav gone — drop the divider + push logo/actions to the edges */
  .jid-header__inner{justify-content:space-between}
  .jid-header__actions{border-left:none; padding-left:0; margin-left:0; gap:14px}
}
@media(max-width:768px){
  .jid-footer__inner{grid-template-columns:1fr 1fr}
  .jid-footer__brand{grid-column:1/-1}
  .jid-search{flex:1 1 100%; order:-1}
  .jid-header__inner{height:78px}
  .jid-header__logo img{height:54px; max-height:54px}
}
@media(max-width:560px){
  .jid-wrap{padding:0 18px}
  .jid-header__inner{padding:0 18px; gap:12px; height:70px}
  .jid-header__logo img{height:46px; max-height:46px}
  /* Book Online lives in the drawer on phones — keep the bar to logo + burger */
  .jid-header__actions .jid-btn--primary{display:none}
  .jid-masthead{padding:44px 0 20px}
  .jid-footcta__inner{padding:40px 18px}
  .jid-footer__inner{grid-template-columns:1fr; gap:28px}
}
@media(prefers-reduced-motion:reduce){
  .jid-anim{animation:none; opacity:1}
  body.jid-page *{transition:none !important}
}
