/* =============================================================
   Hoxton Park Chemist — Classic component/layout/utility CSS
   Ported from the old hoxtonpark theme for the Elementor build.
   Loaded via hpc-core.php after Elementor's base stylesheets.
   ============================================================= */

:root{
  --cdc-green:#289e55;
  --cdc-green-dark:#1f7a42;
  --cdc-red:#e01a22;
  --cdc-red-dark:#b8141b;
  --cdc-yellow:#f7f410;
  --cdc-yellow-deep:#e6dd00;
  --cdc-yellow-soft:#fffbe0;
  --cdc-ink:#111418;
  --cdc-ink-soft:#3b4149;
  --cdc-muted:#6b7380;
  --cdc-bg:#ffffff;
  --cdc-soft:#f5f8f4;
  --cdc-line:#e6ebe4;
  --cdc-shadow:0 1px 2px rgba(17,20,24,.04), 0 8px 24px rgba(17,20,24,.06);
  --cdc-shadow-lg:0 12px 40px rgba(17,20,24,.12);
  --radius:16px;
  --radius-sm:10px;
  --radius-lg:22px;
  --radius-pill:999px;
  --container:1180px;
  --gutter:clamp(1.25rem, 3vw, 2rem);
  --section-y:clamp(4rem, 8vw, 7rem);
  --font-head:Arial,"Helvetica Neue",Helvetica,sans-serif;
  --font-body:Arial,"Helvetica Neue",Helvetica,sans-serif;
}

/* ---------- Typography tightening to match classic Arial SemiCondensed feel ---------- */
h1,h2,h3,h4,.eyebrow,.btn,.float-tag{font-stretch:75%;font-synthesis:none}
::selection{background:var(--cdc-yellow);color:var(--cdc-ink)}

/* Cursor pointer on interactive elements */
a,a *,button,button *,.btn,.btn *,.elementor-button,summary,
input[type="submit"],input[type="button"]{cursor:pointer}

/* ---------- Highlight helper (yellow underline behind word) ---------- */
.highlight,.hpc-highlight,.elementor-widget-heading .highlight{
  box-shadow:inset 0 -.55em 0 var(--cdc-yellow);
  padding:0 .12em;
  border-radius:3px;
}

/* ---------- Eyebrow yellow pill tab ---------- */
.eyebrow,
.elementor-widget-heading .eyebrow,
.elementor-widget-text-editor .eyebrow,
h1.eyebrow,h2.eyebrow,h3.eyebrow,h4.eyebrow,h5.eyebrow,h6.eyebrow,
.elementor-heading-title.eyebrow{
  display:inline-block !important;
  background:var(--cdc-yellow) !important;
  color:var(--cdc-ink) !important;
  padding:.4rem .85rem .42rem !important;
  border-radius:8px !important;
  box-shadow:0 4px 0 var(--cdc-yellow-deep),0 8px 14px -8px rgba(0,0,0,.12) !important;
  font-family:var(--font-head) !important;
  font-weight:800 !important;
  font-size:.74rem !important;
  letter-spacing:.14em !important;
  text-transform:uppercase !important;
  line-height:1.2 !important;
  margin-bottom:.9rem !important;
  text-align:center;
}

/* An entire Elementor heading widget flagged as eyebrow wraps the inline .elementor-heading-title.
   Keep the outer widget from inheriting block-level rules. */
.elementor-widget-heading.eyebrow-wrap .elementor-heading-title{
  display:inline-block;
  background:var(--cdc-yellow);
  color:var(--cdc-ink);
  padding:.4rem .85rem .42rem;
  border-radius:8px;
  box-shadow:0 4px 0 var(--cdc-yellow-deep),0 8px 14px -8px rgba(0,0,0,.12);
  font-weight:800;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;
}

