/* ============================================================================
   chrome.css — generator-injected chrome that core.css does not already cover.
   Reuses the design's CSS variables (--color-*, --font-*) so the injected
   header dropdowns, drawer accordions, and internal-link silos match the design.
   Loaded on EVERY page after core.css.
   ============================================================================ */

/* ---- NAV DROPDOWNS ---------------------------------------------------------
   core.css styles .nav and .nav>a/.nav__toggle as inline links, but does NOT
   position or hide the .nav__menu panel — so these rules own the dropdown:
   relative group, absolutely-positioned panel, HIDDEN by default, opens on
   hover (desktop) or when the toggle is aria-expanded (click/keyboard). */
.nav__group { position: relative; display: inline-flex; }
.nav__group > .nav__toggle { cursor: pointer; }
.nav__toggle svg { width: 13px; height: 13px; flex: none; transition: transform .18s var(--ease); }
.nav__group:hover .nav__toggle svg,
.nav__group .nav__toggle[aria-expanded="true"] svg { transform: rotate(180deg); }

.nav__menu {
  position: absolute; top: 100%; left: 0; margin-top: 6px; z-index: 60;
  min-width: 264px; display: none; flex-direction: column;
  background: var(--color-paper-card); border: 1px solid var(--color-line);
  box-shadow: var(--shadow); padding: 6px;
}
.nav__menu::before {            /* invisible hover bridge above the panel */
  content: ""; position: absolute; left: 0; right: 0; top: -10px; height: 10px;
}
.nav__menu a {
  display: flex; align-items: baseline; justify-content: space-between; gap: 14px;
  padding: 9px 12px; text-decoration: none; color: var(--color-text);
  font-weight: 600; font-size: .95rem; white-space: nowrap;
}
.nav__menu a:hover { background: var(--color-paper-alt); color: var(--color-accent); }
.nav__menu a .sub {
  font-family: var(--font-mono); font-size: 9px; letter-spacing: .08em;
  text-transform: uppercase; color: var(--color-text-muted); font-weight: 500;
}
.nav__menu .nav__all {
  border-top: 1px solid var(--color-line); margin-top: 4px;
  color: var(--color-accent); font-weight: 700;
}
.nav__group:hover .nav__menu,
.nav__group .nav__toggle[aria-expanded="true"] + .nav__menu { display: flex; }
@media (max-width: 980px) {
  .nav__group:hover .nav__menu,
  .nav__group .nav__toggle[aria-expanded="true"] + .nav__menu { display: none; }
}

/* keep the injected header tel/CTA tidy on the homepage scale */
.btn--header { min-height: 46px; padding: 12px 18px; font-size: .96rem; }
@media (max-width: 980px) { .header__actions .btn--header { display: none; } }

/* ---- MOBILE DRAWER ACCORDIONS (Services / Service Area) -------------------- */
.drawer__acc { border-bottom: 1px solid var(--color-line); }
.drawer__acc-toggle {
  width: 100%; display: flex; align-items: center; justify-content: space-between;
  gap: 10px; background: none; border: 0; padding: 14px 4px; cursor: pointer;
  font-family: var(--font-display); font-weight: 800; letter-spacing: -0.01em;
  font-size: 1rem; color: var(--color-ink); text-align: left;
}
.drawer__acc-toggle svg { width: 18px; height: 18px; flex: none; transition: transform .18s var(--ease); color: var(--color-accent); }
.drawer__acc.open .drawer__acc-toggle svg { transform: rotate(180deg); }
.drawer__acc-panel { display: none; padding: 2px 0 12px 12px; }
.drawer__acc.open .drawer__acc-panel { display: flex; flex-direction: column; }
.drawer__acc-panel a {
  text-decoration: none; color: var(--color-ink-soft); font-weight: 600;
  font-family: var(--font-body); padding: 9px 4px; border-bottom: 0;
  font-size: .95rem;
}
.drawer__acc-panel a:hover { color: var(--color-accent); }

/* ---- INTERNAL LINK SILO ---------------------------------------------------- */
.ilinks {
  border-block: 1px solid var(--color-line-strong);
  background: var(--color-paper-card);
  padding-block: clamp(36px, 5vw, 64px);
}
/* when the template already wraps the marker in a .container/section, neutralize
   the standalone band styling so it sits inline */
.section .ilinks, .container > .ilinks, .page-grid .ilinks {
  border: 0; background: transparent; padding-block: 0;
}
.ilinks__head {
  font-family: var(--font-display); font-weight: 800; letter-spacing: -0.02em;
  font-size: clamp(1.3rem, 2.4vw, 1.7rem); color: var(--color-ink);
  max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter);
  margin-bottom: 22px;
}
.section .ilinks__head, .container > .ilinks .ilinks__head, .page-grid .ilinks__head {
  padding-inline: 0; margin-inline: 0;
}
.ilinks__grid {
  max-width: var(--container); margin-inline: auto; padding-inline: var(--gutter);
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px;
}
.section .ilinks__grid, .container > .ilinks .ilinks__grid, .page-grid .ilinks__grid {
  padding-inline: 0;
}
@media (max-width: 900px) { .ilinks__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .ilinks__grid { grid-template-columns: 1fr; } }
.ilink {
  display: flex; align-items: center; gap: 12px; text-decoration: none;
  background: var(--color-paper); border: 1px solid var(--color-line-strong);
  border-left: 3px solid var(--color-accent); border-radius: var(--radius-sm);
  padding: 16px 18px; transition: border-color .15s var(--ease), transform .15s var(--ease);
}
.ilink:hover { border-color: var(--color-accent); transform: translateY(-1px); }
.ilink__k {
  font-family: var(--font-mono); font-size: 9px; letter-spacing: .1em;
  text-transform: uppercase; font-weight: 600; color: var(--color-accent);
  white-space: nowrap; flex: none; min-width: 56px;
}
.ilink__l {
  font-family: var(--font-display); font-weight: 700; letter-spacing: -0.01em;
  font-size: 1rem; color: var(--color-ink); line-height: 1.25;
}
.ilink__go { margin-left: auto; flex: none; color: var(--color-line-strong); }
.ilink__go svg { width: 18px; height: 18px; transform: rotate(-90deg); }
.ilink:hover .ilink__go { color: var(--color-accent); }

/* ---- /services/ and /service-area/ index grids ---------------------------- */
.index-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 32px;
}
@media (max-width: 900px) { .index-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .index-grid { grid-template-columns: 1fr; } }
.index-card {
  display: block; text-decoration: none; background: var(--color-paper-card);
  border: 1px solid var(--color-line-strong); border-top: 3px solid var(--color-accent);
  border-radius: var(--radius); padding: 24px; transition: transform .15s var(--ease), box-shadow .15s var(--ease);
}
.index-card:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.index-card b {
  display: block; font-family: var(--font-display); font-weight: 800;
  letter-spacing: -0.02em; font-size: 1.2rem; color: var(--color-ink);
}
.index-card .sub { display: block; color: var(--color-text-muted); font-size: var(--fs-sm); margin-top: 8px; }
.index-card .go { display: inline-flex; align-items: center; gap: 6px; margin-top: 14px; font-family: var(--font-mono); font-size: 10px; letter-spacing: .08em; text-transform: uppercase; font-weight: 600; color: var(--color-accent); }