/* ---------- Buttons (classic .btn system) ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--font-head);font-weight:700;letter-spacing:.02em;
  font-size:1rem;padding:.95rem 1.6rem;border-radius:var(--radius-pill);
  border:2px solid transparent;cursor:pointer;
  text-decoration:none;white-space:nowrap;
  transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease,border-color .2s ease;
}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--cdc-red);color:#fff;border-color:var(--cdc-red)}
.btn-primary,.btn-primary:link,.btn-primary:visited,.btn-primary:hover,.btn-primary:active,
a.btn-primary,a.btn.btn-primary{color:#fff !important;background:var(--cdc-red) !important;border-color:var(--cdc-red) !important}
.btn-primary:hover,a.btn-primary:hover{background:var(--cdc-red-dark) !important;border-color:var(--cdc-red-dark) !important}
.btn-ghost{background:transparent;color:var(--cdc-green-dark);border-color:var(--cdc-green)}
.btn-ghost:hover{background:var(--cdc-green);color:#fff;transform:translateY(-2px)}
.btn-white{background:#fff;color:var(--cdc-ink);border-color:#fff}
.btn-white:hover{background:var(--cdc-soft)}
.btn-yellow{background:var(--cdc-yellow);color:var(--cdc-ink);border-color:var(--cdc-yellow);font-weight:800}

/* Chunky flat drop shadow (classic signature) */
.btn:not(.nav-cta){
  box-shadow:0 6px 0 rgba(0,0,0,.18) !important;
}
.btn:not(.nav-cta):hover{transform:translateY(-2px);box-shadow:0 8px 0 rgba(0,0,0,.2) !important}
.btn:not(.nav-cta):active{transform:translateY(2px);box-shadow:0 3px 0 rgba(0,0,0,.18) !important}
.btn-primary:not(.nav-cta){box-shadow:0 6px 0 #8e0d14 !important}
.btn-primary:not(.nav-cta):hover{box-shadow:0 8px 0 #8e0d14,0 14px 28px -10px rgba(224,26,34,.45) !important}
.btn-ghost:not(.nav-cta){box-shadow:0 6px 0 var(--cdc-green-dark) !important}
.btn-ghost:not(.nav-cta):hover{box-shadow:0 8px 0 var(--cdc-green-dark),0 14px 28px -10px rgba(40,158,85,.35) !important}
.btn-white:not(.nav-cta){box-shadow:0 6px 0 rgba(0,0,0,.35) !important}
.btn-white:not(.nav-cta):hover{box-shadow:0 8px 0 rgba(0,0,0,.4),0 14px 28px -10px rgba(0,0,0,.3) !important}
.btn-yellow:not(.nav-cta){box-shadow:0 6px 0 var(--cdc-yellow-deep) !important}
.btn-yellow:not(.nav-cta):hover{box-shadow:0 8px 0 var(--cdc-yellow-deep),0 14px 28px -10px rgba(247,244,16,.4) !important}

/* When Elementor button widgets are given classic classes via css_classes, style the inner anchor */
.elementor-widget-button .elementor-button.btn-primary,
.elementor-widget-button .elementor-button.btn-ghost,
.elementor-widget-button .elementor-button.btn-white,
.elementor-widget-button .elementor-button.btn-yellow{
  border-radius:999px;font-weight:800;letter-spacing:.02em;
}

/* ---------- Trust strip (red, white text, black rules) ---------- */
.trust-strip{
  background:var(--cdc-red) !important;
  color:#fff;
  position:relative;
  border-top:6px solid #000;
  border-bottom:6px solid #000;
}
.trust-strip .wrap,.trust-strip-inner{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;
  padding:1.6rem 0;max-width:var(--container);margin:0 auto;
}
.trust-strip .trust-item{
  display:flex;align-items:center;gap:.7rem;justify-content:center;
  font-weight:700;color:#fff !important;font-size:.95rem;
  padding:0 1rem;
}
.trust-strip .trust-item + .trust-item{border-left:1px solid rgba(0,0,0,.25)}
.trust-strip .trust-item svg{width:22px;height:22px;color:#fff;stroke:#fff;flex-shrink:0}
@media (max-width:820px){
  .trust-strip .wrap,.trust-strip-inner{grid-template-columns:repeat(2,1fr);gap:.4rem}
  .trust-strip .trust-item + .trust-item{border-left:0}
  .trust-strip .trust-item:nth-child(odd){border-left:0}
}

/* ---------- Cards ---------- */
.card{
  background:#fff;border:1px solid var(--cdc-line);border-radius:var(--radius);
  padding:1.6rem;
  display:grid;grid-template-columns:auto 1fr;column-gap:1.15rem;row-gap:.45rem;align-items:center;
  position:relative;overflow:hidden;
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--cdc-shadow-lg);border-color:transparent}
.card::before{content:"";position:absolute;top:0;left:0;right:0;height:0;background:var(--cdc-yellow);transition:height .3s ease}
.card:hover::before{height:6px}
.card .icon{
  grid-column:1;grid-row:1;
  width:54px;height:54px;border-radius:14px;
  background:var(--cdc-yellow);color:var(--cdc-ink);
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 4px 0 var(--cdc-yellow-deep);
  transition:transform .25s;
  margin:0;align-self:center;
}
.card .icon svg{width:28px;height:28px;color:var(--cdc-green-dark)}
.card:hover .icon{transform:rotate(-4deg) scale(1.05)}
.card h2,.card h3{grid-column:2;grid-row:1;margin:0;align-self:center;font-family:var(--font-head);font-weight:800;font-size:1.2rem;line-height:1.2}
.card p,.card ul{grid-column:1/-1;color:var(--cdc-ink-soft);margin:.4rem 0 0}

/* ---------- Stats card ---------- */
.stats-card{
  background:#fff;border:1px solid var(--cdc-line);border-radius:var(--radius);
  padding:1.8rem;box-shadow:var(--cdc-shadow);
  position:relative;overflow:hidden;
}
.stats-card::before{content:"";position:absolute;top:0;left:0;right:0;height:6px;background:var(--cdc-yellow)}
.stats-card h3{margin:.4rem 0 1rem;font-size:1.1rem;color:var(--cdc-green-dark);text-transform:uppercase;letter-spacing:.08em}
.stats-card ul{list-style:none;padding:0;margin:0;display:grid;gap:.85rem}
.stats-card li{display:flex;gap:.7rem;align-items:flex-start;font-weight:500}
.stats-card svg{width:22px;height:22px;color:var(--cdc-green);flex-shrink:0;margin-top:2px}

/* ---------- Grid helpers ---------- */
.grid{display:grid;gap:1.2rem}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:820px){
  .grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:640px){
  .grid-4,.grid-3,.grid-2{grid-template-columns:1fr}
}

/* ---------- Intro 2-col ---------- */
.intro-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:clamp(2rem,4vw,3rem);align-items:center}
@media (max-width:820px){.intro-grid{grid-template-columns:1fr}}

/* ---------- Local band (green) ---------- */
.local-band{
  background:linear-gradient(135deg,var(--cdc-green) 0%,var(--cdc-green-dark) 100%);
  color:#fff;border-radius:var(--radius);
  padding:clamp(2rem,4vw,3.5rem);
  position:relative;overflow:hidden;
}
.local-band::before{content:"";position:absolute;right:-80px;top:-80px;width:300px;height:300px;background:radial-gradient(circle,rgba(247,244,16,.22),transparent 60%);border-radius:50%}
.local-band h2{color:#fff;position:relative}
.local-band p{color:rgba(255,255,255,.92);max-width:60ch;position:relative}

/* ---------- Chips ---------- */
.chips{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:1.2rem;position:relative}
.chip{background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.3);color:#fff;padding:.5rem 1rem;border-radius:var(--radius-pill);font-size:.88rem;font-weight:600}
.section:not(.section--soft) .chips:not(.local-band .chips) .chip{
  background:var(--cdc-yellow);color:var(--cdc-ink);border-color:var(--cdc-yellow-deep);font-weight:700;
}

/* ---------- Section H2 yellow underline accent ---------- */
.section h2:not(.cta-band h2):not(.local-band h2):not(.service-hero h2)::after,
.elementor-widget-heading .elementor-heading-title.with-accent::after{
  content:"";display:block;width:64px;height:6px;background:var(--cdc-yellow);border-radius:3px;margin-top:.6rem;
}

/* ---------- CTA band (dark) ---------- */
.cta-band{
  background:linear-gradient(135deg,#1a1f24,#0f1317) !important;
  color:#fff;
  border-radius:var(--radius-lg);
  padding:clamp(3rem,6vw,4.5rem) clamp(1.5rem,4vw,3rem) !important;
  text-align:center;position:relative;overflow:hidden;
}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(800px 300px at 50% 100%,rgba(40,158,85,.25),transparent 60%);pointer-events:none}
.cta-band::after{content:"";position:absolute;top:0;right:0;width:140px;height:140px;background:var(--cdc-yellow);clip-path:polygon(100% 0,0 0,100% 100%);opacity:.95;border-radius:0 var(--radius-lg) 0 0;pointer-events:none}
.cta-band h2,.cta-band h2 *{color:#fff !important;position:relative}
.cta-band p{color:rgba(255,255,255,.85) !important;position:relative;max-width:55ch;margin-left:auto;margin-right:auto}
.cta-band .btns,.cta-band .hero-ctas{position:relative;display:flex;gap:.85rem;justify-content:center;flex-wrap:wrap}
.cta-band .btn-white,.cta-band a.btn[class*="btn-white"]{
  background:var(--cdc-yellow) !important;color:var(--cdc-ink) !important;border-color:var(--cdc-yellow) !important;font-weight:800;
  box-shadow:0 6px 0 var(--cdc-yellow-deep) !important;
}
@media (max-width:640px){.cta-band::after{width:90px;height:90px}}

/* ---------- Float tags (yellow pill) ---------- */
.float-tag{
  position:absolute;background:var(--cdc-yellow);border:1px solid var(--cdc-yellow-deep);
  padding:.75rem 1.05rem;border-radius:var(--radius-pill);
  color:var(--cdc-ink);font-weight:800;font-size:.92rem;
  display:inline-flex;align-items:center;gap:.55rem;
  box-shadow:0 8px 18px -8px rgba(0,0,0,.25),0 4px 0 var(--cdc-yellow-deep);
  animation:hpcFloat 7s ease-in-out infinite;
  will-change:transform;
}
.float-tag svg{width:18px;height:18px;color:var(--cdc-green-dark)}
.float-tag.t1{animation-delay:0s}
.float-tag.t2{animation-delay:1.75s}
.float-tag.t3{animation-delay:3.5s}
.float-tag.t4{animation-delay:5.25s}
@keyframes hpcFloat{
  0%,100%{transform:translate3d(0,0,0)}
  50%{transform:translate3d(0,-8px,0)}
}
@media (prefers-reduced-motion:reduce){.float-tag{animation:none;transform:none}}

/* ---------- Hero photo layout ---------- */
.hero-visual--photo{position:relative;min-height:480px}
.hero-photo{margin:0;position:relative;z-index:2}
.hero-photo img{width:100%;height:auto;display:block;border-radius:28px;box-shadow:0 30px 60px -25px rgba(20,40,25,.35),0 12px 24px -12px rgba(0,0,0,.18);object-fit:cover;aspect-ratio:5/4}
.hero-photo-inset{position:absolute;right:-18px;bottom:-28px;width:42%;max-width:240px;margin:0;z-index:3;border-radius:20px;overflow:hidden;box-shadow:0 24px 48px -20px rgba(0,0,0,.4);border:6px solid #fff;transform:rotate(2deg)}
.hero-photo-inset img{display:block;width:100%;height:auto;aspect-ratio:1/1;object-fit:cover}
.hero-visual--photo .float-tag{z-index:4}
@media (max-width:820px){.hero-photo-inset{width:46%;right:-8px;bottom:-18px}}

/* ---------- FAQ accordion ---------- */
.faq{max-width:820px;margin:0 auto}
.faq details{background:#fff;border:1px solid var(--cdc-line);border-radius:var(--radius-sm);margin-bottom:.8rem;transition:box-shadow .2s}
.faq details[open]{box-shadow:var(--cdc-shadow)}
.faq summary{list-style:none;cursor:pointer;padding:1.1rem 1.3rem;font-family:var(--font-head);font-weight:700;font-size:1.08rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:1.6rem;font-weight:400;color:var(--cdc-green);transition:transform .25s;line-height:1}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .a{padding:0 1.3rem 1.2rem;color:var(--cdc-ink-soft)}

/* ---------- Hours table ---------- */
.hours-table{border-collapse:collapse;width:100%}
.hours-table tr{border-bottom:1px dashed var(--cdc-line)}
.hours-table tr:first-child{border-top:3px solid var(--cdc-yellow)}
.hours-table td{padding:.7rem 0}
.hours-table td:last-child{text-align:right;font-weight:700;color:var(--cdc-green-dark)}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .7s ease,transform .7s ease}
.reveal.is-visible,.reveal.visible{opacity:1;transform:none}

/* ---------- Cinematic service-detail hero ---------- */
.service-hero{
  position:relative;
  background-size:cover;background-position:center;background-repeat:no-repeat;
  min-height:clamp(380px,52vw,560px);
  display:flex;align-items:center;
  overflow:hidden;isolation:isolate;
  color:#fff;margin-bottom:0;
}
.service-hero::before{content:"";position:absolute;inset:0;z-index:0;background:inherit;background-size:cover;background-position:center;filter:saturate(1.05);transform:scale(1.04)}
.service-hero__tint{
  position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(1200px 600px at 15% 40%,rgba(10,25,15,.78),rgba(10,25,15,.35) 55%,transparent 80%),
    linear-gradient(180deg,rgba(0,0,0,.35) 0%,rgba(0,0,0,.55) 100%),
    linear-gradient(90deg,rgba(40,158,85,.30),transparent 55%);
}
.service-hero .container{position:relative;z-index:2;padding-top:clamp(3.5rem,7vw,5rem);padding-bottom:clamp(3.5rem,7vw,5rem)}
.service-hero__inner{max-width:720px;position:relative;z-index:2}
.service-hero .crumbs{color:rgba(255,255,255,.8);margin-bottom:1rem;font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;font-weight:600}
.service-hero .crumbs a{color:#fff;text-decoration:none;border-bottom:1px solid rgba(255,255,255,.4)}
.service-hero__eyebrow{
  display:inline-block;background:var(--cdc-yellow);color:var(--cdc-ink);
  padding:.4rem .85rem;border-radius:8px;
  font-family:var(--font-head);font-weight:800;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;
  box-shadow:0 4px 0 var(--cdc-yellow-deep);margin-bottom:1.2rem;
}
.service-hero h1{color:#fff;font-size:clamp(2rem,4.8vw,3.4rem);line-height:1.05;text-shadow:0 2px 30px rgba(0,0,0,.45);margin-bottom:1rem}
.service-hero h1::after{display:none}
.service-hero .lede{color:rgba(255,255,255,.94);font-size:clamp(1.05rem,1.4vw,1.2rem);max-width:58ch;text-shadow:0 1px 20px rgba(0,0,0,.4);margin-bottom:1.8rem}
.service-hero .hero-ctas{display:flex;gap:.85rem;flex-wrap:wrap}
.service-hero .btn-white{background:#fff !important;color:var(--cdc-ink) !important;border-color:#fff !important}
.service-hero::after{content:"";position:absolute;left:0;right:0;bottom:0;height:60px;z-index:2;background:linear-gradient(180deg,transparent,#fff);pointer-events:none}
@media (max-width:640px){.service-hero{min-height:440px}.service-hero h1{font-size:2rem}}

/* ---------- Elementor-scoped fixes ---------- */

/* Force home hero H1 to wrap to classic 3-line shape */
.hpc-home-hero h1,
.elementor-widget-heading.hpc-home-hero-h1 .elementor-heading-title{
  max-width:14ch;
}
.hpc-services-hero h1,
.elementor-widget-heading.hpc-services-hero-h1 .elementor-heading-title{
  max-width:18ch;
}

/* Services H1 overall: widen yellow highlight so 'real life' fits one line */
.elementor-widget-heading h1 .hpc-highlight{white-space:nowrap}

/* Home services grid: force 2 columns (classic 2x3 layout) */
.hpc-home-services-grid.elementor-section > .elementor-container{
  display:grid !important;
  grid-template-columns:repeat(2,1fr) !important;
  gap:1.2rem;
}
.hpc-home-services-grid .elementor-column{width:auto !important;max-width:none !important}
@media (max-width:640px){
  .hpc-home-services-grid.elementor-section > .elementor-container{grid-template-columns:1fr !important}
}

/* Intro row: stats card column sized correctly */
.hpc-intro-row.elementor-section > .elementor-container{
  display:grid !important;
  grid-template-columns:1.25fr .75fr !important;
  gap:clamp(2rem,4vw,3rem);
  align-items:center;
}
.hpc-intro-row .elementor-column{width:auto !important;max-width:none !important}
@media (max-width:820px){
  .hpc-intro-row.elementor-section > .elementor-container{grid-template-columns:1fr !important}
}

/* Home services section: full-bleed band with soft green background, inner grid stays 1200px */
.hpc-home-services-grid.elementor-section{
  max-width:none !important;
  width:100% !important;
  background:var(--cdc-soft) !important;
}
.hpc-home-services-grid.elementor-section > .elementor-container{
  max-width:1200px !important;
  margin:0 auto !important;
  display:block !important;
  grid-template-columns:none !important;
}
.hpc-home-services-grid .hpc-services-grid-inner{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem;
}
@media (max-width:640px){
  .hpc-home-services-grid .hpc-services-grid-inner{grid-template-columns:1fr}
}
/* Home services cards (new .card markup inside HTML widget) */
.hpc-home-services-grid .card{
  background:#fff;border:1px solid var(--cdc-line);border-radius:var(--radius);
  padding:1.6rem;
  display:grid;grid-template-columns:auto 1fr;column-gap:1.15rem;row-gap:.45rem;
  align-items:center;text-decoration:none;color:var(--cdc-ink);
  position:relative;overflow:hidden;
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;
}
.hpc-home-services-grid .card:hover{transform:translateY(-4px);box-shadow:var(--cdc-shadow-lg);border-color:transparent}
.hpc-home-services-grid .card .icon{
  grid-column:1;grid-row:1;
  width:54px;height:54px;border-radius:14px;
  background:var(--cdc-yellow);color:var(--cdc-ink);
  display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 4px 0 var(--cdc-yellow-deep);
  align-self:center;
}
.hpc-home-services-grid .card .icon svg{width:28px;height:28px;color:var(--cdc-green-dark);stroke:var(--cdc-green-dark)}
.hpc-home-services-grid .card h3{grid-column:2;grid-row:1;margin:0;align-self:center;font-family:var(--font-head);font-weight:800;font-size:1.2rem;line-height:1.2}
.hpc-home-services-grid .card p{grid-column:1/-1;color:var(--cdc-ink-soft);margin:.4rem 0 0;font-size:.98rem}

/* FAQ question font size (home + services + detail pages). Beat Elementor inline defaults. */
.elementor-accordion .elementor-tab-title,
.elementor-accordion .elementor-tab-title a,
.elementor-accordion-item .elementor-accordion-title,
.e-n-accordion-item-title,
.e-n-accordion-item-title-text,
.faq details summary,
.faq summary{
  font-size:1.05rem !important;
  font-weight:700 !important;
  line-height:1.35 !important;
}

/* When an Elementor heading has class "eyebrow" on the outer widget */
.elementor-widget-heading.eyebrow > .elementor-widget-container{display:inline-block}
.elementor-widget-heading.eyebrow .elementor-heading-title{
  display:inline-block !important;
  background:var(--cdc-yellow) !important;
  color:var(--cdc-ink) !important;
  padding:.4rem .85rem .42rem !important;
  border-radius:8px !important;
  box-shadow:0 4px 0 var(--cdc-yellow-deep),0 8px 14px -8px rgba(0,0,0,.12) !important;
  font-weight:800 !important;font-size:.74rem !important;letter-spacing:.14em !important;
  text-transform:uppercase !important;line-height:1.2 !important;
}

/* ===== Hours list (table → ul) ===== */
.hpc-hours{list-style:none;padding:0;margin:0;max-width:380px}
.hpc-hours li{display:flex;justify-content:space-between;gap:1rem;padding:.55rem 0;border-bottom:1px dashed #e0e5dc;font-size:1rem}
.hpc-hours li:last-child{border-bottom:0}
.hpc-hours__day{color:var(--cdc-ink);opacity:.85}
.hpc-hours__time{font-weight:800;color:var(--cdc-green);white-space:nowrap}
/* Dark backgrounds (footer, hero dark bands) */
.elementor-location-footer .hpc-hours li,
.site-footer .hpc-hours li,
.cta-band .hpc-hours li{border-bottom-color:rgba(234,242,232,.18)}
.elementor-location-footer .hpc-hours__day,
.site-footer .hpc-hours__day,
.cta-band .hpc-hours__day{color:#eaf2e8}
.elementor-location-footer .hpc-hours__time,
.site-footer .hpc-hours__time,
.cta-band .hpc-hours__time{color:var(--cdc-yellow)}

/* ===== Footer column spacing + logo pill alignment ===== */
.elementor-location-footer .elementor-container{gap:40px}
.elementor-location-footer .elementor-top-column{padding:0 .5rem}
.elementor-location-footer h3,.elementor-location-footer h4{color:var(--cdc-yellow)!important;margin-bottom:1rem}
@media (max-width:900px){
  .elementor-location-footer .elementor-container{flex-wrap:wrap;gap:2rem}
  .elementor-location-footer .elementor-top-column{flex-basis:100%!important;width:100%!important}
}
